html {
    height: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: 'Poppins', sans-serif;
    background-color: #fff;
    overflow-x: hidden;
    color: #243a4a;
    height: 100vh;
    width: 100vw;
    margin: 0;
}

.font-caveat {
    font-family: 'Caveat', cursive !important;
}

.font-comforta {
    font-family: 'Comfortaa', cursive !important;
}

.font-ds {
    font-family: 'Dancing Script', cursive !important;
}

.font-lato {
    font-family: 'Lato', sans-serif !important;
}

.font-libre {
    font-family: 'Libre Baskerville', serif !important;
}

.font-lora {
    font-family: 'Lora', serif !important;
}

.font-noto {
    font-family: 'Noto Sans JP', sans-serif !important;
}

.font-poppins {
    font-family: 'Poppins', sans-serif !important;
}

.font-shippori {
    font-family: 'Shippori Mincho B1', serif !important;
}

.font-amatic {
    font-family: 'Amatic SC', cursive;
}

.font-code {
    font-family: Consolas, 'Liberation Mono', Courier, monospace !important;
}

.text-biasa{
    color: #243a4a !important;
}

.text-primary {
    color: #6c3c97 !important;
}

.text-secondary {
    color: #aaa8b3 !important;
}

.text-dark {
    color: #4C4C4C !important;
}

.text-white {
    color: #ffffff !important;
}

.text-black {
    color: #343138 !important;
}

.text-red{
    color: #F50057 !important;
}

.text-danger{
    color: #F50057 !important;
}

.text-warning{
    color: #fb6340 !important;
}

.text-yellow {
    color: #FBDF12 !important;
}

.bg-primary{
    background-color: #6c3c97 !important;
}

.bg-secondary{
    background-color: #f3efef !important;
}

.bg-blue{
    background-color: #20ceec !important;
}

.bg-dark-blue{
    background-color: #243a4a !important;
}

.bg-danger {
    background-color: #fb6340 !important;
}

.bg-warning {
    background-color: #fb6340 !important;
}

.bg-yellow {
    background-color: #FBDF12 !important;
}

.bg-success {
    background-color: #2d9b5b !important;
}

.bg-transparent{
    background: transparent !important;
    border: 0px;
}

.bg-trans{
    background: transparent !important;
    border: 0px;
}

.bg-gold{
    background: rgb(174,134,37) !important;
    background: linear-gradient(90deg, rgba(174,134,37,1) 0%, rgba(247,239,138,1) 54%, rgba(210,172,71,1) 87%) !important;
}

.progress {
    background: transparent;
    margin: 0px !important;
    position: fixed !important;
    top: 0px;
    z-index: 99999;
    width: 100% !important;
    left: 0px !important;
}

.nav-container {
    width: 99% !important;
    margin: 0 auto !important;
}

.dash-container {
    width: 95% !important;
    margin: auto !important;
}

.container {
    width: 90% !important;
}

.valign {
    display: flex;
    align-items: center;
    justify-content: center;
}

.nomarg {
    margin: 0 0 0 0 !important;
    padding: 0 0 0 0 !important;
}

strong {
    font-weight: bolder;
}

.strong {
    font-weight: bolder;
}

.coret{
    text-decoration: line-through;
}

.main-area{
    width: 100%;
    height: 100vh;
}

.samping{
    position:fixed;
    height: 100%;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    display: flex;
    align-items: center;
    justify-content: center;
    right: -30px;
    z-index: 3;
}

.samping a{
    transform: rotate(-90deg);
    color: #502f77;
    letter-spacing: 1px;
    font-weight: bold;
    font-size: 15px;
}

.strip{
    position: fixed;
    background-color: #6c3c97;
    height: 30px;
    width: 100%;
    z-index: 3;
}

/* Navigation */
.nav{
    position: fixed;
    background-color: #fff;
    box-shadow: none;
    top: 30px;
    padding-top: 11px;
    height: 85px;
    z-index: 2;
}

.nav .brand img {
    width: 65px;
}

.nav ul {
    padding-top: 5px;
    padding-left: 0;
    list-style-type: none;
}

.nav ul li a {
    font-size: 14px;
    color: #2E2C2F;
    font-weight: bolder;
    letter-spacing: 0.6px;
}

.nav ul li a:hover,
.nav ul li a:focus,
.nav ul li a:active {
    color: #6c3c97;
    background-color: transparent;
}

