body { background: #f5f7fa; }
.vip-main { width: 100%; max-width: 1100px; margin: 0 auto; padding: 40px 0 60px 0; }
.vip-cards { display: flex; gap: 32px; justify-content: center; margin-bottom: 36px; }
.vip-card { background: #fff; border-radius: 18px; box-shadow: 0 4px 32px rgba(21,101,192,0.10); padding: 32px 28px 28px 28px; width: 300px; position: relative; display: flex; flex-direction: column; align-items: center; border: 2px solid transparent; transition: box-shadow 0.18s, border 0.18s; }
.vip-card.hot { border: 2px solid #6563e9; }
.vip-card.recommend { border: 2px solid #ff9800; }
.vip-card.honor { border: 2px solid #7c4dff; }
.vip-badge { position: absolute; top: -18px; right: 24px; background: linear-gradient(90deg,#ff9800,#ffb300); color: #fff; font-size: 15px; font-weight: bold; border-radius: 16px; padding: 3px 18px; box-shadow: 0 2px 8px rgba(255,152,0,0.10); z-index: 2; }
.vip-card.recommend .vip-badge { background: linear-gradient(90deg,#ff9800,#ffb300); }
.vip-card.honor .vip-badge { background: linear-gradient(90deg,#7c4dff,#b388ff); }
.vip-icon { font-size: 38px; color: #6563e9; margin-bottom: 10px; }
.vip-icon.crown { color: #ff9800; }
.vip-icon.diamond { color: #7c4dff; }
.vip-title { font-size: 22px; font-weight: bold; color: #222; margin-bottom: 8px; }
.vip-price { font-size: 32px; font-weight: bold; color: #ff9800; margin-bottom: 18px; }
.vip-price span { font-size: 20px; font-weight: normal; }
.vip-price small { font-size: 15px; color: #888; font-weight: normal; margin-left: 2px; }
.vip-features { list-style: none; padding: 0; margin: 0 0 18px 0; width: 100%; }
.vip-features li { font-size: 16px; color: #333; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.vip-features i { color: #43e97b; font-size: 18px; }
.vip-open-btn { width: 100%; background: linear-gradient(90deg,#6563e9,#43e97b); color: #fff; border: none; border-radius: 24px; padding: 13px 0; font-size: 18px; font-weight: bold; cursor: pointer; box-shadow: 0 2px 8px rgba(101,99,233,0.10); margin-top: 8px; transition: background 0.2s, color 0.2s; }
.vip-open-btn:hover { background: linear-gradient(90deg,#4b48c7,#43e97b); }
.vip-table-section { margin: 38px 0 0 0; }
.vip-table-title { font-size: 20px; font-weight: bold; color: #6563e9; margin-bottom: 12px; text-align: left; }
.vip-table { width: 100%; border-radius: 14px; background: #f7f8fc; box-shadow: 0 2px 12px rgba(21,101,192,0.07); border-collapse: separate; border-spacing: 0; overflow: hidden; }
.vip-table th, .vip-table td { padding: 16px 0; text-align: center; font-size: 16px; color: #333; border-bottom: 1px solid #e3eaf2; }
.vip-table th { background: #edefff; color: #6563e9; font-weight: bold; }
.vip-table tr:last-child td { border-bottom: none; }
.vip-table i.fa-check { color: #43e97b; font-size: 18px; }
.vip-table i.fa-times { color: #d32f2f; font-size: 18px; }
.vip-faq-section { margin: 48px 0 0 0; }
.vip-faq-title { font-size: 20px; font-weight: bold; color: #6563e9; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.vip-faq-list { display: flex; flex-direction: column; gap: 18px; }
.vip-faq-item { background: #fff; border-radius: 12px; box-shadow: 0 2px 12px rgba(21,101,192,0.07); padding: 18px 22px; }
.vip-faq-q { font-size: 16px; color: #222; font-weight: bold; margin-bottom: 6px; }
.vip-faq-a { font-size: 15px; color: #555; }
/* 弹窗样式 */
.modal { display: none; position: fixed; z-index: 9999; left: 0; top: 0; right: 0; bottom: 0; justify-content: center; align-items: center; }
.modal.active { display: flex; }
.modal-mask { position: absolute; left: 0; top: 0; right: 0; bottom: 0; background: rgba(33, 33, 33, 0.45); z-index: 1; }
.modal-dialog { position: relative; z-index: 2; background: #fff; border-radius: 16px; box-shadow: 0 8px 32px rgba(21,101,192,0.18); padding: 38px 32px 28px 32px; min-width: 320px; max-width: 90vw; text-align: center; animation: modalIn 0.22s cubic-bezier(.4,2,.6,1) both; }
@keyframes modalIn { 0% { transform: scale(0.85); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
.modal-title { font-size: 20px; color: #d32f2f; font-weight: bold; margin-bottom: 22px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.modal-title i { color: #ff9800; font-size: 22px; }
.modal-actions { display: flex; justify-content: center; gap: 18px; margin-bottom: 18px; }
.modal-btn { display: inline-flex; align-items: center; gap: 6px; border-radius: 22px; padding: 8px 22px; font-size: 15px; font-weight: bold; text-decoration: none; transition: background 0.18s, color 0.18s; box-shadow: 0 2px 8px rgba(21,101,192,0.07); }
.modal-btn.login { background: #1976d2; color: #fff; }
.modal-btn.login:hover { background: #1251a3; }
.modal-btn.register { background: #e0e0e0; color: #1976d2; }
.modal-btn.register:hover { background: #bdbdbd; }
.modal-btn.recharge { background: linear-gradient(90deg,#6563e9,#43e97b); color: #fff; }
.modal-btn.recharge:hover { background: linear-gradient(90deg,#4b48c7,#43e97b); }
.modal-close { position: absolute; top: 12px; right: 16px; background: none; border: none; font-size: 20px; color: #bbb; cursor: pointer; transition: color 0.18s; }
.modal-close:hover { color: #d32f2f; }
@media (max-width: 1100px) { .vip-main { max-width: 99vw; } .vip-cards { flex-direction: column; align-items: center; gap: 18px; } .vip-card { width: 98vw; max-width: 400px; } }
@media (max-width: 600px) { .vip-main { padding: 18px 0 30px 0; } .vip-card { padding: 18px 8px 18px 8px; } .vip-table th, .vip-table td { padding: 8px 0; font-size: 14px; } .vip-faq-item { padding: 10px 8px; } } 