/* ============================================
   閸忣剙鍙＄紒鍕閺嶅嘲绱?
   ============================================ */

/* 鐞涖劌宕熼弽宄扮础 */
.form-group {
	margin-bottom: 20px;
}

.form-group label {
	display: block;
	font-size: 14px;
	color: var(--text-color);
	margin-bottom: 8px;
	font-weight: 500;
}

.form-group label .required {
	color: var(--primary-color);
	margin-right: 4px;
}

.form-group input[type="text"],
.form-group input[type="password"],
.form-group input[type="email"],
.form-group input[type="url"],
.form-group input[type="number"],
.form-group select,
.form-group textarea {
	width: 100%;
	height: 44px;
	padding: 0 15px;
	border: 1px solid var(--border-color);
	border-radius: 8px;
	font-size: 14px;
	color: var(--text-color);
	background: #fafafa;
	transition: var(--transition);
	box-sizing: border-box;
}

.form-group textarea {
	height: 100px;
	padding: 12px 15px;
	resize: vertical;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	border-color: var(--primary-color);
	background: #fff;
	outline: none;
	box-shadow: 0 0 0 3px var(--primary-light);
}

.form-group .input-tip {
	font-size: 12px;
	color: var(--text-muted);
	margin-top: 6px;
}

.form-group .radio-group,
.form-group .checkbox-group {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
}

.form-group .radio-group label,
.form-group .checkbox-group label {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: normal;
	cursor: pointer;
}

.form-group .radio-group input,
.form-group .checkbox-group input {
	accent-color: var(--primary-color);
	width: 16px;
	height: 16px;
}

/* 閹稿鎸抽弽宄扮础 */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 20px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	transition: var(--transition);
	text-decoration: none;
	border: none;
	gap: 6px;
}

