/* 报价计算器专属样式 */
.calc-hero{background:linear-gradient(135deg,#1a1a1a 0%,#2c2c2c 100%);color:#fff;padding:80px 0 60px;text-align:center;position:relative;overflow:hidden}
.calc-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('https://img.airmie.cn/img/aboutus.jpg') center/cover;opacity:0.15;z-index:0}
.calc-hero .wrapper{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 20px}
.calc-hero h1{font-size:42px;font-weight:bold;margin-bottom:20px;letter-spacing:2px}
.calc-hero .subtitle{font-size:18px;color:#ccc;margin-bottom:30px;line-height:1.6}
.calc-hero .badges{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px}
.calc-hero .badge{background:rgba(255,255,255,0.1);padding:10px 20px;border-radius:30px;font-size:14px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2)}

.calc-main{background:#f5f5f5;padding:60px 0;min-height:600px}
.calc-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 380px;gap:30px;padding:0 20px}

.calc-form{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 20px rgba(0,0,0,0.08)}
.calc-step{display:none;animation:fadeIn 0.4s ease}
.calc-step.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.step-header{display:flex;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ff6b35;color:#fff;border-radius:50%;font-weight:bold;font-size:18px;margin-right:15px;flex-shrink:0}
.step-title{font-size:22px;font-weight:bold;color:#1a1a1a}
.step-subtitle{color:#888;font-size:14px;margin-top:4px}

.option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-bottom:25px}
.option-card{border:2px solid #e8e8e8;border-radius:10px;padding:24px 16px;text-align:center;cursor:pointer;transition:all 0.3s;background:#fff;position:relative}
.option-card:hover{border-color:#ff6b35;transform:translateY(-3px);box-shadow:0 8px 20px rgba(255,107,53,0.15)}
.option-card.selected{border-color:#ff6b35;background:#fff5f0;box-shadow:0 4px 12px rgba(255,107,53,0.2)}
.option-card.selected::after{content:'✓';position:absolute;top:8px;right:10px;width:24px;height:24px;background:#ff6b35;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:bold}
.option-icon{font-size:36px;margin-bottom:10px}
.option-name{font-size:16px;font-weight:bold;color:#1a1a1a;margin-bottom:6px}
.option-desc{font-size:12px;color:#888;line-height:1.5}
.option-price{font-size:14px;color:#ff6b35;font-weight:bold;margin-top:8px}

.method-list{display:flex;flex-direction:column;gap:12px}
.method-card{display:flex;align-items:center;border:2px solid #e8e8e8;border-radius:10px;padding:18px 20px;cursor:pointer;transition:all 0.3s;background:#fff}
.method-card:hover{border-color:#ff6b35}
.method-card.selected{border-color:#ff6b35;background:#fff5f0}
.method-radio{width:20px;height:20px;border:2px solid #ccc;border-radius:50%;margin-right:16px;flex-shrink:0;position:relative;transition:all 0.3s}
.method-card.selected .method-radio{border-color:#ff6b35}
.method-card.selected .method-radio::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#ff6b35;border-radius:50%}
.method-info{flex:1}
.method-name{font-size:16px;font-weight:bold;color:#1a1a1a;margin-bottom:4px}
.method-desc{font-size:13px;color:#888}
.method-price{font-size:16px;font-weight:bold;color:#ff6b35;margin-left:20px;text-align:right}

.qty-section{padding:20px;background:#fafafa;border-radius:10px;margin-bottom:20px}
.qty-display{text-align:center;margin-bottom:20px}
.qty-value{font-size:48px;font-weight:bold;color:#ff6b35;line-height:1}
.qty-unit{font-size:18px;color:#666;margin-left:8px}
.qty-slider{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:#e8e8e8;border-radius:3px;outline:none}
.qty-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;background:#ff6b35;border-radius:50%;cursor:pointer;box-shadow:0 2px 8px rgba(255,107,53,0.4);transition:all 0.2s}
.qty-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.qty-slider::-moz-range-thumb{width:24px;height:24px;background:#ff6b35;border-radius:50%;cursor:pointer;border:none}
.qty-marks{display:flex;justify-content:space-between;margin-top:10px;font-size:12px;color:#999}
.qty-input-wrap{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:15px}
.qty-btn{width:36px;height:36px;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:18px;font-weight:bold;color:#666;transition:all 0.2s}
.qty-btn:hover{border-color:#ff6b35;color:#ff6b35}
.qty-input{width:80px;text-align:center;padding:8px;border:1px solid #ddd;border-radius:6px;font-size:16px}

.discount-info{background:#fff5f0;border-left:4px solid #ff6b35;padding:12px 16px;border-radius:6px;margin-top:15px;font-size:13px;color:#666}
.discount-info strong{color:#ff6b35}

.addon-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.addon-card{display:flex;align-items:flex-start;border:2px solid #e8e8e8;border-radius:10px;padding:16px;cursor:pointer;transition:all 0.3s;background:#fff}
.addon-card:hover{border-color:#ff6b35}
.addon-card.selected{border-color:#ff6b35;background:#fff5f0}
.addon-check{width:20px;height:20px;border:2px solid #ccc;border-radius:4px;margin-right:12px;flex-shrink:0;position:relative;transition:all 0.3s;margin-top:2px}
.addon-card.selected .addon-check{background:#ff6b35;border-color:#ff6b35}
.addon-card.selected .addon-check::after{content:'✓';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:bold}
.addon-info{flex:1}
.addon-name{font-size:15px;font-weight:bold;color:#1a1a1a;margin-bottom:4px}
.addon-desc{font-size:12px;color:#888;line-height:1.5;margin-bottom:6px}
.addon-price{font-size:14px;color:#ff6b35;font-weight:bold}

.step-actions{display:flex;justify-content:space-between;align-items:center;margin-top:30px;padding-top:25px;border-top:1px solid #f0f0f0}
.btn-prev{background:#fff;border:1px solid #ddd;color:#666;padding:12px 28px;border-radius:8px;cursor:pointer;font-size:15px;transition:all 0.3s}
.btn-prev:hover{border-color:#999;color:#333}
.btn-next{background:#ff6b35;color:#fff;border:none;padding:12px 36px;border-radius:8px;cursor:pointer;font-size:15px;font-weight:bold;transition:all 0.3s;box-shadow:0 4px 12px rgba(255,107,53,0.3)}
.btn-next:hover{background:#e55a2b;transform:translateY(-2px);box-shadow:0 6px 16px rgba(255,107,53,0.4)}
.btn-next:disabled{background:#ccc;cursor:not-allowed;box-shadow:none;transform:none}

.progress-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:0 20px}
.progress-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.progress-step::before{content:'';position:absolute;top:14px;left:-50%;right:50%;height:2px;background:#e8e8e8;z-index:0}
.progress-step:first-child::before{display:none}
.progress-step.completed::before,.progress-step.active::before{background:#ff6b35}
.progress-circle{width:30px;height:30px;border-radius:50%;background:#e8e8e8;color:#999;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:bold;position:relative;z-index:1;transition:all 0.3s}
.progress-step.active .progress-circle{background:#ff6b35;color:#fff;box-shadow:0 0 0 4px rgba(255,107,53,0.2)}
.progress-step.completed .progress-circle{background:#ff6b35;color:#fff}
.progress-label{font-size:12px;color:#999;margin-top:8px;text-align:center}
.progress-step.active .progress-label{color:#ff6b35;font-weight:bold}
.progress-step.completed .progress-label{color:#666}

.calc-summary{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px rgba(0,0,0,0.08);position:sticky;top:100px;height:fit-content}
.summary-title{font-size:20px;font-weight:bold;color:#1a1a1a;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}
.summary-empty{text-align:center;padding:40px 20px;color:#999}
.summary-empty i{font-size:48px;color:#ddd;margin-bottom:15px;display:block}
.summary-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px dashed #eee;font-size:14px}
.summary-item:last-of-type{border-bottom:none}
.summary-label{color:#666;flex:1}
.summary-value{color:#1a1a1a;font-weight:500;text-align:right;margin-left:10px}
.summary-discount{color:#52c41a}
.summary-total{margin-top:20px;padding:20px;background:linear-gradient(135deg,#fff5f0 0%,#ffe8dc 100%);border-radius:10px;text-align:center}
.total-label{font-size:14px;color:#666;margin-bottom:8px}
.total-value{font-size:32px;font-weight:bold;color:#ff6b35;line-height:1}
.total-note{font-size:12px;color:#999;margin-top:8px}

.summary-actions{margin-top:25px}
.btn-consult{display:block;width:100%;background:#ff6b35;color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:bold;cursor:pointer;text-align:center;text-decoration:none;transition:all 0.3s;margin-bottom:10px}
.btn-consult:hover{background:#e55a2b;color:#fff;text-decoration:none}
.btn-save{display:block;width:100%;background:#fff;color:#666;border:1px solid #ddd;padding:13px;border-radius:8px;font-size:14px;cursor:pointer;text-align:center;transition:all 0.3s}
.btn-save:hover{border-color:#ff6b35;color:#ff6b35}

.trust-list{margin-top:20px;padding-top:20px;border-top:1px solid #f0f0f0;font-size:12px;color:#888;line-height:1.8}
.trust-list .check{color:#52c41a;margin-right:6px}

/* P1-6: 浮动咨询按钮 */
.float-consult{position:fixed;bottom:30px;right:30px;z-index:999;background:linear-gradient(135deg,#ff6b35,#ff8c42);color:#fff;width:60px;height:60px;border-radius:50%;box-shadow:0 4px 20px rgba(255,107,53,0.5);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;transition:all 0.3s;animation:floatPulse 2s infinite;text-decoration:none}
.float-consult:hover{transform:scale(1.1);text-decoration:none;color:#fff}
@keyframes floatPulse{0%,100%{box-shadow:0 4px 20px rgba(255,107,53,0.5)}50%{box-shadow:0 4px 30px rgba(255,107,53,0.9)}}
.float-consult-tip{position:absolute;right:75px;top:50%;transform:translateY(-50%);background:#1a1a1a;color:#fff;padding:8px 14px;border-radius:6px;white-space:nowrap;font-size:13px;opacity:0;pointer-events:none;transition:all 0.3s}
.float-consult:hover .float-consult-tip{opacity:1;right:80px}
.float-consult-tip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#1a1a1a}
.float-consult-panel{position:fixed;bottom:100px;right:30px;z-index:998;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,0.2);padding:20px;width:280px;display:none;animation:fadeIn 0.3s ease}
.float-consult-panel.open{display:block}
.float-consult-panel h4{font-size:16px;font-weight:bold;color:#1a1a1a;margin-bottom:12px}
.float-consult-panel .channel{display:flex;align-items:center;padding:10px;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all 0.3s;text-decoration:none;color:#1a1a1a}
.float-consult-panel .channel:hover{background:#fff5f0;color:#ff6b35}
.float-consult-panel .channel-icon{width:32px;height:32px;background:#ff6b35;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;margin-right:12px;flex-shrink:0}
.float-consult-panel .channel-info{flex:1}
.float-consult-panel .channel-title{font-size:14px;font-weight:bold;line-height:1.3}
.float-consult-panel .channel-desc{font-size:12px;color:#888;margin-top:2px}

.result-section{text-align:center;padding:20px}
.result-icon{font-size:64px;margin-bottom:20px}
.result-title{font-size:28px;font-weight:bold;color:#1a1a1a;margin-bottom:10px}
.result-subtitle{color:#666;margin-bottom:30px;font-size:15px}
.result-price-box{background:linear-gradient(135deg,#ff6b35 0%,#ff8c42 100%);color:#fff;padding:30px;border-radius:12px;margin-bottom:30px}
.result-price-label{font-size:16px;margin-bottom:10px;opacity:0.9}
.result-price-value{font-size:42px;font-weight:bold}
.result-breakdown{background:#f8f8f8;border-radius:10px;padding:20px;margin-bottom:30px;text-align:left}
.result-breakdown .summary-item{padding:10px 0;border-bottom:1px dashed #ddd}
.result-actions{display:flex;gap:15px;justify-content:center}
.btn-consult-big{background:#ff6b35;color:#fff;padding:15px 40px;border-radius:8px;font-size:18px;font-weight:bold;text-decoration:none;transition:all 0.3s;display:inline-block}
.btn-consult-big:hover{background:#e55a2b;transform:translateY(-2px);box-shadow:0 6px 16px rgba(255,107,53,0.4);color:#fff;text-decoration:none}
.btn-restart{background:#fff;color:#666;border:1px solid #ddd;padding:15px 40px;border-radius:8px;font-size:16px;cursor:pointer;transition:all 0.3s}
.btn-restart:hover{border-color:#999;color:#333}

@media(max-width:768px){
.calc-container{grid-template-columns:1fr;gap:20px}
.calc-summary{position:static;margin-top:20px}
.calc-hero h1{font-size:28px}
.calc-hero .subtitle{font-size:16px}
.calc-hero .badges{flex-direction:column;gap:10px}
.option-grid{grid-template-columns:1fr}
.addon-list{grid-template-columns:1fr}
.result-actions{flex-direction:column}
.btn-consult-big,.btn-restart{width:100%}

/* P1-1: 场景快捷按钮修复 - 覆盖 fui.css 全局 button 样式 */
.scene-btn{
  display:block !important;
  width:100% !important;
  height:auto !important;
  text-align:center !important;
  padding:10px !important;
  background:#fff !important;
  border:1px solid #e8e8e8 !important;
  border-radius:8px !important;
  cursor:pointer !important;

/* P1-1: 场景快捷按钮 - 使用 div 替代 button 绕过 fui.css 全局样式 */
.scene-btn{
  display:block;
  width:100%;
  padding:10px;
  background:#fff;
  border:1px solid #e8e8e8;
  border-radius:8px;
  cursor:pointer;
  transition:all 0.3s;
  font-size:13px;
  text-align:center;
  box-sizing:border-box;
}
.scene-btn > div{display:block;width:100%}
.scene-btn:hover{border-color:#ff6b35;background:#fff5f0;transform:translateY(-2px);box-shadow:0 4px 12px rgba(255,107,53,0.15)}

/* P1-4: 套餐按钮修复 */
.pkg-apply{display:block;width:100%;height:auto !important;padding:8px !important}

/* 修复 重新计算按钮 */
.btn-restart{height:auto !important;padding:12px 30px !important}

/* div 版按钮的 disabled 状态 */
.btn-next[data-disabled='true']{background:#ccc !important;cursor:not-allowed !important;box-shadow:none !important;transform:none !important;pointer-events:none}
.btn-next, .btn-prev, .btn-restart, .btn-save, .qty-btn{display:inline-block;text-align:center;user-select:none;box-sizing:border-box}
.btn-restart{display:inline-block !important;width:auto !important;padding:15px 40px !important;height:auto !important}
.btn-consult-big, .btn-restart{display:inline-block}
