/* ===== PRICING HERO ===== */
.pricing-hero { padding: 60px 0 40px; text-align: center; background: #fff; }
.pricing-hero h1 { font-size: 44px; margin-bottom: 16px; color: #1A1A2E; line-height: 1.2; letter-spacing: -0.02em; }
.pricing-hero p { font-size: 18px; color: #6B7280; max-width: 600px; margin: 0 auto; line-height: 1.6; }

/* ===== SECTION WRAPPERS ===== */
.section-1on1 { background: #F8F9FA; padding: 80px 0; }
.section-group { background: #fff; padding: 80px 0; }
.section-included { background: #F8F9FA; padding: 60px 0; }

/* ===== 1-ON-1 PRICING ===== */
.pricing-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; max-width: 800px; margin: 0 auto; align-items: stretch; }
@media (max-width: 768px) { .pricing-grid { grid-template-columns: 1fr; } }
.price-card { background: #fff; border: 1px solid #E5E7EB; border-radius: 12px; padding: 40px; text-align: left; position: relative; box-shadow: 0 4px 16px rgba(0,0,0,0.06); display: flex; flex-direction: column; }
.price-card-popular { border-top: 3px solid #2ECC71; }
.popular-pill { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: #2ECC71; color: #fff; font-size: 12px; font-weight: 600; padding: 4px 16px; border-radius: 20px; white-space: nowrap; }
.price-amount { font-size: 48px; font-weight: 700; color: #1A1A2E; line-height: 1; margin-bottom: 2px; }
.price-period { font-size: 16px; color: #9CA3AF; font-weight: 400; }
.price-total { font-size: 13px; color: #9CA3AF; margin-top: 4px; margin-bottom: 16px; min-height: 20px; }
.price-desc { font-size: 15px; color: #4B5563; margin-bottom: 24px; }
.pricing-divider { height: 1px; background: #E5E7EB; margin-bottom: 24px; }
.pricing-list { list-style: none; padding: 0; margin-bottom: 32px; }
.pricing-list li { display: flex; gap: 12px; margin-bottom: 12px; color: #4B5563; align-items: flex-start; font-size: 15px; }
@media (max-width: 768px) { .price-card { padding: 24px; } }

/* ===== SMALL GROUP PRICING ===== */
.group-card { background: #fff; border: 1px solid #E5E7EB; border-top: 3px solid #2ECC71; border-radius: 12px; padding: 40px; text-align: center; max-width: 520px; margin: 0 auto; box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
.group-amount { font-size: 48px; font-weight: 700; color: #1A1A2E; line-height: 1; margin-bottom: 8px; }
.group-period { font-size: 18px; color: #9CA3AF; font-weight: 400; }
.group-billing { font-size: 14px; color: #9CA3AF; margin-bottom: 24px; }
.class-badges { display: flex; gap: 12px; justify-content: center; margin: 24px 0; flex-wrap: wrap; }
.class-badge { background: #F8F9FA; color: #1A1A2E; font-size: 13px; font-weight: 600; padding: 8px 16px; border-radius: 20px; }
.group-card .pricing-list { text-align: left; }
.group-card .pricing-list li { text-align: left; }
.group-cancel { font-size: 14px; color: #9CA3AF; margin: 24px 0; }
@media (max-width: 600px) { .group-card { padding: 24px; } }

/* ===== INCLUDED ITEMS ===== */
.included-row { display: flex; justify-content: center; gap: 40px; margin-bottom: 32px; flex-wrap: wrap; }
.included-item { display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; width: 120px; }
.included-icon { width: 40px; height: 40px; border-radius: 8px; background: #E8F8F0; color: #2ECC71; display: flex; align-items: center; justify-content: center; }
.included-label { font-size: 14px; font-weight: 600; color: #1A1A2E; }
.included-note { text-align: center; font-size: 14px; color: #9CA3AF; }

/* ===== FINAL CTA BANNER ===== */
.custom-cta-banner { background: #2D3436; padding: 80px 0; text-align: center; color: #fff; }
.custom-cta-banner h2 { font-size: 36px; margin-bottom: 16px; color: #fff; }
.custom-cta-banner p { font-size: 18px; color: #9CA3AF; max-width: 600px; margin: 0 auto 32px; line-height: 1.6; }

/* ===== FAQ ===== */
.faq { background: #fff; padding: 80px 0; }
.faq-list { max-width: 780px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid #E5E7EB; }
.faq-item:first-child { border-top: 1px solid #E5E7EB; }
.faq-question {
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    padding: 20px 0; cursor: pointer; width: 100%; background: none; border: none;
    font-family: inherit; font-size: 17px; font-weight: 600; color: #1A1A2E; text-align: left;
    transition: color 0.2s ease;
}
.faq-question:hover { color: #2ECC71; }
.faq-toggle {
    width: 28px; height: 28px; border-radius: 50%; border: 1px solid #E5E7EB;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
    font-size: 18px; color: #6B7280; transition: transform 0.3s ease, background 0.2s ease;
}
.faq-item.active .faq-toggle { transform: rotate(45deg); background: #E8F8F0; color: #2ECC71; border-color: #2ECC71; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.faq-answer-inner { padding: 0 0 20px; font-size: 15px; line-height: 1.7; color: #6B7280; }