.dropdown-trigger i {
    font-size: 10px !important;
    margin-left: 3px;
}

#dropdown-layanan {
    width: auto !important;
    max-width: 380px !important;
    right: 10px;
    background-color: #F7F7F7;
}

#dropdown-resource {
    width: auto !important;
    max-width: 190px !important;
    right: 10px;
    background-color: #F7F7F7;
}

#dropdown-auth {
    width: auto !important;
    max-width: 230px !important;
    right: 10px;
    background-color: #F7F7F7;
}

#dropdown-auth-dash {
    width: auto !important;
    max-width: 250px !important;
    right: 330px !important;
    background-color: #F7F7F7;
}

.dropdown-content {
    -webkit-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.15);
    box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.15);
    z-index: 1002;
    opacity: 0;
    position: absolute;
    top: -55px;
    text-align: right;
    background: #fff;
    padding: 0px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    border-radius: 4px;
    -webkit-transition: 0s;
    -o-transition: 0s;
    transition: 0s;
}

.dropdown-content li {
    min-height: 10px !important;
    margin-top: 0px;
    text-align: left !important;
}

.dropdown-content li a .small {
    font-size: 12px !important;
    line-height: 0px !important;
}

.dropdown-content li a i {
    margin-right: 1px;
    font-size: 20px;
}

.dropdown-content li a .icon-left {
    margin-right: 20px !important;
}

.nav .nav-profile img {
    width: 33px;
    margin-left: 13px;
}

/* Header */
.header{
    width: 100%;
    height: 100%;
}

.header-text {
    padding-top: 90px;
    padding-right: 50px;
}

.header-text h3 {
    font-size: 39px;
    line-height: 55px;
    font-weight: 500;
}

.header-text p {
    padding-top: 22px;
    margin-bottom: 25px;
    color: #4a4a4b;
    font-size: 15px;
    line-height: 21px;
    max-width:430px;
}

.header-text a i {
    font-size: 13px;
    font-weight: bold;
    margin-left: 5px;
}

.header-image img{
    padding-top: 60px;
    padding-right: 10px;
    width: 80%;
}

/* Section */
.first-section {
    padding-top: 180px;
    padding-bottom: 80px;
}

.dash-section {
    padding-top: 160px;
    padding-bottom: 40px;
}

.section {
    padding-top: 60px;
    padding-bottom: 60px;
}

.section-title {
    max-width: 720px;
    margin: auto;
}

.section-content h1 {
    font-size: 38px;
    line-height: 57px !important;
}

.section-content h2 {
    font-size: 30px;
    line-height: 43px !important;
}

.section-content h3 {
    font-size: 27px;
    line-height: 38px !important;
}

.section-content h4 {
    font-size: 21px;
    line-height: 32px !important;
}

.section-content h5 {
    font-size: 18px;
    line-height: 30px !important;
}

.section-content p {
    font-size: 15px;
    line-height: 24px;
}

.section-content a {
    font-size: 14px;
}

.section-content .small {
    font-size: 13.5px;
    line-height: 20px;
}

.section-content .icon-head {
    font-size: 24px;
}

.content-right {
    max-width: 500px;
}

.img-left {
    text-align: left;
}

.img-left img {
    width: 75%;
    margin-left: -25px;
}

/*Why*/
.why {
    text-align: center;
    padding-top: 70px;
}

.why i {
    font-size: 40px;
}

.why .title {
    font-size: 15px;
    line-height: 22px;
    font-weight: bold;
    padding-top: 20px;
}

.why .col {
    padding-top: 40px;
    padding-right: 25px;
    padding-left: 25px;
}

.why .content {
    font-size: 15px;
    line-height: 22px;
}

/* Tech */
.tech{
    padding-top: 70px;
}

.tech i{
    font-size: 22px;
    margin: auto !important;
}

.tech .col{
    margin-bottom: 60px;
    height: 150px;
    margin-top: 40px;
    padding-right: 17px;
    padding-left: 17px;
}

.tech p {
    font-size: 15px;
    line-height: 24px;
}

.tech .title {
    margin-top: 25px;
    margin-bottom: 15px;
    font-weight: bold !important;
}

.how{
    padding-top: 70px;
    max-width: 1150px;
    margin: auto;
}

.how .col{
    padding-left: 20px;
    padding-right: 20px;
}

.img-payment {
    height: 17px;
    margin-right: 10px;
    margin-bottom: 10px;
}

