/* Minimal styles to fit existing theme */
.hero { padding: 80px 0; background: linear-gradient(135deg, #101223, #1a1d36); color: #fff; }
.hero .container { max-width: 1140px; margin: 0 auto; }
.hero h1 { font-weight: 800; margin-bottom: 10px; }
.hero p { opacity: .85; }
.hero .hero-badge { display: inline-flex; align-items: center; gap: 10px; background: rgba(255,255,255,.08); padding: 10px 14px; border-radius: 999px; margin-top: 16px; }

.plan-details { padding: 60px 0; }
.plan-header { display: flex; justify-content: space-between; align-items: center; gap: 20px; margin-bottom: 24px; }
.plan-title { margin: 0; font-weight: 700; }
.plan-price { color: #C41E3A; font-weight: 700; }
.plan-tabs .tab-button { border: 0; background: #f1f1f5; padding: 10px 12px; border-radius: 8px; cursor: pointer; }
.plan-tabs .tab-button.active { background: #C41E3A; color: #fff; }

.modules-pricing-wrapper { display: grid; grid-template-columns: 1.2fr .8fr; gap: 24px; }
@media (max-width: 991px) { .modules-pricing-wrapper { grid-template-columns: 1fr; } }

.modules-card { background: #fff; border: 1px solid #eee; border-radius: 16px; padding: 20px; }
.modules-header h3 { margin: 0 0 6px; }
.modules-list { display: grid; grid-template-columns: 1fr; gap: 10px; }
.module-item { display: grid; grid-template-columns: 28px 1fr auto; align-items: center; gap: 12px; padding: 12px; border: 1px solid #eee; border-radius: 12px; background: #fafafa; cursor: pointer; transition: box-shadow .2s, transform .2s; }
.module-item:hover { box-shadow: 0 4px 14px rgba(0,0,0,.06); transform: translateY(-1px); }
.module-item.included { cursor: default; background: #f6fff8; border-color: #e1f4e7; }
.module-item.optional.selected { border-color: #C41E3A; box-shadow: 0 6px 22px rgba(196,30,58,.18); }
.module-icon i { color: #16a34a; }
.module-item.optional .module-icon i { color: #C41E3A; }
.status-badge { display: inline-block; padding: 6px 10px; border-radius: 999px; font-size: 12px; }
.status-badge.included { background: #e8f7ee; color: #0f5132; }
.status-badge.optional { background: #fff0f3; color: #C41E3A; }

.pricing-summary { background: #fff; border: 1px solid #eee; border-radius: 16px; padding: 20px; position: sticky; top: 20px; }
.summary-header h3 { margin: 0 0 12px; }
.summary-content { display: grid; gap: 10px; }
.summary-item { display: flex; justify-content: space-between; }
.summary-item.total .summary-value { color: #C41E3A; font-weight: 800; }
.summary-divider { height: 1px; background: #eee; margin: 8px 0; }
.summary-actions .btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: 10px; background: #C41E3A; color: #fff; border: 0; cursor: pointer; }

.faq-section { padding: 60px 0; }
.faq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 991px) { .faq-grid { grid-template-columns: 1fr; } }
.faq-item { background: #fff; border: 1px solid #eee; border-radius: 12px; padding: 16px; }
.faq-question { display: flex; align-items: center; gap: 8px; margin: 0 0 6px; }
.faq-answer { margin: 0; color: #555; }

.payment-section { padding: 60px 0; }
.payment-methods-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 991px) { .payment-methods-grid { grid-template-columns: 1fr; } }
.payment-method { border: 1px solid #eee; border-radius: 12px; padding: 16px; background: #fff; cursor: pointer; transition: box-shadow .2s, transform .2s, border-color .2s; }
.payment-method.selected { border-color: #C41E3A; box-shadow: 0 8px 28px rgba(196,30,58,.18); transform: translateY(-2px); }
.payment-icon { font-size: 28px; color: #C41E3A; margin-bottom: 10px; }
.feature-tag { display: inline-block; padding: 4px 8px; border-radius: 999px; background: #f5f5f5; font-size: 12px; margin-right: 6px; }

.cta-section { padding: 60px 0; background: linear-gradient(135deg, #101223, #1a1d36); color: #fff; }
.cta-content { text-align: center; }
.cta-buttons { display: inline-flex; gap: 12px; margin-top: 12px; }
.cta-btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: 999px; text-decoration: none; }
.cta-btn.primary { background: #C41E3A; color: #fff; }
.cta-btn.secondary { background: #fff; color: #1a1d36; }

/* feedback + animations */
.selection-feedback, .custom-message { position: fixed; left: 50%; transform: translateX(-50%); bottom: 24px; background: #1a1d36; color: #fff; padding: 10px 14px; border-radius: 10px; opacity: 0; transition: opacity .3s, transform .3s; z-index: 9999; }
.selection-feedback.show, .custom-message.show { opacity: 1; transform: translate(-50%, -4px); }

@keyframes selectPulse { 0% { transform: scale(1);} 50% { transform: scale(1.02);} 100% { transform: scale(1);} }
@keyframes priceChange { 0% { opacity: .6; } 100% { opacity: 1; } }


