@charset "UTF-8";
/* ---- 顶部导航栏 ---- */
#page-topbar { height: 50px; box-shadow: none; border-bottom: 1px solid var(--nq-border-1); }
#page-topbar .navbar-header { height: 50px; padding: 0 8px 0 16px; display: flex; align-items: center; justify-content: space-between; }
.nq-header-left { display: flex; align-items: center; gap: 12px; }
.nq-header-logo { display: flex; align-items: center; text-decoration: none; }
.nq-header-logo img { height: 28px; width: auto; display: block; }
.nq-header-logo .logo-sm { display: none; }
.nq-header-logo .logo-lg { display: flex; align-items: center; }
@media (max-width: 767.98px) {
  .nq-header-logo .logo-lg { display: none; }
  .nq-header-logo .logo-sm { display: flex; align-items: center; }
  .nq-header-logo .logo-sm img { height: 28px; }
}
.nq-header-overview { display: flex; align-items: center; gap: 4px; padding: 0 8px; height: 24px; line-height: 24px; background: var(--nq-primary-light); color: var(--nq-primary) !important; font-size: var(--nq-font-xs); text-decoration: none; border-radius: 4px; white-space: nowrap; transition: background .15s; }
.nq-header-overview:hover { background: rgba(var(--arcoblue-6), 0.15); }
.nq-header-overview i { font-size: 13px; }
.nq-header-nav { display: flex; align-items: center; gap: 4px; }
a.nq-header-nav-link { padding: 0 10px; height: 36px; line-height: 36px; font-size: var(--nq-font-md); color: var(--nq-text-2); text-decoration: none; transition: color .15s; white-space: nowrap; }
a.nq-header-nav-link:hover { color: var(--nq-primary); text-decoration: none; }
.nq-header-right { display: flex; align-items: center; gap: 4px; }
a.nq-header-icon-btn,
button.nq-header-icon-btn,
.nq-header-lang-btn { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: none; background: transparent; cursor: pointer; color: var(--nq-text-2); font-size: 18px; text-decoration: none; transition: color .15s; }
.nq-header-lang-btn { font-size: 20px; }
a.nq-header-icon-btn:hover,
button.nq-header-icon-btn:hover,
.nq-header-lang-btn:hover { color: var(--nq-primary); }
.nq-hover-dropdown { position: relative; }
.nq-hover-dropdown > .dropdown-menu { top: 100%; margin-top: 6px; }
.nq-hover-dropdown::after { content: ''; position: absolute; left: 0; right: 0; top: 100%; height: 8px; }
.nq-hover-dropdown:hover > .dropdown-menu { display: block; }
.nq-header-icon-btn-wrap { position: relative; }
.nq-header-icon-btn-wrap .nq-header-icon-btn { position: relative; }
.nq-header-icon-btn .badge { position: absolute; top: 4px; right: 8; font-size: 9px; min-width: 14px; height: 14px; line-height: 14px; padding: 0 3px; transform: translate(50%, -30%); }
.nq-header-divider { width: 1px; height: 20px; background: var(--nq-border-2); margin: 0 8px; flex-shrink: 0; }
.nq-header-user-btn { display: flex; align-items: center; gap: 8px; padding: 0; border: none; background: transparent; cursor: pointer; transition: color .15s; }
.nq-header-user-btn:hover { background: transparent; }
.nq-header-user-info { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.2; }
.nq-header-user-name { font-size: var(--nq-font-sm); color: var(--nq-text-2); white-space: nowrap; }
.nq-header-user-tag { font-size: 11px; color: var(--nq-text-3); white-space: nowrap; }
.nq-header-avatar { width: 32px; height: 32px; border-radius: 4px; background: var(--nq-primary); color: var(--nq-bg-1); display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; object-fit: cover; }

/* ---- 个人中心下拉 ---- */
.nq-user-dropdown { position: relative; }
.nq-user-dropdown::after { content: ''; position: absolute; left: 0; right: 0; top: 100%; height: 8px; }
.nq-user-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 160px; padding: 4px 0; background: var(--nq-bg-1); border: 1px solid var(--nq-fill-3); border-radius: var(--nq-radius); box-shadow: 0 4px 10px rgba(0,0,0,.1); opacity: 0; visibility: hidden; transform: translateY(-4px); transition: opacity .15s ease, visibility .15s ease, transform .15s ease; z-index: 1050; }
.nq-user-dropdown:hover .nq-user-menu,
.nq-user-dropdown.open .nq-user-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nq-user-menu-item { display: flex; align-items: center; gap: 8px; padding: 8px 16px; font-size: var(--nq-font-sm); color: var(--nq-text-1); text-decoration: none; transition: background .15s, color .15s; white-space: nowrap; }
.nq-user-menu-item i { font-size: 16px; color: var(--nq-text-3); transition: color .15s; }
.nq-user-menu-item:hover { background: var(--nq-fill-1); color: var(--nq-primary); text-decoration: none; }
.nq-user-menu-item:hover i { color: var(--nq-primary); }
.nq-user-menu-danger,
.nq-user-menu-danger i { color: var(--nq-danger) !important; }

/* ---- 多语言下拉 ---- */
.nq-lang-dropdown { position: relative; display: inline-block; }
.nq-lang-dropdown::after { content: ''; position: absolute; left: 0; right: 0; top: 100%; height: 8px; }
.nq-lang-menu { position: absolute; top: calc(100% + 6px); right: 0; min-width: 140px; padding: 4px 0; background: var(--nq-bg-1); border: 1px solid var(--nq-fill-3); border-radius: var(--nq-radius); box-shadow: 0 4px 10px rgba(0,0,0,.1); opacity: 0; visibility: hidden; transform: translateY(-4px); transition: opacity .15s ease, visibility .15s ease, transform .15s ease; z-index: 1050; }
.nq-lang-dropdown:hover .nq-lang-menu,
.nq-lang-dropdown.open .nq-lang-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nq-lang-menu-item { display: flex; align-items: center; gap: 8px; padding: 8px 16px; font-size: var(--nq-font-sm); color: var(--nq-text-1); text-decoration: none; transition: background .15s, color .15s; white-space: nowrap; }
.nq-lang-menu-item:hover { background: var(--nq-fill-1); color: var(--nq-primary); text-decoration: none; }
.nq-lang-menu-item.active { color: var(--nq-primary); font-weight: 500; }

/* ---- 侧边栏 ---- */
.vertical-menu { width: 220px; top: 50px; background: var(--nq-bg-1) !important; border-right: 1px solid var(--nq-border-1); box-shadow: none; }
body.sidebar-enable .vertical-menu { top: 50px; }
#nq-sidebar-nav { padding: 8px 0; }
.nq-nav-item { display: block; }
.nq-nav-link { display: flex; align-items: center; gap: 8px; padding: 0 12px; height: 36px; font-size: var(--nq-font-sm); color: var(--nq-text-2); text-decoration: none; cursor: pointer; border-radius: 4px; margin: 4px 8px; transition: background .15s, color .15s; white-space: nowrap; overflow: hidden; }
.nq-nav-link i:first-child { font-size: 16px; flex-shrink: 0; color: var(--nq-text-1); transition: color .15s; }
.nq-nav-link span { flex: 1; overflow: hidden; text-overflow: ellipsis; }
.nq-nav-link:hover { background: var(--nq-fill-1); color: var(--nq-text-1) !important; text-decoration: none; }
.nq-nav-link:hover i:first-child { color: var(--nq-text-1) !important; }
.nq-nav-link.active { background: var(--nq-primary-light); color: var(--nq-primary); }
.nq-nav-link.active i:first-child { color: var(--nq-primary); }
.nq-nav-link.active:hover { color: var(--nq-primary) !important; }
.nq-nav-link.active:hover i:first-child { color: var(--nq-primary) !important; }
.nq-nav-arrow { font-size: 16px; flex-shrink: 0; color: var(--nq-text-4); transition: transform .2s; margin-left: auto; }
.nq-nav-group.open > .nq-nav-link .nq-nav-arrow { transform: rotate(90deg); }
.nq-nav-sub { display: none; }
.nq-nav-group.open > .nq-nav-sub { display: block; }
.nq-nav-sub-link { padding-left: 36px; height: 36px; font-size: var(--nq-font-sm); }
.nq-nav-sub2-link { padding-left: 52px; }

/* ---- 内容区布局适配 ---- */
.main-content { margin-left: 220px; overflow: visible; }
.main-content.main-content-no-sidebar { margin-left: 0; }
.page-content.page-content-no-sidebar { padding-left: 0; padding-right: 0; }
.page-content-no-sidebar > .container-fluid { padding-left: 0; padding-right: 0; }
.main-content .content { margin-top: 50px; }
.page-content { padding: calc(50px + 24px) 12px 48px 12px; }
.nq-page-title-bar ~ .container-fluid { margin-top: 44px; }
.footer { left: 220px; height: 46px; box-sizing: border-box; padding: 0 16px; background: var(--nq-bg-1); border-top: 1px solid var(--nq-border-1); color: var(--nq-text-3); font-size: var(--nq-font-xs); line-height: 44px; }
.main-content-no-sidebar ~ .footer { left: 0; }

/* ---- 其他 ---- */
.waves-effect { animation: none; }
.waves-effect .waves-ripple { display: none; }

