/* 메인 */
.hero-section {
    position: relative;
    height: 50vh;
    min-height: 400px;
    background: linear-gradient(180deg, rgba(15, 15, 15, 0.7) 0%, rgba(15, 15, 15, 0.9) 100%),
        url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 800"><rect fill="%23252525" width="1200" height="800"/><circle cx="300" cy="400" r="200" fill="%2300A86B" opacity="0.1"/><circle cx="900" cy="400" r="250" fill="%23D4AF37" opacity="0.1"/></svg>');
    background-size: cover;
    background-position: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: var(--spacing-xl);
    overflow: hidden;
}

.hero-decoration {
    position: absolute;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    opacity: 0.05;
    filter: blur(60px);
}

.decoration-1 {
    top: -100px;
    left: -100px;
    background: var(--accent-gold);
    animation: float 8s ease-in-out infinite;
}

.decoration-2 {
    bottom: -100px;
    right: -100px;
    background: var(--accent-green);
    animation: float 10s ease-in-out infinite reverse;
}

@keyframes float {

    0%,
    100% {
        transform: translate(0, 0) scale(1);
    }

    50% {
        transform: translate(30px, -30px) scale(1.1);
    }
}

.hero-logo {
    font-family: var(--font-display);
    font-size: 48px;
    font-weight: 700;
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--spacing-md);
    letter-spacing: 2px;
    animation: slideUp 1s ease-out;
}

.hero-subtitle {
    font-size: 20px;
    color: var(--text-primary);
    margin-bottom: var(--spacing-xs);
    animation: slideUp 1s ease-out 0.2s both;
}

.hero-description {
    font-size: 16px;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
    animation: slideUp 1s ease-out 0.4s both;
}

.cta-buttons {
    width: 100%;
    max-width: 360px;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    animation: slideUp 1s ease-out 0.6s both;
}

.features-section {
    padding: var(--spacing-xl) var(--spacing-lg);
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.feature-item {
    background: var(--bg-card);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    text-align: center;
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.feature-item:hover {
    border-color: rgba(212, 175, 55, 0.3);
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.feature-icon {
    font-size: 36px;
    margin-bottom: var(--spacing-sm);
}

.feature-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.feature-desc {
    font-size: 12px;
    color: var(--text-secondary);
}

.quick-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    text-decoration: none;
    color: var(--text-primary);
    transition: all 0.3s ease;
    margin-bottom: var(--spacing-md);
}

.quick-link:hover {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.05);
    transform: translateX(4px);
}

.quick-link-icon {
    font-size: 24px;
    color: var(--accent-primary);
}

.quick-link-content {
    flex: 1;
    margin: 0 var(--spacing-md);
}

.quick-link-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 4px;
}

.quick-link-desc {
    font-size: 14px;
    color: var(--text-secondary);
}

.quick-link-arrow {
    font-size: 20px;
    color: var(--text-disabled);
}




/* 로그인 */
.login-container {
    min-height: calc(100vh - 60px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--spacing-xl) var(--spacing-lg);
}

.login-title {
    font-size: 32px;
    margin-bottom: var(--spacing-xs);
    text-align: center;
    animation: fadeIn 0.6s ease-out;
}

.login-subtitle {
    text-align: center;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-2xl);
    animation: fadeIn 0.6s ease-out 0.2s both;
}

.login-form {
    animation: slideUp 0.6s ease-out 0.4s both;
}

.remember-group {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.link-text {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 14px;
    transition: color 0.3s ease;
}

.link-text:hover {
    color: var(--accent-primary);
}

.social-login {
    margin-top: var(--spacing-xl);
}

.social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    width: 100%;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-bottom: var(--spacing-sm);
}

.social-btn:hover {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.05);
}

.social-icon {
    font-size: 20px;
}




/* 날짜 및 룸 선택 */
.date-container {
    padding: var(--spacing-lg);
    padding-bottom: 160px;
}

.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-lg);
    background: var(--bg-card);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
    border: 1px solid var(--border-color);
}

.calendar-month {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 600;
}

.calendar-nav-btn {
    background: none;
    border: none;
    color: var(--accent-primary);
    font-size: 24px;
    cursor: pointer;
    padding: var(--spacing-xs);
    transition: all 0.3s ease;
}

.calendar-nav-btn:hover {
    transform: scale(1.2);
}

/* 비활성화 */
.calendar-nav-btn:disabled {
    color: #ccc;
    cursor: not-allowed;
    opacity: 0.5;
    pointer-events: none;
}

/* hover 무력화 */
.calendar-nav-btn:disabled:hover {
    color: #ccc;
}

.calendar {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
}

.calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
    text-align: center;
}

.weekday {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-disabled);
    padding: var(--spacing-xs);
}

.weekday.sunday {
    color: #E74C3C;
}

.weekday.saturday {
    color: #3498DB;
}

.calendar-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: var(--spacing-xs);
}

.day-cell {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--bg-input);
    border: 1px solid #aaa;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.day-cell:hover:not(.disabled):not(.past) {
    border-color: var(--accent-primary);
    transform: scale(1.05);
}

.day-number {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
}

.day-type {
    font-size: 10px;
    color: var(--text-secondary);
    margin-top: 2px;    
    /* white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis; */
}

.day-cell.selected {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-color: var(--accent-gold);
}

.day-cell.selected .day-number,
.day-cell.selected .day-type {
    color: var(--bg-primary);
    font-weight: 700;
}

.day-cell.disabled {
    opacity: 0.3;
    cursor: not-allowed;
    border: none
}

.day-cell.past {
    opacity: 0.5;
    cursor: not-allowed;
    border: none
}

.day-cell.past .day-type {
    color: var(--text-disabled)
}

.day-cell.weekend .day-number {
    color: #3498DB;
}

.day-cell.sunday .day-number {
    color: #E74C3C;
}


.day-cell.holiday {
    position: relative;
}

.day-cell.holiday::after {
    content: '';
    position: absolute;
    top: 4px;
    right: 4px;
    width: 6px;
    height: 6px;
    background: #E74C3C;
    border-radius: 50%;
}

.selected-info {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 2px solid var(--accent-primary);
    margin-bottom: var(--spacing-lg);
    animation: slideUp 0.3s ease-out;
}

.selected-date {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.selected-price {
    color: var(--accent-gold);
    font-size: 14px;
    font-weight: 600;
}

.room-selection {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
    opacity: 0.5;
    pointer-events: none;
    transition: all 0.3s ease;
}

.room-selection.active {
    opacity: 1;
    pointer-events: all;
    border-color: var(--accent-primary);
}

.room-section-title {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--text-primary);
}

.room-grid {
    display: grid;
    gap: var(--spacing-md);
}

.room-card {
    background: var(--bg-input);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.room-card:hover:not(.disabled) {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.room-card.selected {
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(46, 125, 50, 0.1) 100%);
    border-color: var(--accent-gold);
}

.room-card.disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.room-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-sm);
}

.room-name {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.room-status {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

.room-status.available {
    background: rgba(46, 125, 50, 0.2);
    color: var(--accent-green);
}

.room-status.full {
    background: rgba(231, 76, 60, 0.2);
    color: #E74C3C;
}

.room-description {
    font-size: 13px;
    color: var(--text-primary);
    margin-bottom: var(--spacing-sm);
}

.room-features {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-sm);
}

.room-feature {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--text-primary);
    background: rgba(255, 255, 255, 0.05);
    padding: 4px 8px;
    border-radius: 4px;
}

.room-price {
    font-size: 14px;
    color: var(--accent-gold);
    font-weight: 600;
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-color);
}

.room-badge {
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    color: var(--bg-primary);
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 12px;
}

.calendar-legend {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    font-size: 12px;
    color: var(--text-secondary);
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
}

.legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.legend-dot.holiday {
    background: #E74C3C;
}

.legend-dot.weekend {
    background: #3498DB;
}

.legend-dot.disabled {
    background: var(--text-disabled);
}

.cta-section {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    max-width: 480px;
    width: 100%;
    background: linear-gradient(180deg, transparent 0%, rgba(26, 26, 26, 0.98) 20%);
    padding: var(--spacing-lg);
    backdrop-filter: blur(10px);
    z-index: 50;
}


@media (max-width: 480px) {
    .calendar {
        padding: 20px 10px
    }

    .calendar-days {
        gap: 4px
    }

    .day-cell {
        aspect-ratio: 0;
    }

}


/* 인원 및 시간 선택 */
.time-container {
    padding: var(--spacing-lg);
    padding-bottom: 180px;
}

.selected-date-banner {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    color: var(--bg-primary);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
    text-align: center;
    font-weight: 600;
}

.time-slots-section {
    margin-bottom: var(--spacing-xl);
}

.section-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.time-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-sm);
}

.time-slot {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.time-slot:hover:not(.disabled):not(.auto-selected) {
    border-color: var(--accent-primary);
    transform: scale(1.05);
}

.time-slot.selected {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-color: var(--accent-gold);
}

.time-slot.selected .time-text {
    color: var(--bg-primary);
    font-weight: 700;
}

.time-slot.auto-selected {
    background: rgba(212, 175, 55, 0.3);
    border-color: var(--accent-gold);
}

.time-slot.auto-selected .time-text {
    color: var(--text-primary);
    font-weight: 600;
}

.time-slot.disabled {
    opacity: 0.3;
    cursor: not-allowed;
    position: relative;
}

.time-slot.disabled::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 10%;
    right: 10%;
    height: 2px;
    background: var(--text-disabled);
    transform: rotate(-45deg);
}

.time-slot.tail-slot {
    opacity: 0.7;
    border-style: dashed;
}

.time-slot.tail-slot .time-text {
    font-size: 12px;
}

.minor-block-badge {
    position: absolute;
    bottom: 4px;
    left: 50%;
    transform: translateX(-50%);
    background: #FF9800;
    color: white;
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 8px;
    font-weight: 700;
    white-space: nowrap;
    z-index: 10;
}

