/*
 * components.css — UI primitives for the redesign.
 * All visual values reference tokens defined in theme-*.css.
 */

/* ---------- Card ---------- */
.pp-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	color: var(--color-text);
	overflow: hidden;
}

.pp-card--glow {
	box-shadow: var(--shadow-md), var(--shadow-glow);
}

.pp-card--bare {
	background: transparent;
	border: 1px dashed var(--color-border);
	box-shadow: none;
}

.pp-card__head {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 22px;
	border-bottom: 1px solid var(--color-border);
	background: linear-gradient(180deg, var(--color-surface-2) 0%, var(--color-surface) 100%);
	position: relative;
}

.pp-card__head::after {
	content: "";
	position: absolute;
	left: 22px;
	bottom: -1px;
	width: 40px;
	height: 1px;
	background: var(--color-accent);
}

.pp-card__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.05rem;
	color: var(--color-text);
	margin: 0;
	letter-spacing: -0.005em;
}

.pp-card__sub {
	color: var(--color-text-muted);
	font-size: 13px;
}

.pp-card__head--ghost {
	background: transparent;
	border-bottom: 1px solid var(--color-border);
}

.pp-card__actions {
	margin-left: auto;
	display: inline-flex;
	gap: var(--space-2);
}

.pp-card__body {
	padding: var(--space-5);
}

.pp-card__body--tight {
	padding: var(--space-4);
}

.pp-card__foot {
	padding: var(--space-3) var(--space-5);
	background: var(--color-surface-2);
	border-top: 1px solid var(--color-border);
	color: var(--color-text-muted);
	font-size: 12px;
}

/* ---------- Stat ---------- */
.pp-stat {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: var(--space-4) var(--space-5);
	border-radius: var(--radius-md);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
}

.pp-stat__label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-text-muted);
}

.pp-stat__value {
	font-family: var(--font-mono);
	font-size: 1.6rem;
	font-weight: 600;
	color: var(--color-text);
	line-height: 1.15;
	font-variant-numeric: tabular-nums;
}

.pp-stat__hint {
	font-size: 12px;
	color: var(--color-text-faint);
	display: inline-flex;
	gap: 6px;
	align-items: center;
}

.pp-stat__trend {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 12px;
	padding: 2px 8px;
	border-radius: 999px;
	background: var(--accent-soft);
	color: var(--color-accent);
	font-variant-numeric: tabular-nums;
	font-family: var(--font-mono);
}

.pp-stat__trend--up { color: var(--color-success); background: color-mix(in srgb, var(--color-success) 14%, transparent); }
.pp-stat__trend--down { color: var(--color-danger); background: color-mix(in srgb, var(--color-danger) 14%, transparent); }

/* ---------- Button ---------- */
.pp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 var(--space-4);
	height: 38px;
	border-radius: var(--radius-sm);
	border: 1px solid transparent;
	font-weight: 500;
	font-size: 0.94rem;
	letter-spacing: 0.005em;
	color: var(--color-text);
	background: var(--color-surface-2);
	transition: transform var(--motion-fast) ease, box-shadow var(--motion-fast) ease, background var(--motion-fast) ease, color var(--motion-fast) ease, border-color var(--motion-fast) ease;
	white-space: nowrap;
	cursor: pointer;
	user-select: none;
	text-decoration: none;
}

.pp-btn:hover { color: var(--color-text); }
.pp-btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.pp-btn:disabled,
.pp-btn.is-disabled { opacity: 0.55; cursor: not-allowed; }

/* 按钮内的图标统一尺寸，防止 ui_icon('xx', 'sm') 出现两种尺寸 */
.pp-btn .pp-icon { width: 16px; height: 16px; flex-shrink: 0; }
.pp-btn--lg .pp-icon { width: 18px; height: 18px; }
.pp-btn--sm .pp-icon { width: 14px; height: 14px; }

.pp-btn--primary {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
	border-color: transparent;
	box-shadow: var(--shadow-glow);
}
.pp-btn--primary:hover { transform: translateY(-1px); filter: brightness(1.06); color: var(--on-accent); }
.pp-btn--primary:active { transform: translateY(0); filter: brightness(0.98); }

.pp-btn--ghost {
	background: transparent;
	border-color: var(--color-border-strong);
	color: var(--color-text);
}
.pp-btn--ghost:hover { background: var(--color-surface-2); }

.pp-btn--soft {
	background: var(--accent-soft);
	color: var(--color-accent);
}
.pp-btn--soft:hover { background: color-mix(in srgb, var(--color-accent) 22%, transparent); color: var(--color-accent); }