/* ---- 用户中心 - 公告通知列表 ---- */
.nq-news-list { list-style: none; padding: 0; margin: 0; }
.nq-news-item { display: flex; align-items: center; gap: 8px; padding: 9px 0; border-bottom: 1px solid var(--nq-border-1); }
.nq-news-item:last-child { border-bottom: none; padding-bottom: 0; }
.nq-news-item:first-child { padding-top: 8px; }
.nq-news-icon { font-size: 15px; flex-shrink: 0; color: var(--nq-primary); }
.nq-news-title { flex: 1; font-size: var(--nq-font-md); color: var(--nq-text-1); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.nq-news-title:hover { color: var(--nq-primary); text-decoration: none; }
.nq-news-date { flex-shrink: 0; font-size: var(--nq-font-md); color: var(--nq-text-3); }

/* ---- 通用工具 ---- */
.nq-gap-sm { gap: 6px; }
.nq-gap-md { gap: 12px; }
.nq-link-sm { font-size: var(--nq-font-xs); }
.nq-btn-round { border-radius: 20px; white-space: nowrap; }
.nq-icon-blue { color: rgb(var(--arcoblue-6)); }
.nq-icon-green { color: rgb(var(--green-6)); }
.nq-icon-red { color: rgb(var(--red-6)); }
.nq-icon-orange { color: rgb(var(--orange-6)); }

/* ---- 用户中心 - 个人资料卡片 ---- */
.nq-username { font-size: 15px; color: var(--nq-text-1); }
.nq-certifi-tag { font-size: 11px; padding: 1px 6px; border-radius: 3px; background: var(--nq-fill-2); color: var(--nq-text-3); }
.nq-stat-num { font-size: var(--nq-font-xl); font-weight: 600; }
.nq-stat-desc { font-size: var(--nq-font-xs); color: var(--nq-text-3); }

/* ---- 用户中心 - 费用信息卡片 ---- */
.nq-finance-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin-bottom: 4px; }
.nq-finance-amount { font-size: 22px; font-weight: 600; color: var(--nq-text-1); }
.nq-finance-item-value { font-size: 15px; font-weight: 500; color: var(--nq-text-1); }

/* ---- 卡片标题竖线装饰 ---- */
.card-title { position: relative; padding-left: 8px; }
.card-title::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 3px; height: 16px; background: var(--nq-primary); }

/* ---- 用户中心 - 综合统计 ---- */
.nq-dash-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.nq-dash-stat { display: flex; flex-direction: column; background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); padding: 16px 20px; }
.nq-dash-stat-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.nq-dash-stat-label { font-size: var(--nq-font-sm); color: var(--nq-text-3); position: relative; padding-bottom: 8px; }
.nq-dash-stat-label::after { content: ''; position: absolute; left: 0; bottom: 0; width: 24px; height: 3px; border-radius: 2px; background: var(--nq-dash-label-color, var(--nq-primary)); }
.nq-dash-stat:nth-child(1) { --nq-dash-label-color: rgb(var(--arcoblue-6)); }
.nq-dash-stat:nth-child(2) { --nq-dash-label-color: rgb(var(--orange-6)); }
.nq-dash-stat:nth-child(3) { --nq-dash-label-color: rgb(var(--green-6)); }
.nq-dash-stat:nth-child(4) { --nq-dash-label-color: rgb(var(--red-5)); }
.nq-dash-stat-header i { font-size: 18px; color: var(--nq-text-4); }
.nq-dash-stat-body { margin-bottom: 8px; }
.nq-dash-stat-value { font-size: 28px; font-weight: 600; color: var(--nq-text-1); line-height: 1; }
.nq-dash-stat-unit { font-size: var(--nq-font-sm); color: var(--nq-text-3); margin-left: 4px; }
.nq-dash-stat-footer { display: flex; align-items: center; border-top: 1px solid var(--nq-border-1); padding-top: 12px; margin-top: auto; }
.nq-dash-stat-footer a { font-size: var(--nq-font-xs); color: var(--nq-text-3); text-decoration: none; }
.nq-dash-stat-footer a:hover { color: var(--nq-primary); }
.nq-dash-stat-footer a + a::before { content: ""; display: inline-block; width: 1px; height: 10px; background: var(--nq-border-2); margin: 0 10px; vertical-align: middle; }
@media (max-width: 991.98px) { .nq-dash-stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .nq-dash-stats { grid-template-columns: 1fr; } }
/* ---- 用户中心 - 已开通产品 ---- */
.nq-dash-products { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.nq-dash-product { padding: 10px 14px; border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); color: var(--nq-text-1); font-size: var(--nq-font-sm); text-decoration: none; transition: all .15s; }
.nq-dash-product i { font-size: 16px; color: var(--nq-primary); }
.nq-dash-product-count { flex-shrink: 0; color: var(--nq-text-3); transition: color .15s; }
.nq-dash-product:hover { border-color: var(--nq-primary); background: var(--nq-primary-light); text-decoration: none; }
.nq-dash-product:hover .nq-dash-product-count { color: var(--nq-primary); }
@media (max-width: 991.98px) { .nq-dash-products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .nq-dash-products { grid-template-columns: 1fr; } }
/* ---- 产品列表 - 统计卡片 ---- */
.nq-svc-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.nq-svc-stat { padding: 16px 20px; background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); }
.nq-svc-stat-label { font-size: var(--nq-font-sm); color: var(--nq-text-3); margin-bottom: 8px; }
.nq-svc-stat-label i { font-size: 13px; color: var(--nq-text-4); cursor: help; }
.nq-svc-stat-value { font-size: 24px; font-weight: 600; color: var(--nq-text-1); line-height: 1; }
@media (max-width: 991.98px) { .nq-svc-stats { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 575.98px) { .nq-svc-stats { grid-template-columns: repeat(2, 1fr); } }

/* ---- 用户中心 - 安全评估 ---- */
.nq-security-progress { display: flex; align-items: center; justify-content: center; gap: 20px; margin-bottom: 12px; }
.nq-security-ring { position: relative; width: 90px; height: 90px; border-radius: 50%; background: conic-gradient(var(--nq-success) 0deg, var(--nq-fill-2) 0deg); flex-shrink: 0; }
.nq-security-ring-inner { position: absolute; inset: 8px; border-radius: 50%; background: var(--nq-bg-1); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.nq-security-score { font-size: 20px; font-weight: 700; color: var(--nq-text-1); line-height: 1; }
.nq-security-label { font-size: 10px; color: var(--nq-text-3); margin-top: 2px; }
.nq-security-info { display: flex; flex-direction: column; gap: 6px; }
.nq-security-info-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); }
.nq-security-info-level { font-size: var(--nq-font-lg); font-weight: 600; }
.nq-security-ranges { font-size: 11px; color: var(--nq-text-4); text-align: center; margin-top: 4px; }

/* ---- 用户中心 - 费用信息 ---- */
.nq-finance-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.nq-finance-balance { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.nq-finance-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.nq-finance-item { padding: 10px 12px; background: var(--nq-fill-1); border-radius: 4px; text-decoration: none; color: inherit; transition: background .15s; }
a.nq-finance-item:hover { background: var(--nq-fill-2); }
a.nq-finance-item:hover .nq-finance-item-value { color: var(--nq-primary); }

/* ---- 用户中心 - 快捷导航 ---- */
.nq-shortcut-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.nq-shortcut { display: flex; align-items: center; gap: 8px; padding: 0 12px; height: 36px; border: 1px solid var(--nq-border-1); border-radius: 4px; color: var(--nq-text-2); font-size: var(--nq-font-sm); text-decoration: none; transition: background .15s, color .15s, border-color .15s; white-space: nowrap; overflow: hidden; }
.nq-shortcut::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--nq-text-4); flex-shrink: 0; }
.nq-shortcut:hover { background: var(--nq-fill-2); color: var(--nq-primary); text-decoration: none; }
.nq-shortcut:hover::before { background: var(--nq-primary); }
.nq-shortcut-section-title { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin-bottom: 2px; }
.nq-shortcut-add { color: var(--nq-text-4); border: 1px dashed var(--nq-border-2); }
.nq-shortcut-add::before { display: none; }
.nq-shortcut-add:hover { color: var(--nq-primary); border-color: var(--nq-primary); background: transparent; }
.nq-shortcut .nq-shortcut-del { display: none; margin-left: auto; font-size: 14px; color: var(--nq-text-4); cursor: pointer; flex-shrink: 0; }
.nq-shortcut:hover .nq-shortcut-del { display: flex; }
.nq-shortcut .nq-shortcut-del:hover { color: var(--nq-danger); }

