.mb-20 {
	margin-bottom: 20px;
}

.mb-30 {
	margin-bottom: 30px !important;
}

.mb-50 {
	margin-bottom: 50px;
}

.data-card {

	border: 1px solid #d8ebfa;
	box-shadow: 4px 2px 12px 0 #d9ecfb;
	/* border-radius: 8px; */
	border-radius: 0px 8px 0px 8px !important;
	/* background-image: linear-gradient(180deg, rgba(251,253,255,0.8) 0%, rgba(244,250,255,0.4) 100%);
	 */
	background-image: linear-gradient(180deg, #fbfdff 0%, #e6f1f9bf 100%);
	/* background-image: linear-gradient(180deg, #fbfdff 0%, #f4faff 100%); */

	background-position: 0 0;
	background-repeat: no-repeat;
	position: relative;
	padding: 20px;
	background-size: 100% 100%;
	min-height: 130px;
	overflow: hidden;
	transition: all 0.3s ease;
}

.data-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background:  no-repeat -12px -12px;
	background-size: 110% auto;
	z-index: 0;
	pointer-events: none;
}

.data-card:hover {
	transform: translatey(-3px);

}

.data-card-statistic {
	position: relative;
	z-index: 1;
	font-weight: bold;
	font-size: 28px;
	color: #1e6ef2;
	display: block;
	text-align: center;
	margin-top: 20px;
}

.data-card-describe {
	position: relative;
	z-index: 1;
	display: block;
	text-align: center;
	color: #666;
	line-height: 36px;
}

/* 自定义tab导航样式 */
.data-nav {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 30px 0 20px 20px;
}

.nav-item {


	border-radius: 10px 0 0 10px;
	padding: 15px 20px;
	cursor: pointer;
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	gap: 12px;
	font-weight: 500;
	color: #495057;
	text-decoration: none;
}

.nav-item:hover {
	transform: translatey(-3px);
	border-color: #4895ef;
}

.nav-item.active {
	/* background: linear-gradient(135deg, #4361ee, #3f37c9); */
	color: #000;
	background-color: #fff;
	border-color: #4361ee;
}

/* 自定义tab内容样式 */
.tab-content-area {
	padding: 30px;
	min-height: 500px;

	border-left: none;
	background: #ffffff;
	border-top: 1px solid #eee;
	border-radius: 10px;
	border-top-left-radius: 0;
}

.tab-pane {
	display: none;
}

.tab-pane.active {
	display: block;
}

/* 自定义子tab样式 */
.sub-tabs {
	margin: 0px 0;
	margin-bottom: 20px;
	border-bottom: 1px solid #e9ecef;
}

.sub-tab-list {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0;
}

.sub-tab-item {
	padding: 12px 25px;
	cursor: pointer;
	font-weight: 500;
	color: #333;
	position: relative;
	transition: all 0.3s ease;
}

.sub-tab-item:hover {
	color: #4361ee;
}

.sub-tab-item.active {
	color: #4361ee;
}

.sub-tab-item.active::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	height: 3px;
	background: #4361ee;
}

.sub-tab-content,
.statistics-container {
	background: #f8f9fa;
	border-radius: 10px;
	padding: 25px;
	margin-top: 20px;
}

.sub-tab-pane {
	display: none;
}

.sub-tab-pane.active {
	display: block;
}

.chart-container {
	width: 100%;
	height: 354px;
}

.year-iframe {
	width: 100%;
	height: 510px;
	border: 0;
	display: block;
}

@media (max-width: 768px) {
	.data-nav {
		flex-direction: row;
		flex-wrap: wrap;
		min-height: 100px !important;
	}

	.nav-item {
		flex: 1 1 calc(50% - 10px);
		margin: 5px;
		padding: 12px 15px;
		font-size: 14px;
	}

	.sub-tab-list {
		flex-wrap: wrap;
	}

	.sub-tab-item {
		flex: 1 1 auto;
		text-align: center;
		padding: 10px 15px;
		font-size: 14px;
	}

	.data-left {
		border-radius: 10px 10px 0 0;
	}

	.data-nav {
		min-height: auto;
		padding: 12px 12px;
	}

	.tab-content-area {
		padding: 16px;
		min-height: auto;
		border-top: none;
		border-radius: 0 0 10px 10px;
	}

	.year-iframe {
		height: 420px;
	}
}

.data-title {
	background:  center no-repeat;
	background-size: auto 65px;
	height: 65px;
	line-height: 65px;
	text-align: center;
	color: #1f6df3;
	font-size: 28px;
	margin-bottom: 30px;
	margin-top: 50px;
}