.plant {
    max-width: 300px;
    text-align: right
}

/*Testimoni*/
.section-testi {
    padding-top: 100px;
    width: 90%;
    max-width: 600px;
    margin: auto;
}

.section-testi img {
    width: 60px !important;
    margin: auto !important;
    padding-bottom: 25px;
}

/* Footer */
.section-footer .right-footer{
    float: right;
}

.section-footer a{
    font-weight: bolder;
}

/* Collapsible FAQ */
.faq{
    padding-top: 40px;
}

.faq ul{
    padding-left: 0px;
}

.faq li{
    list-style: none;
    padding-left: 0px !important;
}

/*Paralax*/
.parallax {
    position: relative !important;
    background-attachment: fixed !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    min-height: 100% !important;
}

@media only screen and (max-device-width: 1366px) {
    .parallax {
        background-attachment: scroll;
    }
}

.paralax-end {
    background: url('/images/ava/bgf-pc.svg');
}

/*Kelas*/
.kelas{
    max-width: 900px;
    margin: auto;
    padding-top: 30px;
}

.kelas .item{
    padding-top: 40px;
    border-bottom: 1px solid #243a4a;
    padding-bottom: 50px;
}

.kelas .item .detail{
    padding-left: 30px !important;
}

.kelas .item .detail p{
    font-size: 15px;
}

/* Project */
.project-right{
    margin-left: -30px !important;
}

.project-grid{
    margin-top: 40px;
}

.project-grid .col{
    margin-bottom: 10px;
}

.project-grid .card{
    box-shadow: none !important;
    outline: none !important;
    border-radius: 10px !important;
    color: #243a4a;
    border: 1px solid #243a4a;
}

.project-grid .card .card-content{
    padding: 15px;
}

.project-grid .card .card-image img{
    border-top-left-radius: 10px !important;
    border-top-right-radius: 10px !important;
}

.project-grid .card .card-title{
    font-size: 15px;
    line-height: 22px;
    font-weight: 700;
    padding-bottom: 15px !important;
}

.project-grid .card .card-content{
    padding-top: 17px !important;
    padding-bottom: 17px !important;
    color: #000000;
}

.project-grid .card .card-content .sub-title{
    font-size: 11px;
    line-height: 15px;
}

.project-promo{
    text-decoration: line-through;
    font-size: 9px;
}

.project-promo-big{
    text-decoration: line-through;
    font-size: 12px;
}

.list-modul{
    margin-top: 20px;

    flex: 1;
    overflow-y: scroll; /* scroll tetap aktif */
    padding-right: 10px;

    /* sembunyikan scrollbar di semua browser */
    -ms-overflow-style: none;  /* IE dan Edge lama */
    scrollbar-width: none;     /* Firefox */
}

.list-modul .card{
    box-shadow: none;
    border: 1px solid #c9c9c9;
    color: #c9c9c9;
    border-radius: 5px;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 15px;
    padding-right: 15px;
    font-size: 12px;
}

.list-modul .active{
    border: 1px solid #142735;
    color: #142735;
}

.list-modul::-webkit-scrollbar {
    display: none; /* Chrome, Safari */
}

/* Card Modul */
.card-modul{
    box-shadow: none !important;
    outline: none !important;
    margin-top: 40px;
}

.card-modul .card-header{
    padding: 16px;
    border: 1.5px solid #243a4a;
    border-top-right-radius: 20px !important;
    border-top-left-radius: 20px !important;
    border-bottom: 0px !important;
}

.card-modul .card-footer{
    padding: 15px;
    border: 1.5px solid #243a4a;
    border-bottom-right-radius: 20px !important;
    border-bottom-left-radius: 20px !important;
    border-top: 0px !important;
}

.search-modul{
    border-radius: 10px !important;
    border: 1.5px solid #243a4a;
    height: 30px;
    margin-top: -10px;
    margin-right: -5px;
    width: 300px;
    padding: .625rem .75rem;
}

.table-modul tr td{
    border: 1.5px solid #243a4a;
    padding: 12px;
}

.table-modul .row i{
    font-size: 15px; 
    color: #4a5e6d;
    letter-spacing: 0px;
}

.judul-modul{
    font-size: 15px !important;
}

/* Blog */
.nav-blog {
    padding-top: 15px;
}

.nav-blog a {
    margin-right: 10px;
    font-weight: bold;
    font-size: 14px;
    display: inline-block;
}

