/* ═══════════════════════════════════════════
   lucky.css — 幸运转盘组件样式
   
   用途: index.html 聊天页的幸运转盘功能
   加载顺序: style.css → components.css → lucky.css
   ═══════════════════════════════════════════ */

/* ── 横幅 Banner ── */
.lucky-banner{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:20px;cursor:pointer;border:0.5px solid rgba(232,200,76,.3);background:rgba(232,200,76,.06);transition:background .2s}
.lucky-banner:active{background:rgba(232,200,76,.12)}
.lucky-banner--ready{border-color:rgba(232,200,76,.6);background:linear-gradient(135deg,rgba(139,26,60,.15),rgba(232,200,76,.1))}
.lucky-banner--done{border-color:rgba(127,119,221,.4);background:rgba(127,119,221,.08);cursor:default}
.lucky-banner--promo{border-color:rgba(232,200,76,.25)}
.lucky-banner-icon{font-size:26px;flex-shrink:0}
.lucky-banner-text{flex:1;min-width:0}
.lucky-banner-title{font-size:13px;font-weight:500;color:#e8c84c;margin-bottom:2px}
.lucky-banner-sub{font-size:11px;color:rgba(245,232,200,.7);line-height:1.4}
.lucky-banner-arrow{font-size:18px;color:rgba(232,200,76,.6);flex-shrink:0}
.lucky-banner-btn{font-size:11px;color:#e8c84c;border:.5px solid rgba(232,200,76,.5);border-radius:50px;padding:4px 10px;cursor:pointer;background:transparent;flex-shrink:0}
.lucky-progress-bar{height:4px;background:rgba(255,255,255,.08);border-radius:4px;margin-top:5px;overflow:hidden}
.lucky-progress-bar--lg{height:6px;margin-top:8px}
.lucky-progress-fill{height:100%;background:linear-gradient(90deg,#e8c84c,#f5a0c0);border-radius:4px;transition:width .6s ease}

/* ── VIP 大奖横幅 ── */
.lucky-banner-vip{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:24px;cursor:pointer;background:linear-gradient(135deg,#8B1A1A,#C0392B);border:1px solid rgba(232,200,76,.5);position:relative;overflow:hidden;animation:slideInDown .5s ease;box-shadow:0 4px 20px rgba(139,26,26,.4)}
.lucky-banner-vip::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5 L35 20 L50 20 L38 30 L43 45 L30 35 L17 45 L22 30 L10 20 L25 20 Z' fill='%23e8c84c' fill-opacity='0.06'/%3E%3C/svg%3E");opacity:.5;pointer-events:none}
@keyframes slideInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
.lucky-banner-vip-icon{font-size:32px;flex-shrink:0;position:relative;z-index:1}
.lucky-banner-vip-content{flex:1;min-width:0;position:relative;z-index:1}
.lucky-banner-vip-title{font-size:16px;font-weight:600;color:#e8c84c;margin-bottom:3px;font-family:"STKaiti","KaiTi",serif;letter-spacing:1px;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.lucky-banner-vip-sub{font-size:11px;color:rgba(245,232,200,.85);line-height:1.4}
.lucky-banner-vip-btn{flex-shrink:0;padding:8px 18px;border-radius:50px;border:1px solid #e8c84c;background:transparent;color:#e8c84c;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s;position:relative;z-index:1}
.lucky-banner-vip-btn:hover{background:rgba(232,200,76,.2);box-shadow:0 0 15px rgba(232,200,76,.4)}

/* ── Modal 弹窗 ── */
.lucky-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px}
.lucky-modal{background:#1a1025;border:1px solid rgba(232,200,76,.3);border-radius:24px;padding:24px 20px;width:100%;max-width:360px;position:relative;text-align:center;box-shadow:0 0 40px rgba(232,200,76,.1)}
.lucky-modal-close{position:absolute;top:14px;right:16px;background:transparent;border:none;color:rgba(245,232,200,.5);font-size:22px;cursor:pointer;line-height:1;padding:0}
.lucky-modal-title{font-size:18px;font-weight:600;color:#e8c84c;margin-bottom:6px}
.lucky-modal-sub{font-size:11px;color:rgba(245,232,200,.6);margin-bottom:16px;line-height:1.5}
.lucky-modal-tip{font-size:10px;color:rgba(245,232,200,.4);margin-top:10px}

/* ── 说明稿弹窗 ── */
.promo-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9100;display:flex;align-items:center;justify-content:center;padding:20px}
.promo-modal{background:linear-gradient(180deg,#2a1525 0%,#1a0f1a 100%);border:1px solid rgba(232,200,76,.4);border-radius:24px;padding:28px 20px;width:100%;max-width:380px;position:relative;text-align:center;box-shadow:0 0 60px rgba(139,26,26,.4)}
.promo-modal-close{position:absolute;top:14px;right:16px;background:transparent;border:none;color:rgba(245,232,200,.5);font-size:24px;cursor:pointer;line-height:1;padding:0;z-index:10}
.promo-modal-header{margin-bottom:20px}
.promo-modal-icon{font-size:36px;margin-bottom:8px}
.promo-modal-title{font-size:20px;font-weight:600;color:#e8c84c;margin-bottom:6px;font-family:"STKaiti","KaiTi",serif;letter-spacing:1px}
.promo-modal-sub{font-size:13px;color:rgba(245,232,200,.6);font-style:italic}
.promo-modal-body{text-align:left;margin-bottom:20px}
.promo-modal-desc{font-size:13px;color:rgba(245,232,200,.85);line-height:1.7;margin-bottom:16px;padding:12px;background:rgba(139,26,26,.15);border-radius:12px;border-left:3px solid rgba(232,200,76,.4)}
.promo-modal-prizes{background:rgba(255,255,255,.03);border-radius:20px;padding:14px;margin-bottom:14px}
.promo-prize-item{display:flex;align-items:center;gap:10px;font-size:12px;color:rgba(245,232,200,.8);padding:6px 0}
.promo-prize-icon{font-size:16px}
.promo-modal-condition{text-align:center;font-size:11px;color:rgba(232,200,76,.8);padding:8px;background:rgba(232,200,76,.08);border-radius:50px}
.promo-modal-btn{width:100%;padding:16px;border-radius:50px;border:1px solid rgba(232,200,76,.5);background:linear-gradient(135deg,#8B1A3C,#6B4226);color:#e8c84c;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;letter-spacing:2px}
.promo-modal-btn:hover{background:linear-gradient(135deg,#9B2A4C,#7B5236);box-shadow:0 0 20px rgba(232,200,76,.3)}

/* ── 转盘画布 + 按钮 ── */
#lucky-canvas{border-radius:50%;box-shadow:0 0 20px rgba(232,200,76,.15);margin:0 auto;display:block}
.lucky-spin-btn{width:100%;padding:14px;border-radius:50px;border:none;background:linear-gradient(135deg,#8B1A3C,#6B4226);color:#e8c84c;font-size:15px;font-weight:600;cursor:pointer;margin-top:14px;transition:opacity .2s;letter-spacing:2px}
.lucky-spin-btn:disabled{opacity:.5;cursor:not-allowed}
.lucky-spin-btn--disabled{background:rgba(127,119,221,.2);color:rgba(206,203,246,.7);cursor:pointer}

/* ── 奖品预览网格 ── */
.lucky-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0 14px}
.lucky-preview-item{background:rgba(255,255,255,.04);border-radius:16px;padding:10px 6px;text-align:center}
.lucky-preview-img{width:50px;height:50px;border-radius:12px;object-fit:cover;margin:0 auto 4px;display:block}
.lucky-preview-img-placeholder{width:50px;height:50px;border-radius:12px;background:rgba(232,200,76,.1);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 4px}
.lucky-preview-name{font-size:10px;color:rgba(245,232,200,.7);line-height:1.3}

/* ── 进度信息 ── */
.lucky-progress-info{text-align:left;background:rgba(255,255,255,.03);border-radius:16px;padding:12px;margin-bottom:4px}
.lucky-progress-label{font-size:11px;color:rgba(245,232,200,.8);margin-bottom:4px}
.lucky-progress-tip{font-size:10px;color:rgba(245,232,200,.4);margin-top:6px}

/* ── 结果展示 ── */
#about-page *,#feedback-page *{box-sizing:border-box;max-width:100%}
#about-page img,#feedback-page img{width:100%;height:auto}
.lucky-result-firework{font-size:48px;margin:0 0 8px}
.lucky-result-emoji{font-size:64px;margin:8px 0}
.lucky-result-img{width:100px;height:100px;border-radius:20px;object-fit:cover;margin:8px auto;display:block;border:1px solid rgba(232,200,76,.3)}
.lucky-result-name{font-size:20px;font-weight:700;color:#e8c84c;margin:8px 0 4px}
.lucky-result-desc{font-size:11px;color:rgba(245,232,200,.6);margin-bottom:10px}

/* ── 收货地址表单 ── */
.lucky-address-form{text-align:left;margin-bottom:6px}
.lucky-input{width:100%;box-sizing:border-box;background:rgba(255,255,255,.05);border:.5px solid rgba(232,200,76,.25);border-radius:50px;padding:10px 12px;color:#ede6f8;font-size:13px;margin-bottom:8px;outline:none;-webkit-appearance:none;transition:border-color .25s}
.lucky-input:focus{border-color:rgba(232,200,76,.6);box-shadow:0 0 8px rgba(232,200,76,.1)}
.lucky-textarea{min-height:72px;resize:vertical}
.lucky-error-msg{font-size:11px;color:#e87878;text-align:center;margin-top:4px;padding:6px;background:rgba(232,120,120,.1);border-radius:50px}

/* ── Toast 提示 ── */
.lucky-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#333;color:#fff;padding:8px 18px;border-radius:50px;font-size:13px;z-index:10000;pointer-events:none}
