﻿body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; background-color: #fff; color: #333; line-height: 1.5; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; display: flex; flex-direction: row; padding: 15px 0; background-color: #fff; /*box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);*/ margin-bottom: 20px; border-radius: 20px; background: #fff; padding: 0; margin-top: 0px; }

.header { flex: 1; background: white; padding: 20px 0; border-radius: 20px; border-top-right-radius: 0; border-bottom-right-radius: 0; }
.footer { width: 300px; }
.user-info { font-size: 14px; }
.user-info .text-gray { color: #999; }
.actions { font-size: 14px; }
.actions .btn-link { color: #666; text-decoration: none; padding: 0 10px; }

.actions .btn-link:hover { color: #ff6700; }

.vip-tabs { display: flex; justify-content: center; margin: 20px 0 30px 0; background-color: #fffbf0; border-radius: 8px; padding: 10px; }

.vip-tab { padding: 10px 20px; margin: 0 10px; cursor: pointer; border-bottom: 3px solid transparent; transition: all 0.3s; text-align: center; }

.vip-tab:hover { color: #ff6700; }

.vip-tab.active { border-bottom: 3px solid #ff6700; color: #ff6700; font-weight: bold; }

.price-packages { margin-bottom: 40px; }

.package-card { position: relative; /* border: 1px solid #e0e0e0; */ border-radius: 8px; padding: 20px 40px; margin: 10px 0; text-align: center; cursor: pointer; min-height: 120px; display: flex; flex-direction: column; justify-content: center; box-sizing: border-box; background-color: #f5f5f5; box-shadow: 0 2px 5px rgb(255 212 183 / 10%); }

.package-card:hover { border-color: #ff6700; /* transform: translateY(-2px); */ box-shadow: 0 2px 10px rgba(255, 103, 0, 0.1); }

.package-card.active { border-color: #ff6700; /* background-color: #fff3e0; */ /* border: 2px solid #ff6700; */ color: #b55a5a; font-weight: bold; background: linear-gradient(to bottom, #fff3e0, #FED5B4); }

.package-card.active::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-left: 10px solid transparent; border-right: 10px solid transparent; border-top: 10px solid #FED5B4; }

.package-card .current-detail { display: none; }

.highlight-card { background-color: #fff3e0; border: 2px solid #ff6700; position: relative; z-index: 10; }

.highlight-badge { position: absolute; top: -10px; left: 50%; transform: translateX(-50%); background-color: #ff6700; color: white; padding: 5px 15px; border-radius: 10px 10px 10px 2px; font-size: 12px; font-weight: bold; white-space: nowrap; width: 60px; left: 30px; }

.original-price { color: #999; text-decoration: line-through; font-size: 12px; margin: 5px 0; }

.current-price { color: #ff6700; font-size: 24px; font-weight: bold; }

.font-size-30 { font-size: 30px !important; }

.small { font-size: 12px; color: #666; }

.benefits-section { margin-bottom: 40px; padding: 20px; background-color: #fafafa; border-radius: 8px; }

.benefit-item { display: flex; flex-direction: column; align-items: center; margin: 10px 0; text-align: center; }

.benefit-icon { font-size: 24px; margin-bottom: 8px; }

.benefit-item div:nth-child(2) { font-weight: bold; margin-bottom: 4px; }

.text-xs { font-size: 12px; }

.text-sm { font-size: 14px; }

.text-gray { color: #999; }

.text-green { color: #00c853; }

.text-blue { color: #1976d2; }

.privileges-section { margin-bottom: 40px; }

.privilege-table { width: 100%; border-collapse: collapse; margin: 15px 0 5px 0; background-color: #f5f5f5; }

.privilege-table th,.privilege-table td { border: 1px solid #e0e0e0; padding: 2px; text-align: center; font-size: 15px; }

.privilege-table th { background-color: #f5f5f5; }

.vip-highlight { background-color: #fff3e0; /* font-weight: bold; */ font-style: italic; }

.payment-section { border-radius: 8px; padding: 20px; margin-top: 30px; position: sticky; top: 20px; }

.qr-code { width: 150px; height: 150px; margin: 10px auto; border: 1px solid #e0e0e0; display: flex; justify-content: center; align-items: center; background-color: #fff; }

.price-history { margin-top: 20px; }

.price-chart { height: 80px; display: flex; align-items: flex-end; justify-content: center; margin: 10px 0; }

.price-line { position: relative; width: 100%; height: 60px; }

.price-point { position: absolute; width: 10px; height: 10px; background-color: #ff6700; border-radius: 50%; bottom: 0; }

h4 { font-size: 18px; font-weight: bold; color: #333; }

h5 { font-size: 16px; font-weight: bold; color: #333; margin-top: 20px; }

a { color: #1976d2; text-decoration: none; }

a:hover { text-decoration: underline; }

.mt-1 { margin-top: 0.25rem; }

.mt-2 { margin-top: 0.5rem; }

.mt-3 { margin-top: 1rem; }

.mt-4 { margin-top: 1.5rem; }

.mb-1 { margin-bottom: 0.25rem; }

.mb-2 { margin-bottom: 0.5rem; }

.mb-3 { margin-bottom: 1rem; }

.mb-4 { margin-bottom: 1.5rem; }

.mb-6 { margin-bottom: 3rem; }

.ml-2 { margin-left: 0.5rem; }

.ml-3 { margin-left: 1rem; }

/* 响应式设计 */
@media (max-width: 768px) {
    .vip-tabs { flex-wrap: wrap; }

    .vip-tab { margin: 5px; }

    .package-card { min-height: auto; }

    .payment-section { position: static; }
}

.price-packages .row { display: flex; flex-direction: row; gap: 15px; }

.arrow-right { border-left: 2px solid transparent; border-bottom: 2px solid transparent; border-right: 2px solid #c8c8cd; border-top: 2px solid #c8c8cd; height: 12px; width: 12px; margin: 0rpx auto 0; transform: rotate(45deg); -webkit-transform: rotate(45deg); transition: transform 0.3s; }

.question { display: flex; flex-direction: row; justify-content: space-between; background-color: #fafafa; padding: 10px 20px; align-items: center; border-radius: 10px; /* font-style: italic; */ text-decoration: none; }

.no-underline { text-decoration: none !important; }

.box { margin: 0 60px; }

.price-list { display: flex; gap: 15px; }

.line { margin-top: 15px; margin-bottom: 15px; }

.info-container { position: relative; }

.expand-detail { position: absolute; top: 50%; right: 60px; transform: translateY(-50%); background: white; padding: 15px; border-radius: 8px; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1); width: 200px; opacity: 0; visibility: hidden; transition: all 0.3s ease; z-index: 5; border-right: 4px solid #9b59b6; }

.expand:hover + .expand-detail,
.expand-detail:hover { opacity: 1; visibility: visible; right: 70px; }

.privilege-table .checked { font-size: 20px; font-weight: bold; color: #ff6700; }

.qr-container { border: 1px solid #e0e0e0; text-align: center; width: 200px; padding: 10px; }

.qr-code-section { display: flex; align-items: center; justify-content: center; flex-direction: column; }

.price-a { display: flex; align-items: baseline; gap: 10px; justify-content: center; }

/* === 支付成功弹窗样式 === */
.modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9999; display: flex; justify-content: center; align-items: center; }

.modal.hidden { display: none; }

.modal-overlay { position: absolute; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); backdrop-filter: blur(2px); }

.modal-content { position: relative; background: #fff; border-radius: 16px; padding: 32px 24px; width: 85%; max-width: 320px; text-align: center; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15); z-index: 10000; animation: modalFadeIn 0.3s ease-out; }

@keyframes modalFadeIn {
    from { opacity: 0; transform: scale(0.9); }

    to { opacity: 1; transform: scale(1); }
}

.close-btn { position: absolute; top: 16px; right: 16px; background: none; border: none; font-size: 20px; color: #999; cursor: pointer; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; }

.close-btn:hover { color: #333; }

.icon-success { margin-bottom: 16px; }

.modal-title { font-size: 18px; font-weight: 600; color: #222; margin: 0 0 8px; }

.modal-desc { font-size: 14px; color: #666; margin: 0 0 24px; line-height: 1.5; }

.btn-primary { background-color: #07c160; /* 微信绿 */ color: white; border: none; border-radius: 8px; padding: 12px 24px; font-size: 16px; font-weight: 500; cursor: pointer; width: 100%; transition: background-color 0.2s; }

.btn-primary:hover { background-color: #06a651; }

.qrcode-mask { position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: rgba(0,0,0,0.8); display: none; justify-content: center; align-items: center; }
.qrcode-mask .btn-refresh { cursor: pointer; font-size: 12px; text-align: center;border-radius: 10px; color: #fff;position: absolute;z-index: 10;background-color: #1976d2;padding: 8px; }