.nav-blog .fi {
    font-size: 12px !important;
    margin-left: 2px;
    font-weight: bold;
}

.side-blog{
    position:fixed;
    width: 20%;
    padding-right:40px;
    padding-top: 10px;

    height: calc(100vh - 280px); /* penuh setinggi layar */
    display: flex;
    flex-direction: column;
}

.side-blog ul{
    padding-inline-start: 0px !important;
    list-style-type: none;
}

.side-blog ul li{
    line-height: 20px;
    padding-top: 10px;
}

.side-blog ul li a{
    font-size: 14px !important;
    color: #243a4a;
}

.blog-content{
    max-width: 850px;
    margin: auto;
}

/* Detail Konten */
.detail-content{
    margin-top: 40px;
}

.detail-content p{
    font-size: 16px;
    line-height: 27px !important;
    padding-top: 10px;
}

.detail-content a{
    font-weight: bold !important;
}

.detail-content ul,
.detail-content ol{
    padding-top: 0px;
}

.detail-content ul li,
.detail-content ol li{
    font-size: 16px;
    line-height: 27px !important;
    padding-left: 10px;
    padding-top: 10px;
}

.detail-content blockquote{
    margin-top: 30px;
    font-size: 16px;
    line-height: 27px !important;
}

.detail-content h1,
.detail-content h2,
.detail-content h3,
.detail-content h4,
.detail-content h5,
.detail-content h6{
    font-size: 28px;
    line-height: 35px !important;
    padding-top: 20px;
}

.detail-content .img-left{
    align-items: left !important;
    justify-content: left !important;
    margin: none !important;
    display:inline !important;
}

.detail-content img {
    padding-top: 10px;
    padding-bottom: 5px;
    max-width: 100% !important;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
}

.detail-content .note{
    border: 1px solid #000000;
    border-radius: 10px;
    padding-right: 30px;
    padding-left: 30px;
    margin-top: 30px;
    margin-bottom: 20px;
}

.detail-content .note p{
    padding-top: 0px;
}

.detail-right{
    z-index: 3;
    position: fixed;
    right: 5.5%;            /* Jarak dari kanan 10% */
    top: 55%;              /* Posisikan dari atas di 50% */
    transform: translateY(-50%); /* Geser ke atas setengah tinggi elemen agar benar-benar center */
}

/* Section Dropdown */
.detail-dropdown-wrapper{
    position: fixed;
    top: 200px;
    right: 5.5%; 
    z-index: 4;
}

.section-dropdown {
    position: absolute;
    right: calc(100% + 15px); /* jarak 10px dari tombol */
    top: 0;                   /* mulai dari bagian atas tombol */
    background: white;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    padding: 8px 0;
    min-width: 160px;
    display: none;
    z-index: 999;
}

.section-dropdown ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.section-dropdown li {
    padding: 5px 15px;
    cursor: pointer;
    font-size: 13px;
    color: #333;
}

.section-dropdown li:hover {
    background: #f3f4f6;
}

table{
    margin-top: 20px;
    font-size: 14px;
}

/* Pandas Table */
table::-webkit-scrollbar {
    height: 5px;
    background: transparent !important;
}

table::-webkit-scrollbar-thumb {
    background: #7a7878;
    border-radius: 10px;
}

.detail-content table{
    margin-bottom: 20px;
}

.pandas{
    margin-bottom: 20px;
    max-width: 100% !important;;
    overflow-x:scroll !important;
    position: relative;
    display: block;
}

.pandas-min{
    font-size: 11px;
}

.pandas tbody tr:first-child td{  
    background-color: #f5f5f5;
    font-weight: bolder;
}

.pandas tbody tr td:first-child{
    padding-left: 10px !important;
    padding-right: 10px !important;
    text-align: center;
}

.pandas tbody tr td{
    border: 1px solid rgba(0, 0, 0, 0.2);
    padding: 5px;
}

.pandas-auto{
    width: auto !important;
    max-width: 100%;
}

.pandas-auto td{
    padding-left: 10px !important;
    padding-right: 10px !important;
    text-align: center;
}

.pandas .top-red{
    border-top: 2px solid rgb(187, 19, 47);;
}

.pandas .right-red{
    border-right: 2px solid rgb(187, 19, 47);;
}

.pandas .left-red{
    border-left: 2px solid rgb(187, 19, 47);;
}

