/* Beranda User */
.user-dashboard {
	padding: 12px 6px 24px;
}

.user-hero,
.user-actions {
	background: #ffffff;
	border-radius: 24px;
	box-shadow: 0 18px 40px rgba(32, 76, 122, 0.12);
	overflow: hidden;
}

.user-hero {
	position: relative;
	padding: 28px 24px;
	background: linear-gradient(145deg, #0f6cb9 0%, #0d5a99 55%, #123c69 100%);
	text-align: center;
	color: #ffffff;
}

.user-hero::before,
.user-hero::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	pointer-events: none;
}

.user-hero::before {
	width: 180px;
	height: 180px;
	top: -60px;
	right: -40px;
}

.user-hero::after {
	width: 130px;
	height: 130px;
	bottom: -45px;
	left: -20px;
}

.user-avatar-upload {
	position: relative;
	z-index: 1;
	display: inline-block;
	margin-bottom: 16px;
}

.user-avatar-upload .profile-user-img {
	width: 120px;
	height: 120px;
	object-fit: cover;
	border: 4px solid rgba(255, 255, 255, 0.78);
	box-shadow: 0 12px 28px rgba(6, 26, 46, 0.24);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.user-avatar-upload:hover .profile-user-img {
	transform: translateY(-3px) scale(1.02);
	box-shadow: 0 18px 30px rgba(6, 26, 46, 0.28);
}

.user-avatar-hint {
	position: absolute;
	right: -2px;
	bottom: 6px;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: #ffffff;
	color: #0f6cb9;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 10px 18px rgba(6, 26, 46, 0.2);
	font-size: 15px;
}

.user-hero-name {
	position: relative;
	z-index: 1;
	margin: 0;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.2;
}

.user-hero-meta {
	position: relative;
	z-index: 1;
	margin: 8px 0 0;
	color: rgba(255, 255, 255, 0.88);
	font-size: 15px;
	letter-spacing: 0.3px;
}

.user-hero-badges {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 18px;
}

.user-hero-badge {
	padding: 8px 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.16);
	font-size: 13px;
	font-weight: 600;
}

.user-actions {
	padding: 22px;
}

.user-actions-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-bottom: 18px;
	flex-wrap: wrap;
}

.user-actions-title {
	margin: 0;
	font-size: 24px;
	font-weight: 700;
	color: #17324d;
}

.user-actions-subtitle {
	margin: 0;
	font-size: 14px;
	color: #5f7388;
}

.user-actions-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.action-card {
	position: relative;
	display: block;
	padding: 18px 16px;
	border-radius: 20px;
	background: linear-gradient(180deg, #ffffff 0%, #f6faff 100%);
	border: 1px solid rgba(18, 80, 138, 0.10);
	box-shadow: 0 12px 24px rgba(19, 63, 104, 0.08);
	text-align: center;
	text-decoration: none;
	transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
	overflow: hidden;
}

.action-card:hover,
.action-card:focus {
	text-decoration: none;
	transform: translateY(-4px);
	box-shadow: 0 18px 30px rgba(19, 63, 104, 0.14);
	border-color: rgba(15, 108, 185, 0.24);
}

.action-card-icon {
	width: 72px;
	height: 72px;
	margin: 0 auto 14px;
	border-radius: 22px;
	background: linear-gradient(145deg, rgba(15, 108, 185, 0.12), rgba(15, 108, 185, 0.20));
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.action-card-icon img {
	width: 40px;
	height: 40px;
	object-fit: contain;
}

.action-card-icon i {
	font-size: 36px;
	line-height: 1;
	color: #0f6cb9;
}

.action-card-title {
	display: block;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.25;
	color: #16314c;
}

.action-card-desc {
	display: block;
	margin-top: 6px;
	font-size: 13px;
	line-height: 1.45;
	color: #6f8192;
}

.notify-badge {
	position: absolute;
	right: 12px;
	top: 12px;
	min-width: 26px;
	min-height: 26px;
	padding: 4px 8px;
	background: linear-gradient(135deg, #ff5c74 0%, #df2344 100%);
	color: #ffffff;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
	box-shadow: 0 10px 18px rgba(223, 35, 68, 0.24);
	z-index: 2;
}

/* Beranda Staff */
.staff-dashboard {
	padding: 4px 0 26px;
}

.staff-hero {
	position: relative;
	overflow: hidden;
	border-radius: 26px;
	padding: 28px 28px 24px;
	margin-bottom: 22px;
	background: linear-gradient(135deg, #0f6cb9 0%, #0d5a99 48%, #163b63 100%);
	box-shadow: 0 24px 54px rgba(16, 61, 104, 0.16);
	color: #ffffff;
}

.staff-hero::before,
.staff-hero::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	pointer-events: none;
}

.staff-hero::before {
	width: 220px;
	height: 220px;
	top: -90px;
	right: -60px;
}

.staff-hero::after {
	width: 170px;
	height: 170px;
	bottom: -85px;
	left: -35px;
}

.staff-hero-content,
.staff-hero-side {
	position: relative;
	z-index: 1;
}

.staff-hero-kicker {
	display: inline-block;
	padding: 8px 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.14);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.3px;
	margin-bottom: 14px;
}

.staff-hero-title {
	margin: 0;
	font-size: 34px;
	font-weight: 800;
	line-height: 1.12;
}

.staff-hero-text {
	max-width: 620px;
	margin: 12px 0 0;
	font-size: 15px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.88);
}

.staff-hero-side {
	display: flex;
	justify-content: flex-end;
	align-items: stretch;
	height: 100%;
}

.staff-highlight {
	min-width: 220px;
	padding: 18px;
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
	text-align: left;
}

.staff-highlight-label {
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.7px;
	color: rgba(255, 255, 255, 0.72);
}

.staff-highlight-number {
	margin-top: 10px;
	font-size: 42px;
	font-weight: 800;
	line-height: 1;
}

.staff-highlight-text {
	margin-top: 8px;
	font-size: 14px;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.84);
}

