/* ===== 付费墙美化 ===== */
.spcl-locker { margin: 25px 0; }
.spcl-preview { padding: 20px; background: #fff; border: 1px solid #e8e8e8; border-radius: 12px 12px 0 0; }
.spcl-paywall {
    background: #fffbf0; border: 1px solid #e5d5b0; border-radius: 0 0 14px 14px;
    padding: 30px 25px; text-align: center; box-shadow: 0 8px 24px rgba(139,90,43,0.08);
}

.paywall-inner { max-width: 420px; margin: 0 auto; }
.paywall-icon { font-size: 2.4rem; margin-bottom: 5px; }
.paywall-title { font-size: 1.4rem; font-weight: 700; color: #3e2723; margin: 0 0 6px; }
.paywall-price { font-size: 2rem; font-weight: 700; color: #c0392b; margin-bottom: 20px; }

.paywall-qr-row { display: flex; justify-content: center; gap: 30px; flex-wrap: wrap; margin-bottom: 20px; }
.paywall-qr-item { background: #fff; border-radius: 10px; padding: 12px; box-shadow: 0 3px 10px rgba(0,0,0,0.05); }
.paywall-qr-item img { width: 140px; height: 140px; display: block; border-radius: 6px; }
.paywall-qr-item span { display: block; margin-top: 6px; font-size: 0.8rem; color: #666; }

.paywall-note {
    display: flex; align-items: center; justify-content: center; gap: 4px;
    background: #fff8e7; border: 1px solid #f0d78c; border-radius: 8px;
    padding: 10px 15px; margin-bottom: 20px; font-size: 0.9rem; color: #5a3a2a;
}
.paywall-note strong { color: #c0392b; }

.paywall-form { display: flex; flex-direction: column; gap: 12px; text-align: left; }
.paywall-file-label { display: flex; align-items: center; gap: 8px; background: #fff; border: 1px solid #ddd; border-radius: 6px; padding: 10px 15px; cursor: pointer; font-size: 0.9rem; color: #555; }
.paywall-file-label:hover { border-color: #d4af37; }
.paywall-file-label input[type="file"] { display: none; }
.paywall-note-input { width: 100%; padding: 10px 15px; border: 1px solid #ddd; border-radius: 6px; font-size: 0.9rem; }
.paywall-submit { background: #d4af37; color: #fff; border: none; border-radius: 25px; padding: 12px 0; font-size: 1rem; font-weight: 700; cursor: pointer; }
.paywall-login-btn { display: inline-block; background: #d4af37; color: #fff; padding: 12px 30px; border-radius: 25px; text-decoration: none; font-weight: 700; }

/* 附件卡片 */
.spcl-attachments-box { background: #fdfbf7; border: 1px solid #e5d5b0; border-radius: 14px; padding: 28px 24px; margin: 30px 0; box-shadow: 0 6px 18px rgba(139,90,43,0.06); }
.att-heading { font-size: 1.25rem; font-weight: 700; color: #3e2723; margin: 0 0 22px; padding-bottom: 8px; border-bottom: 2px solid #d4af37; }
.spcl-att-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.spcl-att-card { background: #fffef7; border: 1px solid #e8d5b5; border-radius: 10px; padding: 18px 16px; display: flex; align-items: center; gap: 14px; transition: all 0.25s; box-shadow: 0 2px 8px rgba(139,90,43,0.04); }
.spcl-att-card:hover { border-color: #d4af37; box-shadow: 0 6px 18px rgba(139,90,43,0.1); transform: translateY(-2px); }
.att-icon { font-size: 1.8rem; flex-shrink: 0; }
.att-info { flex: 1; min-width: 0; }
.att-title { font-size: 0.95rem; font-weight: 600; color: #4a3a2a; margin-bottom: 8px; }
.att-download { display: inline-block; padding: 6px 18px; background: #d4af37; color: #fff !important; border-radius: 20px; text-decoration: none; font-weight: 600; }
.att-locked { display: inline-block; padding: 6px 18px; background: #ddd; color: #8b7355; border-radius: 20px; font-weight: 500; }
.spcl-att-card.locked { opacity: 0.85; }

/* 提取码 */
.att-code { font-size: 0.85rem; color: #5a3e2b; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.att-code span { background: #fdf6e3; padding: 2px 8px; border-radius: 4px; border: 1px solid #e8d5b5; font-weight: 600; }
.att-copy-btn { background: #e2e8f0; border: none; color: #4a3a2a; padding: 2px 10px; border-radius: 4px; cursor: pointer; transition: background 0.2s; }
.att-copy-btn:hover { background: #d4af37; color: #fff; }