.pandas .bottom-red{
    border-bottom: 2px solid rgb(187, 19, 47);;
}

/* Table Keterangan */
.tabel-keterangan{
    margin-bottom: 20px;
    max-width: 100% !important;;
    overflow-x:scroll !important;
    position: relative;
    display: block;
}

.tabel-keterangan tbody tr:first-child td{  
    background-color: #f5f5f5;
    font-weight: bolder;
}

.tabel-keterangan tbody tr td:first-child{
    padding-left: 10px !important;
    padding-right: 10px !important;
}

.tabel-keterangan tbody tr td{
    border: 1px solid rgba(0, 0, 0, 0.2);
    padding: 5px;
}

/* Tabel 100 */
.tabel-100 tbody tr:first-child td{  
    background-color: #f5f5f5;
    font-weight: bolder;
}

.tabel-100 tbody tr td:first-child{
    padding-left: 10px !important;
    padding-right: 10px !important;
}

.tabel-100 tbody tr td{
    border: 1px solid rgba(0, 0, 0, 0.2);
    padding: 5px;
}

/* Pre Code */
pre{
    font-size: 14px !important;
    margin-top: 25px !important;
    margin-bottom: 20px !important;

    padding-bottom: 5px !important;
    overflow-x: scroll;
    overflow-y: auto;
}

pre::-webkit-scrollbar:vertical {
    width: 0px;
    display: none;
}

code{
    font-size: 14px !important;
    border-radius: 10px !important;
}

.c-out{
    background-color: #ffffff;
    border: 1px solid #646464;
    border-radius: 5px;
    color:#333333
}

.out-out{
    margin-bottom: 10px !important;
}

blockquote {
    margin: 20px 0;
    padding-left: 1.5rem;
    border-left: 5px solid #000000;
}

/*auth*/
.auth {
    height: 100%;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    position: relative;
    background-color: #502f77;
}

.auth .row {
    margin: 0px !important;
}

.side-auth{
    width: 100%;
    height: 100vh;
}

.radio-section .col {
    padding-left: 0px !important;
}

.auth .bg-img {
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
}

.auth .auth-content {
    width: 85%;
    margin: auto;
}

.auth .auth-content p {
    font-size: 15px;
    line-height: 20px;
    margin-top: 0px !important;
    margin-bottom: 10px !important;
}

.auth .auth-content h3 {
    font-size: 28px;
    line-height: 30px;
    margin-top: 0px !important;
    margin-bottom: 30px !important;
}

.auth .auth-content .min p {
    font-size: 14px;
    line-height: 18px;
    margin-top: 0px !important;
    margin-bottom: 3px !important;
}

.auth .input-field input {
    background: transparent;
    color: #ffffff;
}

.auth .input-field label {
    color: #ffffff;
}

.auth .input-field input[type=email]:focus+label,
.auth .input-field input[type=password]:focus+label,
.auth .input-field input[type=text]:focus+label,
.auth .input-field input[type=number]:focus+label {
    color: #ffffff;
    font-weight: bold;
}

.auth .input-field input[type=email]:focus,
.auth .input-field input[type=password]:focus,
.auth .input-field input[type=text]:focus,
.auth .input-field input[type=number]:focus {
    border-bottom: 1px solid #ffffff;
    box-shadow: 0 1px 0 0 #ffffff;
}

.auth [type="radio"]:not(:checked)+span:before,
.auth [type="radio"]:not(:checked)+span:after {
    border: 2px solid #ffffff !important;
}

.auth [type="radio"]:checked+span:after,
.auth [type="radio"].with-gap:checked+span:before,
.auth [type="radio"].with-gap:checked+span:after {
    border: 2px solid #ffffff;
}

.auth [type="radio"]:checked+span:after,
.auth [type="radio"].with-gap:checked+span:after {
    background-color: #ffffff;
}

/* Form */
.form-search,
.select2-container .select2-selection--single {
    font-size: .875rem;
    font-weight: 400;
    line-height: 1.5;
    display: block;
    width: 100%;
    height: calc(1.5em + 1.25rem + 2px);
    padding: .625rem .75rem;
    transition: all .15s cubic-bezier(.68, -.55, .265, 1.55);
    color: #363636;
    border: 1px solid #acacac;
    border-radius: .25rem;
    background-color: #fff;
    background-clip: padding-box;
    box-shadow: 0 3px 2px rgba(233, 236, 239, .05);
}