.pp-btn--danger {
	background: color-mix(in srgb, var(--color-danger) 92%, black);
	color: #fff;
}
.pp-btn--danger:hover { color: #fff; filter: brightness(1.08); }

.pp-btn--icon {
	width: 38px;
	padding: 0;
}

.pp-btn--sm { height: 30px; padding: 0 12px; font-size: 0.84rem; gap: 6px; }
.pp-btn--sm.pp-btn--icon { width: 30px; padding: 0; }

.pp-btn--lg { height: 46px; padding: 0 22px; font-size: 1rem; }
.pp-btn--block { display: flex; width: 100%; }

.pp-btn-group {
	display: inline-flex;
	border-radius: var(--radius-sm);
	overflow: hidden;
	border: 1px solid var(--color-border);
}

.pp-btn-group .pp-btn {
	border-radius: 0;
	border: 0;
	background: transparent;
}

.pp-btn-group .pp-btn + .pp-btn { border-left: 1px solid var(--color-border); }

/* ---------- Form ---------- */
.pp-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.pp-field__label {
	font-size: 13px;
	font-weight: 500;
	color: var(--color-text-muted);
}

.pp-field__label--req::after {
	content: " *";
	color: var(--color-danger);
}

.pp-input,
.pp-select,
.pp-textarea {
	height: 40px;
	padding: 0 12px;
	border-radius: var(--radius-sm);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	color: var(--color-text);
	width: 100%;
	transition: border-color var(--motion-fast) ease, box-shadow var(--motion-fast) ease, background var(--motion-fast) ease;
}

.pp-textarea {
	height: auto;
	padding: 10px 12px;
	min-height: 92px;
	resize: vertical;
}

.pp-input:focus,
.pp-select:focus,
.pp-textarea:focus {
	outline: 0;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px var(--accent-soft);
}

.pp-input::placeholder,
.pp-textarea::placeholder {
	color: var(--color-text-faint);
}

.pp-select {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, currentColor 50%),
		linear-gradient(135deg, currentColor 50%, transparent 50%);
	background-position:
		calc(100% - 18px) 18px,
		calc(100% - 13px) 18px;
	background-size: 5px 5px, 5px 5px;
	background-repeat: no-repeat;
	padding-right: 32px;
	color: var(--color-text);
}

.pp-field__hint {
	font-size: 12px;
	color: var(--color-text-faint);
}

.pp-field__err { font-size: 12px; color: var(--color-danger); }

.pp-checkbox,
.pp-radio {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-size: 13px;
	color: var(--color-text);
}

.pp-checkbox input,
.pp-radio input {
	accent-color: var(--color-accent);
}

.pp-input-group {
	display: flex;
	align-items: stretch;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	background: var(--color-surface);
	overflow: hidden;
}

.pp-input-group:focus-within {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px var(--accent-soft);
}

.pp-input-group .pp-input,
.pp-input-group .pp-select {
	border: 0;
	background: transparent;
	box-shadow: none;
	flex: 1;
}

.pp-input-group__addon {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0 12px;
	color: var(--color-text-muted);
	background: var(--color-surface-2);
	border-right: 1px solid var(--color-border);
}

.pp-input-group__addon:last-child {
	border-right: 0;
	border-left: 1px solid var(--color-border);
}

/* ---------- Tag / Pill ---------- */
.pp-tag {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 10px;
	height: 22px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	background: var(--color-surface-2);
	color: var(--color-text-muted);
	border: 1px solid var(--color-border);
}

.pp-tag--success { color: var(--color-success); background: color-mix(in srgb, var(--color-success) 12%, transparent); border-color: color-mix(in srgb, var(--color-success) 30%, transparent); }
.pp-tag--warning { color: var(--color-warning); background: color-mix(in srgb, var(--color-warning) 14%, transparent); border-color: color-mix(in srgb, var(--color-warning) 30%, transparent); }
.pp-tag--danger { color: var(--color-danger); background: color-mix(in srgb, var(--color-danger) 12%, transparent); border-color: color-mix(in srgb, var(--color-danger) 30%, transparent); }
.pp-tag--accent { color: var(--color-accent); background: var(--accent-soft); border-color: color-mix(in srgb, var(--color-accent) 35%, transparent); }
.pp-tag--solid { background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2)); color: var(--on-accent); border-color: transparent; }

.pp-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--color-text-faint);
}

.pp-dot--pulse {
	box-shadow: 0 0 0 0 currentColor;
	animation: pp-pulse 1.6s ease-out infinite;
	color: inherit;
}

@keyframes pp-pulse {
	0% { box-shadow: 0 0 0 0 color-mix(in srgb, currentColor 35%, transparent); }
	80% { box-shadow: 0 0 0 12px transparent; }
	100% { box-shadow: 0 0 0 0 transparent; }
}

/* ---------- Table ---------- */
.pp-table-wrap {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-surface);
}

.pp-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 13px;
}

.pp-table thead th {
	position: sticky;
	top: 0;
	background: var(--color-surface-2);
	color: var(--color-text-muted);
	font-weight: 600;
	text-align: left;
	padding: 12px 14px;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border-bottom: 1px solid var(--color-border);
}

.pp-table tbody td {
	padding: 14px;
	border-bottom: 1px solid var(--color-border);
	color: var(--color-text);
	vertical-align: middle;
}

.pp-table tbody tr:last-child td { border-bottom: 0; }
.pp-table tbody tr:hover td { background: var(--color-surface-2); }

.pp-table--compact tbody td { padding: 9px 12px; }
.pp-table--compact thead th { padding: 10px 12px; }

.pp-table__num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

.pp-table-empty {
	padding: var(--space-7) var(--space-5);
	text-align: center;
	color: var(--color-text-faint);
}

/* ---------- Page header / Nav pills ---------- */
.pp-page-head {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	margin-bottom: var(--space-5);
}

.pp-page-head__title {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--color-text);
}

.pp-page-head__sub {
	color: var(--color-text-muted);
	font-size: 13px;
}

.pp-page-head__actions { margin-left: auto; display: inline-flex; gap: var(--space-2); }

.pp-pills {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 6px;
	padding: 4px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 999px;
}

.pp-pills__item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: 999px;
	color: var(--color-text-muted);
	font-size: 13px;
	cursor: pointer;
}

.pp-pills__item:hover { color: var(--color-text); }

.pp-pills__item.is-active {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
}

/* ---------- Dropdown / Menu ---------- */
.pp-dropdown {
	position: relative;
	display: inline-block;
}

.pp-menu {
	position: absolute;
	right: 0;
	top: calc(100% + 8px);
	min-width: 180px;
	padding: 6px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	z-index: 60;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px);
	transition: opacity var(--motion-fast) ease, transform var(--motion-fast) ease, visibility var(--motion-fast);
}