.time-text {
    font-size: 16px;
    font-weight: 500;
    color: var(--text-primary);
}

.required-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    background: var(--accent-gold);
    color: var(--bg-primary);
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 8px;
    font-weight: 700;
}

.summary-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 2px solid var(--accent-primary);
    margin-bottom: var(--spacing-lg);
}

.summary-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--accent-primary);
}

.summary-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--border-color);
}

.summary-item:last-child {
    border-bottom: none;
    padding-top: var(--spacing-md);
    margin-top: var(--spacing-sm);
}

.summary-label {
    color: var(--text-primary);
    font-size: 14px;
}

.summary-value {
    color: var(--text-primary);
    font-weight: 600;
    font-size: 14px;
}

.summary-value.price {
    font-family: var(--font-display);
    font-size: 24px;
    color: var(--accent-gold);
}

.additional-section {
    margin-top: var(--spacing-lg);
}

.additional-label {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.people-section {
    margin-bottom: var(--spacing-lg);
}

.people-selector {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-lg);
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-xl);
    border: 2px solid var(--accent-primary);
}

.people-btn {
    width: 48px;
    height: 48px;
    background: var(--bg-input);
    border: 2px solid var(--border-color);
    border-radius: 50%;
    color: var(--accent-primary);
    font-size: 24px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.people-btn:hover:not(:disabled) {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.1);
    transform: scale(1.1);
}

.people-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.people-count {
    font-family: var(--font-display);
    font-size: 48px;
    font-weight: 700;
    color: var(--accent-gold);
    min-width: 80px;
    text-align: center;
}

.people-label {
    font-size: 14px;
    color: var(--text-secondary);
    text-align: center;
    margin-top: var(--spacing-sm);
}



/* 예약자 정보 */
.guest-info-container {
    padding: var(--spacing-lg);
    padding-bottom: 120px;
}

.page-title {
    font-size: 28px;
    margin-bottom: var(--spacing-xs);
    animation: fadeIn 0.6s ease-out;
}

.page-subtitle {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
    animation: fadeIn 0.6s ease-out 0.2s both;
}

.form-section {
    animation: slideUp 0.6s ease-out 0.4s both;
}



/* 예약 정보 확인*/
.page-title.center {
    text-align: center;
}

.page-subtitle.center {
    text-align: center;
}

.confirm-container {
    padding: var(--spacing-lg);
    padding-bottom: 120px;
}

.reservation-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    border: 2px solid var(--accent-primary);
    margin-bottom: var(--spacing-lg);
    animation: slideUp 0.6s ease-out 0.4s both;
}

.reservation-section {
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--border-color);
}

.reservation-section:last-child {
    border-bottom: none;
}

.section-icon {
    font-size: 24px;
    margin-bottom: var(--spacing-sm);
}

.section-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 4px;
    letter-spacing: 0.5px;
    margin-left: 10px
}

.reservation-card .section-label {
    margin-left: 0;
}

.section-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.4;
}

.section-value.highlight {
    font-family: var(--font-display);
    font-size: 24px;
    color: var(--accent-gold);
}

.user-info-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
}

.user-info-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
}

.user-info-item {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-sm) 0;
    font-size: 14px;
}

.user-info-label {
    color: var(--text-secondary);
}

.user-info-value {
    color: var(--text-primary);
    font-weight: 500;
}

.price-breakdown {
    background: rgba(212, 175, 55, 0.05);
    border-radius: var(--radius-sm);
    padding: var(--spacing-md);
    margin-top: var(--spacing-sm);
}

.price-item {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 14px;
}

.price-item.total {
    border-top: 1px solid var(--border-color);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    font-weight: 700;
    font-size: 16px;
}

.edit-btn {
    background: none;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    padding: 8px 16px;
    border-radius: var(--radius-sm);
    font-size: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: var(--spacing-sm);
}

.edit-btn:hover {
    border-color: var(--accent-primary);
    color: var(--accent-primary);
}


/* 이용 수칙 확인 */
.terms-container {
    padding: var(--spacing-lg);
    padding-bottom: 140px;
}

.terms-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
    overflow: hidden;
}

.terms-header {
    padding: var(--spacing-lg);
    background: rgba(212, 175, 55, 0.1);
    border-bottom: 1px solid var(--border-color);
}

.terms-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--accent-gold);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.terms-content {
    padding: var(--spacing-lg);
    max-height: 300px;
    overflow-y: auto;
}

.terms-content::-webkit-scrollbar {
    width: 6px;
}

.terms-content::-webkit-scrollbar-track {
    background: var(--bg-input);
    border-radius: 3px;
}

.terms-content::-webkit-scrollbar-thumb {
    background: var(--accent-gold);
    border-radius: 3px;
}

.terms-item {
    padding: var(--spacing-sm) 0;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.8;
    border-bottom: 1px solid var(--border-color);
}

.terms-item:last-child {
    border-bottom: none;
}

.terms-item strong {
    color: var(--text-primary);
    font-weight: 600;
}

.policy-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.policy-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--accent-primary);
}

.policy-list {
    list-style: none;
}

.policy-item {
    padding: var(--spacing-sm) 0;
    padding-left: var(--spacing-md);
    color: var(--text-secondary);
    font-size: 14px;
    position: relative;
}

.policy-item::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--accent-gold);
}

.policy-highlight {
    background: rgba(231, 76, 60, 0.1);
    color: var(--error);
    padding: var(--spacing-md);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--error);
    margin-top: var(--spacing-sm);
    font-size: 13px;
}

.agreement-section {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 2px solid var(--accent-primary);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {

    0%,
    100% {
        border-color: var(--accent-primary);
    }

    50% {
        border-color: var(--accent-green);
    }
}

.agreement-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    cursor: pointer;
}

.agreement-checkbox input[type="checkbox"] {
    appearance: none;
    width: 24px;
    height: 24px;
    border: 2px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    margin-top: 2px;
    transition: all 0.3s ease;
}

.agreement-checkbox input[type="checkbox"]:checked {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-color: var(--accent-gold);
}

.agreement-checkbox input[type="checkbox"]:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--bg-primary);
    font-size: 16px;
    font-weight: bold;
}

.agreement-label {
    font-size: 15px;
    color: var(--text-primary);
    line-height: 1.6;
}

.agreement-label strong {
    color: var(--accent-gold);
    font-weight: 700;
}




/* 결제 */
.payment-container {
    padding: var(--spacing-lg);
    padding-bottom: 140px;
}

.payment-methods {
    margin-bottom: var(--spacing-xl);
}

.method-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--text-secondary);
}

.payment-method {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    background: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
    cursor: pointer;
    transition: all 0.3s ease;
}

.payment-method:hover {
    border-color: rgba(212, 175, 55, 0.5);
}

.payment-method.selected {
    border-color: var(--accent-gold);
    background: rgba(212, 175, 55, 0.1);
}

.method-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex: 1;
}

.method-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-input);
    border-radius: var(--radius-sm);
    font-size: 24px;
}

.method-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.method-desc {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 2px;
}

.method-radio {
    width: 20px;
    height: 20px;
    border: 2px solid var(--border-color);
    border-radius: 50%;
    position: relative;
    transition: all 0.3s ease;
}

.payment-method.selected .method-radio {
    border-color: var(--accent-gold);
    background: var(--accent-gold);
}

.payment-method.selected .method-radio::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    background: var(--bg-primary);
    border-radius: 50%;
}

.payment-summary {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 2px solid var(--accent-primary);
    margin-bottom: var(--spacing-lg);
}

.summary-row {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-sm) 0;
    font-size: 14px;
}

.summary-row.total {
    border-top: 2px solid var(--border-color);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-md);
    font-weight: 700;
    font-size: 18px;
}

.security-notice {
    display: flex;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background: rgba(0, 168, 107, 0.1);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--success);
    margin-bottom: var(--spacing-lg);
}

.security-icon {
    font-size: 20px;
    color: var(--success);
}

.security-text {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
}

.pay-button {
    font-size: 18px;
    font-weight: 700;
    padding: 20px;
}



/* 예약완료 */
.reservation-card.left {
    text-align: left;
}

.complete-container {
    padding: var(--spacing-xl) var(--spacing-lg);
    padding-bottom: 140px;
    text-align: center;
}

.success-icon {
    width: 100px;
    height: 100px;
    margin: var(--spacing-xl) auto;
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    animation: scaleIn 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

@keyframes scaleIn {
    0% {
        transform: scale(0);
        opacity: 0;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.complete-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    animation: fadeIn 0.6s ease-out 0.3s both;
}

.complete-subtitle {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
    animation: fadeIn 0.6s ease-out 0.4s both;
}

.reservation-number {
    text-align: center;
    padding: var(--spacing-lg);
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
    border: 1px dashed var(--accent-gold);
}

.number-label {
    font-size: 14px;
    color: var(--text-primary);
    margin-bottom: 6px;
    letter-spacing: 0.5px;
}

.number-value {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    color: var(--accent-gold);
    letter-spacing: 2px;
}

.reservation-info {
    display: grid;
    gap: var(--spacing-md);
}

.info-row {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.info-icon {
    font-size: 24px;
    flex-shrink: 0;
}

.info-content {
    flex: 1;
}

.info-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.info-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.5;
}

.access-guide {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
    text-align: left;
}

.guide-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--accent-primary);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.guide-steps {
    list-style: none;
    counter-reset: step-counter;
}

.guide-step {
    padding: var(--spacing-sm) 0;
    padding-left: var(--spacing-xl);
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
    position: relative;
    counter-increment: step-counter;
}

.guide-step::before {
    content: counter(step-counter);
    position: absolute;
    left: 0;
    width: 24px;
    height: 24px;
    background: var(--accent-gold);
    color: var(--bg-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
}

.notice-text {
    font-size: 13px;
    color: var(--text-disabled);
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.action-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.btn-half {
    padding: 16px;
    font-size: 14px;
}



/* 예약내역 */
.list-container {
    padding-bottom: 40px;
}

.tabs-container {
    background: var(--bg-secondary);
    position: sticky;
    top: 60px;
    z-index: 50;
}

.reservation-list {
    padding: var(--spacing-lg);
}

.empty-state {
    text-align: center;
    padding: var(--spacing-2xl) var(--spacing-lg);
}

.empty-icon {
    font-size: 64px;
    margin-bottom: var(--spacing-md);
    opacity: 0.3;
}

.empty-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--text-secondary);
}

.empty-desc {
    font-size: 14px;
    color: var(--text-disabled);
}

.reservation-item {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-md);
    transition: all 0.3s ease;
}