/* 快捷入口选择面板 */
.nq-sc-picker-list { max-height: 320px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.nq-sc-picker-item { padding: 8px 10px 8px 2rem; border-radius: 4px; transition: background .15s; min-height: auto; }
.nq-sc-picker-item:hover { background: var(--nq-fill-2); }
.nq-sc-picker-item.active .custom-control-label { color: var(--nq-primary); }
@media (max-width: 991.98px) { .nq-shortcut-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 575.98px) { .nq-shortcut-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---- 头像 ---- */
.user-center_header { width: 56px; height: 56px; border-radius: 4px; background-color: var(--nq-primary); color: var(--nq-bg-1); font-size: 32px; object-fit: cover; }

.table-responsive { min-height: auto !important; }

.table-container,
.table-responsive,
.table-header { margin-bottom: 0; }

/* ---- 页头标题栏 ---- */
.nq-page-title-bar { position: fixed; top: 50px; left: 220px; right: 0; z-index: 99; height: 44px; display: flex; align-items: center; padding: 0 24px; background: var(--nq-bg-1); border-bottom: 1px solid var(--nq-border-1); }
.nq-page-title-text { font-size: 15px; font-weight: 600; color: var(--nq-text-1); margin: 0; line-height: 1; }
@media (max-width: 992px) { .nq-page-title-bar { left: 0; } }

/* ---- 个人中心 - 账号概览卡片 ---- */
.nq-profile-card { padding: 24px; }

.nq-profile-header { display: flex; align-items: center; gap: 14px; }
.nq-profile-avatar { width: 56px; height: 56px; border-radius: 8px; background: var(--nq-primary); color: var(--nq-bg-1); display: flex; align-items: center; justify-content: center; font-size: 24px; line-height: 1; flex-shrink: 0; object-fit: cover; }
.nq-profile-name-wrap { flex: 1; min-width: 0; }
.nq-profile-name { font-size: var(--nq-font-lg); font-weight: 600; color: var(--nq-text-1); margin-bottom: 6px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.nq-profile-tag { display: inline-flex; align-items: center; gap: 3px; font-size: 11px; padding: 2px 8px; border-radius: 3px; line-height: 1.5; }
.nq-profile-tag i { font-size: 12px; }
.nq-profile-tag-verified { background: rgba(var(--green-6), 0.1); color: rgb(var(--green-6)); }
.nq-profile-tag-unverified { background: var(--nq-fill-2); color: var(--nq-text-3); }

.nq-profile-card hr { border-color: var(--nq-border-1); margin: 16px 0; }

.nq-profile-info-list { display: flex; flex-direction: column; gap: 12px; }
.nq-profile-info-row { display: flex; align-items: center; gap: 10px; font-size: var(--nq-font-sm); }
.nq-profile-info-icon { flex-shrink: 0; width: 20px; text-align: center; color: var(--nq-text-3); font-size: 15px; }
.nq-profile-info-label { flex-shrink: 0; width: 64px; color: var(--nq-text-3); }
.nq-profile-info-value { flex: 1; color: var(--nq-text-1); display: flex; align-items: center; gap: 6px; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-profile-info-value .status { flex-shrink: 0; }
.nq-profile-info-empty { color: var(--nq-text-4); }

.nq-profile-actions { margin-top: 20px; display: flex; flex-direction: column; gap: 8px; }

/* ---- 安全中心 - 账户信息 ---- */
.nq-sec-avatar { width: 80px; height: 80px; font-size: 38px; line-height: 1; border-radius: 8px; flex-shrink: 0; margin-right: 20px; }
.nq-sec-account-grid { flex: 1; display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 20px; min-width: 0; }
.nq-sec-account-field { display: flex; align-items: center; min-width: 0; font-size: var(--nq-font-sm); line-height: 1.6; }
.nq-sec-account-label { flex-shrink: 0; color: var(--nq-text-3); }
.nq-sec-account-value { color: var(--nq-text-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
@media (max-width: 991.98px) { .nq-sec-account-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .nq-sec-account-grid { grid-template-columns: 1fr; } }

/* ---- 安全中心 - 安全项列表 ---- */
.nq-sec-list { display: flex; flex-direction: column; }
.nq-sec-item { display: flex; align-items: center; gap: 12px; padding: 16px; border: 1px solid var(--nq-border-1); margin-bottom: 10px; }
.nq-sec-item:last-child { margin-bottom: 0; }
.nq-sec-item-icon { flex-shrink: 0; width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--nq-primary); background: var(--nq-primary-light); }
.nq-sec-item-body { flex: 1; min-width: 0; }
.nq-sec-item-title { font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-text-1); margin-bottom: 2px; }
.nq-sec-item-desc { font-size: var(--nq-font-xs); color: var(--nq-text-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-sec-item-status { flex-shrink: 0; }
.nq-sec-item-action { flex-shrink: 0; }

.nq-sec-item-compact { gap: 10px; padding: 12px 16px; }
.nq-sec-item-compact .nq-sec-item-icon { width: 32px; height: 32px; font-size: 15px; border-radius: 6px; background: transparent; color: inherit; overflow: hidden; }
.nq-sec-item-compact .nq-sec-item-icon img { width: 100%; height: 100%; object-fit: contain; }

/* ---- 安全中心 - 提醒设置 ---- */
.nq-sec-remind { padding: 16px; border: 1px solid var(--nq-border-1); margin-bottom: 12px; }
.nq-sec-remind:last-child { margin-bottom: 0; }
.nq-sec-remind-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.nq-sec-remind-icon { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--nq-primary); background: var(--nq-primary-light); flex-shrink: 0; }
.nq-sec-remind-title { font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-text-1); margin-bottom: 2px; }
.nq-sec-remind-desc { font-size: var(--nq-font-xs); color: var(--nq-text-3); line-height: 1.5; }
.nq-sec-remind-action { text-align: center; }

/* ---- 消息中心 ---- */
.nq-msg-title { cursor: pointer; max-width: 400px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-msg-title:hover { color: var(--nq-primary); }
.nq-msg-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--nq-danger); margin-right: 4px; margin-bottom: 1px; }
.nq-msg-actions { display: flex; gap: 8px; margin-top: 12px; }

/* Tab 滚动容器 */
.nq-tab-scroll-wrap { display: flex; align-items: stretch; position: relative; margin-bottom: 12px; }
.nq-tab-scroll-inner { overflow: hidden; flex: 1; min-width: 0; }
.nq-tab-scroll-inner::-webkit-scrollbar { display: none; }
.nq-tab-scroll-inner .nav-tabs { border-bottom: none; }
.nq-tab-scroll-btn {
  flex-shrink: 0; width: 24px; border: none; background: transparent;
  color: var(--nq-text-3); cursor: pointer; font-size: 18px; padding: 0;
  display: flex; align-items: center; justify-content: center; transition: color .2s;
  outline: none;
}
.nq-tab-scroll-btn:hover { color: var(--nq-primary); }
.nq-tab-scroll-prev { margin-right: 2px; }
.nq-tab-scroll-next { margin-left: 2px; }

/* 表格排序箭头 */
.nq-sort-arrows {
  display: inline-flex; flex-direction: column; vertical-align: middle;
  margin-left: 4px; font-size: 10px; line-height: 1; cursor: pointer;
}
.nq-sort-arrows i { color: var(--nq-text-4); }
th.pointer { cursor: pointer; }

.badge-auto {
    color: var(--c);
    background: color-mix(in srgb, var(--c) 12%, transparent);
}

/* ---- 支付模态框 ---- */
#pay .modal-header { display: flex; align-items: center; gap: 12px; padding-right: 48px; }
#pay .modal-header .modal-title { flex: 0 1 auto; text-align: left; font-size: var(--nq-font-md); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#pay .modal-header .paySelect { flex: 0 0 auto; float: none; width: auto; min-width: 100px; height: 28px; margin: 0; padding: 0 28px 0 8px; font-size: var(--nq-font-xs); line-height: 26px; color: var(--nq-text-2); background-color: var(--nq-fill-1); border: 1px solid var(--nq-border-2); border-radius: var(--nq-radius); appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23868e9c' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 8px center; background-size: 10px; transition: border-color .15s; }
#pay .modal-header .paySelect:hover { border-color: var(--nq-border-3); }
#pay .modal-header .paySelect:focus { border-color: var(--nq-primary); outline: none; box-shadow: none; }
#pay .modal-header .close { position: absolute; right: 12px; }

.nq-pay-loading { display: flex; align-items: center; justify-content: center; min-height: 200px; }

/* ---- 充值页 - 支付方式网格 ---- */
.nq-gateway-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 20px; }
@media (max-width: 767.98px) { .nq-gateway-grid { grid-template-columns: repeat(2, 1fr); } }

/* 支付方式卡片 */
.nq-gateway-card { position: relative; display: flex; align-items: flex-start; padding: 16px; border: 1px solid var(--nq-border-2); border-radius: var(--nq-radius); cursor: pointer; transition: border-color .15s, background .15s; }
.nq-gateway-card:hover { border-color: var(--nq-primary); }
.nq-gateway-card.active { border-color: var(--nq-primary); background: var(--nq-primary-light); }
.nq-gateway-card-radio { position: absolute; top: 12px; right: 12px; width: 16px; height: 16px; border: 2px solid var(--nq-border-3); border-radius: 50%; box-sizing: border-box; transition: border-color .15s, background .15s; }
.nq-gateway-card.active .nq-gateway-card-radio { border-color: var(--nq-primary); background: var(--nq-primary); box-shadow: inset 0 0 0 2.5px var(--nq-bg-1); }
.nq-gateway-card-body { display: flex; align-items: center; gap: 12px; }
.nq-gateway-card-icon { width: 36px; height: 36px; object-fit: contain; flex-shrink: 0; }
.nq-gateway-card-icon-placeholder { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: 22px; color: var(--nq-primary); background: var(--nq-primary-light); border-radius: var(--nq-radius); flex-shrink: 0; }
.nq-gateway-card-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.nq-gateway-card-title { font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nq-gateway-card.active .nq-gateway-card-title { color: var(--nq-primary); }
.nq-gateway-card-desc { font-size: var(--nq-font-xs); color: var(--nq-text-3); }

/* 充值金额输入 + 快捷按钮 */
.nq-amount-input { position: relative; display: flex; align-items: center; width: 200px; }
.nq-amount-input i { position: absolute; left: 10px; font-size: 16px; color: var(--nq-text-3); z-index: 1; }
.nq-amount-input .form-control { padding-left: 32px; padding-right: 30px; }
.nq-amount-suffix { position: absolute; right: 10px; font-size: var(--nq-font-sm); color: var(--nq-text-3); }
.nq-amount-presets { display: flex; gap: 8px; flex-wrap: wrap; }
.nq-amount-btn { height: 32px; padding: 0 16px; font-size: var(--nq-font-sm); color: var(--nq-text-2); background: var(--nq-bg-1); border: 1px solid var(--nq-border-2); border-radius: var(--nq-radius); cursor: pointer; transition: border-color .15s, color .15s; white-space: nowrap; }
.nq-amount-btn:hover { border-color: var(--nq-primary); color: var(--nq-primary); }
.nq-amount-btn:active { background: var(--nq-primary-light); }

/* ---- 工单 - 步骤指示器 ---- */
.nq-sub-steps { display: flex; align-items: center; justify-content: center; gap: 0; padding: 16px 0 0; }
.nq-sub-step { display: flex; align-items: center; gap: 8px; }
.nq-sub-step-num { width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: var(--nq-font-xs); font-weight: 600; background: var(--nq-fill-2); color: var(--nq-text-3); flex-shrink: 0; }
.nq-sub-step.active .nq-sub-step-num { background: var(--nq-primary); color: var(--nq-bg-1); }
.nq-sub-step-label { font-size: var(--nq-font-sm); color: var(--nq-text-3); white-space: nowrap; }
.nq-sub-step.active .nq-sub-step-label { color: var(--nq-text-1); font-weight: 500; }
.nq-sub-step-arrow { margin: 0 16px; color: var(--nq-text-4); font-size: 14px; flex-shrink: 0; }

/* ---- 工单 - 部门选择卡片 ---- */
.nq-sub-dept-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 991.98px) { .nq-sub-dept-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767.98px) { .nq-sub-dept-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .nq-sub-dept-grid { grid-template-columns: 1fr; } }
.nq-sub-dept-card { display: flex; align-items: flex-start; gap: 12px; padding: 16px; border: 1px solid var(--nq-border-2); border-radius: var(--nq-radius); cursor: pointer; text-decoration: none; transition: border-color .15s, box-shadow .15s; }
.nq-sub-dept-card:hover { border-color: var(--nq-primary); box-shadow: 0 2px 8px rgba(0,0,0,0.04); text-decoration: none; }
.nq-sub-dept-card-icon { flex-shrink: 0; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: 18px; color: var(--nq-primary); background: var(--nq-primary-light); border-radius: var(--nq-radius); }
.nq-sub-dept-card-body { flex: 1; min-width: 0; }
.nq-sub-dept-card-title { font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-text-1); margin-bottom: 4px; }
.nq-sub-dept-card-desc { font-size: var(--nq-font-xs); color: var(--nq-text-3); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }

/* ---- 工单 - 附件上传 ---- */
.nq-sub-file-item { position: relative; display: flex; align-items: center; padding: 10px 14px; border: 1px dashed var(--nq-border-2); border-radius: var(--nq-radius); margin-bottom: 8px; transition: border-color .15s, background .15s; cursor: pointer; }
.nq-sub-file-item:hover { border-color: var(--nq-primary); background: var(--nq-fill-1); }
.nq-sub-file-item.has-file { border-style: solid; border-color: var(--nq-border-2); background: var(--nq-fill-1); }
.nq-sub-file-info { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; pointer-events: none; }
.nq-sub-file-icon { font-size: 16px; color: var(--nq-text-3); flex-shrink: 0; }
.nq-sub-file-item.has-file .nq-sub-file-icon { color: var(--nq-primary); }
.nq-sub-file-name { font-size: var(--nq-font-sm); color: var(--nq-text-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-sub-file-item.has-file .nq-sub-file-name { color: var(--nq-text-1); }
.nq-sub-file-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 1; }
.nq-sub-file-del { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); z-index: 2; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--nq-text-3); border-radius: 50%; transition: background .15s, color .15s; cursor: pointer; }
.nq-sub-file-del:hover { background: rgba(var(--red-6), 0.1); color: rgb(var(--red-6)); }

