/* 韩信28 仿站 - H5 响应式 */
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'PingFang SC',sans-serif;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);color:#333;line-height:1.6;min-height:100vh;overflow-x:hidden}
.container{max-width:500px;margin:0 auto;min-height:100vh;background:#fff;box-shadow:0 0 30px rgba(0,0,0,.1);width:100%}
.top-section{background:linear-gradient(135deg,#20b2aa,#008b8b,#006666);color:#fff;padding:25px 20px;position:relative;overflow:hidden}
.top-section::before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;position:relative;z-index:1}
.header-left{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:bold}
.header-left::before{content:"🎯";font-size:24px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.header-right{display:flex;gap:8px;flex-shrink:0}
.member-btn,.auth-btn{white-space:nowrap}
.member-btn{background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.1));color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 16px;border-radius:20px;font-size:13px;cursor:pointer;transition:all .3s;backdrop-filter:blur(10px);position:relative;overflow:hidden}
.member-btn:hover{background:rgba(255,255,255,.3);transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,.2)}
.auth-btn{background:linear-gradient(135deg,#ffa500,#ff8c00);color:#fff;border:none;padding:10px 16px;border-radius:20px;font-size:13px;cursor:pointer;transition:all .3s;font-weight:600;box-shadow:0 3px 10px rgba(255,165,0,.3)}
.auth-btn:hover{background:linear-gradient(135deg,#ff8c00,#ff7700);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,165,0,.4)}
.current-period{background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.05));padding:25px;border-radius:15px;margin-bottom:25px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);position:relative;z-index:1}
.period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:nowrap;gap:8px}
.period-info{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.analysis-status{background:linear-gradient(135deg,#28a745,#20a040);padding:6px 15px;border-radius:15px;font-size:12px;font-weight:500;animation:statusBlink 2s infinite;box-shadow:0 2px 8px rgba(40,167,69,.3);white-space:nowrap;flex-shrink:0}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:.8}}
.numbers-display{display:flex;align-items:center;justify-content:center;gap:15px;font-size:22px;font-weight:bold}
.number-circle{width:45px;height:45px;background:linear-gradient(135deg,#fff,#f8f9fa);color:#333;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:all .3s;position:relative}
.number-circle:hover{color:#fff;transform:scale(1.1)}
.number-circle.result{background:linear-gradient(135deg,#ffa500,#ff8c00);color:#fff;transform:scale(1.2);box-shadow:0 6px 20px rgba(255,165,0,.4);animation:resultPulse 2s infinite}
@keyframes resultPulse{0%,100%{transform:scale(1.2)}50%{transform:scale(1.3)}}
.plus-sign{color:rgba(255,255,255,.8);font-size:18px;font-weight:normal}
.service-section{background:#fff;padding:25px 20px;border-bottom:1px solid #f0f0f0}
.service-cards{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.service-card .desc{white-space:normal;word-break:keep-all}
.service-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e9ecef;border-radius:15px;padding:20px;text-align:center;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.service-card:hover{border-color:#20b2aa;transform:translateY(-5px);box-shadow:0 8px 25px rgba(32,178,170,.2)}
.service-card.recharge{border-color:#28a745}
.service-card.recharge:hover{border-color:#28a745;box-shadow:0 8px 25px rgba(40,167,69,.2)}
.service-card.recharge .icon{color:#28a745}
.service-card.contact .icon{color:#20b2aa}
.service-card .icon{font-size:32px;display:block;margin-bottom:10px}
.service-card .title{font-weight:bold;margin-bottom:5px}
.insight-card{background:linear-gradient(135deg,#20b2aa,#17a2a2,#008b8b);color:#fff;margin:25px 20px;padding:20px 25px;border-radius:15px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 8px 25px rgba(32,178,170,.3);position:relative;overflow:hidden;flex-wrap:nowrap;gap:12px}
.insight-card::before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 50%);animation:rotate 8s linear infinite}
@keyframes rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.insight-left{display:flex;align-items:center;gap:12px;font-size:16px;font-weight:600;position:relative;z-index:1;min-width:0;flex-shrink:0}
.insight-right{display:flex;align-items:center;gap:20px;position:relative;z-index:1;flex-shrink:0}
.insight-left::before{content:"💡";font-size:24px;animation:bounce 2s infinite}
@keyframes bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}
.accuracy-container{text-align:center}
.accuracy-text{font-size:14px;margin-bottom:8px;opacity:.9}
.accuracy-number{font-size:28px;font-weight:bold}
.progress-bar{width:80px;height:6px;background:rgba(255,255,255,.3);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,#ffa500,#ffb84d);border-radius:3px}
.tabs-section{background:#fff;margin:0 20px;border-radius:15px;overflow:hidden;box-shadow:0 4px 15px rgba(0,0,0,.1)}
.tabs-container{background:linear-gradient(135deg,#f8f9fa,#fff);border-bottom:1px solid #e9ecef}
.tabs{display:flex;flex-wrap:nowrap}
.tab{flex:1;min-width:0;padding:18px 8px;text-align:center;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s;font-weight:500;position:relative;background:transparent;white-space:nowrap;font-size:14px}
.tab::before{content:"";position:absolute;bottom:0;left:50%;width:0;height:3px;background:linear-gradient(90deg,#20b2aa,#17a2a2);transition:all .3s;transform:translateX(-50%)}
.tab.active{color:#20b2aa;background:linear-gradient(135deg,rgba(32,178,170,.05),rgba(32,178,170,.02))}
.tab.active::before{width:80%}
.tab:hover{color:#20b2aa;background:rgba(32,178,170,.05)}
.data-table{background:#fff}
.table-header{display:grid;grid-template-columns:90px 1fr 130px 90px;background:linear-gradient(135deg,#20b2aa,#17a2a2);color:#fff;padding:18px 0;font-weight:600;text-align:center}
.table-row{display:grid;grid-template-columns:90px 1fr 130px 90px;padding:18px 0;border-bottom:1px solid #f0f0f0;text-align:center;align-items:center;transition:all .3s;position:relative}
.table-row:hover{background:linear-gradient(90deg,rgba(32,178,170,.02),transparent);transform:translateX(5px)}
.period-number{color:#666;font-weight:600;white-space:nowrap}
.lottery-numbers{font-weight:bold;color:#333;white-space:nowrap}
.predictions{display:flex;justify-content:center;gap:8px;flex-wrap:nowrap}
.prediction-badge{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:bold;transition:all .3s;flex-shrink:0}
.prediction-badge:hover{transform:scale(1.1)}
.prediction-small{background:linear-gradient(135deg,#20b2aa,#17a2a2);box-shadow:0 2px 8px rgba(32,178,170,.3)}
.prediction-blue{background:linear-gradient(135deg,#007bff,#0056b3);box-shadow:0 2px 8px rgba(0,123,255,.3)}
.prediction-red{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 2px 8px rgba(220,53,69,.3)}
.prediction-orange{background:linear-gradient(135deg,#ffa500,#ff8c00);box-shadow:0 2px 8px rgba(255,165,0,.3)}
.result-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:16px;transition:all .3s}
.result-badge:hover{transform:scale(1.15)}
.result-correct{background:linear-gradient(135deg,#28a745,#20a040);color:#fff;box-shadow:0 4px 12px rgba(40,167,69,.3);animation:correctPulse 2s infinite}
@keyframes correctPulse{0%,100%{box-shadow:0 4px 12px rgba(40,167,69,.3)}50%{box-shadow:0 6px 20px rgba(40,167,69,.5)}}
.result-wrong{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 4px 12px rgba(220,53,69,.3)}
.result-more{background:linear-gradient(135deg,#ffa500,#ff8c00);color:#fff;box-shadow:0 4px 12px rgba(255,165,0,.3);animation:waiting 2s infinite}
@keyframes waiting{0%,100%{opacity:1}50%{opacity:.6}}
.bottom-stats{background:linear-gradient(135deg,#fff,#f8f9fa);margin:25px 20px 20px;padding:25px;border-radius:15px;text-align:center;box-shadow:0 4px 15px rgba(0,0,0,.1);border:1px solid #e9ecef}
.auth-page,.recharge-page{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;align-items:center;justify-content:center}
.auth-page.show,.recharge-page.show{display:flex}
.auth-modal,.recharge-modal{background:#fff;max-width:420px;width:90%;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.auth-header{background:linear-gradient(135deg,#20b2aa,#008b8b);color:#fff;padding:25px;text-align:center;position:relative}
.recharge-header{background:linear-gradient(135deg,#28a745,#20a040);color:#fff;padding:25px;text-align:center;position:relative}
.auth-close,.recharge-close{position:absolute;top:15px;right:15px;background:rgba(255,255,255,.2);border:none;color:#fff;width:35px;height:35px;border-radius:50%;cursor:pointer;font-size:24px}
.auth-content,.recharge-content{padding:35px 30px}
.auth-input{width:100%;padding:15px 18px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px}
.auth-submit{width:100%;background:linear-gradient(135deg,#20b2aa,#17a2a2);color:#fff;border:none;padding:18px;border-radius:12px;font-size:16px;font-weight:bold;cursor:pointer}
.price-options{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:25px}
.price-option{border:2px solid #e9ecef;border-radius:12px;padding:20px;text-align:center;cursor:pointer}
.price-option.selected{border-color:#28a745}
.price-option .amount{font-size:24px;font-weight:bold;color:#28a745}
.contact-btn{display:block;width:100%;background:linear-gradient(135deg,#28a745,#20a040);color:#fff;text-align:center;padding:18px;border-radius:12px;text-decoration:none;font-weight:bold}
.loading{display:inline-block;width:20px;height:20px;border:2px solid #f3f3f3;border-top-color:#20b2aa;border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.success-checkmark,.error-cross{display:inline-block;width:20px;height:20px;border-radius:50%}
.success-checkmark{background:#28a745}
.error-cross{background:#dc3545}
.auth-status.success{background:#d4edda;color:#155724;padding:15px;border-radius:12px;margin-bottom:15px}
.auth-status.error{background:#f8d7da;color:#721c24;padding:15px;border-radius:12px;margin-bottom:15px}
.payment-info{margin-bottom:20px}
.payment-steps{list-style:none;padding:0;counter-reset:s}
.payment-steps li{padding:8px 0;padding-left:28px;position:relative;counter-increment:s}
.payment-steps li::before{content:counter(s);position:absolute;left:0;background:#28a745;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}
.auth-info{border:1px solid #e9ecef;padding:20px;border-radius:12px;margin-top:15px}
.auth-info-title{font-weight:bold;color:#20b2aa;margin-bottom:10px}
.auth-info-list{list-style:none;padding:0}
.auth-info-list li{padding:6px 0;font-size:14px;color:#666}
.auth-form-group{margin-bottom:20px}
.auth-label{display:block;font-weight:600;margin-bottom:8px;color:#333}
.drag-indicator{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:40px;height:4px;background:rgba(255,255,255,.3);border-radius:2px}
.scroll-indicator{text-align:center;padding:10px;font-size:12px;color:#666}

/* 原站响应式 - 与 dz.hanxin28.com 完全一致 */
@media (max-width: 480px) {
    .container {
        max-width: 100%;
    }

    .top-section {
        padding: 20px 15px;
    }

    .header-left {
        font-size: 18px;
    }

    .header-right {
        gap: 8px;
    }

    .member-btn,
    .auth-btn {
        padding: 8px 12px;
        font-size: 12px;
    }

    .current-period {
        padding: 20px;
        margin-bottom: 20px;
    }

    .numbers-display {
        gap: 12px;
        font-size: 20px;
    }

    .number-circle {
        width: 40px;
        height: 40px;
    }

    .service-section {
        padding: 20px 15px;
    }

    .service-cards {
        gap: 12px;
    }

    .service-card {
        padding: 18px 15px;
    }

    .service-card .icon {
        font-size: 28px;
    }

    .service-card .title {
        font-size: 15px;
    }

    .insight-card {
        margin: 20px 15px;
        padding: 18px 20px;
    }

    .accuracy-number {
        font-size: 24px;
    }

    .tabs-section {
        margin: 0 15px;
    }

    .tab {
        padding: 15px 8px;
        font-size: 13px;
    }

    .table-header,
    .table-row {
        grid-template-columns: 70px 1fr 110px 70px;
        padding: 15px 0;
    }

    .prediction-badge {
        width: 28px;
        height: 28px;
        font-size: 12px;
    }

    .result-badge {
        width: 32px;
        height: 32px;
        font-size: 14px;
    }

    .bottom-stats {
        margin: 20px 15px;
        padding: 20px;
        gap: 15px;
    }

    .stat-number {
        font-size: 24px;
    }

    .auth-modal,
    .recharge-modal {
        width: 95%;
    }

    .auth-content,
    .recharge-content {
        padding: 25px 20px;
    }

    .recharge-page {
        padding: 5px;
        align-items: flex-start;
    }

    .recharge-modal {
        max-width: 100%;
        max-height: calc(100vh - 10px);
        margin: 0;
        border-radius: 15px;
    }

    .recharge-header {
        padding: 20px 15px;
    }

    .recharge-title {
        font-size: 20px;
    }

    .recharge-subtitle {
        font-size: 14px;
    }

    .price-options {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .price-option {
        padding: 15px;
    }

    .price-option .amount {
        font-size: 20px;
    }

    .price-option .label {
        font-size: 11px;
    }

    .payment-info {
        padding: 15px;
    }

    .payment-steps li {
        font-size: 13px;
        padding: 6px 0;
        padding-left: 25px;
    }

    .payment-steps li::before {
        width: 18px;
        height: 18px;
        font-size: 11px;
    }

    .contact-btn {
        padding: 15px;
        font-size: 15px;
    }
}

@media (max-width: 360px) {
    .recharge-modal {
        border-radius: 10px;
    }

    .recharge-header {
        padding: 15px 10px;
    }

    .recharge-content {
        padding: 20px 15px;
    }

    .price-option {
        padding: 12px;
    }

    .payment-info {
        padding: 12px;
    }
}

@media (max-height: 600px) and (orientation: landscape) {
    .recharge-page {
        align-items: flex-start;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .recharge-modal {
        max-height: calc(100vh - 20px);
        margin: 0;
    }

    .recharge-header {
        padding: 15px 25px;
    }

    .recharge-content {
        padding: 20px 30px;
    }
}