.staff-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
	margin-bottom: 22px;
}

.staff-stat-card {
	position: relative;
	overflow: hidden;
	padding: 22px 18px 18px;
	border-radius: 24px;
	background: linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
	border: 1px solid rgba(20, 76, 132, 0.08);
	box-shadow: 0 16px 34px rgba(16, 61, 104, 0.08);
	transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.staff-stat-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 20px 38px rgba(16, 61, 104, 0.14);
	border-color: rgba(15, 108, 185, 0.16);
}

.staff-stat-card::after {
	content: "";
	position: absolute;
	inset: auto -40px -45px auto;
	width: 130px;
	height: 130px;
	border-radius: 50%;
	background: rgba(15, 108, 185, 0.05);
}

.staff-stat-icon {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: #ffffff;
	box-shadow: 0 12px 24px rgba(15, 108, 185, 0.18);
	margin-bottom: 18px;
}

.is-template .staff-stat-icon { background: linear-gradient(135deg, #1f8df0, #1258b2); }
.is-agenda .staff-stat-icon { background: linear-gradient(135deg, #22b8cf, #137b92); }
.is-batal .staff-stat-icon { background: linear-gradient(135deg, #ff7a59, #e44a2d); }
.is-tracking .staff-stat-icon { background: linear-gradient(135deg, #7d67ff, #4e36d8); }
.is-publikasi .staff-stat-icon { background: linear-gradient(135deg, #16b36b, #0b8554); }
.is-registrasi .staff-stat-icon { background: linear-gradient(135deg, #f3b33d, #ce8300); }

.staff-stat-label {
	display: block;
	font-size: 15px;
	font-weight: 700;
	color: #17324d;
}

.staff-stat-number {
	display: block;
	margin-top: 8px;
	font-size: 34px;
	font-weight: 800;
	line-height: 1;
	color: #0f2f4b;
}

.staff-stat-number.is-empty {
	font-size: 18px;
	font-weight: 700;
	color: #547089;
	letter-spacing: 0.4px;
}

.staff-stat-desc {
	display: block;
	margin-top: 10px;
	font-size: 13px;
	line-height: 1.55;
	color: #667b90;
	min-height: 40px;
}

.staff-stat-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 14px;
	font-size: 13px;
	font-weight: 700;
	color: #0f6cb9;
	text-decoration: none;
}

.staff-stat-link:hover,
.staff-stat-link:focus {
	color: #0c5692;
	text-decoration: none;
}

.staff-info-box {
	border-radius: 24px;
	border: 1px solid rgba(20, 76, 132, 0.08);
	box-shadow: 0 18px 38px rgba(16, 61, 104, 0.08);
	overflow: hidden;
	background: #ffffff;
}

.staff-info-head {
	padding: 18px 22px;
	background: linear-gradient(135deg, #f8fbff 0%, #eef5ff 100%);
	border-bottom: 1px solid rgba(20, 76, 132, 0.08);
}

.staff-info-title {
	margin: 0;
	font-size: 24px;
	font-weight: 800;
	color: #17324d;
}

.staff-info-subtitle {
	margin: 6px 0 0;
	font-size: 14px;
	color: #6b7f92;
}

.staff-info-body {
	padding: 22px;
	font-size: 15px;
	line-height: 1.75;
	color: #314b64;
	background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

@media (max-width: 1199px) {
	.staff-stats-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 991px) {
	.user-dashboard {
		padding-top: 6px;
	}
	.user-hero {
		margin-bottom: 18px;
	}
	.user-actions-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.staff-hero {
		padding: 24px 22px;
	}
	.staff-hero-title {
		font-size: 30px;
	}
	.staff-hero-side {
		justify-content: flex-start;
		margin-top: 18px;
	}
	.staff-stats-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.user-hero {
		padding: 24px 18px;
	}
	.user-hero-name {
		font-size: 24px;
	}
	.user-actions {
		padding: 18px;
	}
	.user-actions-title {
		font-size: 22px;
	}
	.user-actions-grid {
		grid-template-columns: 1fr;
	}
	.action-card {
		padding: 16px 14px;
	}

	.staff-hero-title {
		font-size: 25px;
	}
	.staff-hero-text {
		font-size: 14px;
	}
	.staff-highlight {
		min-width: 0;
		width: 100%;
	}
	.staff-stats-grid {
		grid-template-columns: 1fr;
	}
	.staff-stat-card {
		padding: 18px 16px 16px;
	}
	.staff-info-head,
	.staff-info-body {
		padding: 18px;
	}
}