/* ---- 工单 - 聊天窗口 ---- */
.nq-sub-chat-window { display: flex; flex-direction: column; border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); overflow: hidden; }

.nq-sub-chat-messages { height: 500px; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 20px; background: var(--nq-fill-1); }
.nq-sub-chat-messages::-webkit-scrollbar { width: 6px; }
.nq-sub-chat-messages::-webkit-scrollbar-thumb { background: var(--nq-border-3); border-radius: 3px; }
.nq-sub-chat-messages::-webkit-scrollbar-track { background: transparent; }

.nq-sub-chat-msg { display: flex; gap: 10px; max-width: 75%; }
.nq-sub-chat-msg.is-self { flex-direction: row-reverse; margin-left: auto; }

.nq-sub-chat-avatar { flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 600; color: var(--nq-bg-1); }
.nq-sub-chat-avatar.admin { background: var(--nq-primary); }
.nq-sub-chat-avatar.user { background: rgb(var(--green-6)); }

.nq-sub-chat-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.nq-sub-chat-msg.is-self .nq-sub-chat-body { align-items: flex-end; }

.nq-sub-chat-meta { display: flex; align-items: center; gap: 8px; font-size: var(--nq-font-xs); color: var(--nq-text-3); }
.nq-sub-chat-meta-name { font-weight: 500; color: var(--nq-text-2); }

.nq-sub-chat-bubble { position: relative; padding: 10px 14px; border-radius: 12px; font-size: var(--nq-font-sm); line-height: 1.8; color: var(--nq-text-1); word-break: break-word; box-shadow: 0 1px 2px rgba(0,0,0,0.04); }
.nq-sub-chat-bubble.admin { background: var(--nq-bg-1); border-top-left-radius: 4px; }
.nq-sub-chat-bubble.user { background: var(--nq-bg-1); border-top-right-radius: 4px; }

.nq-sub-chat-attach { margin-top: 8px; padding-top: 8px; border-top: 1px solid rgba(0,0,0,0.06); display: flex; flex-direction: column; gap: 4px; }
.nq-sub-chat-attach-link { font-size: var(--nq-font-xs); color: var(--nq-primary); display: inline-flex; align-items: center; gap: 4px; }
.nq-sub-chat-attach-link:hover { text-decoration: underline; }

.nq-sub-chat-rating { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--nq-border-1); }
.nq-sub-chat-rating-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); display: flex; align-items: center; }
.nq-sub-chat-rating-stars { display: flex; gap: 2px; }
.nq-sub-chat-star { font-size: 18px; color: var(--nq-border-3); cursor: pointer; transition: color .15s, transform .15s; }
.nq-sub-chat-star.active { color: rgb(var(--orange-5)); }
.nq-sub-chat-star.hover { color: rgb(var(--orange-5)); transform: scale(1.15); }
.nq-sub-chat-rating[data-rated] .nq-sub-chat-star { cursor: default; }
.nq-sub-chat-rating[data-rated] .nq-sub-chat-star.hover { transform: none; }

.nq-sub-chat-input { padding: 16px 20px; background: var(--nq-bg-1); border-top: 1px solid var(--nq-border-1); }

.nq-sub-chat-toolbar { display: flex; align-items: center; gap: 4px; }
.nq-sub-chat-tool-btn { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; font-size: 18px; color: var(--nq-text-3); border-radius: var(--nq-radius); cursor: pointer; transition: color .15s, background .15s; }
.nq-sub-chat-tool-btn:hover { color: var(--nq-primary); background: var(--nq-primary-light); }
.nq-sub-chat-file-preview { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.nq-sub-chat-file-preview:empty { display: none; }
.nq-sub-chat-file-item { position: relative; display: flex; align-items: center; gap: 8px; padding: 6px 28px 6px 6px; background: var(--nq-fill-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); }
.nq-sub-chat-file-item img { width: 32px; height: 32px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.nq-sub-chat-file-item-name { font-size: var(--nq-font-xs); color: var(--nq-text-2); max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body.nq a.nq-sub-chat-file-item-del { position: absolute; top: -6px; right: -6px; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: 12px; background: var(--nq-bg-1); border: 1px solid var(--nq-border-2); border-radius: 50%; color: var(--nq-text-3); cursor: pointer; transition: color .15s, border-color .15s; }
body.nq a.nq-sub-chat-file-item-del:hover { color: rgb(var(--red-6)); border-color: rgb(var(--red-6)); text-decoration: none; }

/* ---- 工单 - 右侧信息面板 ---- */
.nq-sub-ticket-info { display: flex; flex-direction: column; gap: 12px; }
.nq-sub-ticket-info-row { display: flex; align-items: baseline; justify-content: space-between; font-size: var(--nq-font-sm); }
.nq-sub-ticket-info-label { color: var(--nq-text-3); flex-shrink: 0; }
.nq-sub-ticket-info-value { color: var(--nq-text-1); text-align: right; word-break: break-all; }

/* ---- 知识库 - 搜索框图标 ---- */
.nq-kb-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); font-size: 16px; color: var(--nq-text-3); pointer-events: none; z-index: 1; }

/* ---- 知识库 - 文章列表 ---- */
.nq-kb-list { display: flex; flex-direction: column; gap: 10px; }

a.nq-kb-item { display: flex; align-items: flex-start; gap: 16px; padding: 14px 16px; border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); text-decoration: none; transition: border-color .15s, box-shadow .15s; }
a.nq-kb-item:hover { border-color: var(--nq-primary); box-shadow: 0 2px 8px rgba(0,0,0,0.04); text-decoration: none; }

.nq-kb-item-main { flex: 1; min-width: 0; }
.nq-kb-item-title { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); margin-bottom: 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transition: color .15s; }
a.nq-kb-item:hover .nq-kb-item-title { color: var(--nq-primary); }

.nq-kb-item-meta { display: flex; align-items: center; gap: 16px; font-size: var(--nq-font-xs); color: var(--nq-text-3); }
.nq-kb-item-meta span { display: inline-flex; align-items: center; gap: 4px; }
.nq-kb-item-meta i { font-size: 13px; }



/* ---- 知识库 - 分类列表 ---- */
.nq-kb-cate-list { display: flex; flex-direction: column; gap: 2px; }

.nq-kb-cate-item { display: flex; align-items: center; gap: 4px; padding: 7px 0; font-size: var(--nq-font-sm); color: var(--nq-text-2); text-decoration: none; transition: color .15s; }
.nq-kb-cate-item:hover { color: var(--nq-primary); text-decoration: none; }
.nq-kb-cate-item > i { font-size: 14px; color: var(--nq-text-4); flex-shrink: 0; transition: color .15s; }
.nq-kb-cate-item:hover > i { color: var(--nq-primary); }
.nq-kb-cate-item > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-kb-cate-count { flex-shrink: 0; margin-left: auto; font-size: 11px; color: var(--nq-bg-1); background: var(--nq-primary); min-width: 20px; height: 18px; line-height: 18px; text-align: center; padding: 0 6px; border-radius: 9px; }

/* ---- 知识库 - 详情页 ---- */
.nq-kb-content { font-size: var(--nq-font-md); color: var(--nq-text-2); line-height: 1.8; word-break: break-word; }
.nq-kb-content img { max-width: 100%; height: auto; border-radius: var(--nq-radius); }
.nq-kb-content p { display: block; white-space: normal; margin-bottom: 12px; }
.nq-kb-content pre { white-space: pre-wrap; word-wrap: break-word; background: var(--nq-fill-1); padding: 16px; border-radius: var(--nq-radius); font-size: var(--nq-font-sm); line-height: 1.6; border: 1px solid var(--nq-border-1); }
.nq-kb-content a { color: var(--nq-primary); }
.nq-kb-content a:hover { text-decoration: underline; }

/* ---- 实名认证 - 首页（未认证） ---- */
.nq-vf-home-header { text-align: center; padding: 40px 0 24px; }
.nq-vf-home-title { font-size: 22px; font-weight: 700; color: var(--nq-text-1); margin: 0 0 8px; }
.nq-vf-home-subtitle { font-size: var(--nq-font-md); color: var(--nq-text-3); margin: 0 0 16px; }
.nq-vf-home-tips { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; }
.nq-vf-home-tip { display: inline-flex; align-items: center; gap: 4px; font-size: var(--nq-font-sm); color: var(--nq-text-2); }
.nq-vf-home-tip i { font-size: 15px; color: var(--nq-primary); }