.data-left {
	background-image: linear-gradient(180deg, #e9f4fd 0%, #afd5f5 100%);
	border-radius: 0px 0 0 10px;
}

.data-nav {

	background:  no-repeat center bottom;
	background-size: 80% auto;


	position: relative;
	min-height: 572px;
}


.data-title-2 {
	font-size: 22px;
	text-align: center;
	margin-bottom: 20px;
}

.data-title-s {
	line-height: 42px;
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 10px;
	position: relative;
	padding-left: 10px;
}

.data-title-s.s {
	font-size: 18px;
	padding-left: 0px;
}

.data-title-s.s #resultdesc {
	color: #999;
	font-size: 16px;
	font-weight: 400;
	margin-left: 6px
}

.data-title-s::before {
	content: "";
	display: inline-block;
	height: 24px;
	background-color: #1f6df3;
	position: absolute;
	left: 0;
	top: 8px;
	bottom: 4px;
	width: 4px;
}

.data-title-s.s::before {
	display: none;
}

.data-container {

	/* border-radius: 10px; */
	border-radius: 0px 8px 0px 8px !important;
	/* border: 1px solid #afd5f5; */
	/* box-shadow: 4px 2px 0 0 #d9ecfb; */
	box-shadow: 4px 2px 12px 0 #d9ecfb;
	margin-bottom: 50px;
}


.data-search-btn {
	background-color: #ff9800;
	color: white;
	border: none;
	padding: 6px 20px;
	border-radius: 4px;
	margin-left: 10px;
	margin-right: 30px;
}

.chart-reset-btn,
.chart-toggle-btn-icon1,
.chart-toggle-btn-icon2 {
	display: inline-block;
	width: 20px;
	height: 20px;
	text-indent: -999em;
	border: none;
	opacity: 0.7;
}

.chart-toggle-btn-icon1 {
	background:  center no-repeat;
	background-size: auto 100%;
}

.chart-toggle-btn-icon2 {
	background:  center no-repeat;
	background-size: auto 100%;
}

.chart-reset-btn {
	background:  center no-repeat;
	background-size: auto 100%;
	margin-right: 30px;
}

.chart-reset-btn:hover,
.chart-toggle-btn-icon1:hover,
.chart-toggle-btn-icon2:hover {
	opacity: 1;
}

.statistics-container {
	margin-bottom: 50px;
}

.statistics-container li {
	/* border-bottom: 1px solid #555; */
	line-height: 50px;

}

.statistics-container li .date {
	color: #999;
}

.filter-bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding: 8px 0;
}

.filter-bar span {
	margin-right: 6px;
}

.filter-bar .form-control {
	display: inline-block;
	width: auto;
	min-width: 96px;
	height: 32px;
	line-height: 32px;
	padding: 4px 8px;
	-webkit-appearance: menulist;
	appearance: menulist;
}

.filter-bar .data-search-btn {
	margin-left: 0;
	margin-right: 10px;
	padding: 6px 14px;
}

.filter-bar .chart-toggle-btn-icon1,
.filter-bar .chart-toggle-btn-icon2,
.filter-bar .chart-reset-btn {
	width: 24px;
	height: 24px;
}

.filter-bar .chart-reset-btn {
	margin-right: 10px;
}

.filter-bar .export-btn {
	flex: 0 0 auto;
}

@media (max-width: 768px) {
	.filter-bar {
		gap: 6px;
	}

	.filter-bar .form-control {
		min-width: 88px;
		height: 32px;
	}

	.filter-bar .data-search-btn {
		padding: 6px 12px;
		margin-right: 8px;
	}

	.filter-bar .chart-toggle-btn-icon1,
	.filter-bar .chart-toggle-btn-icon2,
	.filter-bar .chart-reset-btn {
		width: 28px;
		height: 28px;
	}
}

.latest-data-title {
	position: relative;
}

.latest-data-title .more,
.data-title-s .more {
	position: absolute;
	right: 20px;
	top: 10px;
	color: #999;
	font-size: 16px;
	font-weight: normal;
}

.query-form .form-row {
	display: flex;
	align-items: center;
	margin-bottom: 12px;
}

.query-label {
	flex: 0 0 80px;
}

.query-field {
	flex: 1 1 auto;
}

.query-actions {
	margin-left: 158px;
}