.area-tulis {
    font-size: .875rem;
    font-weight: 400;
    line-height: 1.5;
    display: block;
    width: 100%;
    height: 100%;
    max-height: 150px;
    padding: .625rem .75rem;
    transition: all .15s cubic-bezier(.68, -.55, .265, 1.55);
    color: #363636;
    border: 1px solid #dee2e6;
    border-radius: .25rem;
    background-color: #fff;
    background-clip: padding-box;
    box-shadow: 0 3px 2px rgba(233, 236, 239, .05);
}

.form-search:focus {
    border-color: #9150CB;
    outline: 0;
    background-color: #fff;
    box-shadow: 0 3px 9px rgba(50, 50, 9, 0), 3px 4px 8px rgba(94, 114, 228, .1);
}

.area-tulis:focus {
    border-color: #9150CB;
    outline: 0;
    background-color: #fff;
    box-shadow: 0 3px 9px rgba(50, 50, 9, 0), 3px 4px 8px rgba(94, 114, 228, .1);
}

.form-text{
    line-height: 19px !important;
    font-size: 12px !important;
}

.select2-search--dropdown .select2-search__field{
    border-radius: .25rem !important;
    height: 2.5rem !important;
    font-size: 12px !important;
}

form [type="radio"]:not(:checked)+span:before,
form [type="radio"]:not(:checked)+span:after {
    border: 2px solid #9150CB !important;
}

form [type="radio"]:checked+span:after,
form [type="radio"].with-gap:checked+span:before,
form [type="radio"].with-gap:checked+span:after {
    border: 2px solid #9150CB;
}

form [type="radio"]:checked+span:after,
form [type="radio"].with-gap:checked+span:after {
    background-color: #9150CB;
}

[type="checkbox"]:checked+span:not(.lever):before{
    border-right: 2px solid #9150CB;
    border-bottom: 2px solid #9150CB;
}

.file-field .btn {
    padding: 0 10px; /* Mengurangi padding dalam tombol */
    font-size: 12px; /* Memperkecil ukuran font */
    height: 30px; /* Menyesuaikan tinggi tombol */
    line-height: 30px; /* Menyesuaikan garis vertikal */
}

/* Memperkecil tinggi input teks */
.file-path-wrapper input {
    height: 30px; /* Sesuaikan tinggi input teks */
    font-size: 12px; /* Ukuran teks lebih kecil */
}


/* Button */
.btn {
    text-transform: capitalize;
    margin-top: 5px;
    margin-right: 8px;
    border-radius: 5px;
    font-weight: bold;
}

.btn:hover,
.btn:active,
.btn:focus {
    box-shadow: none;
    outline: none;
}

.btn-rounded{
    border-radius: 50px !important;
    display: inline-flex;          /* aktifkan flexbox untuk konten dalam tombol */
    align-items: center;           /* rata tengah secara vertikal */
    justify-content: center;       /* rata tengah secara horizontal */
    text-align: center;  
}

.btn-xs {
    height: 28px;
    line-height: 28px;
    font-size: 13px !important;
}

.btn-noshad {
    background-color: #ffffff !important;
    color: #243a4a !important;
    box-shadow: none !important;
    outline: none !important;
}

.btn-nopad{
    padding-left: 5px;
    padding-right: 5px;
}

.btn-justnoshad {
    box-shadow: none !important;
    outline: none !important;
}