.nq-vf-home-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 24px; }
@media (max-width: 767.98px) { .nq-vf-home-grid { grid-template-columns: 1fr; } }

.nq-vf-home-option { position: relative; background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); padding: 48px 28px; min-height: 380px; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; transition: border-color .2s, box-shadow .2s; }
.nq-vf-home-option:hover { border-color: var(--nq-primary); box-shadow: 0 2px 12px rgba(0,0,0,0.04); }

.nq-vf-home-option-icon { width: 56px; height: 56px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 26px; margin: 0 auto 16px; background: var(--nq-primary-light); color: var(--nq-primary); transition: transform .2s; }
.nq-vf-home-option:hover .nq-vf-home-option-icon { transform: scale(1.08); }
.nq-vf-home-option-icon.enterprise { background: rgba(var(--arcoblue-6), 0.08); color: rgb(var(--arcoblue-7)); }

.nq-vf-home-option-title { font-size: var(--nq-font-lg); font-weight: 600; color: var(--nq-text-1); margin: 0 0 8px; transition: margin .3s; }
.nq-vf-home-option:hover .nq-vf-home-option-title { margin: 0 0 20px; }
 
/* 默认内容：描述+标签+提示 */
.nq-vf-home-option-default { transition: none; }
.nq-vf-home-option:hover .nq-vf-home-option-default { display: none; }

.nq-vf-home-option-desc { font-size: var(--nq-font-sm); color: var(--nq-text-3); margin: 0 0 16px; line-height: 1.6; }

.nq-vf-home-option-tags { display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.nq-vf-home-tag { display: inline-flex; align-items: center; gap: 3px; font-size: var(--nq-font-xs); color: var(--nq-text-2); padding: 3px 10px; border: 1px solid var(--nq-border-2); border-radius: 20px; white-space: nowrap; }
.nq-vf-home-tag i { font-size: var(--nq-font-sm); color: var(--nq-primary); }

.nq-vf-home-option-tip { font-size: var(--nq-font-xs); color: var(--nq-text-4); margin: 0; }

/* 悬停内容：按钮 */
.nq-vf-home-option-hover { display: none; }
.nq-vf-home-option:hover .nq-vf-home-option-hover { display: block; animation: nq-vf-fade-in .25s ease; }
@keyframes nq-vf-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

.nq-vf-home-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 24px; font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-bg-1); background: var(--nq-primary); border: none; border-radius: var(--nq-radius); cursor: pointer; transition: background .15s; }
.nq-vf-home-btn:hover { background: var(--nq-primary-hover); color: var(--nq-bg-1); }
.nq-vf-home-btn i { font-size: 15px; transition: transform .15s; }
.nq-vf-home-btn:hover i { transform: translateX(3px); }


/* ---- 实名认证 - 状态页（审核中/已认证/未通过） ---- */
.nq-vf-status-header { text-align: center; padding: 40px 16px 24px; }
.nq-vf-status-icon { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 30px; margin: 0 auto 16px; }
.nq-vf-status-icon.pending { background: rgba(var(--arcoblue-6), 0.1); color: var(--nq-primary); }
.nq-vf-status-icon.success { background: rgba(var(--green-6), 0.1); color: var(--nq-success); }
.nq-vf-status-icon.fail { background: rgba(var(--red-6), 0.1); color: var(--nq-danger); }
.nq-vf-status-title { font-size: 20px; font-weight: 700; color: var(--nq-text-1); margin: 0 0 6px; }
.nq-vf-status-subtitle { font-size: var(--nq-font-md); color: var(--nq-text-3); margin: 0; }

/* 进度条 */
.nq-vf-progress { display: flex; align-items: center; justify-content: center; gap: 0; padding: 0 0 28px; }
.nq-vf-progress-item { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.nq-vf-progress-dot { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; background: var(--nq-fill-2); color: var(--nq-text-4); transition: all .2s; }
.nq-vf-progress-item.completed .nq-vf-progress-dot { background: var(--nq-primary); color: var(--nq-bg-1); }
.nq-vf-progress-item.active .nq-vf-progress-dot { background: rgba(var(--arcoblue-6), 0.15); color: var(--nq-primary); box-shadow: 0 0 0 4px rgba(var(--arcoblue-6), 0.08); }
.nq-vf-progress-item.fail .nq-vf-progress-dot { background: rgba(var(--red-6), 0.15); color: var(--nq-danger); }
.nq-vf-progress-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); white-space: nowrap; }
.nq-vf-progress-item.completed .nq-vf-progress-label,
.nq-vf-progress-item.active .nq-vf-progress-label { color: var(--nq-text-1); font-weight: 500; }
.nq-vf-progress-line { width: 80px; height: 2px; background: var(--nq-fill-3); margin: 0 12px; margin-bottom: 28px; }
.nq-vf-progress-line.completed { background: var(--nq-primary); }

/* 信息卡片 */
.nq-vf-info-card { background: var(--nq-fill-1); border-radius: var(--nq-radius); padding: 20px 24px; margin: 0 auto 20px; max-width: 520px; }
.nq-vf-info-title { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); margin: 0 0 16px; display: flex; align-items: center; gap: 6px; }
.nq-vf-info-title i { font-size: 16px; color: var(--nq-primary); }
.nq-vf-info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 24px; }
@media (max-width: 575.98px) { .nq-vf-info-grid { grid-template-columns: 1fr; } }
.nq-vf-info-item { display: flex; align-items: center; gap: 8px; font-size: var(--nq-font-sm); }
.nq-vf-info-label { flex-shrink: 0; color: var(--nq-text-3); min-width: 64px; }
.nq-vf-info-value { color: var(--nq-text-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---- 实名认证 - 失败原因卡片 ---- */
.nq-vf-fail-card { max-width: 520px; margin: 0 auto 24px; background: rgba(var(--red-6), 0.06); border: 1px solid rgba(var(--red-6), 0.15); border-radius: var(--nq-radius); padding: 16px 20px; }
.nq-vf-fail-header { display: flex; align-items: center; gap: 6px; font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-danger); margin-bottom: 8px; }
.nq-vf-fail-header i { font-size: 18px; }
.nq-vf-fail-content { font-size: var(--nq-font-sm); color: var(--nq-text-2); line-height: 1.6; }

/* ---- 实名认证 - 操作按钮组 ---- */
.nq-vf-actions { display: flex; align-items: center; justify-content: center; gap: 12px; padding-bottom: 8px; }

/* ---- 实名认证 - 提交按钮加载动画 ---- */
.nq-vf-loading { display: inline-block; animation: nq-loading-circle 1s linear infinite; }

/* ---- 实名认证 - 通用 ---- */
.nq-verified-id-guide { width: 100%; height: 150px; background-color: var(--nq-fill-2); display: flex; justify-content: space-around; align-items: center; }
.nq-verified-id-guide-text { width: 175px; height: 85px; line-height: 24px; font-size: var(--nq-font-sm); color: var(--nq-text-2); }
.nq-verified-download-tpl { cursor: pointer; color: var(--nq-primary); font-size: var(--nq-font-xs); padding-top: 5px; }
.nq-verified-download-tpl:hover { text-decoration: underline; }
.custom-file-label::after { content: '浏览' !important; }

/* ---- API 管理 - 未开启 ---- */
#protocolModal p { font-size: var(--nq-font-md); line-height: 25px; }
.nq-api-protocol-dialog { max-width: 55% !important; }
.nq-api-empty { text-align: center; padding: 60px 24px 40px; }
.nq-api-empty-icon { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; margin: 0 auto 20px; background: var(--nq-primary-light); color: var(--nq-primary); }
.nq-api-empty-title { font-size: 20px; font-weight: 700; color: var(--nq-text-1); margin: 0 0 8px; }
.nq-api-empty-desc { font-size: var(--nq-font-md); color: var(--nq-text-3); margin: 0 0 28px; }
.nq-api-empty-actions { margin-bottom: 12px; }
.nq-api-empty-agree { margin-bottom: 16px; font-size: var(--nq-font-sm); color: var(--nq-text-2); display: flex; justify-content: center; }
.nq-api-empty-agree .form-check { display: inline-flex; align-items: center; padding-left: 0; gap: 6px; }
.nq-api-empty-agree a { color: var(--nq-primary); }
.nq-api-empty-agree a:hover { text-decoration: underline; }
.nq-api-empty-check { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; font-weight: 400; }
.nq-api-empty-check input { margin: 0; }
.nq-api-empty-requirements { display: flex; flex-direction: column; gap: 10px; max-width: 400px; margin: 0 auto 28px; }
.nq-api-empty-req-item { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--nq-fill-1); border-radius: var(--nq-radius); font-size: var(--nq-font-sm); color: var(--nq-text-2); }
.nq-api-empty-req-item i { font-size: 18px; color: var(--nq-primary); flex-shrink: 0; }
.nq-api-empty-req-item span { flex: 1; text-align: left; }
.nq-api-empty-req-item .btn { flex-shrink: 0; }
.nq-api-empty-features { display: flex; align-items: center; justify-content: center; gap: 32px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--nq-border-1); }
.nq-api-empty-feature { display: flex; align-items: center; gap: 6px; font-size: var(--nq-font-sm); color: var(--nq-text-3); }
.nq-api-empty-feature i { font-size: 16px; color: var(--nq-primary); }

