/* 全球建材B2B贸易管理系统 V3.7 - 全局统一设计系统 */
/* 所有页面必须引用此文件，创建时间 2026-04-10 */
:root{
  --bg-primary:#0f172a;--bg-card:#1e293b;--bg-card-hover:#263348;--bg-input:#0f172a;
  --border:#334155;--border-light:#475569;
  --accent:#3b82f6;--accent-hover:#2563eb;--accent-glow:rgba(59,130,246,.15);
  --success:#10b981;--success-bg:rgba(16,185,129,.1);
  --warning:#f59e0b;--warning-bg:rgba(245,158,11,.1);
  --danger:#ef4444;--danger-bg:rgba(239,68,68,.1);
  --purple:#8b5cf6;--cyan:#06b6d4;
  --text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;
  --radius-card:10px;--radius-btn:8px;--radius-input:10px;
  --font-family:-apple-system,'Microsoft YaHei','Segoe UI',sans-serif;
  --font-mono:'Consolas','Courier New',monospace;
  --shadow:0 8px 32px rgba(0,0,0,.3);--shadow-sm:0 2px 8px rgba(0,0,0,.2);
  --transition:all .2s ease;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);font-size:14px;min-height:100vh;line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{opacity:.85}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-primary)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ===== 通用按钮 ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-btn);border:none;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-family);transition:var(--transition);white-space:nowrap}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px var(--accent-glow)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{opacity:.85}
.btn-warning{background:var(--warning);color:#fff}
.btn-warning:hover{opacity:.85}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{opacity:.85}
.btn-purple{background:var(--purple);color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-primary)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.btn-sm{padding:4px 10px;font-size:11px}

/* ===== 通用表单 ===== */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}
.form-input,.form-select{width:100%;background:rgba(15,23,42,.6);border:1px solid var(--border);border-radius:var(--radius-input);padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:var(--font-family);outline:none;transition:border-color .2s}
.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.form-input::placeholder{color:var(--text-muted)}
.form-select option{background:var(--bg-card);color:var(--text-primary)}

/* ===== 通用卡片 ===== */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);padding:18px 20px;transition:var(--transition)}
.card:hover{border-color:var(--border-light)}
.card h3{font-size:14px;margin-bottom:14px;color:var(--accent);border-left:3px solid var(--accent);padding-left:10px;display:flex;align-items:center;justify-content:space-between}

/* ===== KPI 数字 ===== */
.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-card);padding:16px;text-align:center;transition:var(--transition)}
.kpi:hover{border-color:var(--accent)}
.kpi .num{font-size:26px;font-weight:700;margin-bottom:4px}
.kpi .lbl{font-size:12px;color:var(--text-secondary)}

/* ===== 表格 ===== */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
th{color:var(--text-secondary);font-weight:600;font-size:12px;position:sticky;top:0;background:var(--bg-card)}
tr:hover td{background:rgba(59,130,246,.03)}

/* ===== 弹窗 ===== */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2000;display:none;align-items:center;justify-content:center}
.modal-mask.show{display:flex}
.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:480px;max-width:92vw;max-height:80vh;overflow-y:auto}
.modal-box h3{font-size:16px;margin-bottom:16px;color:var(--accent)}