.reservation-item:hover {
    border-color: var(--accent-primary);
    box-shadow: var(--shadow-md);
}

.item-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
}

.item-date {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 600;
    color: var(--text-primary);
}

.item-status {
    padding: 6px 12px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

.status-upcoming {
    background: rgba(0, 168, 107, 0.2) !important;
    color: var(--success) !important;
}

.status-completed {
    background: rgba(184, 184, 184, 0.2) !important;
    color: var(--text-secondary) !important;
}

.status-cancelled {
    background: rgba(231, 76, 60, 0.2) !important;
    color: var(--error) !important;
}

.item-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.info-line {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 14px;
    color: var(--text-primary);
}

.info-icon {
    font-size: 16px;
    width: 20px;
}

.item-number {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.item-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.action-btn {
    flex: 1;
    padding: 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-input);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.action-btn:hover {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.1);
}

.action-btn.primary {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-color: var(--accent-gold);
    color: var(--bg-primary);
}

.action-btn.danger {
    border-color: var(--error);
    color: var(--error);
}

.action-btn.danger:hover {
    background: rgba(231, 76, 60, 0.1);
}

.filter-bar {
    display: flex;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--bg-card);
    overflow-x: auto;
}

.filter-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    font-size: 13px;
    white-space: nowrap;
    cursor: pointer;
    transition: all 0.3s ease;
}

.filter-btn.active {
    background: var(--accent-gold);
    border-color: var(--accent-gold);
    color: var(--bg-primary);
}






/* 요금안내 */
.pricing-container {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

.pricing-title {
    font-size: 28px;
    margin-bottom: var(--spacing-xs);
    animation: fadeIn 0.6s ease-out;
}

.pricing-subtitle {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
    animation: fadeIn 0.6s ease-out 0.2s both;
}

.category-title {
    font-weight: 700;
    color: var(--accent-gold);
}

.category-subtitle {
    font-size: 12px;
    color: var(--text-primary);
    margin-top: 2px;
}

.pricing .price-zero {
    color: var(--text-primary);
}

.pricing .price-addon {
    color: var(--text-primary);
}

.pricing .note-cell {
    color: var(--text-primary);
}

.policy-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.highlight {
    color: var(--accent-gold);
    font-weight: 600;
}

.price-table-wrapper {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
    border: 2px solid var(--border-color);
    overflow-x: auto;
}

.price-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    min-width: 800px;
}

.price-table th {
    background: rgba(212, 175, 55, 0.1);
    color: var(--text-primary);
    font-weight: 600;
    padding: var(--spacing-sm);
    text-align: center;
    border: 1px solid var(--border-color);
    font-size: 12px;
    white-space: nowrap;
}

.price-table td {
    padding: var(--spacing-sm);
    text-align: center;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    font-size: 12px;
}

.price-table .category-cell {
    background: rgba(212, 175, 55, 0.05);
    font-weight: 600;
    color: var(--text-primary);
}

.price-table .daytime-bg {
    background: rgba(255, 248, 220, 0.3);
}

.price-table .nighttime-bg {
    background: rgba(220, 255, 220, 0.2);
}

.price-table .sub-category-cell {
    background: rgba(212, 175, 55, 0.03);
    font-weight: 500;
}

.price-table .price-value {
    color: var(--accent-gold);
    font-weight: 700;
    font-size: 15px;
}

.price-table .price-zero {
    color: var(--error);
    font-weight: 700;
}

.price-table .price-addon {
    color: var(--error);
    font-size: 11px;
}

.price-table .note-cell {
    text-align: left;
    font-size: 11px;
    line-height: 1.5;
}

.price-card-mobile {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    border: 1px solid var(--border-color);
}

.price-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    border-bottom: 2px solid rgba(212, 175, 55, 0.2);
}

.price-card-category {
    font-size: 18px;
    font-weight: 700;
    color: var(--accent-gold);
}

.price-card-type {
    font-size: 13px;
    color: var(--text-primary);
}

.price-card-main {
    margin-bottom: var(--spacing-md);
}

.price-card-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-xs) 0;
}

.price-card-label {
    font-size: 15px;
    color: var(--text-primary);
}

.price-card-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-gold);
}

.price-card-value.zero {
    color: var(--text-primary);
}

.price-card-addon {
    background: rgba(212, 175, 55, 0.05);
    border-radius: var(--radius-sm);
    padding: var(--spacing-sm);
    margin-top: var(--spacing-sm);
    display: flex;
    justify-content: space-between;
}

.price-card-addon-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.price-card-addon-item {
    font-size: 13px;
    color: var(--text-primary);
    padding: 2px 0;
}

.price-card-note {
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-color);
}

.notes-section {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-xl);
}

.note-item {
    padding: var(--spacing-sm) 0;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
}

.note-item:last-child {
    border-bottom: none;
}

.note-item svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.note-item a {
    color: var(--accent-gold);
    text-decoration: underline;
    cursor: pointer;
}

.note-item a:hover {
    color: var(--accent-green);
}

.policy-section {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-xl);
}

.policy-title.flex {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.policy-item2 {
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    gap: var(--spacing-md);
}

.policy-item2:last-child {
    border-bottom: none;
}

.policy-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-sm);
    color: var(--accent-gold);
}

.policy-content {
    flex: 1;
}

.policy-content strong {
    color: var(--text-primary);
    font-weight: 600;
    display: block;
    margin-bottom: 4px;
}

.policy-content p {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

.policy-content .highlight {
    color: var(--error);
    font-weight: 600;
}

.info-section {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-xl);
}

.info-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--accent-primary);
}

.info-list {
    list-style: none;
}

.info-item {
    padding: var(--spacing-sm) 0;
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.6;
    border-bottom: 1px solid var(--border-color);
}

.info-item:last-child {
    border-bottom: none;
}

.info-item::before {
    content: '•';
    color: var(--accent-gold);
    margin-right: var(--spacing-sm);
}


@media (max-width: 768px) {
    .price-table-wrapper {
        display: none;
    }

    .section-title2 {
        font-size: 16px;
    }

    .price-cards-mobile {
        display: block;
    }

    .pricing-container {
        padding: var(--spacing-md);
        padding-bottom:50px;
    }
}

/* 고객센터 */
.content-container {
    padding: var(--spacing-lg);
    padding-bottom: 60px;
}

.contact-card {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-radius: var(--radius-lg);
    padding: var(--spacing-2xl);
    text-align: center;
    margin-bottom: var(--spacing-xl);
    box-shadow: var(--shadow-lg);
}

.contact-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-md);
}

.contact-icon svg {
    display: inline-block;
}

.contact-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    color: var(--bg-primary);
}

.contact-phone {
    font-size: 32px;
    font-weight: 700;
    color: var(--bg-primary);
    text-decoration: none;
    display: block;
    margin-bottom: var(--spacing-md);
    font-family: var(--font-display);
}

.contact-description {
    color: var(--bg-primary);
    font-size: 16px;
    font-weight: 500;
    opacity: 0.95;
}

.section {
    margin-bottom: var(--spacing-xl);
}

.info-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
}

.hours-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.hours-icon {
    color: var(--accent-gold);
}

.hours-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.hours-subtitle {
    font-size: 14px;
    color: var(--text-secondary);
}

.holiday-notice {
    background: rgba(231, 76, 60, 0.1);
    border-radius: var(--radius-sm);
    padding: var(--spacing-md);
    border-left: 3px solid var(--error);
}

.holiday-title {
    color: var(--error);
    font-size: 14px;
    font-weight: 600;
}

.holiday-text {
    color: var(--text-secondary);
    font-size: 13px;
    margin-top: 4px;
}

.quick-links {
    display: grid;
    gap: var(--spacing-md);
}

.quick-link2 {
    display: block;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    text-decoration: none;
    transition: all 0.3s ease;
}

.quick-link-content2 {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.quick-link-inner {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.quick-link-icon2 {
    background: rgba(212, 175, 55, 0.1);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.quick-link-icon2 svg {
    color: var(--accent-gold);
}

.quick-link-title.white {
    color: var(--text-primary);
}

.quick-link-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
}

.quick-link-arrow {
    color: var(--text-disabled);
}

.contact-text {
    color: var(--text-primary);
    line-height: 1.8;
    font-size: 15px;
    margin-bottom: var(--spacing-md);
}

.contact-list {
    color: var(--text-secondary);
    line-height: 2;
    font-size: 15px;
    padding-left: var(--spacing-lg);
}

.location-item {
    display: flex;
    align-items: start;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.location-icon {
    color: var(--accent-gold);
    flex-shrink: 0;
    margin-top: 2px;
}

.location-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.location-text {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.6;
}




/* 자주 묻는 질문 */
.faq-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-md);
    overflow: hidden;
    transition: all 0.3s ease;
}

.faq-item:hover {
    border-color: rgba(212, 175, 55, 0.3);
}

.faq-item.active {
    border-color: var(--accent-gold);
    box-shadow: 0 0 0 1px var(--accent-gold);
}

.faq-question {
    padding: var(--spacing-lg);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
    transition: all 0.3s ease;
}

.faq-question:hover {
    background: rgba(212, 175, 55, 0.05);
}

.faq-question-text {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    flex: 1;
    line-height: 1.5;
}

.faq-icon {
    color: var(--accent-gold);
    transition: transform 0.3s ease;
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.faq-item.active .faq-icon {
    transform: rotate(180deg);
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
}

.faq-answer-content {
    padding: 0 var(--spacing-lg) var(--spacing-lg) var(--spacing-lg);
    color: var(--text-secondary);
    line-height: 1.8;
    font-size: 15px;
}

.faq-item.active .faq-answer {
    max-height: 800px;
}

.faq-category {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 600;
    color: var(--text-primary);
    margin: var(--spacing-xl) 0 var(--spacing-md) 0;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--accent-gold);
}

.faq-category:first-child {
    margin-top: 0;
}



/* 예약 조회 */
.inquiry-container {
    min-height: calc(100vh - 60px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--spacing-xl) var(--spacing-lg);
}

.inquiry-form {
    animation: slideUp 0.6s ease-out 0.4s both;
}

.inquiry-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-xl);
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
}