/* ---- API 管理 - 已开启 ---- */
.nq-api-key-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.nq-api-key-info { display: flex; align-items: center; gap: 8px; font-size: var(--nq-font-sm); flex-wrap: wrap; }
.nq-api-key-code { font-size: var(--nq-font-sm); padding: 4px 10px; background: var(--nq-fill-1); border-radius: var(--nq-radius); color: var(--nq-text-1); word-break: break-all; }
.nq-api-key-actions { display: flex; gap: 8px; }
.nq-api-stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 767.98px) { .nq-api-stat-grid { grid-template-columns: 1fr; } }
.nq-api-stat-icon { width: 44px; height: 44px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.nq-api-stat-icon.nq-icon-blue { background: rgba(var(--arcoblue-6), 0.1); }
.nq-api-stat-icon.nq-icon-green { background: rgba(var(--green-6), 0.1); }
.nq-api-stat-icon.nq-icon-orange { background: rgba(var(--orange-6), 0.1); }
.nq-api-stat-value { font-size: 22px; font-weight: 600; color: var(--nq-text-1); line-height: 1.3; }
.nq-api-stat-ratio { font-size: var(--nq-font-xs); font-weight: 400; color: var(--nq-text-3); margin-left: 8px; }

/* ---- 合同管理 ---- */
.nq-ct-sign-dialog { max-width: 900px; margin: 1.75rem auto; }
.nq-ct-party-table { padding: 0 70px; }
.nq-ct-enclosure { padding: 0 40px; }
.nq-ct-cost { border-top: 1px solid var(--nq-border-1); border-left: 1px solid var(--nq-border-1); border-right: 1px solid var(--nq-border-1); width: 100%; height: 40px; line-height: 40px; }
#signature { width: 100%; display: flex; justify-content: center; }
.signatureCanvas { border: 1px dashed var(--nq-text-1) !important; }
.nq-ct-hidden { display: none; }
.nq-ct-modal-tip { font-size: var(--nq-font-sm); color: var(--nq-text-3); margin-bottom: 16px; line-height: 1.6; }
.nq-ct-info-list { display: flex; flex-direction: column; gap: 14px; }
.nq-ct-info-row { display: flex; align-items: center; gap: 10px; font-size: var(--nq-font-sm); }
.nq-ct-info-label { flex-shrink: 0; width: 72px; color: var(--nq-text-3); text-align: right; }
.nq-ct-info-label .nq-ct-required { color: var(--nq-danger); display: none; margin-right: 2px; }
.nq-ct-info-value { flex: 1; color: var(--nq-text-1); min-width: 0; }
.nq-ct-info-value .form-control { font-size: var(--nq-font-sm); }
.nq-ct-info-value a { color: var(--nq-primary); font-size: var(--nq-font-xs); }
.nq-ct-info-value a:hover { text-decoration: underline; }
.nq-ct-default-tag { background: rgba(var(--arcoblue-6), 0.2); color: var(--nq-bg-1); border-radius: 5px; }
#signContractContent { padding: 20px 40px; }
.nq-ct-mail-info { margin: 10px 0; }
.nq-ct-search-wrap { position: relative; }
.nq-ct-search-wrap .form-control { padding-left: 32px; }
.nq-ct-search-wrap i { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); font-size: 16px; color: var(--nq-text-3); cursor: pointer; }
.nq-ct-tip-color { color: var(--nq-danger); }
@media screen and (max-width: 768px) {
  .nq-ct-party-table { padding: 0; display: block; }
  #afcContent .control-label { text-align: left; }
}

/* ---- 账单详情 ---- */
.nq-vb-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding-bottom: 20px; border-bottom: 1px solid var(--nq-border-1); margin-bottom: 20px; }
.nq-vb-logo { height: 44px; width: auto; }
.nq-vb-status { text-align: right; }
.nq-vb-status-text { font-size: var(--nq-font-xl); font-weight: 600; }
.nq-vb-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
@media (max-width: 575.98px) { .nq-vb-info-grid { grid-template-columns: 1fr; } }
.nq-vb-info-title { font-size: var(--nq-font-sm); font-weight: 600; color: var(--nq-text-1); margin-bottom: 6px; }
.nq-vb-info-text { font-size: var(--nq-font-sm); color: var(--nq-text-2); line-height: 1.8; }
.nq-vb-meta { font-size: var(--nq-font-sm); color: var(--nq-text-2); margin-bottom: 20px; }
.nq-vb-meta strong { color: var(--nq-text-1); }
.nq-vb-table { width: 100%; border-collapse: collapse; font-size: var(--nq-font-sm); }
.nq-vb-table th { background: var(--nq-fill-1); color: var(--nq-text-3); font-weight: 500; padding: 10px 12px; border-bottom: 1px solid var(--nq-border-1); }
.nq-vb-table td { padding: 10px 12px; border-bottom: 1px solid var(--nq-border-1); color: var(--nq-text-1); }
.nq-vb-table tfoot td { font-weight: 600; background: var(--nq-fill-1); }
.nq-vb-section-title { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); margin: 24px 0 12px; }
.nq-vb-actions { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--nq-border-1); }
@media print {
  .nq-vb-actions { display: none !important; }
}

/* ---- 合并账单 ---- */
.nq-cb-summary { display: flex; align-items: center; gap: 24px; padding: 16px 20px; background: var(--nq-fill-1); border-radius: var(--nq-radius); margin-bottom: 16px; }
.nq-cb-summary-item { display: flex; align-items: center; gap: 6px; font-size: var(--nq-font-sm); }
.nq-cb-summary-label { color: var(--nq-text-3); }
.nq-cb-summary-value { color: var(--nq-text-1); font-weight: 500; }
.nq-cb-summary-total { font-size: var(--nq-font-xl); font-weight: 600; color: var(--nq-primary); }
.nq-cb-list { display: flex; flex-direction: column; gap: 12px; }
.nq-cb-card { border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); overflow: hidden; }
.nq-cb-card-header { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: var(--nq-fill-1); }
.nq-cb-card-icon { width: 32px; height: 32px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 16px; color: var(--nq-primary); background: var(--nq-primary-light); flex-shrink: 0; }
.nq-cb-card-title { flex: 1; font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); }
.nq-cb-card-amount { font-size: 15px; font-weight: 600; color: var(--nq-primary); flex-shrink: 0; }
.nq-cb-card-body { padding: 4px 16px; }
.nq-cb-item { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--nq-border-1); font-size: var(--nq-font-sm); }
.nq-cb-item:last-child { border-bottom: none; }
.nq-cb-item-desc { flex: 1; color: var(--nq-text-3); min-width: 0; font-size: var(--nq-font-xs); line-height: 1.6; word-break: break-all; }
.nq-cb-item-amount { flex-shrink: 0; color: var(--nq-text-2); font-size: var(--nq-font-xs); }
.nq-cb-footer { display: flex; align-items: center; gap: 8px; margin-top: 20px; }

/* ---- 信用额度 - 未开通 ---- */
.nq-cr-empty { text-align: center; padding: 60px 24px 40px; }
.nq-cr-empty-icon { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; margin: 0 auto 20px; background: var(--nq-primary-light); color: var(--nq-primary); }
.nq-cr-empty-title { font-size: 20px; font-weight: 700; color: var(--nq-text-1); margin: 0 0 8px; }
.nq-cr-empty-desc { font-size: var(--nq-font-md); color: var(--nq-text-3); margin: 0 0 28px; line-height: 1.6; }
.nq-cr-empty-features { display: flex; align-items: center; justify-content: center; gap: 32px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--nq-border-1); flex-wrap: wrap; }
.nq-cr-empty-feature { display: flex; align-items: center; gap: 6px; font-size: var(--nq-font-sm); color: var(--nq-text-3); }
.nq-cr-empty-feature i { font-size: 16px; color: var(--nq-primary); }

/* ---- 信用额度 - 已开通 ---- */
.nq-cr-dashboard { display: flex; gap: 12px; margin-bottom: 20px; }
@media (max-width: 767.98px) { .nq-cr-dashboard { flex-direction: column; } }
.nq-cr-gauge { flex: 0 0 auto; display: flex; align-items: center; gap: 20px; padding: 20px 24px; border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); }
.nq-cr-gauge-chart { width: 100px; height: 100px; flex-shrink: 0; }
.nq-cr-gauge-info { display: flex; flex-direction: column; gap: 10px; }
.nq-cr-gauge-row { display: flex; align-items: center; gap: 8px; font-size: var(--nq-font-sm); }
.nq-cr-gauge-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.nq-cr-gauge-label { color: var(--nq-text-3); min-width: 48px; }
.nq-cr-gauge-val { color: var(--nq-text-1); font-weight: 500; }
.nq-cr-cards { flex: 1; display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.nq-cr-card { flex: 1; display: flex; align-items: center; gap: 14px; padding: 16px 20px; border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); }
.nq-cr-card-icon { width: 40px; height: 40px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.nq-cr-card-body { flex: 1; min-width: 0; }
.nq-cr-card-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin-bottom: 2px; }
.nq-cr-card-value { font-size: var(--nq-font-xl); font-weight: 600; color: var(--nq-text-1); line-height: 1.3; }
.nq-cr-card-extra { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin-top: 2px; }
.nq-cr-card-extra .badge { vertical-align: middle; }
.nq-cr-card-action { flex-shrink: 0; }

/* ---- 推广中心 - 顶部统计栏 ---- */
.nq-aff-top { background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); padding: 20px 24px; margin-bottom: 12px; }
.nq-aff-top-main { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--nq-border-1); }
.nq-aff-top-balance-label { font-size: var(--nq-font-sm); color: var(--nq-text-3); margin-bottom: 4px; }
.nq-aff-top-balance-val { font-size: 28px; font-weight: 700; color: var(--nq-text-1); line-height: 1.2; }
.nq-aff-top-balance-val small { font-size: var(--nq-font-md); font-weight: 400; color: var(--nq-text-3); margin-left: 4px; }
.nq-aff-top-stats { display: flex; gap: 0; }
.nq-aff-top-stat { flex: 1; text-align: center; position: relative; }
.nq-aff-top-stat:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 28px; background: var(--nq-border-1); }
.nq-aff-top-stat-val { font-size: var(--nq-font-xl); font-weight: 600; color: var(--nq-text-1); line-height: 1.3; }
.nq-aff-top-stat-val small { font-size: var(--nq-font-xs); font-weight: 400; color: var(--nq-text-3); margin-left: 2px; }
.nq-aff-top-stat-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin-top: 2px; }
@media (max-width: 767.98px) { .nq-aff-top-stats { flex-wrap: wrap; gap: 12px; } .nq-aff-top-stat { flex: 0 0 calc(50% - 6px); } .nq-aff-top-stat::after { display: none; } }

