/* ── Intro Module ── */
.intro-section { font-family: 'Inter', sans-serif; }

.intro-bg-lines { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.intro-line {
    position: absolute; background: rgba(255,255,255,0.03);
    border-radius: 50%; transform: rotate(-15deg);
}
.intro-line-1 { width: 600px; height: 600px; top: -200px; right: -150px; }
.intro-line-2 { width: 400px; height: 400px; bottom: -100px; left: -100px; }
.intro-line-3 { width: 1px; height: 100%; top: 0; left: 50%; background: rgba(255,255,255,0.04); transform: none; border-radius: 0; }

.intro-container { max-width: 1100px; margin: 0 auto; padding: 0 32px; position: relative; z-index: 1; }

.intro-badge-wrap { text-align: center; margin-bottom: 28px; }
.intro-badge {
    display: inline-flex; align-items: center; gap: 8px;
    border: 1px solid rgba(255,255,255,0.15);
    padding: 6px 18px; border-radius: 100px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
    text-transform: uppercase; color: rgba(255,255,255,0.7);
    backdrop-filter: blur(8px);
}
.intro-badge-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: #c9a84c; flex-shrink: 0;
    box-shadow: 0 0 8px #c9a84c;
}

.intro-header { text-align: center; max-width: 780px; margin: 0 auto 60px; }
.intro-title {
    font-size: clamp(1.6rem, 3.5vw, 2.6rem);
    font-weight: 800; line-height: 1.2;
    letter-spacing: -0.02em; margin-bottom: 20px;
    color: inherit;
}
.intro-desc { font-size: 1rem; line-height: 1.8; color: rgba(255,255,255,0.6); max-width: 680px; margin: 0 auto; }

.intro-stats {
    display: flex; align-items: center; justify-content: center;
    gap: 0; margin-bottom: 64px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px; overflow: hidden;
    backdrop-filter: blur(8px);
    background: rgba(255,255,255,0.03);
}
.intro-stat { flex: 1; text-align: center; padding: 28px 20px; display: flex; flex-direction: column; gap: 6px; }
.intro-stat-num { font-size: 2rem; font-weight: 800; letter-spacing: -0.03em; color: #c9a84c; line-height: 1; }
.intro-stat-label { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.45); }
.intro-stat-divider { width: 1px; height: 60px; background: rgba(255,255,255,0.08); flex-shrink: 0; }

.intro-feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 56px; }
.intro-feat {
    padding: 32px 28px; border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.03);
    backdrop-filter: blur(8px);
    transition: border-color 0.3s, background 0.3s;
}
.intro-feat:hover { border-color: rgba(201,168,76,0.3); background: rgba(201,168,76,0.04); }
.intro-feat-icon { width: 44px; height: 44px; margin-bottom: 20px; color: #c9a84c; }
.intro-feat-icon svg { width: 100%; height: 100%; }
.intro-feat-title { font-size: 1rem; font-weight: 700; margin-bottom: 10px; color: inherit; letter-spacing: -0.01em; }
.intro-feat-desc { font-size: 0.875rem; line-height: 1.7; color: rgba(255,255,255,0.5); }

.intro-cta-wrap { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.intro-btn-primary {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 32px; border-radius: 100px;
    background: #c9a84c; color: #0a0a0f;
    font-size: 0.875rem; font-weight: 800;
    letter-spacing: 0.04em; text-transform: uppercase;
    text-decoration: none;
    transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 4px 24px rgba(201,168,76,0.3);
}
.intro-btn-primary svg { width: 16px; height: 16px; }
.intro-btn-primary:hover { background: #e0bc5a; transform: translateY(-2px); box-shadow: 0 8px 32px rgba(201,168,76,0.4); }
.intro-btn-ghost {
    display: inline-flex; align-items: center;
    padding: 14px 32px; border-radius: 100px;
    border: 1px solid rgba(255,255,255,0.2);
    color: rgba(255,255,255,0.8);
    font-size: 0.875rem; font-weight: 600;
    letter-spacing: 0.04em; text-transform: uppercase;
    text-decoration: none;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.intro-btn-ghost:hover { border-color: rgba(255,255,255,0.5); color: #fff; background: rgba(255,255,255,0.05); }

@media (max-width: 768px) {
    .intro-container { padding: 0 20px; }
    .intro-feats { grid-template-columns: 1fr; gap: 14px; }
    .intro-stats { flex-wrap: wrap; }
    .intro-stat { min-width: 45%; }
    .intro-stat-divider { display: none; }
    .intro-title { font-size: 1.5rem; }
}