.example-text {
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: 6px;
    margin-left: 10px
}

.result-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-xl);
    border: 2px solid var(--accent-primary);
    margin-top: var(--spacing-xl);
    display: none;
    animation: slideUp 0.3s ease-out;
}

.result-header {
    text-align: center;
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
}

.result-status {
    display: inline-block;
    padding: 8px 16px;
    background: rgba(0, 168, 107, 0.2);
    color: var(--success);
    border-radius: 16px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.result-number {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 700;
    color: var(--accent-gold);
    letter-spacing: 1px;
}

.result-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.result-row {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.result-icon {
    font-size: 24px;
    flex-shrink: 0;
}

.result-content {
    flex: 1;
}

.result-label {
    font-size: 12px;
    color: var(--text-disabled);
    margin-bottom: 4px;
}

.result-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.5;
}

.result-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
}

.result-actions button:only-child {
  grid-column: 1 / -1;
}

.action-button {
    padding: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-input);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.action-button:hover {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.1);
}

.action-button.danger {
    border-color: var(--error);
    color: var(--error);
}

.action-button.danger:hover {
    background: rgba(231, 76, 60, 0.1);
}


/* 예약 내역 */
.modal-hide {
    display: none;
}

.modal-detail {
    max-width: 480px;
    width: 90%;
}

.modal-alert {
    max-width: 380px;
    width: 90%;
    text-align: center;
}

.detail-number-container {
    margin-bottom: var(--spacing-lg);
}

.detail-number {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 600;
    color: var(--accent-gold);
}

.detail-info-box {
    background: var(--bg-input);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
}

.detail-info-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.detail-info-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.detail-icon {
    color: var(--accent-primary);
}

.detail-info-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 2px;
}

.detail-info-value {
    font-size: 16px;
    font-weight: 600;
    color: Var(--text-primary)
}

.detail-price-divider {
    border-top: 1px solid var(--border-color);
    padding-top: var(--spacing-md);
    margin-top: var(--spacing-sm);
}

.detail-price-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.detail-price-label {
    font-size: 14px;
    color: var(--text-secondary);
}

.detail-price-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--accent-gold);
}

.button-group {
    display: flex;
    gap: var(--spacing-sm);
}

.button-flex {
    flex: 1;
}

.btn-cancel {
    background: var(--error);
    border-color: var(--error);
    color: white;
}

.alert-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-md);
}

.alert-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.alert-message {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
}

.btn-full-width {
    width: 100%;
}

.confirm-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.confirm-message {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
    white-space: pre-line;
}

.fade-in {
    animation: fadeIn 0.3s ease-out forwards;
    opacity: 0;
}



/* 내 정보 */
.mypage-container {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

.profile-section {
    background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-green) 100%);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
    text-align: center;
    color: var(--bg-primary);
    animation: slideUp 0.6s ease-out;
}

.profile-avatar {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-md);
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    border: 3px solid rgba(255, 255, 255, 0.3);
}

.profile-name {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 4px;
}

.profile-email {
    font-size: 15px;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.stat-item {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: 24px 0;
    text-align: center;
    border: 1px solid var(--border-color);
    transition: all 0.3s ease;
}

.stat-item:hover {
    border-color: var(--accent-primary);
    transform: translateY(-2px);
}

.stat-value {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    color: var(--accent-gold);
    margin-bottom: 4px;
}

.stat-label {
    font-size: 14px;
    color: var(--text-secondary);
}

.menu-section {
    margin-bottom: var(--spacing-lg);
}

.menu-list {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.menu-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    color: var(--text-primary);
}

.menu-item:last-child {
    border-bottom: none;
}

.menu-item:hover {
    background: rgba(212, 175, 55, 0.05);
}

.menu-left {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.menu-icon {
    font-size: 20px;
    width: 32px;
    text-align: center;
}

.menu-text {
    font-size: 16px;
    font-weight: 500;
}

.menu-arrow {
    font-size: 18px;
    color: var(--text-disabled);
}

.logout-button {
    width: 100%;
    padding: var(--spacing-lg);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-bottom: var(--spacing-md);
}

.logout-button:hover {
    border-color: var(--error);
    color: var(--error);
    background: rgba(231, 76, 60, 0.05);
}

.withdrawal-link {
    display: block;
    text-align: center;
    color: var(--text-secondary);
    font-size: 13px;
    text-decoration: none;
    padding: var(--spacing-sm);
    transition: color 0.3s ease;
}

.withdrawal-link:hover {
    color: var(--error);
    text-decoration: underline;
}

.version-info {
    text-align: center;
    color: var(--text-disabled);
    font-size: 12px;
    margin-top: var(--spacing-xl);
}



/* 비밀번호 변경 */
.form-wrapper {
    padding: var(--spacing-lg);
}

.info-box-wrapper {
    margin-bottom: var(--spacing-xl);
}

.password-form {
    padding-bottom: 40px;
}



/* 상세 가격표 */
.member-badge {
    display: inline-block;
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-green));
    color: #000;
    font-size: 14px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: var(--radius-sm);
    margin-left: var(--spacing-sm);
}

.table-header-cell {
    vertical-align: middle;
}

.table-category-cell {
    vertical-align: middle;
}

.table-time-cell {
    text-align: center;
    font-size: 11px;
    vertical-align: middle;
    color: var(--text-primary);
}

.table-price-cell {
    vertical-align: middle;
    color: var(--text-primary);
}

.table-price-highlight {
    color: var(--accent-gold);
    font-weight: 700;
    vertical-align: middle;
    font-size: 16px;
}

.table-discount-cell {
    border: 2px solid var(--accent-gold);
    background: rgba(212, 175, 55, 0.05);
    vertical-align: middle;
}

.table-discount-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-gold);
}

.table-total-cell {
    font-weight: 700;
    vertical-align: middle;
    color: var(--text-primary);
}

.table-total-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
}

.table-empty-cell {
    vertical-align: middle;
}

.category-daytime {
    background: rgba(255, 248, 220, 0.3);
    vertical-align: middle;
}

.category-nighttime {
    background: rgba(220, 255, 220, 0.2);
    vertical-align: middle;
}

.category-text {
    color: var(--text-primary);
}

.price-info-box {
    background: rgba(212, 175, 55, 0.03);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 8px;
}

.price-info-title {
    font-size: 11px;
    color: var(--text-secondary);
    margin-bottom: 8px;
    font-weight: 600;
}

.price-info-row {
    border: none;
    padding: 2px 0;
}

.price-info-label {
    font-size: 11px;
}

.discount-box {
    background: rgba(212, 175, 55, 0.05);
    border: 2px solid var(--accent-gold);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 12px;
}

.discount-content {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: revert;
}

.discount-label {
    font-size: 14px;
    font-weight: 600;
}

.discount-content .discount-detail-content {
	display: flex;
    justify-content: space-between;
}

.discount-content .discount-detail-content .discount-label,.discount-content .discount-detail-content .discount-value{
	font-size: 12px !important;
}

.discount-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-gold);
}

.addon-box-daytime {
    background: rgba(255, 248, 220, 0.2);
}

.addon-box-daytime .addon-total .addon-total-content {
	display: flex;
	justify-content: space-between;
	font-size: 14px !important;
}

.addon-box-nighttime {
    background: rgba(220, 255, 220, 0.2);
}

.addon-row {
    padding: 4px 0;
}

.addon-total {
    text-align: right;
    padding-top: 8px;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.addon-total-value {
    font-size: 14px;
    font-weight: 700;
}

.addon-arrow {
    font-size: 12px;
    color: var(--text-primary);
    margin-left: 8px;
}

.section-spacing {
    margin-top: var(--spacing-xl);
}



/* 가격표 테이블 스타일 */
.section-title2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--accent-gold);
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-sm);
    border-left: 4px solid var(--accent-gold);
}

.price-table2 {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    min-width: 1000px;
    margin-bottom: var(--spacing-xl);
}

.price-table2:last-child {
    margin-bottom: 0;
}

.price-table2 th {
    background: rgba(212, 175, 55, 0.1);
    color: var(--text-primary);
    font-weight: 600;
    padding: var(--spacing-sm);
    text-align: center;
    border: 1px solid var(--border-color);
    font-size: 12px;
    white-space: nowrap;
}

.price-table2 td {
    padding: var(--spacing-sm);
    text-align: center;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    font-size: 12px;
}

.price-table2 .category-cell {
    background: rgba(212, 175, 55, 0.05);
    font-weight: 600;
    color: var(--text-primary);
}

.price-table2 .time-cell {
    background: rgba(212, 175, 55, 0.03);
    font-size: 11px;
}

.price-table2 .daytime-bg {
    background: rgba(255, 248, 220, 0.3);
}

.price-table2 .nighttime-bg {
    background: rgba(220, 255, 220, 0.2);
}

.price-table2 .price-value {
    color: var(--text-primary);
    font-weight: 600;
    font-size: 13px;
}

.price-table2 .price-highlight {
    color: var(--accent-gold);
    font-weight: 700;
    font-size: 15px;
}