/* ---- 推广中心 - 推广链接 + 规则 ---- */
.nq-aff-link-row { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.nq-aff-link-box { flex: 1; min-width: 280px; }
.nq-aff-link-label { font-size: var(--nq-font-sm); color: var(--nq-text-3); display: block; margin-bottom: 6px; }
.nq-aff-link-input { display: flex; gap: 8px; }
.nq-aff-link-input .form-control { flex: 1; }
.nq-aff-rules { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }
.nq-aff-rule-tag { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--nq-fill-1); border-radius: var(--nq-radius); font-size: var(--nq-font-xs); color: var(--nq-text-3); white-space: nowrap; }
.nq-aff-rule-tag strong { color: var(--nq-primary); font-weight: 600; }

/* ---- 推广中心 - 未开通页 ---- */
.nq-aff-empty { text-align: center; padding: 40px 0 20px; }
.nq-aff-empty-icon { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; margin: 0 auto 20px; background: var(--nq-primary-light); color: var(--nq-primary); }
.nq-aff-empty-title { font-size: 20px; font-weight: 700; color: var(--nq-text-1); margin-bottom: 8px; }
.nq-aff-empty-desc { font-size: var(--nq-font-md); color: var(--nq-text-3); margin-bottom: 32px; line-height: 1.6; }
.nq-aff-empty-steps { display: flex; gap: 24px; justify-content: center; margin-bottom: 32px; flex-wrap: wrap; }
.nq-aff-empty-step { flex: 0 0 200px; text-align: center; }
.nq-aff-empty-step-img { height: 48px; margin-bottom: 12px; }
.nq-aff-empty-step h4 { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); margin-bottom: 4px; }
.nq-aff-empty-step p { font-size: var(--nq-font-xs); color: var(--nq-text-3); margin: 0; line-height: 1.5; }