.btn-primary {
    background-color: #6c3c97;
    color: #ffffff !important;
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus {
    background-color: #6c3c97 !important;
    color: #ffffff !important;
}

.btn-secondary {
    background-color: #ffffff !important;
    color: #343138 !important;
}

.btn-secondary:hover,
.btn-secondary:active,
.btn-secondary:focus {
    background-color: #fafafa !important;
    color: #343138 !important;
}

.btn-white {
    background-color: #ffffff !important;
    color: #6c3c97;
}

.btn-white:hover,
.btn-white:active,
.btn-white:focus {
    background-color: #fafafa !important;
    color: #6c3c97;
}

.btn-abu{
    background-color: #eeeded !important;
    color: #6c3c97;
    box-shadow: none;
    outline: none;
}

.btn-abu:hover,
.btn-abu:active,
.btn-abu:focus {
    background-color: #ece9e9 !important;
    color: #6c3c97;
}

.btn-cta{
    color: #ffffff !important;
    background-color: #6c3c97;
    border-radius: 45px;
    position: fixed;
    bottom: 20px;
    right: 30px;
    margin: auto;
    z-index: 4;
}

.btn-cta:hover,
.btn-cta:active,
.btn-cta:focus {
    color: #ffffff !important;
    background-color: #6c3c97;
    box-shadow: 0 2px 2px 0 rgb(0 0 0 / 14%), 0 3px 1px -2px rgb(0 0 0 / 12%), 0 1px 5px 0 rgb(0 0 0 / 20%) !important;
}

/* Badge */
.badge-new{
    position: absolute !important;
    top: 7px;
    right: 3px;
    height: 15px !important;
    background-color: #FBDF12;
    line-height: 15px !important;
    color: #6c3c97 !important;
    font-size: 10px !important;
    border-radius: 3px;
    letter-spacing: .5px;
}

.badge-you{
    height: 15px !important;
    padding-left: 7px;
    padding-right: 7px;
    background-color: #FBDF12;
    line-height: 15px !important;
    color: #6c3c97 !important;
    font-size: 10px !important;
    font-weight: 700;
    border-radius: 3px;
    letter-spacing: .5px;
}

.badge-project{
    height: 15px !important;
    background-color: #ffffff;
    line-height: 15px !important;
    color: #303030 !important;
    font-size: 9px !important;
    border-radius: 6px;
    letter-spacing: .5px;
    float:none !important;
    margin-left: 0px !important;
    margin-right: 5px !important;
    margin-bottom: 5px !important;
    display: inline-block;
}

.badge-hot{
    height: 15px !important;
    padding-left: 2px;
    padding-right: 2px;
    background-color: rgb(240, 108, 67);
    line-height: 15px !important;
    color: #ffffff !important;
    font-size: 10px !important;
    font-weight: 700;
    border-radius: 3px;
    letter-spacing: .5px;
}

.badge-lunas{
    height: 15px !important;
    padding-left: 7px;
    padding-right: 7px;
    background-color: #6c3c97;
    line-height: 15px !important;
    color: #ffffff !important;
    font-size: 10px !important;
    font-weight: 700;
    border-radius: 3px;
    letter-spacing: .5px;
}

.dot {
    height: 5px;
    width: 5px;
    position: absolute;
    top: 3px !important;
    margin-left: 3px;
    background-color: #bbb;
    border-radius: 50%;
    display: inline-block;
}

.badge-tag{
    height: 15px !important;
    background-color: #f5f5f5;
    line-height: 15px !important;
    color: #243a4a;
    font-size: 10px !important;
    border-radius: 3px;
    letter-spacing: .5px;
    float:none !important;
    margin-left: 0px !important;
    margin-right: 5px !important;
    margin-top: 10px;
}

.badge-tag:hover{
    color: #243a4a !important;
    background-color: #ebe8e8;
}

.badge-word{
    height: 15px !important;
    background-color: #f5f5f5;
    line-height: 15px !important;
    font-size: 10px !important;
    border-radius: 3px;
    letter-spacing: .5px;
    float:right !important;
    margin-left: 10px !important;
    margin-top: 8px !important;
}

.modal-konfirmasi{
    background-color: #f6f2fa;
    border-radius: 10px;
    max-width: 90%;
    width: 400px;
    top: 50% !important;
    transform: translateY(-50%) !important;
    max-height: 90% !important;
}

/* Alert */
.alert {
    position: relative;
    margin-bottom: 1rem;
    padding: 1rem 1.5rem;
    border: 1px solid transparent;
    border-radius: 10px !important;
    color: #ffffff;
}

.alert p{
    font-size: 1rem !important;
}

.alert-la{
    position: fixed !important;
    right: 0px !important;
    bottom: -20px !important;
    z-index: 99999;
    width: 100% !important;
    height: auto !important;
    border-radius: 0px !important;
}

.alert-announcement{
    position: fixed;
    background-color: transparent;
    width:90%;
    max-width: 400px;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    z-index: 999999;
}

.alert-announcement img{
    width: 100%;
    border-radius: 10px;
}

.uk-alert-close {
    position: absolute;
    cursor: pointer;
    top: 20px;
    right: 15px;
    color: inherit;
    opacity: 0.4;
}

.uk-alert-close:first-child + * {
    margin-top: 0;
}

.uk-alert-close:hover,
.uk-alert-close:focus {
    color: inherit;
    opacity: 0.8;
}

/*Scroll Bar*/
::-webkit-scrollbar {
    width: 4px;
    height: 4px;
    background: transparent !important;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: #6c3c97;
}

/* Cursor */
.uk-alert-close{
    cursor: pointer;
}

a{
    cursor: pointer;
}

.pointer{
    cursor: pointer !important;
}

.drag {
    cursor: url(/images/ava/cursor-drag2.png), auto;
}

.qris-area{
    margin-top: 50px;
    text-align: center;
    margin-bottom: 50px;
}

.qris-area img{
    width: 100%;
    max-width: 200px;
    border-radius: 10px;
}

/*Particle*/
#particles-js {
    width: 100%;
    height: 100%;
    position: absolute;
    background-color: transparent;
    background-repeat: no-repeat;
}

