/**
 * 파일명: campaigns.css
 * 파일경로: /home/testitkr/public_html/assets/css/pages/
 * 기능: 퀵 가이드 슬라이드 모달 (campaigns.php + posts.php 공통 로드)
 *       campaign-hero-actions / campaign-filter / cfilter-* → style.css 로 이전
 * 작성일: 2026-05-31
 */

/* ============================================================================
 * Quick Guide Modal
 * ========================================================================= */

.qguide-overlay {
    position: fixed;
    inset: 0;
    background: rgba(14, 26, 43, 0.55);
    backdrop-filter: blur(4px);
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.qguide-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

.qguide-modal {
    background: var(--color-surface);
    border-radius: var(--radius-xl);
    width: 100%;
    max-width: 460px;
    padding: var(--space-7) var(--space-6) var(--space-5);
    position: relative;
    box-shadow: var(--shadow-lg);
    transform: translateY(16px);
    transition: transform 0.25s ease;
}

.qguide-overlay.is-open .qguide-modal {
    transform: translateY(0);
}

.qguide-close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: var(--color-surface-alt);
    color: var(--color-text-sub);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition), color var(--transition);
}

.qguide-close:hover {
    background: var(--color-lavender-strong);
    color: var(--color-primary);
}

.qguide-slides {
    position: relative;
    min-height: 220px;
    overflow: hidden;
}

.qguide-slide {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    opacity: 0;
    transform: translateX(40px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: none;
    padding: 0 var(--space-2);
}

.qguide-slide.is-active {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
    position: relative;
}

.qguide-slide.is-prev {
    opacity: 0;
    transform: translateX(-40px);
}

.qguide-icon {
    font-size: 48px;
    line-height: 1;
    margin-bottom: var(--space-4);
}

.qguide-title {
    font-size: var(--fs-lg);
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: var(--space-3);
    color: var(--color-text-strong);
}

.qguide-body {
    font-size: var(--fs-base);
    color: var(--color-text-sub);
    line-height: 1.75;
    margin: 0;
}

.qguide-cta { margin-top: var(--space-4); }

.qguide-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    margin-top: var(--space-5);
}

.qguide-prev,
.qguide-next {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text);
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color var(--transition), background var(--transition);
    flex-shrink: 0;
}

.qguide-prev:hover,
.qguide-next:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
}

.qguide-prev:disabled,
.qguide-next:disabled { opacity: 0.3; cursor: default; }

.qguide-dots {
    display: flex;
    gap: var(--space-2);
    align-items: center;
}

.qguide-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: var(--color-border-strong);
    padding: 0;
    cursor: pointer;
    transition: background var(--transition), width var(--transition);
}

.qguide-dot.is-active {
    background: var(--color-primary);
    width: 20px;
    border-radius: 4px;
}

.qguide-footer {
    text-align: center;
    margin-top: var(--space-3);
}

.qguide-skip {
    background: none;
    border: none;
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    cursor: pointer;
    padding: var(--space-2);
    font-family: var(--font-sans);
    transition: color var(--transition);
}

.qguide-skip:hover { color: var(--color-text-sub); }