.pp-dropdown.is-open .pp-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.pp-menu__item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 10px;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-size: 13px;
	cursor: pointer;
	text-decoration: none;
}

.pp-menu__item:hover { background: var(--color-surface-2); color: var(--color-text); }
.pp-menu__sep { height: 1px; background: var(--color-border); margin: 6px 4px; }
.pp-menu__head { padding: 6px 10px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-faint); }

/* ---------- Modal ---------- */
.pp-modal {
	position: fixed;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
	z-index: 200;
}

.pp-modal.is-open { display: flex; }

.pp-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(8, 11, 22, 0.55);
	backdrop-filter: blur(4px);
}

.pp-modal__dialog {
	position: relative;
	width: 100%;
	max-width: 480px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	animation: pp-modal-in 180ms ease;
}

.pp-modal__head {
	padding: var(--space-4) var(--space-5);
	border-bottom: 1px solid var(--color-border);
	display: flex;
	align-items: center;
	gap: var(--space-3);
}

.pp-modal__title { font-weight: 600; font-size: 1rem; color: var(--color-text); }

.pp-modal__close {
	margin-left: auto;
	color: var(--color-text-muted);
	width: 28px;
	height: 28px;
	border-radius: var(--radius-sm);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.pp-modal__close:hover { background: var(--color-surface-2); color: var(--color-text); }

.pp-modal__body { padding: var(--space-5); }
.pp-modal__foot {
	padding: var(--space-4) var(--space-5);
	border-top: 1px solid var(--color-border);
	display: flex;
	gap: var(--space-2);
	justify-content: flex-end;
	background: var(--color-surface-2);
}

@keyframes pp-modal-in {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

/* ---------- Toast / Banner ---------- */
.pp-toast-stack {
	position: fixed;
	top: 20px;
	right: 20px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	z-index: 300;
	pointer-events: none;
}

.pp-toast {
	min-width: 220px;
	max-width: 380px;
	padding: 12px 14px;
	border-radius: var(--radius-md);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-md);
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	pointer-events: auto;
	animation: pp-toast-in 200ms ease;
}

.pp-toast--success { border-left: 3px solid var(--color-success); }
.pp-toast--warning { border-left: 3px solid var(--color-warning); }
.pp-toast--danger { border-left: 3px solid var(--color-danger); }
.pp-toast--info { border-left: 3px solid var(--color-accent); }

@keyframes pp-toast-in {
	from { opacity: 0; transform: translateX(20px); }
	to { opacity: 1; transform: translateX(0); }
}

.pp-banner {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 14px;
	border-radius: var(--radius-md);
	background: var(--color-surface-2);
	border: 1px solid var(--color-border);
	color: var(--color-text-muted);
	font-size: 13px;
}

.pp-banner--info { color: var(--color-accent); background: var(--accent-soft); border-color: color-mix(in srgb, var(--color-accent) 30%, transparent); }
.pp-banner--warning { color: var(--color-warning); background: color-mix(in srgb, var(--color-warning) 12%, transparent); border-color: color-mix(in srgb, var(--color-warning) 30%, transparent); }
.pp-banner--danger { color: var(--color-danger); background: color-mix(in srgb, var(--color-danger) 12%, transparent); border-color: color-mix(in srgb, var(--color-danger) 30%, transparent); }
.pp-banner--success { color: var(--color-success); background: color-mix(in srgb, var(--color-success) 12%, transparent); border-color: color-mix(in srgb, var(--color-success) 30%, transparent); }

/* ---------- Pagination ---------- */
.pp-pagination {
	display: inline-flex;
	gap: 4px;
	align-items: center;
}

.pp-pagination a,
.pp-pagination span {
	min-width: 32px;
	height: 32px;
	padding: 0 10px;
	border-radius: var(--radius-sm);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	color: var(--color-text-muted);
	font-size: 13px;
	font-family: var(--font-mono);
}

.pp-pagination a:hover { color: var(--color-text); border-color: var(--color-border-strong); }
.pp-pagination .is-active {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	border-color: transparent;
	color: var(--on-accent);
}

/* ---------- Brand mark / Logo ---------- */
.pp-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--color-text);
	font-weight: 600;
	font-family: var(--font-display);
	letter-spacing: 0.01em;
}

.pp-brand__mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
	box-shadow: var(--shadow-glow);
	flex-shrink: 0;
}

.pp-brand__mark svg { width: 26px; height: 26px; }
.pp-brand__name { font-size: 1.05rem; line-height: 1.1; font-weight: 700; letter-spacing: -0.005em; }
/* 紧凑场景（顶栏 inline、小卡） */
.pp-brand--sm .pp-brand__mark { width: 32px; height: 32px; border-radius: 10px; }
.pp-brand--sm .pp-brand__mark svg { width: 20px; height: 20px; }
.pp-brand--sm .pp-brand__name { font-size: 0.95rem; }
/* 大尺寸（登录卡 / hero / footer） */
.pp-brand--lg .pp-brand__mark { width: 56px; height: 56px; border-radius: 16px; }
.pp-brand--lg .pp-brand__mark svg { width: 36px; height: 36px; }
.pp-brand--lg .pp-brand__name { font-size: 1.25rem; }
.pp-brand__sub {
	display: block;
	font-size: 10px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--color-text-faint);
	margin-top: 4px;
}

/* ---------- Mini chart sparkline backgrounds ---------- */
.pp-spark {
	width: 100%;
	height: auto;
	display: block;
}