.price-table2 .price-discount {
    color: var(--error);
    font-weight: 700;
}

.price-table2 .price-addon {
    color: var(--error);
    font-size: 11px;
}

.price-table2 .total-cell {
    background: rgba(212, 175, 55, 0.05);
    font-weight: 700;
    color: var(--accent-gold);
}

.info-notice {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-xl);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.info-notice-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-sm);
    color: var(--accent-gold);
}

.info-notice-text {
    flex: 1;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
}

.detail-card-mobile {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    border: 1px solid var(--border-color);
}

.detail-card-header {
    padding-bottom: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    border-bottom: 2px solid rgba(212, 175, 55, 0.2);
}

.detail-card-category {
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-gold);
    margin-bottom: 4px;
}

.detail-card-type {
    font-size: 13px;
    color: var(--text-secondary);
}

.detail-card-time {
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 2px;
}

.detail-card-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--border-color);
}

.detail-card-row:last-child {
    border-bottom: none;
}

.detail-card-label {
    font-size: 12px;
    color: var(--text-secondary);
}

.detail-card-value {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}

.detail-card-value.discount {
    color: var(--error);
}

.detail-card-total {
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-sm);
    padding: var(--spacing-sm);
    margin-top: var(--spacing-sm);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.detail-card-total-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}

.detail-card-total-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-gold);
}

.detail-card-addon {
    background: rgba(212, 175, 55, 0.05);
    border-radius: var(--radius-sm);
    padding: var(--spacing-sm);
    margin-top: var(--spacing-sm);
}

.detail-card-addon-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.detail-card-addon-item {
    font-size: 11px;
    color: var(--error);
    padding: 2px 0;
}




/* 개인정보 처리방침 */
.date-info {
    margin-bottom: var(--spacing-xl);
}

.date-text {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
}


.section-text {
    color: var(--text-secondary);
    line-height: 1.8;
    font-size: 15px;
    margin-bottom: var(--spacing-sm);
}

.section-text-lg {
    color: var(--text-secondary);
    line-height: 1.8;
    font-size: 15px;
    margin-bottom: var(--spacing-lg);
}

.info-box2 {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.info-list2 {
    color: var(--text-secondary);
    line-height: 2;
    font-size: 15px;
    padding-left: var(--spacing-lg);
}

.subsection {
    margin-bottom: var(--spacing-md);
}

.subsection-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
    color: var(--text-primary);
}

.info-table {
    width: 100%;
    color: var(--text-secondary);
    font-size: 14px;
}

.info-table tr {
    border-bottom: 1px solid var(--border-color);
}

.info-table th {
    padding: var(--spacing-sm);
    text-align: left;
    color: var(--text-primary);
}

.info-table td {
    padding: var(--spacing-sm);
}

.contact-info {
    color: var(--text-primary);
    font-size: 15px;
    line-height: 2;
}


/* 개인정보 수정 */
.profile-form {
    padding-bottom: 40px;
}

.disabled-input {
    background: var(--bg-input);
    opacity: 0.5;
    cursor: not-allowed;
}

.form-container .input-label {
    margin-left: 10px;
    color: var(--text-primary)
}



/* 환불 규정 */
.section-text-sm {
    color: var(--text-secondary);
    line-height: 1.8;
    font-size: 15px;
    margin-bottom: var(--spacing-sm);
}

.refund-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.refund-card-danger {
    background: var(--bg-card);
    border: 1px solid rgba(231, 76, 60, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
}

.refund-card-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
    color: var(--text-primary);
}

.refund-percentage-success {
    color: var(--success);
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.refund-percentage-warning {
    color: var(--warning);
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.refund-percentage-error {
    color: var(--error);
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.refund-description {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.6;
}

.procedure-list {
    color: var(--text-secondary);
    line-height: 2;
    font-size: 15px;
    padding-left: var(--spacing-lg);
}



/* 회원가입 */
.signup-container {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

.signup-title {
    font-size: 28px;
    margin-bottom: var(--spacing-xs);
    animation: fadeIn 0.6s ease-out;
}

.signup-subtitle {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
    animation: fadeIn 0.6s ease-out 0.2s both;
}

.verification-section {
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(80, 200, 120, 0.1) 100%);
    border: 2px solid var(--accent-gold);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
    animation: slideUp 0.6s ease-out 0.4s both;
}

.verification-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--accent-gold);
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.verification-desc {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
    line-height: 1.6;
}

.verification-buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.verify-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: var(--spacing-md);
    background: var(--bg-card);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: 600;
    font-size: 13px;
}

.verify-btn:hover {
    border-color: var(--accent-gold);
    background: rgba(212, 175, 55, 0.1);
    transform: translateY(-2px);
}

.verify-btn svg {
    width: 28px;
    height: 28px;
}

.verify-btn.kakao {
    color: #FEE500;
}

.verify-btn.naver {
    color: #03C75A;
}

.verify-btn.pass {
    color: #0064FF;
}

.verified-badge {
    display: none;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-md);
    background: rgba(80, 200, 120, 0.2);
    border: 2px solid var(--accent-green);
    border-radius: var(--radius-md);
    color: var(--accent-green);
    font-weight: 600;
    margin-top: var(--spacing-md);
}

.verified-badge.active {
    display: flex;
}

.verified-info {
    display: none;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

.verified-info.active {
    display: grid;
}

.verified-item {
    background: var(--bg-card);
    padding: var(--spacing-sm);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-color);
}

.verified-item-label {
    font-size: 11px;
    color: var(--text-disabled);
    margin-bottom: 4px;
}

.verified-item-value {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}

.age-notice {
    background: rgba(255, 152, 0, 0.1);
    border: 2px solid #FF9800;
    border-radius: var(--radius-md);
    padding: var(--spacing-sm);
    margin-top: var(--spacing-md);
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-xs);
}

.age-notice-icon {
    color: #FF9800;
    flex-shrink: 0;
}

.age-notice-text {
    font-size: 13px;
    color: var(--text-primary);
    line-height: 1.5;
}

.input-with-button {
    display: flex;
    gap: var(--spacing-sm);
}

.input-with-button .input-field {
    flex: 1;
}

.check-btn {
    padding: 16px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--accent-primary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.check-btn:hover {
    border-color: var(--accent-primary);
    background: rgba(212, 175, 55, 0.1);
}

.password-strength {
    margin-top: var(--spacing-xs);
    font-size: 12px;
    color: var(--text-disabled);
}

.strength-bar {
    height: 4px;
    background: var(--border-color);
    border-radius: 2px;
    margin-top: 6px;
    overflow: hidden;
}

.strength-fill {
    height: 100%;
    width: 0%;
    background: var(--accent-gold);
    transition: width 0.3s ease;
}

.terms-section {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.terms-title2 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
}

.term-item {
    margin-bottom: var(--spacing-md);
}

.term-item:last-child {
    margin-bottom: 0;
}

.term-link {
    color: var(--accent-primary);
    text-decoration: none;
    font-size: 13px;
    margin-left: 4px;
}

.term-link:hover {
    text-decoration: underline;
}

.terms-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    z-index: 1000;
    overflow-y: auto;
}

.terms-modal.active {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
}

.terms-modal-content {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    max-width: 600px;
    width: 100%;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    animation: slideUp 0.3s ease-out;
}

.terms-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
}

.terms-modal-header h3 {
    font-size: 20px;
    font-weight: 600;
    margin: 0;
}

.terms-modal-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 4px;
    transition: all 0.3s ease;
}

.terms-modal-close:hover {
    color: var(--text-primary);
}

.terms-modal-body {
    padding: var(--spacing-lg);
    overflow-y: auto;
    flex: 1;
    line-height: 1.8;
    color: var(--text-secondary);
}

.terms-modal-body h4 {
    color: var(--text-primary);
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-sm);
    font-size: 16px;
}

.terms-modal-body p {
    margin-bottom: var(--spacing-md);
    font-size: 14px;
}

.terms-modal-body ul {
    margin-left: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.terms-modal-body li {
    margin-bottom: var(--spacing-xs);
    font-size: 14px;
}

.terms-modal-footer {
    padding: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
}

.terms-modal-footer .btn {
    width: 100%;
}

@media (max-width: 768px) {
    .verification-buttons {
        grid-template-columns: 1fr;
    }

    .verified-info {
        grid-template-columns: 1fr;
    }

    .terms-modal-content {
        max-height: 90vh;
    }
}



/* 이용약관 */
.section-text-mb-sm {
    color: var(--text-secondary);
    line-height: 1.8;
    font-size: 15px;
    margin-bottom: var(--spacing-sm);
}

.terms-list {
    color: var(--text-secondary);
    line-height: 2;
    font-size: 15px;
    padding-left: var(--spacing-lg);
}



/* 회원 탈퇴 */
.withdrawal-container {
    padding: var(--spacing-lg);
    padding-bottom: 120px;
}

.warning-icon {
    width: 80px;
    height: 80px;
    margin: var(--spacing-xl) auto;
    background: rgba(231, 76, 60, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    animation: pulse2 2s ease-in-out infinite;
}

@keyframes pulse2 {

    0%,
    100% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.05);
        opacity: 0.8;
    }
}

.warning-card {
    background: rgba(231, 76, 60, 0.1);
    border: 2px solid var(--error);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.warning-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--error);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.warning-list {
    list-style: none;
}

.warning-item {
    padding: var(--spacing-sm) 0;
    padding-left: var(--spacing-lg);
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.6;
    position: relative;
}

.warning-item::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--error);
    font-size: 18px;
}

.notice-card {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    border: 1px solid var(--border-color);
    margin-bottom: var(--spacing-lg);
}

.notice-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    color: var(--accent-gold);
}

.notice-content {
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.8;
}

.password-section {
    margin-bottom: var(--spacing-lg);
}

.agreement-section2 {
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 2px solid var(--error);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.agreement-section2 .agreement-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    cursor: pointer;
    margin-bottom: var(--spacing-md);
}