.btn-primary {
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%) !important;
color: #fff !important;
border: none !important;
padding: 10px 28px;
border-radius: 10px;
font-weight: 600;
text-decoration: none;
font-size: 14px;
line-height: 1.4;
transition: all 0.2s;
cursor: pointer;
box-shadow: 0 2px 8px rgba(247,98,52,0.2);
}
.btn-primary .home-emoji,
.btn-primary i { color: #fff !important; }
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%) !important;
color: #fff !important;
transform: translateY(-2px);
box-shadow: 0 8px 22px rgba(247,98,52,0.35);
}
.btn-primary:hover .home-emoji,
.btn-primary:hover i,
.btn-primary:focus .home-emoji,
.btn-primary:focus i,
.btn-primary:active .home-emoji,
.btn-primary:active i { color: #fff !important; }

.btn-secondary {
background: #f5f5f5;
color: var(--text-secondary);
border: 1px solid var(--border-color);
}
.btn-secondary:hover { background: #eee; }

.btn-outline {
display: inline-block;
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%) !important;
color: #fff !important;
padding: 10px 28px;
border-radius: 10px;
font-weight: 600;
text-decoration: none;
transition: all 0.2s;
cursor: pointer;
border: none !important;
box-shadow: 0 2px 8px rgba(247,98,52,0.2);
}
.btn-outline .home-emoji,
.btn-outline i { color: #fff !important; }
.btn-outline:hover,
.btn-outline:focus,
.btn-outline:active {
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%) !important;
color: #fff !important;
transform: translateY(-2px);
box-shadow: 0 8px 22px rgba(247,98,52,0.35);
}
.btn-outline:hover .home-emoji,
.btn-outline:hover i,
.btn-outline:focus .home-emoji,
.btn-outline:focus i,
.btn-outline:active .home-emoji,
.btn-outline:active i { color: #fff !important; }

.btn-danger {
display: inline-block;
background: linear-gradient(135deg, #e5552a 0%, #f27952 100%) !important;
color: #fff !important;
padding: 10px 28px;
border-radius: 10px;
font-weight: 600;
text-decoration: none;
transition: all 0.2s;
cursor: pointer;
border: none !important;
box-shadow: 0 2px 8px rgba(229,85,42,0.2);
}
.btn-danger .home-emoji,
.btn-danger i { color: #fff !important; }
.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active {
background: linear-gradient(135deg, #e5552a 0%, #f27952 100%) !important;
color: #fff !important;
transform: translateY(-2px);
box-shadow: 0 8px 22px rgba(229,85,42,0.35);
}
.btn-danger:hover .home-emoji,
.btn-danger:hover i,
.btn-danger:focus .home-emoji,
.btn-danger:focus i,
.btn-danger:active .home-emoji,
.btn-danger:active i { color: #fff !important; }

.btn-sm { padding: 6px 12px; font-size: 12px; }
.btn-lg { padding: 14px 28px; font-size: 16px; }
.btn-block { width: 100%; }
/* 閸楋紕澧栭弽宄扮础 */
.card {
	background: var(--card-bg);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
}

.card-header {
	padding: 18px 24px;
	border-bottom: 1px solid var(--border-color);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.card-header h3 {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-color);
	margin: 0;
}

.card-body {
	padding: 24px;
}

/* 鐞涖劍鐗搁弽宄扮础 */
.table {
	width: 100%;
	border-collapse: collapse;
}

.table th,
.table td {
	padding: 14px 16px;
	text-align: left;
	border-bottom: 1px solid var(--border-color);
	font-size: 14px;
}

.table th {
	background: #fafbfc;
	color: var(--text-secondary);
	font-weight: 500;
	font-size: 13px;
}

.table tr:hover {
	background: #fafbfc;
}

.table tr:last-child td {
	border-bottom: none;
}

/* 閺嶅洨顒锋い?*/
.tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--border-color);
	margin-bottom: 24px;
}

.tabs .tab-item {
	padding: 12px 20px;
	font-size: 14px;
	color: var(--text-secondary);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: var(--transition);
}

.tabs .tab-item:hover {
	color: var(--primary-color);
}

.tabs .tab-item.active {
	color: var(--primary-color);
	border-bottom-color: var(--primary-color);
	font-weight: 500;
}

/* 闂堛垹瀵樼仦?*/
.breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 15px 0;
	font-size: 14px;
	color: var(--text-muted);
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.breadcrumb a {
	color: var(--text-secondary);
	text-decoration: none;
	transition: var(--transition);
}

.breadcrumb a:hover {
	color: var(--primary-color);
}

.breadcrumb .separator {
	color: var(--border-color);
}

.breadcrumb .current {
	color: var(--text-color);
	font-weight: 500;
}

/* 閸掑棝銆?*/
.pagination {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin: 24px 0;
}

.pagination a,
.pagination span {
	padding: 8px 14px;
	border-radius: 6px;
	font-size: 14px;
	text-decoration: none;
	transition: var(--transition);
}

.pagination a {
	background: var(--card-bg);
	color: var(--text-secondary);
	border: 1px solid var(--border-color);
}

.pagination a:hover {
	background: var(--primary-light);
	color: var(--primary-color);
	border-color: var(--primary-color);
}

.pagination span.current {
	background: var(--primary-color);
	color: #fff;
	border: 1px solid var(--primary-color);
}

/* 缁岃櫣濮搁幀?*/
.empty-state {
	text-align: center;
	padding: 60px 20px;
}

.empty-state .empty-icon {
	font-size: 60px;
	color: #ddd;
	margin-bottom: 20px;
}

.empty-state .empty-text {
	font-size: 15px;
	color: var(--text-muted);
	margin-bottom: 20px;
}

/* 閹绘劗銇氬?*/
.alert {
	padding: 15px 20px;
	border-radius: 8px;
	margin-bottom: 20px;
	font-size: 14px;
}

.alert-info {
	background: #e3f2fd;
	color: #1976d2;
	border: 1px solid #90caf9;
}

.alert-success {
	background: #e8f5e9;
	color: #2e7d32;
	border: 1px solid #a5d6a7;
}

.alert-warning {
	background: #fff3e0;
	color: #f57c00;
	border: 1px solid #ffcc80;
}

.alert-danger {
	background: #fce4ec;
	color: #c62828;
	border: 1px solid #ef9a9a;
}

/* 閸旂姾娴囬悩鑸碘偓?*/
.loading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 40px;
}

.loading-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid var(--border-color);
	border-top-color: var(--primary-color);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

/* 瀹搞儱鍙跨猾?*/
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-muted { color: var(--text-muted); }
.text-primary { color: var(--primary-color); }
.mt-10 { margin-top: 10px; }
.mt-20 { margin-top: 20px; }
.mb-10 { margin-bottom: 10px; }
.mb-20 { margin-bottom: 20px; }

/* 閸濆秴绨插?*/
@media screen and (max-width: 768px) {
    .form-group input[type='text'],
    .form-group input[type='password'],
    .form-group input[type='email'],
    .form-group input[type='url'],
    .form-group input[type='number'],
    .form-group select,
    .form-group textarea {
        height: 40px;
        font-size: 13px;
    }
    .btn {
        padding: 8px 16px;
        font-size: 13px;
    }
    .tabs .tab-item {
        padding: 10px 15px;
        font-size: 13px;
    }
}

.site-foot {
    display: block !important;
    width: 100%;
    padding: 28px 0 32px !important;
    background: #fafbfc !important;
    border-top: 1px solid #eef0f3 !important;
    text-align: center !important;
    margin: 0 !important;
}
.site-foot__inner {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    max-width: max-content !important;
    gap: 10px !important;
    padding: 0 20px !important;
    flex-wrap: wrap !important;
}
.site-foot__name {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: #333;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.3px;
}
.site-foot__dot { color: #f76234; flex-shrink: 0; font-size: 13px; line-height: 1; }
.site-foot__name-link { color: #333; text-decoration: none; transition: color 0.2s ease; }
.site-foot__name-link:hover { color: #f76234; }
.site-foot__sep { color: #c8ccd1; font-size: 12px; }
.site-foot__beian { color: #8a8f96; font-size: 12px; text-decoration: none; transition: color 0.2s ease; }
.site-foot__beian:hover { color: #f76234; }
@media (max-width: 480px) {
    .site-foot { padding: 22px 0 24px !important; }
    .site-foot__name { font-size: 12px; }
    .site-foot__beian { font-size: 11px; }
}
.home-emoji {
    color: #f76234 !important;
    font-size: 15px;
    margin-right: 4px;
    vertical-align: middle;
    display: inline-block;
    line-height: 1;
    transform: translateY(-1px);
}
.home-card__title-icon.home-emoji {
    font-size: 16px;
}
.home-empty__icon.home-emoji {
    font-size: 32px;
    color: #f76234 !important;
    display: block;
    margin-bottom: 12px;
}
.side-menu-icon.home-emoji {
    font-size: 14px;
    margin-right: 6px;
}
.btn-primary .btn-primary,
.btn-primary .home-emoji,
.btn-primary:hover,
.btn-primary:hover .home-emoji,
.btn-primary:focus,
.btn-primary:focus .home-emoji,
.btn-primary:active,
.btn-primary:active .home-emoji,
.btn-outline,
.btn-outline .home-emoji,
.btn-outline:hover,
.btn-outline:hover .home-emoji,
.btn-danger,
.btn-danger .home-emoji {
    color: #fff !important;
}
.home-emoji {
    margin-right: 4px;
}
.pm-un-wrap {
display: block;
padding: 0 !important;
background: transparent !important;
border: none !important;
border-radius: 0 !important;
}
.pm-un-wrap input {
display: block;
}
.pm-select-link {
display: inline-flex;
align-items: center;
gap: 4px;
margin-top: 10px;
padding: 8px 18px;
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%);
color: #fff !important;
border-radius: 10px;
text-decoration: none;
font-weight: 600;
font-size: 13px;
transition: all 0.2s;
box-shadow: 0 2px 8px rgba(247,98,52,0.2);
}
.pm-select-link:hover {
transform: translateY(-1px);
box-shadow: 0 6px 16px rgba(247,98,52,0.3);
}
.pm-select-link .home-emoji { color: #fff !important; }
.un_selector { padding: 0 !important; background: transparent !important; border: none !important; }
.pm-un-wrap { padding: 0 !important; background: transparent !important; border: none !important; }
.pm-select-link {
display: inline-flex; align-items: center; gap: 4px; margin-top: 10px;
padding: 8px 18px;
background: linear-gradient(135deg, #f76234 0%, #ff8a5c 100%) !important;
color: #fff !important; border-radius: 10px; text-decoration: none; font-weight: 600; font-size: 13px;
transition: all 0.2s; box-shadow: 0 2px 8px rgba(247,98,52,0.2);
}
.pm-select-link:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(247,98,52,0.3); }
.pm-select-link .home-emoji, .pm-select-link i { color: #fff !important; }