.pp-spark__fill { fill: url(#ppSparkFill); }
.pp-spark__line { fill: none; stroke: var(--color-accent); stroke-width: 2; }

/* ---------- Footer ---------- */
.pp-foot {
	padding: var(--space-7) 0 var(--space-6);
	border-top: 1px solid var(--color-border);
	background: var(--color-surface);
	color: var(--color-text-muted);
}

.pp-foot__copy { font-size: 12px; color: var(--color-text-faint); }

/* ============================================================
 * App-level primitives (admin + merchant 共享)
 * 之前误放在 layout-admin.css，导致商户端 KPI/page-head 塌陷
 * ============================================================ */

.pp-page-head {
	display: flex;
	align-items: flex-end;
	gap: var(--space-4);
	margin-bottom: var(--space-5);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--color-border);
	position: relative;
}

.pp-page-head::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 80px;
	height: 1px;
	background: linear-gradient(90deg, var(--color-accent), transparent);
}

.pp-page-head > div:first-child { flex: 1; min-width: 0; }

.pp-page-head__title {
	font-family: var(--font-display);
	font-size: clamp(1.6rem, 2.4vw, 2rem);
	font-weight: 600;
	color: var(--color-text);
	letter-spacing: -0.01em;
	margin: 0;
	line-height: 1.15;
}

.pp-page-head__sub {
	color: var(--color-text-muted);
	font-size: 14px;
	margin-top: 8px;
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.pp-page-head__sub code {
	font-family: var(--font-mono);
	font-size: 13px;
	padding: 3px 10px;
	background: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xs);
	color: var(--color-accent);
	font-weight: 500;
}

.pp-page-head__actions {
	display: inline-flex;
	gap: var(--space-2);
	align-items: center;
	flex-shrink: 0;
}

@media (max-width: 720px) {
	.pp-page-head { flex-direction: column; align-items: stretch; }
	.pp-page-head__actions { justify-content: flex-start; }
}

/* ---------- KPI Grid ---------- */
.pp-kpi-grid {
	display: grid;
	gap: var(--space-4);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1180px) { .pp-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .pp-kpi-grid { grid-template-columns: minmax(0, 1fr); } }

.pp-kpi {
	position: relative;
	padding: 22px 24px;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	display: flex;
	flex-direction: column;
	gap: 4px;
	overflow: hidden;
	min-height: 124px;
	box-shadow: var(--shadow-sm);
	transition: transform var(--motion-fast) ease, border-color var(--motion-fast) ease, box-shadow var(--motion-fast) ease;
}

.pp-kpi::before {
	content: "";
	position: absolute;
	left: 0; top: 0; bottom: 0;
	width: 3px;
	background: linear-gradient(180deg, var(--color-accent), transparent 70%);
	opacity: 0.6;
}

.pp-kpi::after {
	content: "";
	position: absolute;
	right: -28px;
	top: -28px;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: radial-gradient(circle, var(--accent-soft) 0%, transparent 70%);
	pointer-events: none;
	opacity: 0.5;
}

.pp-kpi:hover {
	transform: translateY(-1px);
	border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
	box-shadow: var(--shadow-md);
}

.pp-kpi__label {
	font-size: 12px;
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-weight: 600;
}

.pp-kpi__value {
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	font-size: clamp(1.8rem, 2.6vw, 2.2rem);
	color: var(--color-text);
	font-weight: 600;
	letter-spacing: -0.015em;
	line-height: 1.1;
	margin-top: 4px;
}

.pp-kpi__foot {
	display: inline-flex;
	gap: 6px;
	align-items: center;
	font-size: 12px;
	color: var(--color-text-muted);
	margin-top: 4px;
}

.pp-kpi__foot svg { width: 14px; height: 14px; }

.pp-kpi--accent { background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2)); color: var(--on-accent); }
.pp-kpi--accent .pp-kpi__label { color: color-mix(in srgb, var(--on-accent) 75%, transparent); }
.pp-kpi--accent .pp-kpi__value { color: var(--on-accent); }
.pp-kpi--accent .pp-kpi__foot { color: color-mix(in srgb, var(--on-accent) 80%, transparent); }
.pp-kpi--accent::before { background: linear-gradient(180deg, var(--on-accent), transparent); opacity: 0.5; }
.pp-kpi--accent::after { background: radial-gradient(circle, color-mix(in srgb, var(--on-accent) 25%, transparent) 0%, transparent 70%); }

/* ---------- Dashboard 2-col grid ---------- */
.pp-dash-grid {
	display: grid;
	gap: var(--space-5);
	grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
}

@media (max-width: 1024px) { .pp-dash-grid { grid-template-columns: minmax(0, 1fr); } }

/* ---------- Wallet ---------- */
.pp-wallet-grid {
	display: grid;
	gap: var(--space-4);
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
}

@media (max-width: 1024px) { .pp-wallet-grid { grid-template-columns: minmax(0, 1fr); } }

.pp-wallet {
	position: relative;
	padding: clamp(22px, 2.6vw, 32px);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
	overflow: hidden;
	isolation: isolate;
}

.pp-wallet::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.1) 1px, transparent 0);
	background-size: 22px 22px;
	opacity: 0.3;
	pointer-events: none;
}

.pp-wallet::after {
	content: "";
	position: absolute;
	right: -80px;
	bottom: -80px;
	width: 260px;
	height: 260px;
	border-radius: 50%;
	background: radial-gradient(circle, color-mix(in srgb, var(--on-accent) 18%, transparent) 0%, transparent 70%);
	pointer-events: none;
}

.pp-wallet__label {
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--on-accent) 78%, transparent);
	font-weight: 600;
	position: relative;
}