/* ---- 产品列表 - 操作列组合按钮 ---- */
.nq-split-btn { position: relative; display: inline-flex; }
.nq-split-btn .nq-split-main { border-radius: var(--nq-radius) 0 0 var(--nq-radius); position: relative; }
.nq-split-btn .nq-split-main::after { content: ''; position: absolute; right: -1px; top: 50%; transform: translateY(-50%); height: 50%; width: 1px; background: rgba(255,255,255,.5); z-index: 1; }
.nq-split-btn .btn.nq-split-arrow { border-radius: 0 var(--nq-radius) var(--nq-radius) 0; padding: 4px 5px; font-size: var(--nq-font-md); min-width: 0; }
.nq-split-menu { display: none; position: fixed; z-index: 1050; min-width: 70px; padding: 4px 0; background: var(--nq-bg-1); border: 1px solid var(--nq-fill-3); border-radius: var(--nq-radius); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.nq-split-menu.show { display: block; }
.nq-split-menu a { display: block; padding: 0 12px; height: 32px; line-height: 32px; font-size: var(--nq-font-sm); color: var(--nq-text-1); white-space: nowrap; transition: background .1s; }
.nq-split-menu a:hover { background: var(--nq-fill-2); color: var(--nq-text-1); text-decoration: none; }
.nq-split-menu a.disabled { color: var(--nq-text-4); cursor: not-allowed; pointer-events: none; }

/* ---- 产品列表 - 自定义多选下拉 ---- */
.nq-multisel { position: relative; display: inline-block; }
.nq-multisel-trigger { display: inline-flex; align-items: center; gap: 6px; height: 32px; padding: 0 12px; border: 1px solid var(--nq-border-2); border-radius: var(--nq-radius); background: var(--nq-bg-1); color: var(--nq-text-2); font-size: var(--nq-font-sm); cursor: pointer; user-select: none; white-space: nowrap; transition: border-color .15s; }
.nq-multisel-trigger:hover { border-color: var(--nq-border-3); }
.nq-multisel.open .nq-multisel-trigger { border-color: rgb(var(--arcoblue-6)); color: var(--nq-text-1); }
.nq-multisel.open .nq-multisel-trigger i { transform: rotate(0); }
.nq-multisel-trigger i { font-size: 16px; transition: transform .2s; transform: rotate(180deg); }
.nq-multisel-dropdown { display: none; position: absolute; right: 0; top: calc(100% + 4px); z-index: 1050; min-width: 140px; padding: 4px 0; background: var(--nq-bg-1); border: 1px solid var(--nq-fill-3); border-radius: var(--nq-radius); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.nq-multisel.open .nq-multisel-dropdown { display: block; }
.nq-multisel-option { padding: 4px 12px; transition: background .1s; }
.nq-multisel-option:hover { background: var(--nq-fill-2); }
.nq-multisel-option .custom-control { min-height: auto !important; }
.nq-multisel-option .custom-control-label { font-size: var(--nq-font-sm); font-weight: 400; color: var(--nq-text-1); cursor: pointer; }
.nq-multisel-actions { display: flex; justify-content: center; gap: 8px; padding: 8px 12px 4px; border-top: 1px solid var(--nq-fill-3); margin-top: 4px; }

/* ---- 产品列表 - 视图切换按钮 ---- */
.nq-view-toggle { display: inline-flex; border: 1px solid rgb(var(--arcoblue-6)); border-radius: var(--nq-radius); overflow: hidden; }
.nq-view-btn { display: flex; align-items: center; justify-content: center; padding: 0 14px; height: 30px; border: none; background: var(--nq-bg-1); color: rgb(var(--arcoblue-6)); font-size: var(--nq-font-sm); cursor: pointer; transition: all .15s; }
.nq-view-btn + .nq-view-btn { border-left: 1px solid rgb(var(--arcoblue-6)); }
.nq-view-btn:hover { background: rgb(var(--arcoblue-1)); }
.nq-view-btn.active { color: var(--nq-bg-1); background: rgb(var(--arcoblue-6)); }

/* ---- 产品列表 - 卡片视图 ---- */
.nq-view-card { margin-bottom: 1rem; }
.nq-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.nq-card-item { border: 1px solid var(--nq-fill-3); border-radius: var(--nq-radius); background: var(--nq-bg-1); transition: box-shadow .2s; }
.nq-card-item:hover { box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.nq-card-header { display: flex; justify-content: space-between; align-items: flex-start; padding: 14px 16px 10px; border-bottom: 1px solid var(--nq-fill-3); background: var(--nq-fill-2); }
.nq-card-title { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; margin-right: 8px; }
.nq-card-title a { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nq-card-title a:hover { color: rgb(var(--arcoblue-6)); text-decoration: none; }
.nq-card-title small { font-size: var(--nq-font-xs); color: var(--nq-text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nq-card-body { padding: 10px 16px; }
.nq-card-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; font-size: var(--nq-font-sm); }
.nq-card-label { color: var(--nq-text-3); flex-shrink: 0; }
.nq-card-value { color: var(--nq-text-1); text-align: right; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nq-card-more { position: relative; }
.nq-card-more-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: none; border-radius: var(--nq-radius); background: transparent; color: var(--nq-text-3); font-size: 18px; cursor: pointer; transition: all .15s; }
.nq-card-more-btn:hover { color: var(--nq-text-1); }
.nq-card-footer { display: flex; justify-content: space-between; align-items: center; padding: 10px 16px; border-top: 1px solid var(--nq-fill-3); }
.nq-card-loader,
.nq-card-nomore { text-align: center; padding: 16px 0; font-size: var(--nq-font-sm); color: var(--nq-text-3); }
.nq-card-loader i { margin-right: 4px; }

/* ---- 产品详情页 ---- */
.nq-sd-error-tip { color: var(--nq-danger); margin: 0; padding: 0; line-height: 36px; margin-left: 13rem; display: none; }
.nq-sd-ml-8 { margin-left: 8.3rem; }
.nq-sd-contract-mc { width: 100%; height: 100%; position: fixed; right: 0; top: 0; background: rgb(var(--gray-10)); z-index: 999999; opacity: 0.4; }
.nq-sd-pt-9 { padding-top: 9px; }
.nq-sd-must-reinstall:before { content: '*'; color: var(--nq-danger); }
.nq-sd-flex-col { flex-direction: column; }
.nq-sd-flex-col .reinstallAgreeCheckbox, .reinstallAgreeCheckbox { color: var(--nq-danger); }

/* ---- 顶栏 ---- */
.nq-sd-topbar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; padding: 12px 16px; }
.nq-sd-topbar-left { display: flex; align-items: center; gap: 8px; min-width: 0; flex: 1 1 0%; overflow: hidden; max-width: 100%; font-size: var(--nq-font-md); font-weight: 500; color: var(--nq-text-1); }
.nq-sd-back { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: none; padding: 0; background: none; border-radius: var(--nq-radius); color: var(--nq-text-2); font-size: 18px; transition: background .15s, color .15s; flex-shrink: 0; cursor: pointer; }
.nq-sd-back:hover { background: var(--nq-fill-2); color: var(--nq-primary); text-decoration: none; }
.nq-sd-topbar-left .card-title { margin: 0; padding-left: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; flex: 1 1 0%; font-size: inherit; font-weight: inherit; }
.nq-sd-topbar-left .card-title::before { display: none; }
.nq-sd-topbar-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.nq-sd-topbar-actions .btn.btn-sm { display: inline-flex; align-items: center; padding: 0 10px; height: 30px; font-size: var(--nq-font-xs); line-height: 1; }
.nq-sd-topbar-actions .btn i { font-size: 15px; line-height: 1; vertical-align: middle; }
.nq-sd-topbar-actions .service_module_button.disabled, .nq-sd-topbar-actions .dropdown-menu .service_module_button.disabled { opacity: .45; pointer-events: none; cursor: not-allowed; }

/* ---- 概览两栏布局 ---- */
.nq-ov-grid { display: grid; grid-template-columns: 3fr 1fr; gap: 16px; }
.nq-ov-col { display: flex; flex-direction: column; gap: 16px; }
.nq-ov-card { background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); overflow: hidden; }
.nq-ov-card-head { display: flex; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--nq-border-1); }
.nq-ov-card-head .btn { display: inline-flex; align-items: center; padding: 0 10px; height: 24px; font-size: var(--nq-font-xs); line-height: 1; }
.nq-ov-card-head .card-title { margin: 0; font-size: var(--nq-font-md); }
.nq-ov-tag { margin-left: auto; padding: 2px 10px; font-size: var(--nq-font-xs); line-height: 1.4; }
.nq-ov-tag.tag-pending { background: var(--nq-warning-light); color: var(--nq-warning); }
.nq-ov-tag.tag-active { background: var(--nq-success-light); color: var(--nq-success); }
.nq-ov-tag.tag-cancelled { background: rgba(var(--gray-5), 0.12); color: rgb(var(--gray-5)); }
.nq-ov-tag.tag-fraud { background: var(--nq-danger-light); color: var(--nq-danger); }
.nq-ov-tag.tag-deleted { background: rgba(var(--gray-10), 0.12); color: rgb(var(--gray-10)); }
.nq-ov-tag.tag-suspended { background: var(--nq-danger-light); color: var(--nq-danger); }
.nq-ov-tag.tag-due-success { background: var(--nq-success-light); color: var(--nq-success); }
.nq-ov-tag.tag-due-warning { background: var(--nq-warning-light); color: var(--nq-warning); }
.nq-ov-tag.tag-due-danger { background: var(--nq-danger-light); color: var(--nq-danger); }
.nq-ov-card-body { padding: 12px 16px; }
.nq-ov-grid > .nq-ov-col:first-child .nq-ov-card-body { display: grid; grid-template-columns: 1fr 1fr; gap: 0 20px; }
.nq-ov-grid > .nq-ov-col:first-child .nq-ov-card-body .nq-ov-row { justify-content: flex-start; }
.nq-ov-grid > .nq-ov-col:first-child .nq-ov-card-body .nq-ov-label { width: 70px; flex-shrink: 0; }
.nq-ov-grid > .nq-ov-col:first-child .nq-ov-card-body .nq-ov-value { text-align: left; padding-left: 8px; }
.nq-ov-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.nq-ov-actions .btn { display: inline-flex; align-items: center; padding: 0 8px; height: 20px; font-size: var(--nq-font-xs); line-height: 1; border-radius: 4px; }
.nq-ov-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 0; font-size: var(--nq-font-md); }
.nq-ov-label { color: var(--nq-text-3); white-space: nowrap; flex-shrink: 0; }
.nq-ov-value { color: var(--nq-text-1); text-align: right; padding-left: 12px; word-break: break-all; }
.nq-ov-price { color: var(--nq-primary); font-weight: 600; font-size: 15px; }

/* ---- 电源状态 ---- */
.nq-ov-status { display: flex; align-items: center; }
.nq-ov-status-icon { font-size: 15px; line-height: 1; margin-right: 4px; flex-shrink: 0; color: var(--nq-text-4); vertical-align: -1px; }
.nq-ov-status-icon.dot-active, .nq-ov-status-icon.dot-on { color: var(--nq-success); }
.nq-ov-status-icon.dot-suspended { color: var(--nq-danger); }
.nq-ov-status-icon.dot-off { color: rgb(var(--gray-10)); }
.nq-ov-status-icon.dot-pending { color: var(--nq-warning); }
.nq-ov-status-icon.dot-process, .nq-ov-status-icon.dot-waiting { color: var(--nq-primary); }
.nq-ov-status-icon.dot-process::before, .nq-ov-status-icon.dot-waiting::before { content: '' !important; display: inline-block; width: 12px; height: 12px; border: 1.5px solid var(--nq-fill-3); border-top-color: var(--nq-primary); border-radius: 50%; animation: nq-btn-spin .6s linear infinite; vertical-align: middle; }
.nq-ov-status-refresh { display: inline-flex; align-items: center; cursor: pointer; padding: 0 4px; border-radius: 4px; transition: background .15s; }
.nq-ov-status-refresh:hover { background: var(--nq-fill-2); }

/* ---- 可复制文本 ---- */
.nq-ov-copyable { cursor: pointer; transition: color .15s; }
.nq-ov-copyable:hover { color: var(--nq-primary); }

/* ---- 密码行 ---- */
.nq-ov-pwd-wrap { display: flex; align-items: center; gap: 4px; }
.nq-ov-pwd-text { letter-spacing: 1px; }
.nq-ov-icon-btn { font-size: var(--nq-font-md); line-height: 1; cursor: pointer; color: var(--nq-text-3); transition: color .15s; flex-shrink: 0; }
.nq-ov-icon-btn:hover { color: var(--nq-primary); }

/* ---- 开关 ---- */
.nq-ov-switch { position: relative; display: inline-block; width: 32px; height: 18px; margin: 0; vertical-align: middle; cursor: pointer; }
.nq-ov-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.nq-ov-switch-slider { position: absolute; inset: 0; background: var(--nq-fill-3); border-radius: 9px; transition: background .2s; }
.nq-ov-switch-slider::before { content: ''; position: absolute; left: 2px; top: 2px; width: 14px; height: 14px; background: var(--nq-bg-1); border-radius: 50%; box-shadow: 0 1px 3px rgba(0,0,0,.15); transition: transform .2s; }
.nq-ov-switch input:checked + .nq-ov-switch-slider { background: var(--nq-primary); }
.nq-ov-switch input:checked + .nq-ov-switch-slider::before { transform: translateX(14px); }
.nq-ov-switch input:disabled + .nq-ov-switch-slider { opacity: .5; cursor: not-allowed; }

/* ---- 流量统计概览 ---- */
.nq-traffic-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 20px; }
.nq-ts-item { background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); border-radius: var(--nq-radius); padding: 16px 20px; display: flex; flex-direction: column; gap: 8px; }
.nq-ts-label { font-size: var(--nq-font-xs); color: var(--nq-text-3); font-weight: 500; }
.nq-ts-value { font-size: 22px; font-weight: 700; color: var(--nq-text-1); letter-spacing: -.5px; line-height: 1.2; }
.nq-ts-value.nq-ts-used { color: var(--nq-primary); }
.nq-ts-value.nq-ts-remain { color: #10b981; }
.nq-ts-value.nq-ts-percent { color: #f59e0b; }
@media (max-width: 768px) { .nq-traffic-stats { grid-template-columns: repeat(2, 1fr); gap: 10px; } .nq-ts-item { padding: 12px 14px; } .nq-ts-value { font-size: 18px; } }

/* ---- 图表组件 ---- */
.nq-chart-grid { display: flex; flex-wrap: wrap; gap: 20px; }
.nq-chart-item { flex: 1 1 calc(50% - 10px); min-width: 0; background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); padding: 20px; }
.nq-chart-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 16px; }
.nq-chart-left { display: flex; align-items: center; gap: 10px; }
.nq-chart-title { font-size: var(--nq-font-md); font-weight: 600; color: var(--nq-text-1); white-space: nowrap; letter-spacing: .3px; }
.nq-chart-left select { width: 140px; }
.nq-chart-right { position: relative; display: flex; align-items: center; }
.nq-chart-range { display: inline-flex; background: var(--nq-fill-1); padding: 2px; gap: 2px; }
.nq-chart-range .nq-cr-btn { padding: 4px 12px; font-size: var(--nq-font-xs); color: var(--nq-text-3); background: transparent; border: none; cursor: pointer; white-space: nowrap; transition: all .2s ease; font-weight: 500; }
.nq-chart-range .nq-cr-btn:hover { color: var(--nq-text-1); }
.nq-chart-range .nq-cr-btn.active { background: var(--nq-bg-1); color: var(--nq-primary); box-shadow: 0 1px 3px rgba(0,0,0,.08); }
.nq-chart-box { width: 100%; height: 320px; }
.nq-chart-picker { display: none; position: absolute; top: calc(100% + 8px); right: 0; background: var(--nq-bg-1); border: 1px solid var(--nq-border-1); box-shadow: var(--nq-shadow-3); padding: 16px; z-index: 10; white-space: nowrap; }
.nq-chart-picker.show { display: block; }
.nq-chart-picker .nq-cp-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--nq-text-2); }
.nq-chart-picker .nq-cp-row + .nq-cp-row { margin-top: 10px; }
.nq-chart-picker input { width: 170px; font-size: 13px; }
.nq-chart-picker .nq-cp-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 12px; }
@media (max-width: 1367px) { .nq-chart-item { flex: 1 1 100%; } }

/* ---- 流量进度条 ---- */
.nq-ov-flow-bar { padding-top: 10px; }
.nq-ov-flow-bar .progress-bar { font-size: 0; line-height: 8px; }

/* ---- 顶部搜索框（未登录） ---- */
.nq-header-search { position: relative; margin-right: 8px; }
.nq-header-search-input { width: 180px; border-radius: 20px; font-size: 12px; padding-left: 32px !important; height: 32px; }
.nq-header-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--nq-text-4); font-size: 14px; z-index: 1; }
.nq-header-register-btn { height: 50px; border-radius: 0; padding: 0 20px; font-size: var(--nq-font-sm); font-weight: 500; display: flex; align-items: center; margin-right: -8px; }

/* ---- 按钮加载动画 ---- */
.btn.is-loading { pointer-events: none; display: inline-flex !important; align-items: center; justify-content: center; gap: 6px; }
.btn-block.is-loading { display: flex !important; }
.btn .btn-loading { display: none; }
.btn.is-loading .btn-loading { display: inline-flex; align-items: center; }
.btn .btn-loading::before { content: ''; width: 14px; height: 14px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: nq-btn-spin .6s linear infinite; }
.btn-outline-primary.is-loading .btn-loading::before,
.btn-outline-light.is-loading .btn-loading::before { border-color: rgba(0,0,0,.08); border-top-color: var(--nq-text-2); }
@keyframes nq-btn-spin { to { transform: rotate(360deg); } }

/* ---- 响应式 ---- */
@media (max-width: 976px) {
  .nq-sd-topbar { flex-direction: column; align-items: stretch; }
  .nq-sd-topbar-actions { flex-wrap: wrap; }
  .nq-ov-grid { grid-template-columns: 1fr; }
}