.latest-data {
	overflow: hidden;
	/* 	    border-radius: 8px; */
	border-radius: 0px 8px 0px 8px !important;
	height: 120px;
	border-top: 1px solid #eee;
	border-left: 1px solid #eee;
	/* box-shadow: 7px 7px 25px 0px rgba(220, 220, 220, 0.8); */
	box-shadow: 4px 2px 12px 0 #d9ecfb;
	padding-left: 30px;
}

.latest-data.s {
	background-image: linear-gradient(180deg, #fbfdff 0%, #e6f1f9bf 100%);
}

.latest-data.swiper-container-vertical>.swiper-pagination-bullets {
	right: 30px;
}

.latest-data ul>li {
	padding: 30px;
}

.latest-data ul>li>a {
	display: block;
	line-height: 60px;
	font-size: 24px;
	text-align: center;
	font-weight: bold;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	color: #1777ff;
	outline: none !important;
}

.quick-links {
	display: flex;
	align-items: center;
	justify-content: space-around;
	height: 100%;
	padding: 10px 20px;
}

.quick-link {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	color: #333;
	font-size: 16px;
}

.quick-link img {
	width: 66px;
	height: 64px;
	object-fit: contain;
}

.quick-link-icon {
	display: block;
	width: 40px;
	height: 40px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 40px 40px;
}

.icon-dataset {
	background-image: ;
}

.icon-api {
	background-image: ;
}

.quick-link span {
	margin-top: 8px;
}

.site-header {
	background-color: #4a8df8;
	color: #fff;
}

.header-inner {
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: none;
	box-sizing: border-box;
	padding: 0;
}

.site-logo {
	font-weight: 700;
	color: #fff;
	font-size: 22px;
	background: url(/uploads/image/misjfb/sjfb-logo.png) no-repeat left center;
    padding-left: 60px;
    text-indent: -999em;
    width: 326px;
    height: 50px;
    background-size: auto 44px;
    line-height: 50px;

}

.site-nav a {
	color: #fff;
	text-decoration: none;
	margin-left: 20px;
	font-weight: bold;
	font-size: 18px;
}

.site-nav a:hover {
	opacity: .85;
}

.nav-toggle {
	display: none;
	background: transparent;
	border: none;
	color: #fff;
	font-size: 16px;
}

.site-nav a {
	padding: 8px 12px;
}

.site-nav a.active {
	background: rgba(255, 255, 255, .2);
	border-radius: 4px;

	font-weight: 600;
}

@media (max-width: 768px) {
	.site-header {
		position: relative;
		overflow: visible;
	}

	.site-header .container {
		padding-left: 0;
		padding-right: 0;
	}

	.header-inner {
		height: auto;
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		flex-wrap: wrap;
		padding: 14px 12px;
		position: relative;
	}

	.nav-toggle {
		display: block;
		margin-left: auto;
		align-self: center;
	}

	.site-nav {
		display: flex;
		flex-direction: column;
		width: 100%;
		padding: 10px 0;
		order: 2;
		flex-basis: 100%;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background-color: #4a8df8;
		box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
		border-top: 1px solid rgba(255, 255, 255, 0.2);
		z-index: 1000;
		max-height: 0;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transform: translatey(-6px);
		transition: max-height 0.25s ease, opacity 0.2s ease, transform 0.25s ease;
	}

	.site-nav.open {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		max-height: 80vh;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		transform: translatey(0);
	}

	.site-nav a {
		margin-left: 0;
		padding: 12px 16px;
		display: block;
		margin: 0 12px;
	}

	.nav-toggle {
		width: 40px;
		height: 40px;
		background: transparent;
		border: 1px solid rgba(255, 255, 255, 0.5);
		border-radius: 8px;
		padding: 0;
		display: inline-flex;
		justify-content: center;
		align-items: center;
	}

	.nav-toggle .nav-icon {
		width: 22px;
		height: 2px;
		background: #fff;
		border-radius: 2px;
		position: relative;
		transition: transform 0.25s ease;
	}

	.nav-toggle .nav-icon::before,
	.nav-toggle .nav-icon::after {
		content: '';
		position: absolute;
		left: 0;
		width: 22px;
		height: 2px;
		background: #fff;
		border-radius: 2px;
		transition: transform 0.25s ease, opacity 0.2s ease, top 0.25s ease;
	}

	.nav-toggle .nav-icon::before {
		top: -6px;
	}

	.nav-toggle .nav-icon::after {
		top: 6px;
	}

	.nav-toggle[aria-expanded="true"] .nav-icon {
		transform: rotate(45deg);
	}

	.nav-toggle[aria-expanded="true"] .nav-icon::before {
		transform: rotate(-90deg);
		top: 0;
	}

	.nav-toggle[aria-expanded="true"] .nav-icon::after {
		opacity: 0;
	}
}

.stats-row {
	display: flex;
	flex-wrap: wrap;
	margin-left: -15px;
	margin-right: -15px;
}

.stats-row .col-md-3 {
	float: none;
	flex: 0 0 25%;
	max-width: 25%;
	padding-left: 15px;
	padding-right: 15px;
}

.stats-row .data-card-statistic {
	font-variant-numeric: tabular-nums;
	font-feature-settings: "tnum";
	letter-spacing: 0.2px;
}

@media (max-width: 768px) {
	.inner{
		padding: 20px;
	}
	.stats-row .col-md-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.latest-data-h5 a {
		font-size: 16px !important;
	}
}

@media (max-width: 480px) {
	.inner{
		padding: 16px;
	}
	.stats-row .col-md-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.nav-item {
		flex: 1 1 100%;
		height: 50px;
	}

	.year-iframe {
		height: 360px;
	}

	.latest-data-h5 a {
		font-size: 14px !important;
	}
}

@media (max-width: 768px) {
	.inner{
		padding: 20px;
	}
	.stats-row .data-card {
		min-height: 110px;
		padding: 14px;
		box-shadow: 3px 2px 12px 0 #d9ecfb;
	}

	.stats-row .data-card-statistic {
		font-size: 22px;
		margin-top: 12px;
		font-weight: 600;
	}

	.stats-row .data-card-describe {
		font-size: 12px;
		line-height: 28px;
	}

	.mb-50 {
		margin-bottom: 30px;
	}
}

@media (max-width: 480px) {
	.inner{
		padding: 16px;
	}
	.stats-row .data-card {
		min-height: 80px;
		padding: 8px;
		box-shadow: 2px 1px 6px 0 #d9ecfb;
	}

	.stats-row .col-md-3 {
		padding-left: 8px;
		padding-right: 8px;
	}

	.stats-row .data-card-statistic {
		font-size: 16px;
		margin-top: 6px;
		font-weight: 600;
		letter-spacing: 0.1px;
	}

	.stats-row .data-card-describe {
		font-size: 11px;
		line-height: 20px;
	}
}

/* 数据集列表样式 */
.dataset-item {
	align-items: center;
}

.dataset-tag {
	display: block;
	padding: 14px 16px;
	border-radius: 4px;
	font-weight: 600;
	text-align: center;
	background-color: #e8e8e8;
	color: #666;
}




.dataset-list-item {
	position: relative;
	transition: all 0.3s;
	display: block;
	border-radius: 4px;
	padding: 14px 16px;
	background: #f4faff;
	border: 1px solid #d8ebfa;
	line-height: 36px;
	/* box-shadow: 0 4px 0 0 rgba(220,220,220,0.50); */
	    box-shadow: 4px 2px 12px 0 #d9ecfb;
}
.dataset-list-item:hover{transform: translatey(-3px);}
.dataset-list-item .date {
	position: absolute;
	top: 14px;
	right: 14px;
	color: #bbb;

}
.dataset-list-item a{
	display: inline-block;
}

.channel-tag {
	display: inline-block;
	margin-right: 8px;
	padding: 2px 8px;
	background: #cee7fa;
	color: #1f6df3;
	border: 1px solid #d8ebfa;
	font-size: 12px;
	font-weight: 600
}

.dataset-card {
	display: block;
	padding: 14px 18px;
	border: 1px solid #d8ebfa;
	border-radius: 0px 8px 0px 8px !important;
	background-image: linear-gradient(180deg, #fbfdff 0%, #e6f1f9bf 100%);
	box-shadow: 4px 2px 12px 0 #d9ecfb;
	color: #333;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.dataset-card:hover {
	color: #1f6df3;
}

.dataset-tag.active {
	background-image: linear-gradient(90deg, #6f73f6 0%, #3fa7f5 100%);

}

.dataset-tag.active a {
	color: #fff !important;
}

@media (max-width:768px) {
	.dataset-card {
		font-size: 14px;
		padding: 12px 14px;
	}

	.dataset-tag {
		padding: 10px 12px;
	}
}

/* 数据详情元信息表格与cta */
.dataset-meta-table {
	width: 100%;
	border: 2px solid #e6edf7;

	border-collapse: separate;
	border-spacing: 0;
	background: #fff;
	overflow: hidden;
}

.dataset-meta-table col.label-col {
	width: 140px;
}

.dataset-meta-table td {
	padding: 12px 16px;
	border-right: 2px solid #e6edf7;
	border-bottom: 2px solid #e6edf7;
}

.dataset-meta-table tr td:last-child {
	border-right: none;
}

.dataset-meta-table tr:last-child td {
	border-bottom: none;
}

.dataset-meta-table .meta-label {
	background: #f5f8ff;
	font-weight: 600;
	color: #2f3a4a;
}

.dataset-meta-table .meta-value {
	background: #fff;
	color: #4a4a4a;
}

.dataset-meta-table tbody tr:nth-child(even) td.meta-value {
	background: #fafbff;
}

.cta-row {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin: 40px 0 16px;
}

.cta-btn {
	display: inline-block;
	padding: 10px 28px;
	border-radius: 22px;
	text-decoration: none;
	font-weight: 600;
	min-width: 100px;
	text-align: center;
}

.btn-login {
	background-color: #ff9800;
	color: #fff;
}

.btn-register {
	background-color: #cfe0ff;
	color: #1f6df3;
}

.cta-btn:hover {
	opacity: 0.92;
}

.cta-tips {
	text-align: center;
	font-size: 18px;
	color: #333;
	font-weight: bold;
}

@media (max-width: 768px) {
	.dataset-meta-table col.label-col {
		width: 120px;
	}

	.cta-row {
		margin: 24px 0 12px;
	}

	.cta-tips {
		font-size: 16px;
	}
}

.query-form {
	max-width: 720px;
	margin: 0 auto
}

.query-form .form-row {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 22px
}

.query-label {
	flex: 0 0 140px;
	background: #e9f4fd;
	color: #333;
	border: 1px solid #d8ebfa;
	border-radius: 4px;
	text-align: center;
	height: 44px;
	line-height: 44px;
	font-weight: 600
}

.query-field {
	flex: 1 1 auto
}

.query-select,
.query-input {
	width: 100%;
	height: 40px;
	border: 1px solid #e6e6e6;
	border-radius: 4px;
	padding: 6px 12px
}

.query-actions {
	display: flex;
	align-items: center;
	justify-content: start;
	margin-top: 10px
}

.query-btn {
	background-color: #ff9800;
	color: #fff;
	border: none;
	padding: 10px 28px;
	border-radius: 24px;
	box-shadow: 0 4px 12px rgba(255, 152, 0, .25)
}

.query-reset-btn {
	background: #ddd;
	color: #666;
	border: 1px solid #ddd;
	padding: 10px 18px;
	border-radius: 24px;
	margin-left: 10px
}

.hidden {
	display: none !important
}

.toast-container {
	position: fixed;
	left: 50%;
	transform: translatex(-50%);
	bottom: 20%;
	z-index: 9999;
	pointer-events: none
}

.toast {
	display: inline-block;
	background: rgba(0, 0, 0, .85);
	color: #fff;
	padding: 10px 16px;
	border-radius: 8px;
	opacity: 0;
	transform: translatey(10px);
	transition: opacity .2s ease, transform .2s ease;
	font-size: 14px
}

.toast.show {
	opacity: 1;
	transform: translatey(0)
}

@media (max-width:768px) {
	.query-form {
		max-width: none;
		padding: 0 12px
	}

	.query-label {
		flex-basis: 110px;
		height: 36px;
		line-height: 36px
	}

	.query-select,
	.query-input {
		height: 36px
	}

	.query-actions {
		margin-left: 126px;
	}
}

.footer {
	background-color: #eeeded !important;
	color: #333;
}


.copyright p a,
.copyright p span {
	color: #333;
}

.cta-row-res-meta-label {
	color: #666;
	margin-bottom: 10px;
	font-weight: bold;
}

.cta-row-res {
	padding: 20px;
	background-color: #fafbff;
	border: 0.5px solid #eee;
	margin-top: 20px;
}

.user-name {
	padding-left: 30px;
	background: url(/uploads/image/misjfb/usericon.png) no-repeat 10px center;
	background-size: 16px auto;
	font-weight: bold;
}

.logout-btn {
	background: url(/uploads/image/misjfb/icon-logout.png) no-repeat 10px center;
	background-size: 16px auto;
	padding-left: 28px;
}

.wrap{
	background: url(/uploads/image/misjfb/bg.png) no-repeat center 520px;
	    background-size: 1920px auto;
}