.pp-wallet__value {
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	font-size: clamp(2.4rem, 4vw, 3.2rem);
	margin-top: 14px;
	letter-spacing: -0.025em;
	font-weight: 600;
	position: relative;
	line-height: 1.05;
}

.pp-wallet__meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
	margin-top: 26px;
	padding-top: 18px;
	border-top: 1px solid color-mix(in srgb, var(--on-accent) 22%, transparent);
	color: color-mix(in srgb, var(--on-accent) 82%, transparent);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 600;
	position: relative;
}

@media (max-width: 560px) { .pp-wallet__meta { grid-template-columns: 1fr; gap: 12px; } }

.pp-wallet__meta b {
	display: block;
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	font-size: 22px;
	color: var(--on-accent);
	margin-top: 8px;
	letter-spacing: -0.01em;
	font-weight: 600;
	text-transform: none;
	line-height: 1.1;
}

.pp-wallet__actions {
	display: inline-flex;
	gap: 10px;
	margin-top: var(--space-5);
	position: relative;
	z-index: 1;
}

.pp-wallet__actions .pp-btn {
	background: var(--on-accent);
	color: var(--color-accent);
	border: 0;
}

.pp-wallet__actions .pp-btn:hover { color: var(--color-accent); filter: brightness(0.96); }

.pp-wallet__actions .pp-btn--ghost {
	background: transparent;
	border: 1px solid color-mix(in srgb, var(--on-accent) 35%, transparent);
	color: var(--on-accent);
}

.pp-wallet__actions .pp-btn--ghost:hover { background: color-mix(in srgb, var(--on-accent) 10%, transparent); color: var(--on-accent); }

/* ---------- Generic shell content padding helper ---------- */
.pp-shell-pad {
	padding: clamp(20px, 2.4vw, 32px) clamp(16px, 2.4vw, 32px);
}

/* ============================================================
 * BS3 共存安全网：确保新版组件在 BS3 兼容模式下也能渲染
 * ============================================================ */

/* 防止 BS3 的 .panel/.row/.col 等规则污染 pp-* 内部布局 */
.pp-app .pp-kpi-grid { display: grid !important; }
.pp-app .pp-dash-grid { display: grid !important; }
.pp-app .pp-wallet-grid { display: grid !important; }
.pp-app .pp-page-head { display: flex !important; }
.pp-app .pp-cluster { display: flex !important; }
.pp-app .pp-stack { display: flex !important; flex-direction: column; }
.pp-app .pp-grid { display: grid !important; }

/* BS3 .panel 与 pp-card 分开（pp-card 不应被当作 BS3 panel） */
.pp-app .pp-card { float: none; clear: both; }
.pp-app .pp-card .panel-heading,
.pp-app .pp-card .panel-body,
.pp-app .pp-card .panel-footer { background: transparent; border: 0; padding: 0; }

/* 表单 input - BS3 .form-control 类与 pp-input 共存 */
.pp-app .pp-input,
.pp-app .pp-select,
.pp-app .pp-textarea {
	background: var(--color-surface) !important;
	color: var(--color-text) !important;
	border: 1px solid var(--color-border) !important;
}

/* svg 在 BS3 img 规则下保持原始尺寸 */
.pp-app svg.pp-icon { max-width: none; }

/* ============================================================
 * Layer (layui-layer) 弹窗 token 化主题
 * - 给所有 layer.alert / layer.confirm / layer.open 套上 .pp-layer-skin
 * - 让弹窗在三个主题（saas / blackgold / datascreen）下保持视觉一致
 * ============================================================ */
.layui-layer.pp-layer-skin {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-lg) !important;
	box-shadow: var(--shadow-lg) !important;
	color: var(--color-text) !important;
	min-width: 320px;
}
.layui-layer.pp-layer-skin .layui-layer-title {
	background: var(--color-surface-2) !important;
	border-bottom: 1px solid var(--color-border) !important;
	color: var(--color-text) !important;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 15px;
	height: 46px !important;
	line-height: 46px !important;
	padding: 0 56px 0 22px;
}
.layui-layer.pp-layer-skin .layui-layer-content {
	color: var(--color-text) !important;
	padding: 22px 24px !important;
	font-size: 14px !important;
	line-height: 1.7 !important;
	min-height: 60px !important;
	background: var(--color-surface) !important;
}
.layui-layer.pp-layer-skin .layui-layer-content.layui-layer-padding {
	padding: 22px 24px 22px 60px !important;
	background-position: 22px 22px !important;
	background-size: 24px 24px !important;
}
.layui-layer.pp-layer-skin .layui-layer-btn {
	padding: 12px 22px 18px !important;
	border-top: 1px solid var(--color-border) !important;
	background: var(--color-surface) !important;
	text-align: right !important;
}
.layui-layer.pp-layer-skin .layui-layer-btn a {
	background: var(--color-accent) !important;
	color: var(--on-accent) !important;
	border: 0 !important;
	padding: 0 22px !important;
	height: 38px !important;
	line-height: 38px !important;
	border-radius: var(--radius-sm) !important;
	font-family: var(--font-body) !important;
	font-weight: 600 !important;
	font-size: 13.5px !important;
	box-shadow: var(--shadow-glow) !important;
	transition: filter 140ms ease !important;
	margin-left: 8px !important;
}
.layui-layer.pp-layer-skin .layui-layer-btn a:hover { filter: brightness(1.06); color: var(--on-accent) !important; }
.layui-layer.pp-layer-skin .layui-layer-btn .layui-layer-btn1 {
	background: var(--color-surface-2) !important;
	color: var(--color-text-muted) !important;
	box-shadow: none !important;
	border: 1px solid var(--color-border) !important;
}
.layui-layer.pp-layer-skin .layui-layer-setwin {
	right: 12px !important;
	top: 12px !important;
}
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close {
	background-image: none !important;
	width: 22px !important;
	height: 22px !important;
	position: relative;
}
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close::before,
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close::after {
	content: ""; position: absolute;
	left: 10px; top: 4px; width: 2px; height: 14px;
	background: var(--color-text-muted); transform-origin: center;
}
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close::before { transform: rotate(45deg); }
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close::after  { transform: rotate(-45deg); }
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close:hover::before,
.layui-layer.pp-layer-skin .layui-layer-setwin .layui-layer-close:hover::after { background: var(--color-text); }
.layui-layer-shade { background: rgba(8,11,22,0.55) !important; }
.layui-layer-msg.pp-layer-skin {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-md) !important;
	color: var(--color-text) !important;
	box-shadow: var(--shadow-md) !important;
}
.layui-layer-msg.pp-layer-skin .layui-layer-content { padding: 14px 18px !important; }


