/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;background:#f5f5f5;color:#333;line-height:1.5;min-height:100vh}
input,button,textarea{font:inherit;color:inherit;-webkit-appearance:none;border:none;outline:none}
button{touch-action:manipulation;cursor:pointer}
a{color:inherit;text-decoration:none}

/* ===== Layout ===== */
.page{display:none;padding:16px 20px;min-height:100vh}
.page.active{display:block}

/* ===== Toast ===== */
#toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:9999;pointer-events:none;opacity:0;transition:opacity .2s}
#toast.show{opacity:1}

/* ===== Loading ===== */
#loading-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.7);color:#fff;padding:16px 32px;border-radius:12px;font-size:15px;z-index:9998;display:none}

/* ===== Login Page ===== */
.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:#fff;border-radius:16px;padding:40px 30px;width:100%;max-width:380px;box-shadow:0 4px 20px rgba(0,0,0,.08);text-align:center}
.login-icon{font-size:48px;margin-bottom:16px}
.login-title{font-size:22px;font-weight:700;color:#2c3e50;display:block;margin-bottom:8px}
.login-desc{font-size:14px;color:#999;display:block;margin-bottom:24px}
.phone-input{width:100%;height:48px;font-size:16px;border:2px solid #e0e0e0;border-radius:12px;padding:0 16px;text-align:center;margin-bottom:16px;transition:border-color .2s}
.phone-input:focus{border-color:#2c3e50}
.agreement-row{display:flex;align-items:center;justify-content:center;gap:4px;font-size:13px;margin-bottom:20px;flex-wrap:wrap}.cb-wrapper{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:2.5px solid #bdc3c7;border-radius:4px;flex-shrink:0;cursor:pointer;transition:all .15s;margin-right:2px}.cb-wrapper.checked{background:#2c3e50;border-color:#2c3e50}.cb-wrapper.checked::after{content:'✓';color:#fff;font-size:14px;font-weight:700;line-height:1}.agreement-row label{cursor:pointer}
.agreement-row a{color:#3498db}
.login-btn{width:100%;height:48px;background:#2c3e50;color:#fff;border-radius:12px;font-size:17px;font-weight:600;transition:opacity .2s}
.login-btn:disabled{opacity:.4}
.login-btn.loading{pointer-events:none}
.error-msg{color:#e74c3c;font-size:13px;margin-top:12px}
.login-footer{text-align:center;margin-top:30px;font-size:12px;color:#ccc}.login-footer a{color:#999}

/* ===== Header ===== */
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.header-title{font-size:20px;font-weight:700;color:#2c3e50}
.header-actions{display:flex;gap:10px;align-items:center}
.btn-scan{background:#fef9e7;color:#f39c12;border:1px solid #f39c12;border-radius:20px;padding:6px 14px;font-size:14px}
.btn-time{background:#eaf7e1;color:#27ae60;border-radius:20px;padding:6px 14px;font-size:14px}
.btn-add{background:#c0392b;color:#fff;border-radius:20px;padding:8px 20px;font-size:15px}

/* ===== Search ===== */
.search-bar{display:flex;align-items:center;background:#fff;border-radius:20px;padding:10px 16px;margin-bottom:16px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.search-input{flex:1;height:36px;font-size:14px;background:#f5f5f5;border-radius:16px;padding:0 16px;border:none}
.search-clear{margin-left:10px;font-size:16px;color:#999;background:none;padding:4px 8px}
.search-results{background:#fff;border-radius:12px;margin-bottom:16px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.search-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f0f0f0}
.search-item:last-child{border-bottom:none}
.si-main{cursor:pointer;flex:1}
.si-name{font-size:16px;font-weight:700;color:#2c3e50}
.si-code{font-size:13px;color:#999;margin-top:2px}
.si-sub-btn{background:#c0392b;color:#fff;border-radius:16px;padding:6px 16px;font-size:13px}
.search-hint{text-align:center;padding:30px 0;font-size:14px;color:#999}

/* ===== Time Config ===== */
.time-config{background:#eafaf1;border:1px solid #a9dfbf;border-radius:12px;padding:18px;margin-bottom:20px}
.time-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.time-config-title{font-size:15px;font-weight:700;color:#27ae60}
.time-config-close{font-size:20px;color:#999;background:none;padding:4px}
.time-config-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #d5f5e3}
.time-cb{width:32px;height:32px;display:flex;align-items:center;justify-content:center;margin-right:12px;font-size:20px;background:none;cursor:pointer}
.time-config-label{font-size:15px;color:#333;flex:1}
.time-config-value{background:#fff;padding:8px 18px;border-radius:8px;font-size:15px}
.time-config-value.disabled{color:#ccc;background:#f5f5f5}
.time-config-apply{width:100%;background:#27ae60;color:#fff;border-radius:20px;padding:14px 0;font-size:16px;text-align:center;margin-top:12px}
.time-result{margin-top:8px;text-align:center;font-size:13px;color:#27ae60;padding:8px;border-radius:6px;background:#d5f5e3}
.time-result.error{color:#c0392b;background:#fdedec}

/* ===== Stock Cards ===== */
.stock-card{background:#fff;border-radius:12px;padding:22px 20px;margin-bottom:14px;box-shadow:0 2px 8px rgba(0,0,0,.06);cursor:pointer;transition:transform .1s}
.stock-card:active{transform:scale(.98)}
.card-header{display:flex;align-items:center;margin-bottom:10px}
.stock-name{font-size:18px;font-weight:700;color:#2c3e50;margin-right:10px}
.stock-code{font-size:13px;color:#999;margin-right:auto}
.tag{padding:3px 12px;border-radius:12px;font-size:12px;font-weight:600}
.tag-buy{background:#e8f5e9;color:#2e7d32}
.tag-sell{background:#ffebee;color:#c62828}
.tag-watch{background:#fef9e7;color:#ef6c00}
.tag-wait{background:#eceff1;color:#546e7a}
.tag-heavy-buy{background:#1b5e20;color:#fff;font-weight:700}
.tag-heavy-sell{background:#b71c1c;color:#fff;font-weight:700}
.tag-dir-bull { background: #fff3e0; color: #e65100; border: 1px solid #ffe0b2; margin-left: 4px; }
.tag-dir-bear { background: #e3f2fd; color: #1565c0; border: 1px solid #bbdefb; margin-left: 4px; }
.tag-dir-neutral { background: #f5f5f5; color: #757575; border: 1px solid #e0e0e0; margin-left: 4px; }
.card-body-simple{display:flex;align-items:baseline;gap:12px;padding:6px 0 10px}
.price-simple{font-size:22px;font-weight:800;color:#1976d2}
.change-simple{font-size:14px;font-weight:600}
.change-simple.up{color:#e53935}.change-simple.down{color:#43a047}
.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid #f0f0f0}
.tap-hint{font-size:13px;color:#3498db}
.push-badge{font-size:12px;background:#eef;color:#3498db;padding:2px 8px;border-radius:6px;margin-left:4px}
.empty-state{text-align:center;padding:80px 0;color:#999}
.empty-icon{font-size:60px;display:block;margin-bottom:16px}
.empty-text{font-size:18px;display:block}.empty-hint{font-size:14px;margin-top:8px;display:block}

/* ===== Report Page ===== */
.report-page{background:#f5f5f5}
.back-btn{display:inline-flex;align-items:center;gap:4px;font-size:14px;color:#3498db;background:none;margin-bottom:16px;padding:4px 0}
.price-bar{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.big-price{font-size:34px;font-weight:800;color:#2c3e50}
.change{font-size:18px}.change.up{color:#c0392b}.change.down{color:#27ae60}

/* Signal card */
.signal-card{background:#fef9e7;border-left:5px solid #c0392b;padding:18px;border-radius:10px;margin-bottom:16px}
.signal-title{font-size:16px;font-weight:700;display:block;margin-bottom:6px;color:#c0392b}
.signal-text{font-size:20px;font-weight:700;color:#c0392b;display:block;margin-bottom:6px}
.signal-meta{font-size:13px;color:#666;line-height:1.6}

/* Section */
.section{background:#fff;border-radius:12px;padding:18px;margin-bottom:14px}
.section-title{font-size:17px;font-weight:700;color:#2c3e50;display:block;margin-bottom:14px;border-left:3px solid #3498db;padding-left:12px}
.ind-grid{display:flex;flex-direction:column;gap:8px}
.ind-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f5f5f5}
.ind-l{font-size:14px;color:#666;flex-shrink:0}.ind-v{font-size:14px;color:#333;font-weight:700;text-align:right}

/* Volume items */
.vol-item{margin-bottom:10px;padding:10px;background:#f9f9f9;border-radius:8px}
.vol-label{font-size:13px;color:#999;display:block;margin-bottom:4px}
.vol-val{font-size:13px;color:#333;line-height:1.6}
.vol-val.dim{color:#bbb;font-style:italic}

/* Cards */
.card{padding:18px;border-radius:12px;margin-bottom:14px}
.card-title{font-size:17px;font-weight:700;display:block;margin-bottom:12px}
.card-row{display:flex;flex-direction:column;margin-bottom:6px}
.card-label{font-size:13px;color:#999}.card-val{font-size:14px;color:#333;line-height:1.5}

.card-support{background:#e8f8f5;border-left:5px solid #1abc9c}
.card-resist{background:#f5eef8;border-left:5px solid #8e44ad}
.card-trade{background:#eaf7e1;border-left:5px solid #27ae60}.card-trade .card-title{color:#27ae60}
.card-warn{background:#fdedec;border-left:5px solid #e74c3c}.card-warn .card-title{color:#c0392b}
.card-scores{background:#fef9e7;border-left:5px solid #f39c12}.card-scores .card-title{color:#f39c12}
.card-battle{background:#f5f5ff;border-left:5px solid #3498db}.card-battle .card-title{color:#3498db}

.green{color:#27ae60;font-weight:700}.red{color:#c0392b;font-weight:700}
.warn-text{font-size:14px;color:#c0392b;display:block;margin-bottom:6px;line-height:1.5}
.risk-box{background:#fdedec;padding:18px;border-radius:12px;color:#999;font-size:13px;line-height:1.6;margin-top:16px}

/* Kline card */
.kline-card{background:#eaf7e1;border-left:5px solid #27ae60;padding:18px;border-radius:12px;margin-bottom:14px}
.kline-text{font-size:13px;color:#27ae60;line-height:1.6;display:block}

/* Score grid */
.score-grid{display:flex;flex-wrap:wrap;gap:8px}
.score-item{width:calc(33.33% - 6px);background:#fff;padding:10px;border-radius:8px;text-align:center}
.score-l{font-size:12px;color:#999;display:block}.score-v{font-size:16px;font-weight:700;display:block;margin-top:4px}
.score-v.up{color:#c0392b}.score-v.down{color:#27ae60}

/* Detail list */
.detail-list{margin-top:10px;border-top:1px solid rgba(142,68,173,.2);padding-top:10px}
.detail-title{font-size:13px;font-weight:700;color:#8e44ad;display:block;margin-bottom:6px}
.detail-item{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:13px}
.detail-tag{font-size:12px}.resist-tag{color:#e74c3c}.support-tag{color:#27ae60}
.detail-type{color:#666;min-width:48px}.detail-price{font-weight:700;color:#333}.detail-date{color:#999}

/* Battle */
.battle-item{margin-bottom:6px;padding:6px;background:#fff;border-radius:6px}
.battle-text{font-size:13px;color:#333;line-height:1.5}

/* ===== Scanner Page ===== */
.scanner-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-radius:12px;margin-bottom:12px}
.scanner-title{font-size:18px;font-weight:700;color:#2c3e50}
.scanner-meta{font-size:12px;color:#999;text-align:right}
.scan-card{border-radius:12px;padding:18px;margin-bottom:12px;border-left:5px solid #3498db;cursor:pointer;transition:transform .1s}
.scan-card:active{transform:scale(.98)}
.scan-card.type-etf{border-left-color:#e67e22}
.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.type-badge{font-size:11px;padding:2px 8px;border-radius:6px;color:#fff}
.type-badge.stock{background:#3498db}.type-badge.etf{background:#e67e22}

.score-badge{font-size:22px;font-weight:700}.score-high{color:#c0392b}.score-mid{color:#f39c12}.score-low{color:#3498db}
.detect-badge{font-size:12px;color:#e67e22;margin-left:8px}.spike-badge{font-size:12px;color:#e74c3c;margin-left:8px}
.card-body{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.metric{flex:0 0 calc(33.33% - 6px);background:#f8f9fa;padding:10px;border-radius:8px;text-align:center}
.metric-label{font-size:11px;color:#999;display:block;margin-bottom:3px}
.metric-val{font-size:14px;font-weight:700;color:#333;display:block}
.metric-val.up{color:#c0392b}.metric-val.down{color:#27ae60}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}
.price-val{font-size:15px;color:#333}.date-val{font-size:12px;color:#999}
.scan-footer{text-align:center;padding:12px;font-size:12px;color:#ccc;line-height:1.5}
.scan-card{background:#fff}

/* ===== Subscribe Page ===== */
.subscribe-search{display:flex;gap:10px;margin-bottom:16px;align-items:center}
.sub-search-input{flex:1;height:44px;font-size:15px;background:#fff;border-radius:12px;padding:0 16px;box-shadow:0 2px 6px rgba(0,0,0,.06)}
.sub-search-btn{height:44px;padding:0 20px;background:#c0392b;color:#fff;border-radius:12px;font-size:15px;white-space:nowrap}
.sub-result-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#fff;border-radius:10px;margin-bottom:8px;cursor:pointer}
.sub-result-item:active{background:#f8f8f8}
.result-name{font-size:16px;font-weight:700;color:#2c3e50}.result-code{font-size:13px;color:#999;margin:0 8px}.result-ex{font-size:12px;color:#666}
.selected-card{background:#fff;border-radius:12px;padding:20px;margin-top:12px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.selected-title{font-size:13px;color:#999;display:block;margin-bottom:6px}
.selected-name{font-size:18px;font-weight:700;color:#2c3e50;display:block;margin-bottom:16px}
.time-section{margin-bottom:16px}
.time-section-title{font-size:14px;font-weight:700;color:#333;display:block;margin-bottom:10px}
.time-row{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}
.time-check{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;background:none;cursor:pointer}
.time-label{font-size:14px;color:#333;flex:1;margin-left:8px}
.time-value{background:#f8f8f8;padding:6px 14px;border-radius:8px;font-size:14px}
.time-value.disabled{color:#ccc}
.subscribe-btn{width:100%;height:48px;background:#27ae60;color:#fff;border-radius:12px;font-size:16px;font-weight:600;margin-top:8px}
.subscribe-btn:disabled{opacity:.4}
.hint-box{text-align:center;padding:60px 20px;color:#999}
.hint-icon{font-size:40px;display:block;margin-bottom:12px}
.hint-text{font-size:14px;line-height:1.6}

/* ===== Navbar ===== */
.navbar{position:sticky;top:0;background:#fff;padding:12px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.navbar-title{font-size:17px;font-weight:700;color:#2c3e50}
.navbar-back{font-size:14px;color:#3498db;background:none;display:flex;align-items:center;gap:4px}
.navbar-right{font-size:14px;color:#999;background:none}

/* ===== Utility ===== */
.hidden{display:none!important}
.text-center{text-align:center}
.w-full{width:100%}

/* ETF */
.etf-badge{background:#e3f2fd;color:#1976d2;font-size:10px;padding:1px 5px;border-radius:3px;margin-left:4px;font-weight:500}
.card-code{display:flex;align-items:center;gap:4px}