.agreement-section2 .agreement-checkbox:last-child {
    margin-bottom: 0;
}

.agreement-section2 .agreement-checkbox input[type="checkbox"] {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid var(--border-color);
    border-radius: 4px;
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    margin-top: 2px;
    transition: all 0.3s ease;
}

.agreement-section2 .agreement-checkbox input[type="checkbox"]:checked {
    background: var(--error);
    border-color: var(--error);
}

.agreement-section2 .agreement-checkbox input[type="checkbox"]:checked::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 14px;
    font-weight: bold;
}

.action-buttons2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
}

/* HJ 로딩 팝업 추가 (2026-02-10)*/
.full_loading_div {
	position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
    display: none;
    justify-content: center;
    align-items: center;
}

.full_loading_background {
	position: absolute;
    width: 100%;
    height: 100%;
    background: rgb(211,211,211,0.4);
}

.full_loading_img {
	width: 7rem;
}

.verification-buttons {display:block; margin-bottom:0}
.verification-buttons button{width:100%}

/* Footer */
.site-footer {
  background: #252525;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 24px 20px;
  margin-top: 8px;
}

.footer-info {
  text-align: center;
}

.footer-info p {
  font-size: 12px;
  color: #B8B8B8;
  line-height: 1.8;
  margin: 0;
  word-break: keep-all;
}

.footer-copy {
  margin-top: 8px !important;
  font-size: 12px;
  color:#B8B8B8;
}
.footer-links {
  margin-top: 10px;
  display: flex;
  justify-content: center;
  gap: 10px;
}
.footer-links a {
  font-size: 14px;
  font-weight: 700;
  color:#fff;
  text-decoration: none;
  transition: color 0.2s ease;
}
.footer-links a:hover {
  color: var(--accent-gold);
}

/* 260309 이용약관 */
.terms-list{position:relative}
.terms-list li{list-style:none; line-height:1.6; margin-bottom:5px;}
.terms-list span{position:absolute; left:0;}
.section.margin ul{margin-bottom:20px}
.terms .section-title{margin-bottom:10px}

.privacy .section .subsection-title:nth-of-type(n+2){margin-top:20px}
.section-text.margin{margin-top:10px}
.nomargin {padding-left:0}
.privacy .section-title{margin-bottom:10px}
.privacy .info-box2{padding:16px}

/* 아이디 찾기 */
 .find-container {
  padding: var(--spacing-xl) var(--spacing-lg);
  padding-bottom: 100px;
}

.find-title {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: var(--spacing-xs);
  animation: fadeIn 0.6s ease-out;
}

.find-subtitle {
  color: var(--text-secondary);
  font-size: 14px;
  margin-bottom: var(--spacing-2xl);
  line-height: 1.6;
  animation: fadeIn 0.6s ease-out 0.1s both;
}

/* 탭 */
.tab-group {
  display: flex;
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  padding: 4px;
  margin-bottom: var(--spacing-xl);
  animation: slideUp 0.5s ease-out 0.2s both;
}

.tab-btn {
  flex: 1;
  padding: 12px;
  background: none;
  border: none;
  border-radius: 6px;
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
}

.tab-btn.active {
  background: var(--accent-gold);
  color: #000;
  font-weight: 700;
}

/* 폼 패널 */
.tab-panel {
  display: none;
  animation: fadeIn 0.3s ease-out;
}
.tab-panel.active {
  display: block;
}

/* 인증 버튼 */
.verify-row {
  display: flex;
  gap: var(--spacing-sm);
}

.verify-row .input-field {
  flex: 1;
}

.send-btn {
  padding: 16px 16px;
  background: var(--bg-card);
  border: 1px solid var(--accent-gold);
  border-radius: var(--radius-sm);
  color: var(--accent-gold);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.send-btn:hover {
  background: rgba(212,175,55,0.1);
}

.send-btn:disabled {
  border-color: var(--border-color);
  color: var(--text-disabled);
  cursor: not-allowed;
}

.timer-text {
  font-size: 13px;
  color: #E74C3C;
  text-align: right;
  margin-top: 6px;
  min-height: 18px;
}

/* 결과 카드 */
.result-card {
  display: none;
  background: linear-gradient(135deg, rgba(212,175,55,0.08) 0%, rgba(80,200,120,0.08) 100%);
  border: 1px solid var(--accent-gold);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  text-align: center;
  margin-bottom: var(--spacing-xl);
  animation: slideUp 0.4s ease-out;
}

.result-card.show {
  display: block;
}

.result-icon {
  margin-bottom: var(--spacing-md);
}

.result-label {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: var(--spacing-xs);
}

.result-id {
  font-size: 22px;
  font-weight: 700;
  color: var(--accent-gold);
  letter-spacing: 1px;
  margin-bottom: var(--spacing-xs);
}

.result-date {
  font-size: 12px;
  color: var(--text-disabled);
}

.result-btn-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-xl);
}

/* 에러 메시지 */
.error-msg {
  font-size: 13px;
  color: #E74C3C;
  margin-top: var(--spacing-xs);
  display: none;
}

.error-msg.show {
  display: block;
}



/* 비밀번호 찾기 */
    /* 단계 표시 */
.step-indicator {
  display: flex;
  align-items: center;
  margin-bottom: var(--spacing-xl);
  animation: slideUp 0.5s ease-out 0.2s both;
}

.step-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 2px solid var(--border-color);
  color: var(--text-disabled);
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  flex-shrink: 0;
}

.step-dot.active {
  background: var(--accent-gold);
  border-color: var(--accent-gold);
  color: #000;
}

.step-dot.done {
  background: rgba(80,200,120,0.2);
  border-color: #50C878;
  color: #50C878;
}

.step-label {
  font-size: 11px;
  margin-top: 4px;
  color: var(--text-disabled);
  text-align: center;
  white-space: nowrap;
}

.step-label.active {
  color: var(--accent-gold);
  font-weight: 600;
}

.step-label.done {
  color: #50C878;
}

.step-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.step-line {
  flex: 1;
  height: 2px;
  background: var(--border-color);
  margin: 0 var(--spacing-xs);
  margin-bottom: 18px;
  transition: background 0.3s ease;
}

.step-line.done {
  background: #50C878;
}

/* 단계 패널 */
.step-panel {
  display: none;
  animation: fadeIn 0.35s ease-out;
}
.step-panel.active {
  display: block;
}

.find .section-label {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: var(--spacing-lg);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--accent-gold);
}

/* 비밀번호 강도 */
.password-strength {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-xs);
}

.strength-bar {
  flex: 1;
  height: 4px;
  background: var(--bg-input);
  border-radius: 2px;
  overflow: hidden;
}

.strength-fill {
  height: 100%;
  width: 0%;
  border-radius: 2px;
  transition: width 0.3s ease, background 0.3s ease;
}

.strength-text {
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
}

/* 완료 카드 */
.done-card {
  text-align: center;
  padding: var(--spacing-2xl) var(--spacing-lg);
  animation: slideUp 0.4s ease-out;
}

.done-icon {
  width: 72px;
  height: 72px;
  background: rgba(212,175,55,0.1);
  border: 2px solid var(--accent-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--spacing-lg);
}

.done-title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: var(--spacing-xs);
}

.done-desc {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: var(--spacing-2xl);
}

/* 260323 - 메인 수정 */
.logo{display:flex; align-items:center; justify-content:center;}
.logo>img{width:140px}

.hero-section .hero-logo{font-size:32px; letter-spacing:-0.25px; -webkit-text-fill-color:#fff; font-family:var(--font-body);}
.hero-section .hero-subtitle{font-weight:300; font-size:16px; margin-top:10px;}
.hero-section .hero-description{font-weight:300; font-size:16px;}
.hero-section .cta-buttons{margin-top:10px}

.features-section .text-center {font-family:var(--font-body); font-weight:400; font-size:18px;}

.sidebar-logo{font-family:var(--font-body); letter-spacing:-0.25px;;}

/* ===== 입금대기 페이지 ===== */
.pending_container { padding: var(--spacing-xl) var(--spacing-lg); padding-bottom: 160px; text-align: center; }
.pending_title { font-size: 26px; font-weight: 700; margin-bottom: var(--spacing-sm); animation: fadeIn 0.5s ease-out 0.3s both; }
.pending_subtitle { color: var(--text-secondary); font-size: 14px; line-height: 1.7; margin-bottom: var(--spacing-xl); animation: fadeIn 0.5s ease-out 0.4s both; }

/* 계좌 안내 카드 */
.account_card { background: var(--bg-card); border-radius: var(--radius-lg); padding: var(--spacing-lg); border: 2px solid rgba(212, 175, 55, 0.3); margin-bottom: var(--spacing-lg); text-align: left; animation: slideUp 0.5s ease-out 0.5s both; }
.account_card_title { font-size: 15px; font-weight: 700; color: var(--accent-gold); margin-bottom: var(--spacing-md); display: flex; align-items: center; gap: 8px; }
.account_info_box { background: rgba(212, 175, 55, 0.06); border-radius: var(--radius-md); padding: var(--spacing-md) var(--spacing-lg); margin-bottom: var(--spacing-md); }
.account_bank { font-size: 13px; color: var(--text-secondary); margin-bottom: 4px; }
.account_num_row { display: flex; align-items: center; justify-content: space-between; gap: var(--spacing-sm); }
.account_num { font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--text-primary); letter-spacing: 1px; }
.copy_btn { display: flex; align-items: center; gap: 5px; padding: 8px 14px; background: var(--accent-gold); color: var(--bg-primary); border: none; border-radius: var(--radius-sm); font-size: 13px; font-weight: 700; cursor: pointer; transition: opacity 0.2s; flex-shrink: 0; }
.copy_btn:hover { opacity: 0.85; }
.copy_btn.copied { background: var(--success); }
.account_holder { font-size: 13px; color: var(--text-secondary); margin-top: 6px; }
.account_amount_row { display: flex; justify-content: space-between; align-items: center; margin-top: var(--spacing-sm); padding-top: var(--spacing-sm); border-top: 1px solid var(--border-color); }
.account_amount_label { font-size: 13px; color: var(--text-secondary); }
.account_amount_value { font-size: 18px; font-weight: 700; color: var(--accent-gold); font-family: var(--font-display); }