/* ============================================================
 * Legacy Bootstrap 3 表单 / 列表 / 按钮 → 设计令牌全局桥接
 * 用 `.pp-app` 限定，仅作用于已开启新 UI 的容器（admin/merchant），
 * 不会影响收银台、支付页、注册等独立排版页面。
 *
 * 解决问题：
 *   - 旧 admin/user 业务页（editinfo / pay_channel / domain / risk ...）
 *     大量直接使用原生 .form-control / .btn / .list-group 等 BS3 类，
 *     在 blackgold / datascreen 深色主题下未受 token 控制，呈现"裸 BS3"。
 *   - 这里集中桥接，无需逐页改写。
 * ============================================================ */

/* ------ 表单输入控件 ------ */
.pp-app .form-control {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	color: var(--color-text) !important;
	border-radius: var(--radius-sm) !important;
	box-shadow: none !important;
	height: 38px;
	line-height: 1.5;
	font-size: 14px;
	padding: 7px 12px;
	transition: border-color var(--motion-fast) ease, box-shadow var(--motion-fast) ease;
}
.pp-app textarea.form-control { height: auto; min-height: 88px; padding: 10px 12px; line-height: 1.6; }
.pp-app select.form-control { padding-right: 30px; cursor: pointer; }
.pp-app .form-control::placeholder { color: var(--color-text-faint); }
.pp-app .form-control:focus {
	border-color: var(--color-accent) !important;
	box-shadow: 0 0 0 3px var(--accent-soft) !important;
	outline: 0 !important;
}
.pp-app .form-control[disabled],
.pp-app .form-control[readonly],
.pp-app fieldset[disabled] .form-control {
	background: var(--color-surface-2) !important;
	color: var(--color-text-muted) !important;
	cursor: not-allowed;
}
.pp-app input[type="text"]:not(.form-control),
.pp-app input[type="email"]:not(.form-control),
.pp-app input[type="password"]:not(.form-control),
.pp-app input[type="number"]:not(.form-control),
.pp-app input[type="search"]:not(.form-control),
.pp-app input[type="tel"]:not(.form-control),
.pp-app input[type="url"]:not(.form-control),
.pp-app textarea:not(.form-control),
.pp-app select:not(.form-control) {
	color: var(--color-text);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: 7px 12px;
	font-size: 14px;
}

/* ------ Input group ------ */
.pp-app .input-group { display: flex; align-items: stretch; }
.pp-app .input-group .form-control { flex: 1; }
.pp-app .input-group-addon {
	background: var(--color-surface-2) !important;
	border: 1px solid var(--color-border) !important;
	color: var(--color-text-muted) !important;
	padding: 0 12px;
	display: inline-flex;
	align-items: center;
	font-size: 13px;
	border-radius: 0;
}
.pp-app .input-group .form-control:not(:first-child),
.pp-app .input-group .input-group-addon:not(:first-child) { border-left: 0 !important; }
.pp-app .input-group > :first-child { border-top-left-radius: var(--radius-sm) !important; border-bottom-left-radius: var(--radius-sm) !important; }
.pp-app .input-group > :last-child  { border-top-right-radius: var(--radius-sm) !important; border-bottom-right-radius: var(--radius-sm) !important; }
.pp-app .input-group .input-group-btn .btn { height: 38px; }

