label > input[type="file"] {
	display: none;
}

span[validation-for]:empty {
	display: none;
}

span[validation-for] {
	background-color: var(--bs-warning);
	padding: 2px 12px;
	display: inline-block;
	border-radius: 4px;
	font-size: .75rem;
	color: var(--bs-dark);
	margin-top: .25rem;
	text-align: left;
	text-wrap: inherit;
}

.ar-1-1 {
	aspect-ratio: 1/1 !important;
}

.ar-16-9 {
	aspect-ratio: 16/9 !important;
}

.ar-16-75 {
	aspect-ratio: 16/7.5 !important;
}

table.dataTable tbody td.sorting_1 {
	background-color: unset !important;
}

.flex-gap-05 {
	gap: 0.5rem !important;
}

.flex-gap-1 {
	gap: 1rem !important;
}

.datepicker {
	padding: 4px !important;
}

.datepicker td, .datepicker th {
	padding: .4rem;
}

body.vertical-collpsed #side-profile {
	display: none !important;
}

#side-profile a.icon {
	background: var(--bs-white) !important;
	color: var(--bs-primary) !important;
	width: 32px !important;
	height: 32px !important;
	border-radius: 50%;
	text-align: center;
	line-height: 2rem;
}

#side-profile a.icon i {
	color: var(--bs-primary) !important;
}

.img-cover-center {
	object-fit: cover !important;
	object-position: center !important;
}

.text-ellipsis {
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}

/* Teks elipsis 2 baris */
.text-ellipsis-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Teks elipsis 3 baris */
.text-ellipsis-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}


.form-group {
	margin-bottom: .75rem;
}

.cursor-pointer {
	cursor: pointer !important;
}

.text-prewrap {
	white-space: pre-wrap;
}

.select2-container--default .select2-selection--single {
	border-radius: var(--bs-radius) !important;
}

#bottom-nav {
	position: fixed;
	left: 0;
	bottom: 0;
	background: #fff;
	z-index: 10000;
	margin-bottom: 0;
	display: flex;
	width: 100vw;
	box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.15);
}

#bottom-nav li {
	flex: 1 1 0; /* ini yang bikin lebarnya sama */
	text-align: center;
}

#bottom-nav li a {
	text-decoration: none;
	color: var(--bs-white);
	padding: 1rem .25rem;
}

#bottom-nav li a.nuxt-link-active,
#bottom-nav li a.active {
	color: var(--bs-yellow) !important;
	font-weight: bold;
}

.listview {
	list-style: none;
	padding: 0;
	margin: 0;
	background: #fff;
	border-radius: var(--bs-radius);
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
	font-family: sans-serif;
}

.listview li {
	border-bottom: 1px solid #eee;
}

.listview li:last-child {
	border-bottom: none;
}

.listview li a {
	display: flex;
	align-items: center;
	padding: 12px 16px;
	color: var(--bs-body);
	text-decoration: none;
	transition: background 0.2s, color 0.2s;
}

.listview li a i {
	margin-right: 12px;
	color: var(--bs-primary);
	min-width: 20px;
	text-align: center;
}

.listview li a:hover {
	background: #f9f9f9;
	color: #000;
}

.data-listview {
	list-style: none;
	padding: 0;
	margin: 0;
}

.data-listview li {
	padding: 0;
	margin: 0;
	margin-bottom: 1rem;
}

.data-listview button {
	border: none;
	cursor: pointer;
	width: 100%;
	background: var(--bs-white);
	border-radius: var(--bs-radius);
	margin: 0;
	overflow: hidden;
	display: flex;
	padding: 1rem;
	gap: 1rem;
	align-items: center;
}

#__layout {
	overflow: hidden;
}

.skeleton {
  background-color: #e2e2e2;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}

/* Shimmer effect */
.skeleton::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  height: 100%;
  width: 100%;
  background: linear-gradient(to right, transparent 0%, #f5f5f5 50%, transparent 100%);
  animation: shimmer 1.2s infinite;
}

@keyframes shimmer {
  100% {
    left: 100%;
  }
}

/* Variasi skeleton */
.skeleton.skeleton-text {
  height: 1rem;
  margin-bottom: 0.5rem;
}

.skeleton.skeleton-avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  flex-shrink: 0;
}

.skeleton.skeleton-line {
  height: 0.75rem;
  margin-bottom: 0.5rem;
}

.skeleton.skeleton-title {
  height: 1.5rem;
  width: 80%;
  margin-bottom: 0.75rem;
}

.skeleton.skeleton-thumbnail {
  width: 100%;
  height: 180px;
  border-radius: 8px;
  margin-bottom: 1rem;
}

.skeleton.skeleton-button {
  height: 2.2rem;
  width: 120px;
  border-radius: 25px;
}

.skeleton.skeleton-badge {
  height: 1rem;
  width: 60px;
  border-radius: 6px;
}

.skeleton.skeleton-icon {
  height: 24px;
  width: 24px;
  border-radius: 4px;
}

.skeleton.skeleton-card {
  width: 100%;
  padding: 1rem;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.owl-theme .owl-controls .owl-page span {
  background: #007bff !important;
}
.owl-theme .owl-controls .owl-buttons div {
  color: #fff !important;
  background: #007bff !important;
  padding: 5px 15px;
  border-radius: 50%;
}

.bg-card-profile {
    background: linear-gradient(to right, var(--bs-warning), var(--bs-warning), var(--bs-danger));
}

.navbar-header .dropdown .show.header-item {
    background-color: #00000021 !important;
}

.bg-main-content {
    background: var(--bs-primary);
    width: 100%;
    height: 240px;
    position: absolute;
    top: 0;
    left: 0;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--bs-white);
}

.sidebar-admin .vertical-menu {
	background: var(--bs-primary);
}

.sidebar-admin .vertical-menu [data-simplebar] {
    background: var(--bs-primary-hover);
    border-top-right-radius: var(--bs-radius);
}

.sidebar-admin #sidebar-menu ul li a,
.sidebar-admin #sidebar-menu ul li a i,
.sidebar-admin #sidebar-menu ul li ul.sub-menu li a,
.menu-title {
    color: var(--bs-white);
}

.sidebar-admin #sidebar-menu ul li ul.sub-menu li a:hover,
.sidebar-admin #sidebar-menu ul li a:hover,
.sidebar-admin #sidebar-menu ul li a:hover i,
.mm-active > a {
    color: var(--bs-primary-light) !important;
}

.sidebar-admin #sidebar-menu .nuxt-link-exact-active,
.sidebar-admin #sidebar-menu .nuxt-link-exact-active i {
	background: var(--bs-warning);
    color: var(--bs-white) !important;
    border-top-right-radius: var(--bs-radius);
    border-bottom-right-radius: var(--bs-radius);
}

.sidebar-admin #sidebar-menu .nuxt-link-exact-active:hover,
.sidebar-admin #sidebar-menu .nuxt-link-exact-active:hover i {
	color: var(--bs-white) !important;
}