/* 타이머 */
.timer_box { display: flex; align-items: center; gap: 10px; padding: var(--spacing-md) var(--spacing-lg); background: rgba(231, 76, 60, 0.08); border: 1px solid rgba(231, 76, 60, 0.3); border-radius: var(--radius-md); }
.timer_icon { color: var(--error); flex-shrink: 0; }
.timer_text { font-size: 13px; color: var(--error); font-weight: 600; flex: 1; line-height: 1.5; }
.timer_countdown { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--error); flex-shrink: 0; min-width: 60px; text-align: right; }

/* 예약번호 카드 */
.res_num_card { background: var(--bg-card); border-radius: var(--radius-lg); padding: var(--spacing-lg); border: 2px solid var(--accent-primary); margin-bottom: var(--spacing-lg); text-align: left; animation: slideUp 0.5s ease-out 0.6s both; }
.res_num_label { font-size: 16px; color: var(--text-primary); margin-bottom: 6px; letter-spacing: 0.5px; text-align: center; }
.res_num_value { font-family: var(--font-display); font-size: 24px; font-weight: 700; color: var(--accent-gold); letter-spacing: 2px; text-align: center; padding: var(--spacing-md); background: rgba(212, 175, 55, 0.07); border-radius: var(--radius-md); border: 1px dashed rgba(212, 175, 55, 0.4); margin-bottom: var(--spacing-md); }
.res_info_row { display: flex; align-items: center; gap: var(--spacing-md); padding: var(--spacing-sm) 0; border-bottom: 1px solid var(--border-color); }
.res_info_row:last-child { border-bottom: none; }
.res_info_icon { font-size: 20px; flex-shrink: 0; width: 28px; text-align: center; }
.res_info_content { flex: 1; }
.res_info_label { font-size: 11px; color: var(--text-secondary); margin-bottom: 3px; }
.res_info_value { font-size: 15px; font-weight: 600; color: var(--text-primary); }

/* 확정 안내 카드 */
.notice_card { background: rgba(0, 168, 107, 0.06); border: 1px solid rgba(0, 168, 107, 0.25); border-radius: var(--radius-md); padding: var(--spacing-md) var(--spacing-lg); margin-bottom: var(--spacing-lg); text-align: left; animation: slideUp 0.5s ease-out 0.7s both; }
.notice_title { font-size: 14px; font-weight: 700; color: var(--success); margin-bottom: var(--spacing-sm); display: flex; align-items: center; gap: 6px; }
.notice_steps { list-style: none; display: grid; gap: 8px; }
.notice_step { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--text-secondary); line-height: 1.6; }
.step_num { width: 20px; height: 20px; background: rgba(0, 168, 107, 0.2); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: var(--success); flex-shrink: 0; margin-top: 1px; }
.step_sub { font-size: 12px; color: var(--text-secondary); display: block; margin-top: 2px; }

/* CTA */
.cta_section { position: fixed; bottom: 0; left: 50%; transform: translateX(-50%); max-width: 480px; width: 100%; background: linear-gradient(180deg, transparent 0%, rgba(26, 26, 26, 0.98) 20%); padding: var(--spacing-lg); backdrop-filter: blur(10px); z-index:50; }
.action_btns { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-sm); }
.btn_half { padding: 16px; font-size: 14px; }

@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

.discount-row span {
	font-size: 13px;
	color : #ff00008c;
}

.price-card-bottom {
	padding-top: 15px;
    align-items: center;
    padding-top: var(--spacing-md);
    margin-top: var(--spacing-md);
    border-top: 2px solid rgba(212, 175, 55, 0.2);
}

.price-card-bottom .price-card-title {
	display: flex;
    justify-content: space-between;
    color: #2c8bdb;
}

.price-card-bottom .price-card-title .price-card-left {
	font-size: 18px;
    font-weight: bold;
}

.price-card-bottom .price-card-title .price-card-right {
	font-size: 12px;
    font-weight: bold;
}
 /******* 예약내역 ********/
:root { --z-sticky: 50; --z-modal: 300; }

.status-pending { background: rgba(212, 175, 55, 0.2); color: var(--accent-gold); }

/* 입금 대기 안내 */
.pending-notice {margin-bottom:14px; display: flex; align-items: center; gap: 8px; margin-top: var(--spacing-sm); padding: var(--spacing-sm) var(--spacing-md); background: rgba(212, 175, 55, 0.08); border: 1px solid rgba(212, 175, 55, 0.25); border-radius: var(--radius-sm); font-size: 13px; color: var(--accent-gold); }
.pending-dot { width: 6px; height: 6px; background: var(--accent-gold); border-radius: 50%; flex-shrink: 0; animation: pendingPulse 1.5s ease-in-out infinite; }
.pending-timer { margin-left: auto; font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--accent-gold); flex-shrink: 0; }
.pending-timer.urgent { color: var(--error); animation: timerUrgent 0.8s ease-in-out infinite; }

/* 모달 - 입금 대기 안내 */
.pending_modal_notice { background: rgba(212, 175, 55, 0.08); border: 1px solid rgba(212, 175, 55, 0.3); border-radius: 12px; padding: 16px; margin-bottom: 16px; }
.pending_modal_title { font-size: 13px; font-weight: 700; color: var(--accent-gold); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.pending_modal_desc { font-size: 13px; color: var(--text-secondary); line-height: 1.7; margin-bottom: 10px; }
.account_copy_row { display: flex; align-items: center; justify-content: space-between; background: var(--bg-input); border-radius: 8px; padding: 10px 14px; }
.account_copy_bank { font-size: 11px; color: var(--text-disabled); margin-bottom: 3px; }
.account_copy_num { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--text-primary); letter-spacing: 1px; }
.modal_copy_btn { display: flex; align-items: center; gap: 5px; padding: 8px 14px; background: var(--accent-gold); color: var(--bg-primary); border: none; border-radius: 8px; font-size: 13px; font-weight: 700; cursor: pointer; flex-shrink: 0; transition: background 0.2s; }
.modal_copy_btn.copied { background: var(--success); }

@keyframes pendingPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
@keyframes timerUrgent { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }

/* ===== 결제 로딩 페이지 ===== */
.loading_wrap {
	display: flex;
  	flex-direction: column;
  	align-items: center;
  	justify-content: center;
  	min-height: 100vh;
  	padding: var(--spacing-xl) var(--spacing-lg);
  	text-align: center;
  	position: relative;
  	overflow: hidden;
}

/* 배경 파티클 효과 */
.loading_wrap::before {
  	content: '';
  	position: absolute;
  	width: 300px;
  	height: 300px;
  	border-radius: 50%;
  	background: radial-gradient(circle, rgba(212, 175, 55, 0.06) 0%, transparent 70%);
  	top: 50%;
  	left: 50%;
  	transform: translate(-50%, -50%);
  	animation: pulse_bg 3s ease-in-out infinite;
}

@keyframes pulse_bg {
  	0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.6; }
  	50% { transform: translate(-50%, -50%) scale(1.3); opacity: 1; }
}

/* 메인 로딩 아이콘 영역 */
.spinner_wrap {
  	position: relative;
  	width: 120px;
  	height: 120px;
  	margin: 0 auto var(--spacing-xl);
}

/* 외부 회전 링 */
.ring_outer {
  	position: absolute;
  	inset: 0;
  	border-radius: 50%;
  	border: 3px solid transparent;
  	border-top-color: var(--accent-gold);
  	border-right-color: rgba(212, 175, 55, 0.3);
  	animation: spin_outer 1.4s cubic-bezier(0.5, 0, 0.5, 1) infinite;
}

/* 내부 회전 링 */
.ring_inner {
  	position: absolute;
  	inset: 14px;
  	border-radius: 50%;
  	border: 2px solid transparent;
  	border-top-color: var(--accent-green);
  	border-left-color: rgba(0, 168, 107, 0.3);
  	animation: spin_inner 1s cubic-bezier(0.5, 0, 0.5, 1) infinite reverse;
}

/* 중앙 아이콘 */
.spinner_center {
  	position: absolute;
  	inset: 28px;
  	border-radius: 50%;
  	background: linear-gradient(135deg, rgba(212, 175, 55, 0.15) 0%, rgba(0, 168, 107, 0.1) 100%);
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	border: 1px solid rgba(212, 175, 55, 0.2);
  	animation: center_pulse 2s ease-in-out infinite;
}