/* ------ 通用按钮 token 化（覆盖 BS3 默认配色） ------ */
.pp-app .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	height: 38px;
	padding: 0 16px;
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: 13.5px;
	font-weight: 600;
	line-height: 1;
	border: 1px solid transparent;
	transition: filter var(--motion-fast) ease, background var(--motion-fast) ease, border-color var(--motion-fast) ease, color var(--motion-fast) ease;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
}
.pp-app .btn:hover, .pp-app .btn:focus { text-decoration: none; }
.pp-app .btn-default,
.pp-app .btn-white {
	background: var(--color-surface) !important;
	border-color: var(--color-border) !important;
	color: var(--color-text) !important;
	box-shadow: var(--shadow-sm);
}
.pp-app .btn-default:hover, .pp-app .btn-white:hover {
	background: var(--color-surface-2) !important;
	border-color: var(--color-border-strong) !important;
	color: var(--color-accent) !important;
}
.pp-app .btn-primary,
.pp-app .btn-info {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2)) !important;
	border-color: transparent !important;
	color: var(--on-accent) !important;
	box-shadow: var(--shadow-glow);
}
.pp-app .btn-primary:hover, .pp-app .btn-info:hover { filter: brightness(1.05); color: var(--on-accent) !important; }
.pp-app .btn-success { background: var(--color-success) !important; border-color: var(--color-success) !important; color: #fff !important; }
.pp-app .btn-warning { background: var(--color-warning) !important; border-color: var(--color-warning) !important; color: #fff !important; }
.pp-app .btn-danger  { background: var(--color-danger)  !important; border-color: var(--color-danger)  !important; color: #fff !important; }
.pp-app .btn-link {
	background: transparent !important;
	border: 0 !important;
	color: var(--color-accent) !important;
	box-shadow: none !important;
	padding: 0 6px;
}
.pp-app .btn-xs { height: 26px; padding: 0 10px; font-size: 12px; border-radius: var(--radius-xs); }
.pp-app .btn-sm { height: 32px; padding: 0 12px; font-size: 13px; }
.pp-app .btn-lg { height: 44px; padding: 0 22px; font-size: 15px; }
.pp-app .btn-block { display: flex; width: 100%; }
.pp-app .btn[disabled],
.pp-app .btn.disabled,
.pp-app fieldset[disabled] .btn { opacity: .55; cursor: not-allowed; filter: none; }

/* ------ List group（资料模态、密保等大量使用） ------ */
.pp-app .list-group { background: transparent; border-radius: var(--radius-md); border: 1px solid var(--color-border); overflow: hidden; }
.pp-app .list-group-item {
	background: var(--color-surface) !important;
	border: 0 !important;
	border-bottom: 1px solid var(--color-border) !important;
	color: var(--color-text) !important;
	padding: 12px 16px;
	font-size: 14px;
}
.pp-app .list-group-item:last-child { border-bottom: 0 !important; }
.pp-app .list-group-item-heading { color: var(--color-text); font-weight: 600; }
.pp-app .list-group-item-text { color: var(--color-text-muted); }

/* ------ 标签 / 徽章 ------ */
.pp-app .label { padding: 3px 8px; border-radius: var(--radius-xs); font-size: 11px; font-weight: 600; letter-spacing: 0.02em; }
.pp-app .label-default { background: var(--color-surface-2); color: var(--color-text-muted); }
.pp-app .label-info    { background: var(--color-accent); color: var(--on-accent); }
.pp-app .label-success { background: var(--color-success); color: #fff; }
.pp-app .label-warning { background: var(--color-warning); color: #fff; }
.pp-app .label-danger  { background: var(--color-danger);  color: #fff; }
.pp-app .badge { background: var(--color-surface-2); color: var(--color-text-muted); border-radius: 999px; padding: 2px 8px; font-size: 11px; font-weight: 600; }

/* ------ Modal（BS3 modal 在 admin pay_channel 等仍在使用） ------ */
.pp-app .modal-backdrop { background: rgba(8, 11, 22, 0.55) !important; }
.pp-app .modal-content {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-md) !important;
	color: var(--color-text) !important;
	box-shadow: var(--shadow-lg);
}
.pp-app .modal-header  { border-bottom: 1px solid var(--color-border) !important; padding: 14px 18px; }
.pp-app .modal-header .close { color: var(--color-text-muted); opacity: 1; text-shadow: none; }
.pp-app .modal-header .close:hover { color: var(--color-accent); }
.pp-app .modal-title { color: var(--color-text); font-family: var(--font-display); font-weight: 600; font-size: 16px; }
.pp-app .modal-body  { padding: 18px; color: var(--color-text); }
.pp-app .modal-footer { border-top: 1px solid var(--color-border) !important; padding: 12px 18px; background: var(--color-surface-2); border-radius: 0 0 var(--radius-md) var(--radius-md); }

/* ------ Popover / Tooltip ------ */
.pp-app .popover { background: var(--color-surface) !important; border: 1px solid var(--color-border) !important; box-shadow: var(--shadow-md); border-radius: var(--radius-sm); color: var(--color-text); }
.pp-app .popover-title { background: var(--color-surface-2); border-bottom: 1px solid var(--color-border); color: var(--color-text); }
.pp-app .popover-content { color: var(--color-text-muted); }

/* ------ 表格细化（增强 admin/merchant 桥接） ------ */
.pp-app .table { color: var(--color-text); }
.pp-app .table > thead > tr > th,
.pp-app .table > tbody > tr > td,
.pp-app .table > tfoot > tr > td { border-color: var(--color-border) !important; padding: 10px 12px; }
.pp-app .table-bordered, .pp-app .table-bordered > thead > tr > th, .pp-app .table-bordered > tbody > tr > td { border-color: var(--color-border) !important; }
.pp-app .table-condensed > thead > tr > th, .pp-app .table-condensed > tbody > tr > td { padding: 6px 10px; }
.pp-app .table > tbody > tr > td.info,
.pp-app .table > tbody > tr.info > td { background: var(--accent-soft) !important; color: var(--color-text); }

/* ------ 全局排版 ------ */
.pp-app h1, .pp-app h2, .pp-app h3, .pp-app h4, .pp-app h5, .pp-app h6,
.pp-app .h1, .pp-app .h2, .pp-app .h3, .pp-app .h4 {
	font-family: var(--font-display);
	color: var(--color-text);
}
.pp-app p { color: var(--color-text); line-height: 1.6; }
.pp-app small, .pp-app .small { color: var(--color-text-muted); }
.pp-app strong, .pp-app b { color: var(--color-text); }

/* ------ 兼容 Glyphicon（部分老 admin 用 .glyphicon-*） ------ */
.pp-app .glyphicon { color: inherit; }

/* ------ Bootstrap-table 工具栏的搜索框 ------ */
.pp-app .fixed-table-toolbar .search input { height: 32px; padding: 4px 10px; }

/* ------ 滚动条美化（不强制，但避免深色主题下默认白色滚动条突兀） ------ */
.pp-app ::-webkit-scrollbar { width: 10px; height: 10px; }
.pp-app ::-webkit-scrollbar-track { background: transparent; }
.pp-app ::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }
.pp-app ::-webkit-scrollbar-thumb:hover { background: var(--color-border-strong); }


/* ------ Nav pills（set.php 顶部 tab 用 .nav-pills） ------ */
.pp-app .nav-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 var(--space-4);
	padding: 6px;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	list-style: none;
}
.pp-app .nav-pills > li { margin: 0 !important; }
.pp-app .nav-pills > li > a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 14px;
	border-radius: var(--radius-sm);
	color: var(--color-text-muted);
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	transition: color var(--motion-fast) ease, background var(--motion-fast) ease;
}
.pp-app .nav-pills > li > a:hover {
	background: var(--color-surface-2);
	color: var(--color-text);
}
.pp-app .nav-pills > li.active > a,
.pp-app .nav-pills > li.active > a:focus,
.pp-app .nav-pills > li.active > a:hover {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
	box-shadow: var(--shadow-glow);
}

/* ------ Checkbox / Radio（admin/user 表单大量原生使用） ------ */
.pp-app .checkbox, .pp-app .radio { color: var(--color-text); }
.pp-app .checkbox label, .pp-app .radio label { padding-left: 22px; position: relative; cursor: pointer; }
.pp-app input[type="checkbox"], .pp-app input[type="radio"] { accent-color: var(--color-accent); }

/* ------ help-block / form 反馈文本 ------ */
.pp-app .help-block { color: var(--color-text-faint); font-size: 12px; margin-top: 6px; }
.pp-app .has-error .form-control { border-color: var(--color-danger) !important; }
.pp-app .has-error .control-label, .pp-app .has-error .help-block { color: var(--color-danger); }
.pp-app .has-success .form-control { border-color: var(--color-success) !important; }
.pp-app .has-warning .form-control { border-color: var(--color-warning) !important; }

/* ------ Pagination（admin 列表 + bootstrap-table 分页） ------ */
.pp-app .pagination { display: inline-flex; gap: 4px; padding: 0; margin: 12px 0; }
.pp-app .pagination > li > a,
.pp-app .pagination > li > span {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	color: var(--color-text-muted) !important;
	border-radius: var(--radius-xs) !important;
	padding: 6px 12px;
	margin: 0 !important;
}
.pp-app .pagination > li > a:hover { color: var(--color-accent) !important; background: var(--color-surface-2) !important; }
.pp-app .pagination > .active > a,
.pp-app .pagination > .active > a:hover,
.pp-app .pagination > .active > span {
	background: var(--color-accent) !important;
	border-color: var(--color-accent) !important;
	color: var(--on-accent) !important;
}
.pp-app .pagination > .disabled > a,
.pp-app .pagination > .disabled > span { opacity: .45; cursor: not-allowed; }

/* ------ Dropdown（bootstrap-table 工具栏、admin 过滤按钮 等） ------ */
.pp-app .dropdown-menu {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-border) !important;
	box-shadow: var(--shadow-lg) !important;
	border-radius: var(--radius-sm) !important;
	padding: 6px !important;
	min-width: 160px;
}
.pp-app .dropdown-menu > li > a,
.pp-app .dropdown-menu > .dropdown-item {
	color: var(--color-text) !important;
	padding: 8px 12px !important;
	border-radius: var(--radius-xs) !important;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
}
.pp-app .dropdown-menu > li > a:hover { background: var(--accent-soft) !important; color: var(--color-accent) !important; }
.pp-app .dropdown-menu .divider { background: var(--color-border) !important; margin: 4px 0 !important; }
.pp-app .caret { border-top-color: currentColor; opacity: .6; }

/* ------ Bootstrap-table 工具栏 ------ */
.pp-app .fixed-table-toolbar .columns, .pp-app .fixed-table-toolbar .search { margin-right: 6px; }
.pp-app .fixed-table-toolbar .btn { height: 32px; padding: 0 12px; font-size: 12px; }
.pp-app .fixed-table-toolbar .search input { height: 32px; font-size: 12px; }
.pp-app .fixed-table-pagination { padding: 8px 12px; background: var(--color-surface-2); border-top: 1px solid var(--color-border); border-radius: 0 0 var(--radius-md) var(--radius-md); }
.pp-app .fixed-table-pagination .page-list .btn-default { background: var(--color-surface); border-color: var(--color-border); color: var(--color-text); }
.pp-app .fixed-table-pagination .pagination-info { color: var(--color-text-muted); font-size: 12px; }

/* ------ 顶部 nav-tabs（与 nav-pills 不同，set.php 的某些 mod 仍用） ------ */
.pp-app .nav-tabs > li > a { border-color: transparent; }
.pp-app .nav-tabs > li.active > a { background: var(--color-surface); border-color: var(--color-border) var(--color-border) transparent; color: var(--color-text); }

/* ------ Panel-primary / Panel-info 在 admin/user 业务页常见 ------ */
.pp-app .panel-primary { border-color: var(--color-border); }
.pp-app .panel-primary > .panel-heading {
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-2));
	color: var(--on-accent);
	border-color: transparent;
}
.pp-app .panel-info > .panel-heading {
	background: var(--accent-soft);
	color: var(--color-accent);
	border-color: color-mix(in srgb, var(--color-accent) 24%, var(--color-border));
}
.pp-app .panel-info { border-color: color-mix(in srgb, var(--color-accent) 24%, var(--color-border)); }