/* ===== Toast 通知组件 ===== */
#hyf-toast-container{position:fixed;top:20px;right:20px;z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:400px}
.hyf-toast{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-size:13px;line-height:1.5;pointer-events:auto;box-shadow:var(--shadow);transform:translateX(120%);opacity:0;transition:all .35s cubic-bezier(.4,0,.2,1)}
.hyf-toast.show{transform:translateX(0);opacity:1}
.hyf-toast.hide{transform:translateX(120%);opacity:0}
.hyf-toast-icon{flex-shrink:0;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:1px}
.hyf-toast-body{flex:1;min-width:0}
.hyf-toast-title{font-weight:600;font-size:13px;margin-bottom:2px}
.hyf-toast-msg{color:var(--text-secondary);font-size:12px;word-break:break-word}
.hyf-toast-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 0 0 8px;line-height:1}
.hyf-toast-close:hover{color:var(--text-primary)}
/* 类型样式 */
.hyf-toast-success{border-left:3px solid var(--success)}
.hyf-toast-success .hyf-toast-icon{background:var(--success-bg);color:var(--success)}
.hyf-toast-error{border-left:3px solid var(--danger)}
.hyf-toast-error .hyf-toast-icon{background:var(--danger-bg);color:var(--danger)}
.hyf-toast-warning{border-left:3px solid var(--warning)}
.hyf-toast-warning .hyf-toast-icon{background:var(--warning-bg);color:var(--warning)}
.hyf-toast-info{border-left:3px solid var(--accent)}
.hyf-toast-info .hyf-toast-icon{background:var(--accent-glow);color:var(--accent)}
/* 进度条（自动关闭倒计时） */
.hyf-toast-progress{position:absolute;bottom:0;left:0;height:2px;border-radius:0 0 10px 10px;transition:width linear}
.hyf-toast-success .hyf-toast-progress{background:var(--success)}
.hyf-toast-error .hyf-toast-progress{background:var(--danger)}
.hyf-toast-warning .hyf-toast-progress{background:var(--warning)}
.hyf-toast-info .hyf-toast-progress{background:var(--accent)}

/* ===== 标签 ===== */
.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}
.tag-success{background:var(--success-bg);color:var(--success)}
.tag-warning{background:var(--warning-bg);color:var(--warning)}
.tag-danger{background:var(--danger-bg);color:var(--danger)}
.tag-info{background:var(--accent-glow);color:var(--accent)}
.tag-purple{background:rgba(139,92,246,.1);color:var(--purple)}

/* ===== 状态点 ===== */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-up{background:var(--success);box-shadow:0 0 6px var(--success);animation:pulse 2s infinite}
.dot-warn{background:var(--warning);box-shadow:0 0 6px var(--warning);animation:pulse 1.5s infinite}
.dot-down{background:var(--danger);box-shadow:0 0 6px var(--danger);animation:blink .8s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,.5)}50%{opacity:.5}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* ===== 导航 ===== */
.top-nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(15,23,42,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 24px}
.nav-brand{display:flex;align-items:center;gap:12px}
.nav-logo{width:38px;height:38px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;box-shadow:0 0 20px var(--accent-glow)}
.nav-title{font-size:18px;font-weight:700;letter-spacing:1px}
.nav-title span{color:var(--accent)}
.nav-clock{font-family:var(--font-mono);font-size:15px;color:var(--accent);background:var(--bg-card);padding:6px 16px;border-radius:8px;border:1px solid var(--border)}

/* ===== 底部导航（三屏） ===== */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;z-index:800;height:46px}
.bottom-nav a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;height:100%;transition:var(--transition)}
.bottom-nav a:hover{color:var(--text-primary);background:rgba(59,130,246,.05)}
.bottom-nav a.active{color:var(--accent);background:rgba(59,130,246,.1)}

/* ===== 背景装饰 ===== */
.bg-grid{position:fixed;inset:0;z-index:0;background-image:linear-gradient(rgba(59,130,246,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.03) 1px,transparent 1px);background-size:60px 60px}
.bg-glow{position:fixed;z-index:0;width:500px;height:500px;border-radius:50%;filter:blur(120px);opacity:.12}

/* ===== 加载状态 ===== */
.hyf-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:32px 0;color:var(--text-muted);font-size:13px}
.hyf-loading .spinner{width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
.hyf-loading-sm{padding:16px 0;font-size:12px;gap:6px}
.hyf-loading-sm .spinner{width:14px;height:14px;border-width:2px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== 响应式 ===== */
@media(max-width:768px){
  .top-nav{padding:0 12px;height:50px}
  .nav-title{font-size:15px}
  .kpi{padding:12px}
  .kpi .num{font-size:20px}
}