@keyframes spin_outer {
  	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

@keyframes spin_inner {
  	0% { transform: rotate(0deg); }
  	100% { transform: rotate(360deg); }
}

@keyframes center_pulse {
  	0%, 100% { opacity: 0.7; transform: scale(0.95); }
  	50% { opacity: 1; transform: scale(1.05); }
}

/* 도트 로딩 애니메이션 */
.dots_wrap {
  	display: flex;
  	gap: 6px;
  	justify-content: center;
  	margin-bottom: var(--spacing-xl);
}

.dot {
  	width: 8px;
  	height: 8px;
  	border-radius: 50%;
  	background: var(--accent-gold);
  	opacity: 0.3;
  	animation: dot_blink 1.4s ease-in-out infinite;
}

.dot:nth-child(1) { animation-delay: 0s; }
.dot:nth-child(2) { animation-delay: 0.2s; }
.dot:nth-child(3) { animation-delay: 0.4s; }

@keyframes dot_blink {
  	0%, 100% { opacity: 0.2; transform: scale(0.8); }
  	50% { opacity: 1; transform: scale(1.2); background: var(--accent-green); }
}

/* 텍스트 */
.loading_title {
  	font-size: 22px;
  	font-weight: 700;
  	margin-bottom: var(--spacing-sm);
  	animation: fadeIn 0.6s ease-out;
}

.loading_desc {
  	font-size: 14px;
  	color: var(--text-secondary);
  	line-height: 1.8;
  	margin-bottom: var(--spacing-xl);
  	animation: fadeIn 0.6s ease-out 0.2s both;
}

/* 상태 메시지 (동적으로 변경) */
.status_msg {
  	display: inline-flex;
  	align-items: center;
  	gap: 8px;
  	padding: 10px 20px;
  	background: rgba(212, 175, 55, 0.08);
  	border: 1px solid rgba(212, 175, 55, 0.2);
  	border-radius: 100px;
  	font-size: 13px;
  	color: var(--accent-gold);
  	font-weight: 500;
  	animation: fadeIn 0.6s ease-out 0.4s both;
  	transition: all 0.4s ease;
}

.status_dot {
  	width: 6px;
  	height: 6px;
  	border-radius: 50%;
  	background: var(--accent-gold);
  	animation: dot_blink 1s ease-in-out infinite;
}

/* 안내 카드 */
.notice_box {
  	width: 100%;
  	background: var(--bg-card);
  	border-radius: var(--radius-md);
  	padding: var(--spacing-lg);
  	border: 1px solid var(--border-color);
  	text-align: left;
  	margin-top: var(--spacing-xl);
  	animation: fadeIn 0.6s ease-out 0.5s both;
}

.notice_row {
 	display: flex;
  	align-items: flex-start;
  	gap: 12px;
  	padding: var(--spacing-xs) 0;
  	font-size: 13px;
  	color: var(--text-primary);
  	line-height: 1.6;
}

.notice_row + .notice_row {
  	border-top: 1px solid rgba(255,255,255,0.04);
  	margin-top: 6px;
  	padding-top: 10px;
}

.notice_icon {
  	color: var(--accent-gold);
  	flex-shrink: 0;
  	margin-top: 2px;
}

/* 진행 바 */
@keyframes fadeIn {
  	from { opacity: 0; transform: translateY(12px); }
  	to { opacity: 1; transform: translateY(0); }
}

/* ===== 결제 실패 페이지 ===== */
.error_wrap {
  	display: flex;
  	flex-direction: column;
  	align-items: center;
  	padding: var(--spacing-xl) var(--spacing-lg);
  	padding-bottom: 160px;
  	text-align: center;
}

/* 상단 아이콘 */
.error_icon_wrap {
  	width: 100px;
  	height: 100px;
  	margin: var(--spacing-xl) auto var(--spacing-lg);
  	background: rgba(231, 76, 60, 0.08);
  	border: 2.5px solid var(--error);
  	border-radius: 50%;
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	animation: scaleIn 0.55s cubic-bezier(0.68, -0.55, 0.265, 1.55), iconPulse 2.5s ease-in-out 0.6s infinite;
  	flex-shrink: 0;
}

@keyframes scaleIn {
  	0% { transform: scale(0); opacity: 0; }
  	100% { transform: scale(1); opacity: 1; }
}

@keyframes iconPulse {
  	0%, 100% { box-shadow: 0 0 0 0 rgba(231, 76, 60, 0.25); }
  	50% { box-shadow: 0 0 0 14px rgba(231, 76, 60, 0); }
}

/* 타이틀 */
.error_title {
  	font-size: 26px;
  	font-weight: 700;
  	margin-bottom: var(--spacing-xs);
  	animation: fadeUp 0.5s ease-out 0.3s both;
}

.error_subtitle {
  	font-size: 14px;
  	color: var(--text-secondary);
  	line-height: 1.7;
  	margin-bottom: var(--spacing-xl);
  	animation: fadeUp 0.5s ease-out 0.4s both;
}

/* 실패 사유 카드 (메인) */
.reason_card {
  	width: 100%;
  	background: var(--bg-card);
  	border-radius: var(--radius-lg);
  	padding: var(--spacing-lg);
  	border: 1px solid rgba(231, 76, 60, 0.3);
  	margin-bottom: var(--spacing-md);
  	text-align: left;
  	animation: fadeUp 0.5s ease-out 0.5s both;
}

.reason_header {
  	display: flex;
  	align-items: center;
  	gap: 10px;
  	margin-bottom: var(--spacing-md);
  	padding-bottom: var(--spacing-md);
 	border-bottom: 1px solid var(--border-color);
}

.reason_badge {
  	display: inline-flex;
  	align-items: center;
  	gap: 6px;
  	padding: 5px 12px;
  	background: rgba(231, 76, 60, 0.12);
  	border: 1px solid rgba(231, 76, 60, 0.3);
  	border-radius: 100px;
  	font-size: 12px;
  	font-weight: 700;
  	color: var(--error);
  	letter-spacing: 0.3px;
}

.reason_code_label {
  	font-size: 12px;
  	color: var(--text-secondary);
  	margin-left: auto;
}

.reason_main {
  	display: flex;
  	align-items: flex-start;
  	gap: var(--spacing-md);
  	margin-bottom: var(--spacing-md);
}

.reason_icon_circle {
  	width: 44px;
  	height: 44px;
  	border-radius: 50%;
  	background: rgba(231, 76, 60, 0.1);
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	flex-shrink: 0;
}

.reason_text_wrap {
  	flex: 1;
  	text-align: left;
}

.reason_label {
  	font-size: 11px;
  	color: var(--text-secondary);
  	margin-bottom: 4px;
  	letter-spacing: 0.5px;
  	text-transform: uppercase;
}

.reason_text {
  	font-size: 17px;
  	font-weight: 700;
  	color: var(--error);
  	line-height: 1.4;
}

.reason_desc {
  	font-size: 13px;
  	color: var(--text-primary);
  	line-height: 1.7;
  	margin-top: var(--spacing-xs);
}

/* 결제 정보 요약 */
.payment_summary {
  	border-top: 1px solid var(--border-color);
  	padding-top: var(--spacing-md);
  	display: grid;
  	gap: 8px;
}

.summary_row {
  	display: flex;
  	justify-content: space-between;
  	align-items: center;
  	font-size: 13px;
}

.summary_label {
  	color: var(--text-secondary);
}

.summary_value {
  	font-weight: 600;
  	color: var(--text-primary);
}

/* 해결 방법 카드 */
.solution_card {
  	width: 100%;
  	background: rgba(212, 175, 55, 0.05);
  	border: 1px solid rgba(212, 175, 55, 0.2);
  	border-radius: var(--radius-md);
  	padding: var(--spacing-lg);
  	text-align: left;
  	margin-bottom: var(--spacing-md);
  	animation: fadeUp 0.5s ease-out 0.6s both;
}

.solution_title {
  	font-size: 14px;
  	font-weight: 700;
  	color: var(--accent-gold);
  	margin-bottom: var(--spacing-md);
  	display: flex;
  	align-items: center;
  	gap: 8px;
}

.solution_list {
  	list-style: none;
  	display: grid;
  	gap: 10px;
}

.solution_item {
  	display: flex;
  	align-items: flex-start;
  	gap: 10px;
  	font-size: 13px;
  	color: var(--text-secondary);
  	line-height: 1.6;
}

.solution_num {
  	width: 20px;
  	height: 20px;
  	background: rgba(212, 175, 55, 0.15);
  	border-radius: 50%;
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	font-size: 11px;
  	font-weight: 700;
  	color: var(--accent-gold);
  	flex-shrink: 0;
  	margin-top: 1px;
}

/* 고객센터 안내 */
.cs_row {
  	width: 100%;
  	display: flex;
  	align-items: center;
  	gap: 10px;
  	padding: var(--spacing-md) var(--spacing-lg);
  	background: var(--bg-card);
  	border-radius: var(--radius-md);
  	border: 1px solid var(--border-color);
  	text-align: left;
  	margin-bottom: var(--spacing-xl);
  	animation: fadeUp 0.5s ease-out 0.7s both;
}

.cs_icon {
  	width: 36px;
  	height: 36px;
  	border-radius: var(--radius-sm);
  	background: rgba(212, 175, 55, 0.1);
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	flex-shrink: 0;
  	color: var(--accent-gold);
}

.cs_text {
  	flex: 1;
}

.cs_label {
  	font-size: 11px;
  	color: var(--text-secondary);
  	margin-bottom:-5px
}

.cs_number {
  	font-size: 16px;
  	font-weight: 700;
  	color: var(--text-primary);
  	font-family: var(--font-display);
}

/* 하단 고정 버튼 */
.cta_section {
  	position: fixed;
  	bottom: 0;
  	left: 50%;
  	transform: translateX(-50%);
  	max-width: 480px;
  	width: 100%;
  	background: linear-gradient(180deg, transparent 0%, rgba(26, 26, 26, 0.98) 20%);
  	padding: var(--spacing-lg);
  	backdrop-filter: blur(10px);
  	z-index: 50;
}

.btn_wrap {
  	display: grid;
  	grid-template-columns: 1fr 1fr;
  	gap: var(--spacing-sm);
  	margin-bottom: var(--spacing-sm);
}

.btn_full {
  	grid-column: 1 / -1;
}

.btn_half {
  	padding: 16px;
  	font-size: 14px;
}

/* 재시도 버튼 강조 */
.btn-retry {
  	background: var(--error);
  	color: white;
  	box-shadow: 0 4px 16px rgba(231, 76, 60, 0.3);
}

.btn-retry:hover {
  	background: #c0392b;
  	box-shadow: 0 6px 24px rgba(231, 76, 60, 0.4);
  	transform: translateY(-2px);
}

@keyframes fadeUp {
  	from { opacity: 0; transform: translateY(14px); }
  	to { opacity: 1; transform: translateY(0); }
}

 /*260424 메인 수정*/
.quick-link-title{margin-bottom:0}
.quick-link-icon{display:flex; align-items:center;justify-content: center;}