.grecaptcha-badge {
    transform: scale(0.8);
    bottom: 10px !important;
    box-shadow: none !important;
}

/* Dashboard */
.custom-2080 {
    display: flex;
    width: 100%;
}

.custom-left {
    position: fixed;
    top: 30px;
    left: 0;
    width: 20%;
    height: calc(100vh - 30px);       /* full tinggi layar */
    overflow: hidden;    /* agar tidak scrollable */
    background: #fff;    /* opsional, supaya tidak transparan */
    z-index: 999;        /* memastikan berada di depan konten */
}

.custom-right {
    margin-left: 20%;
    width: 80%;
}

.custom-right .nav .row{
    max-width: 80%;
    margin-left: 0%;
}

.side-dash{
    border-right: 1px solid #e0e0e0;
    height: 100vh;
}

.dash-title{
    margin-top: 25px;
    text-align: center;
}

.dash-title p{
    font-size: 16px;
    font-weight: bold;
}

.dash-menu {
    list-style: none;   /* hilangkan bullet */
    margin-top: 50px;
    margin-left: 10px;
    padding: 0;
}

.dash-menu li a {
    display: flex;              /* icon kiri, text kanan */
    align-items: center;        /* vertikal rata */
    gap: 0px;                  /* jarak icon-text */
    text-decoration: none;      /* hilangkan underline */
    color: #333;                /* opsional */
    padding: 10px 0;
    font-weight: 500;
}

.dash-menu li a i {
    font-size: 18px;            /* ukuran icon */
}

.dash-card {
    display: flex;
    justify-content: space-between;
    align-items: center;

    background: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    padding: 20px;
    width: 100%;
    margin-bottom: 20px;
}

.dash-title {
    font-size: 12px;
    font-weight: 600;
    color: #777;
    letter-spacing: 1px;
}

.dash-number {
    margin: 7px 0;
    font-size: 25px !important;
    font-weight: bolder;
}

.dash-link{
    margin-bottom: 0px !important;
    padding-bottom: 0px !important;
}

.dash-link a {
    font-size: 13px;
    color: #243a4a;
    text-decoration: none;
}

.dash-card-icon {
    margin-top: -25px;
    background: #6a0dad; /* ungu, sesuaikan */
    width: 55px;
    height: 55px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.dash-card-icon i {
    color: white;
    font-size: 28px;
}

/* Card Modul */
.card-dashboard{
    box-shadow: none !important;
    outline: none !important;
}

.card-dashboard .card-header{
    padding: 16px;
    border: 1.5px solid #243a4a;
    border-top-right-radius: 20px !important;
    border-top-left-radius: 20px !important;
    border-bottom: 0px !important;
}

.card-dashboard .card-footer{
    padding: 15px;
    border: 1.5px solid #243a4a;
    border-bottom-right-radius: 20px !important;
    border-bottom-left-radius: 20px !important;
    border-top: 0px !important;
}

.table-dashboard{
    margin-top: 0px;
    border: 1.5px solid #243a4a;
}

.table-dashboard tr th{
    padding: 12px;
}

.table-dashboard tr td{
    border: 1.5px solid #243a4a;
    padding: 12px;
    border-right: 0px !important;
    border-left: 0px !important;
}

.card-profile{
    display: flex;
    justify-content: space-between;
    align-items: center;

    background: #ffffff;
    border: 1px solid #8799a5;
    border-radius: 12px;
    padding: 20px;
    margin-top: 20px;
    width: 100%;
}

.card-profile .card-content{
    width: 100%;
    padding-top: 20px;
    padding-bottom: 10px;
}
