/* 客户展示页样式 */
:root {
    --primary: #1F3864;
    --accent: #007ACC;
    --accent2: #E86C00;
    --bg: #F7F8FA;
    --card: #fff;
    --text: #333;
    --text2: #666;
    --text3: #999;
    --border: #E5E7EB;
    --danger: #C00000;
    --success: #10B981;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif; background: var(--bg); color: var(--text); -webkit-font-smoothing: antialiased; }

.topbar { position:sticky; top:0; z-index:100; background:#fff; border-bottom:1px solid var(--border); padding:0 16px; height:56px; display:flex; align-items:center; justify-content:space-between; box-shadow:0 1px 3px rgba(0,0,0,.06); }
.topbar-left { display:flex; align-items:center; gap:10px; }
.topbar-logo { width:36px; height:36px; border-radius:8px; object-fit:contain; }
.topbar-name { font-size:17px; font-weight:700; color:var(--primary); }
.topbar-right { display:flex; align-items:center; gap:8px; }
.contact-btn { background:var(--accent2); color:#fff; border:none; padding:8px 14px; border-radius:20px; font-size:13px; cursor:pointer; display:flex; align-items:center; gap:5px; }
.contact-btn:hover { opacity:.9; }

.contact-modal { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.4); z-index:200; align-items:center; justify-content:center; }
.contact-modal.show { display:flex; }
.contact-card { background:#fff; border-radius:16px; padding:24px; width:90%; max-width:360px; text-align:center; }
.contact-card h3 { margin:0 0 16px; color:var(--primary); font-size:18px; }
.contact-item { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid #f3f4f6; font-size:14px; color:var(--text2); }
.contact-item i { width:20px; color:var(--accent); }
.contact-close { margin-top:16px; background:var(--primary); color:#fff; border:none; padding:10px 30px; border-radius:20px; cursor:pointer; font-size:14px; }

.search-bar { padding:12px 16px 0; }
.search-bar input { width:100%; padding:10px 16px 10px 38px; border:1.5px solid var(--border); border-radius:24px; font-size:15px; outline:none; background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23999' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 10-1.397 1.398h-.001l3.85 3.85a1 1 0 001.415-1.414l-3.85-3.85zm-5.242.156a5 5 0 110-10 5 5 0 010 10z'/%3E%3C/svg%3E") 14px center no-repeat; transition:border-color .2s; }
.search-bar input:focus { border-color:var(--accent); }

.cats { display:flex; gap:8px; padding:12px 16px; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.cats::-webkit-scrollbar { display:none; }
.cat-tag { flex-shrink:0; padding:6px 16px; border-radius:20px; border:1.5px solid var(--border); background:#fff; font-size:13px; cursor:pointer; color:var(--text2); transition:all .2s; }
.cat-tag.active, .cat-tag:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

.products { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; padding:4px 16px 80px; }
@media(max-width:768px) { .products { grid-template-columns:repeat(2,1fr); gap:10px; padding:4px 12px 80px; } }
@media(max-width:480px) { .products { grid-template-columns:repeat(2,1fr); gap:8px; } }

.p-card { background:#fff; border-radius:12px; overflow:hidden; box-shadow:0 1px 4px rgba(0,0,0,.06); transition:transform .2s,box-shadow .2s; cursor:pointer; }
.p-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.1); }
.p-card img { width:100%; aspect-ratio:1; object-fit:cover; background:#f3f4f6; display:block; }
.p-card .p-info { padding:10px 12px; }
.p-card .p-name { font-size:14px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.p-card .p-model { font-size:11px; color:var(--text3); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.p-card .p-specs { font-size:11px; color:var(--text3); margin-top:3px; line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.p-card .p-price { font-size:16px; font-weight:700; color:var(--danger); margin-top:6px; }
.p-card .p-tags { display:flex; gap:4px; margin-top:6px; flex-wrap:wrap; }
.p-card .p-tag { font-size:10px; padding:1px 6px; border-radius:8px; background:#ecfdf5; color:#059669; }

.detail-modal { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.5); z-index:200; overflow-y:auto; }
.detail-modal.show { display:block; }
.detail-card { background:#fff; max-width:600px; margin:40px auto; border-radius:16px; overflow:hidden; position:relative; }
@media(max-width:768px) { .detail-card { margin:0; border-radius:0; min-height:100vh; } }
.detail-close { position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:50%; background:rgba(0,0,0,.4); color:#fff; border:none; font-size:18px; cursor:pointer; z-index:1; display:flex; align-items:center; justify-content:center; }
.detail-img { width:100%; max-height:400px; object-fit:contain; background:#f9fafb; }
.detail-body { padding:20px; }
.detail-body h2 { font-size:22px; color:var(--primary); margin:0 0 8px; }
.detail-body .d-model { font-size:14px; color:var(--text2); margin-bottom:12px; }
.detail-body .d-price { font-size:28px; font-weight:700; color:var(--danger); margin-bottom:16px; }
.detail-body .d-specs { background:#f9fafb; border-radius:10px; padding:12px 16px; }
.detail-body .d-specs h4 { font-size:14px; color:var(--text2); margin:0 0 8px; }
.detail-body .spec-row { display:flex; font-size:13px; padding:4px 0; }
.detail-body .spec-key { color:var(--text3); width:80px; flex-shrink:0; }
.detail-body .spec-val { color:var(--text); }
.detail-body .d-desc { margin-top:16px; font-size:14px; color:var(--text2); line-height:1.6; }
.detail-body .d-tags { display:flex; gap:6px; margin-top:12px; flex-wrap:wrap; }
.detail-body .d-tag { font-size:12px; padding:3px 10px; border-radius:12px; background:#ecfdf5; color:#059669; }

.quote-section { display:none; }
.quote-section.show { display:block; }
.quote-header { background:linear-gradient(135deg,var(--primary),var(--accent)); color:#fff; padding:24px 16px; text-align:center; }
.quote-header h2 { font-size:22px; margin:0 0 6px; }
.quote-header .q-client { font-size:14px; opacity:.8; }
.quote-header .q-amount { font-size:32px; font-weight:700; margin-top:10px; }
.quote-header .q-date { font-size:12px; opacity:.6; margin-top:4px; }

.quote-items { padding:16px; }
.q-item { display:flex; gap:12px; padding:14px 0; border-bottom:1px solid #f3f4f6; align-items:center; }
.q-item img { width:56px; height:56px; border-radius:8px; object-fit:cover; flex-shrink:0; background:#f3f4f6; }
.q-item-info { flex:1; min-width:0; }
.q-item-name { font-size:14px; font-weight:600; }
.q-item-spec { font-size:12px; color:var(--text3); margin-top:2px; }
.q-item-price { text-align:right; flex-shrink:0; }
.q-item-unit { font-size:13px; color:var(--text2); }
.q-item-amt { font-size:15px; font-weight:700; color:var(--danger); margin-top:2px; }

.quote-summary { padding:16px; background:#fff; border-radius:12px; margin:0 16px 16px; box-shadow:0 1px 4px rgba(0,0,0,.06); }
.q-row { display:flex; justify-content:space-between; padding:6px 0; font-size:14px; color:var(--text2); }
.q-row.total { border-top:2px solid var(--border); padding-top:10px; margin-top:6px; font-size:18px; font-weight:700; color:var(--primary); }
.q-row.total .val { color:var(--danger); }

.quote-footer { padding:16px; text-align:center; font-size:12px; color:var(--text3); line-height:1.8; }
.quote-footer a { color:var(--accent); text-decoration:none; }

.empty { text-align:center; padding:60px 20px; color:var(--text3); }
.empty i { font-size:48px; opacity:.2; margin-bottom:12px; }
.empty p { font-size:14px; }

.loading { text-align:center; padding:40px; color:var(--text3); }
.loading i { font-size:24px; animation:spin 1s linear infinite; }
@keyframes spin { 100% { transform:rotate(360deg); } }

.back-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; margin:16px; background:#fff; border:1px solid var(--border); border-radius:20px; font-size:13px; color:var(--text2); cursor:pointer; }
.back-btn:hover { background:#f9fafb; }

/* 产品卡片 - 加入询价按钮 */
.p-card .p-action { padding:0 12px 10px; }
.p-card .btn-add-inq { width:100%; padding:6px 0; border:1.5px solid var(--accent2); background:transparent; color:var(--accent2); border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; transition:all .2s; display:flex;align-items:center;justify-content:center;gap:4px; }
.p-card .btn-add-inq:hover { background:var(--accent2); color:#fff; }
.p-card .btn-add-inq.added { border-color:var(--success); color:var(--success); background:#f0fdf4; pointer-events:none; }

/* 详情弹窗中的加入询价按钮 */
.detail-add-btn { width:100%; margin-top:16px; padding:10px 0; border:none; background:var(--accent2); color:#fff; border-radius:10px; font-size:15px; font-weight:600; cursor:pointer; transition:opacity .2s; display:flex;align-items:center;justify-content:center;gap:6px; }
.detail-add-btn:hover { opacity:.9; }
.detail-add-btn.added { background:var(--success); pointer-events:none; }

/* 底部询价浮动栏 */
.inquiry-bar { position:fixed; bottom:0; left:0; right:0; z-index:150; background:var(--primary); color:#fff; box-shadow:0 -3px 12px rgba(0,0,0,.15); cursor:pointer; animation:slideUp .25s ease-out; }
.inquiry-bar-inner { max-width:600px; margin:0 auto; padding:10px 20px; display:flex; align-items:center; gap:8px; font-size:14px; }
.inquiry-bar i.fa-shopping-cart { font-size:18px; }
.inquiry-bar strong { font-size:17px; }
.inquiry-total { margin-left:auto; font-weight:700; font-size:16px; }
@keyframes slideUp { from{transform:translateY(100%);} to{transform:translateY(0);} }

/* 询价提交弹窗 */
.inquiry-modal { display:none; position:fixed; top:0; left:0; right:0; bottom:0; z-index:250; background:rgba(0,0,0,.5); overflow-y:auto; align-items:flex-start; justify-content:center; padding:40px 16px; }
.inquiry-modal.show { display:flex; }
.inquiry-modal-content { background:#fff; border-radius:16px; width:100%; max-width:520px; max-height:85vh; overflow-y:auto; animation:modalIn .2s ease-out; }
@media(min-width:520px) { .inquiry-modal-content { margin:20px auto 0; } }
@keyframes modalIn { from{opacity:0; transform:translateY(20px);} to{opacity:1; transform:translateY(0);} }

.inquiry-modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--border); position:sticky; top:0; background:#fff; border-radius:16px 16px 0 0; z-index:1; }
.inquiry-modal-header h3 { font-size:17px; color:var(--primary); margin:0; }
.inquiry-close { width:32px; height:32px; border-radius:50%; border:none; background:#f3f4f6; color:var(--text2); font-size:16px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.inquiry-close:hover { background:#e5e7eb; }

/* 已选产品列表 */
.inquiry-items { padding:16px 20px 8px; }
.inq-item { display:flex; gap:10px; padding:12px 0; border-bottom:1px solid #f3f4f6; align-items:center; }
.inq-item-img { width:48px; height:48px; border-radius:8px; object-fit:cover; flex-shrink:0; background:#f3f4f6; }
.inq-item-info { flex:1; min-width:0; }
.inq-item-name { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.inq-item-price { font-size:13px; color:var(--danger); font-weight:600; margin-top:2px; }
.inq-item-qty-wrap { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.inq-item-qty { width:42px; height:30px; text-align:center; border:1px solid var(--border); border-radius:6px; font-size:13px; outline:none; }
.inq-item-qty-btn { width:28px; height:30px; border:1px solid var(--border); background:#fff; border-radius:6px; font-size:14px; cursor:pointer; color:var(--text2); display:flex;align-items:center;justify-content:center; }
.inq-item-qty-btn:hover { background:#f3f4f6; }
.inq-item-remove { color:#ccc; font-size:16px; cursor:pointer; margin-left:4px; padding:4px; }
.inq-item-remove:hover { color:#C00000; }

/* 合计行 */
.inquiry-sum-row { display:flex; justify-content:space-between; align-items:center; padding:14px 20px; border-top:2px solid var(--border); font-size:15px; color:var(--text2); font-weight:600; }
.inquiry-sum-val { font-size:22px; color:#C00000; font-weight:700; }

/* 表单区域 */
.inquiry-form { padding:16px 20px; border-top:1px solid #f3f4f6; }
.inquiry-form h4 { font-size:14px; color:var(--primary); margin:0 0 12px; }
.inq-form-group { margin-bottom:12px; }
.inq-form-group label { display:block; font-size:13px; color:var(--text2); margin-bottom:4px; }
.inq-form-group input, .inq-form-group textarea { width:100%; padding:9px 12px; border:1.5px solid var(--border); border-radius:8px; font-size:14px; outline:none; transition:border-color .2s; }
.inq-form-group input:focus, .inq-form-group textarea:focus { border-color:var(--accent); }

/* 提交按钮 */
.inquiry-submit-btn { width:100%; margin:0 20px 20px; padding:12px 0; border:none; background:var(--accent2); color:#fff; border-radius:10px; font-size:16px; font-weight:700; cursor:pointer; display:flex;align-items:center;justify-content:center;gap:8px; transition:opacity .2s; }
.inquiry-submit-btn:hover { opacity:.9; }
.inquiry-submit-btn:disabled { opacity:.5; cursor:not-allowed; }

/* 提交成功 */
.inquiry-success { text-align:center; padding:40px 20px; }
.inquiry-success i { font-size:52px; color:var(--success); margin-bottom:12px; display:block; }
.inquiry-success p { font-size:16px; color:var(--text); }
