@font-face {
    font-family: 'Inter Black';
    src: url('fonts/Inter-Black.eot');
    src: url('fonts/Inter-Black.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Black.woff2') format('woff2'),
        url('fonts/Inter-Black.woff') format('woff'),
        url('fonts/Inter-Black.ttf') format('truetype'),
        url('fonts/Inter-Black.svg#Inter-Black') format('svg');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter Bold';
    src: url('fonts/Inter-Bold.eot');
    src: url('fonts/Inter-Bold.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Bold.woff2') format('woff2'),
        url('fonts/Inter-Bold.woff') format('woff'),
        url('fonts/Inter-Bold.ttf') format('truetype'),
        url('fonts/Inter-Bold.svg#Inter-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter ExtraBold';
    src: url('fonts/Inter-ExtraBold.eot');
    src: url('fonts/Inter-ExtraBold.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-ExtraBold.woff2') format('woff2'),
        url('fonts/Inter-ExtraBold.woff') format('woff'),
        url('fonts/Inter-ExtraBold.ttf') format('truetype'),
        url('fonts/Inter-ExtraBold.svg#Inter-ExtraBold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter ExtraLight';
    src: url('fonts/Inter-ExtraLight.eot');
    src: url('fonts/Inter-ExtraLight.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-ExtraLight.woff2') format('woff2'),
        url('fonts/Inter-ExtraLight.woff') format('woff'),
        url('fonts/Inter-ExtraLight.ttf') format('truetype'),
        url('fonts/Inter-ExtraLight.svg#Inter-ExtraLight') format('svg');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter Light';
    src: url('fonts/Inter-Light.eot');
    src: url('fonts/Inter-Light.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Light.woff2') format('woff2'),
        url('fonts/Inter-Light.woff') format('woff'),
        url('fonts/Inter-Light.ttf') format('truetype'),
        url('fonts/Inter-Light.svg#Inter-Light') format('svg');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter Medium';
    src: url('fonts/Inter-Medium.eot');
    src: url('fonts/Inter-Medium.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Medium.woff2') format('woff2'),
        url('fonts/Inter-Medium.woff') format('woff'),
        url('fonts/Inter-Medium.ttf') format('truetype'),
        url('fonts/Inter-Medium.svg#Inter-Medium') format('svg');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter Regular';
    src: url('fonts/Inter-Regular.eot');
    src: url('fonts/Inter-Regular.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Regular.woff2') format('woff2'),
        url('fonts/Inter-Regular.woff') format('woff'),
        url('fonts/Inter-Regular.ttf') format('truetype'),
        url('fonts/Inter-Regular.svg#Inter-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter Thin';
    src: url('fonts/Inter-Thin.eot');
    src: url('fonts/Inter-Thin.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-Thin.woff2') format('woff2'),
        url('fonts/Inter-Thin.woff') format('woff'),
        url('fonts/Inter-Thin.ttf') format('truetype'),
        url('fonts/Inter-Thin.svg#Inter-Thin') format('svg');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter SemiBold';
    src: url('fonts/Inter-SemiBold.eot');
    src: url('fonts/Inter-SemiBold.eot?#iefix') format('embedded-opentype'),
        url('fonts/Inter-SemiBold.woff2') format('woff2'),
        url('fonts/Inter-SemiBold.woff') format('woff'),
        url('fonts/Inter-SemiBold.ttf') format('truetype'),
        url('fonts/Inter-SemiBold.svg#Inter-SemiBold') format('svg');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face{
	font-family: 'FontAwesome';
	src: url('fonts/fontawesome-webfont.eot?v=4.7.0');
	src: url('fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'),
		url('fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'),
		url('fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'),
		url('fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'),
		url('fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');
	font-weight: normal;
	font-style:normal;
}

.err{
	position: relative;
	display: block;
	color: red;
	text-align: left;
	display: none;
}
	.err:before{
		font-family: FontAwesome;
		content:"\f071";
		padding-right: 5px;
	}
	.text-error,
	.text-error:focus{
		border: solid 1px red;
	}

.swal-sm {
	width: 350px !important;
	font-size: 14px;
}

.swal-sm .swal2-popup {
  padding-top: 2.5em !important;
}

.swal-sm .swal2-title {
  	font-size: 16px !important;
}

.swal-sm .swal2-html-container {
  	font-size: 14px !important;
}

.swal-sm .swal2-confirm,
.swal-sm .swal2-cancel {
	padding: 4px 12px !important;
	font-size: 14px !important;
	border-radius: 4px !important;
}

/* Ukuran ikon swal2 (success, error, warning, dll) */
.swal-sm .swal2-icon {
  width: 50px !important;
  height: 50px !important;
  margin-top: 30px !important;
  margin-bottom: 10px !important;
}

/* Success icon (centang) penyesuaian */
.swal-sm .swal2-icon.swal2-success .swal2-success-line-tip,
.swal-sm .swal2-icon.swal2-success .swal2-success-line-long {
  height: 3px !important;
  background-color: #4ba319;
}

.swal-sm .swal2-icon.swal2-success .swal2-success-line-tip {
  top: 26px !important;
  left: 8px !important;
  width: 18px !important;
  transform: rotate(45deg);
}

.swal-sm .swal2-icon.swal2-success .swal2-success-line-long {
  top: 22px !important;
  right: 3px !important;
  width: 30px !important;
  transform: rotate(-45deg);
}

/* Lingkaran icon success */
.swal-sm .swal2-icon.swal2-success .swal2-success-ring {
  width: 50px !important;
  height: 50px !important;
  border-width: 4px !important;
}

/* Error icon (X) penyesuaian */
.swal-sm .swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
  top: 23px !important;
  width: 30px !important;
  height: 3px !important;
  background-color: #e93c3c;
}

.swal-sm .swal2-icon.swal2-error .swal2-x-mark-line-left {
  left: 10px !important;
  transform: rotate(45deg);
}

.swal-sm .swal2-icon.swal2-error .swal2-x-mark-line-right {
  right: 10px !important;
  transform: rotate(-45deg);
}

.badge-medium {
  font-size: 0.95em; /* Anda bisa coba 0.9em, 1em, 1.1em, dst. */
  padding: 0.35em 0.6em; /* Sesuaikan padding agar proporsional dengan font-size */
}

.table-footer{
	background-color: #ddd;
	font-weight: bold;
}
.text-input{
	font-weight: normal;
}
.trx-footer{
	background-color: #fff;
	font-weight: bold;
}

.modal-fullscreen{
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
}

/* Samain tinggi Select2 sama input form-control */
.select2-container--bootstrap4 .select2-selection {
    height: calc(2.25rem + 2px) !important;
    padding: 0.375rem 0.75rem !important;
    display: flex !important;
    align-items: center !important; /* bikin isi sejajar vertikal */
}
/* Biar teks Select2 center */
.select2-container--bootstrap4 .select2-selection__rendered {
    padding-left: 0 !important;
    padding-right: 1.5rem !important; /* spasi untuk arrow */
    line-height: normal !important;
}
/* Biar arrow sejajar di tengah */
.select2-container--bootstrap4 .select2-selection__arrow {
    position: absolute !important;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
}
/* Perbaiki posisi clear icon di select2 */
.select2-container--bootstrap4 .select2-selection__clear {
    position: absolute !important;
    right: 1.5rem; /* kasih jarak sebelum arrow ▼ */
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
    padding: 0;
}
/* Styling clear icon agar pas di tengah dan ukurannya pas */
.select2-container--bootstrap4 .select2-selection__clear {
    position: absolute !important;
    right: 1.5rem; /* jarak sebelum arrow ▼ */
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    line-height: 16px; /* bikin tanda X di tengah */
    text-align: center;
    border-radius: 50%;
    background: #e0e0e0; /* warna lingkaran */
    font-size: 14px;
    color: #555;
    cursor: pointer;
    opacity: 0.8;
}
.select2-container--bootstrap4 .select2-selection__clear:hover {
    background: #d6d6d6;
    opacity: 1;
}

.modal-xl-fullscreen{
	width: 100%;
	max-width: 1200px; 
	left: 50%;
	transform: translateX(-50%) !important;
	padding: 0px;
	margin: 0px;
}
.modal-md{
	width: 100%;
	max-width: 600px; 
}
	.content-fullscreen{
		height: 100vh;
	}
		.body-scroll{
			height: calc(100vh - 180px);
			overflow-y: auto;
		}
		.body-max{
			height: calc(100vh - 50px);
			overflow-y: auto;
		}

.hidden-form {
	display: none;
}

/*Tablet / iPad / Laptop Portraid*/
@media only screen
and (min-width: 601px) {
	
}


/*Tablet / iPad / Laptop Landscape*/
@media only screen
and (min-width: 1024px) {
  body{
    position: relative;
    display: block;
    width: 100vw;
    height: 100vh;
  }
    .body-redemption {
      position: relative;
      display: block;
      width: 100vw;
      height: 100vh;
      background-image: url('../../images/Background.png');
      background-size: cover;
    }
      .judul{
        position: relative;
        display: block;
        padding: 2vw;
        padding-bottom: 20px !important;
      }
        .judul img{
          height: 10vh;
        }
      .box-content{
        position: relative;
        display: block;
        width: 100vw;
        padding: 2vw;
        padding-top: 0 !important;
      }
        .content{
          position: relative;
          display: block;
          width: 100%;
          padding: 5px 1vw;
          background-color: #fff;
          border-radius: 10px;
        }
          .sub-content{
            padding: .3vw;
          }
            .isi-content{
              position: relative;
              display: block;
              padding: 5px 1vw;
              border-radius: 10px;
            }
              .sub-judul{
                position: relative;
                display: block;
                width: 100%;
                text-align: center;
                font-family: 'Inter Bold';
                font-size: 2vw;
                color: #fff;
              }
              .sub-sub-judul{
                position: relative;
                display: block;
                width: 100%;
                text-align: center;
                font-family: 'Inter Bold';
                font-size: 1.3vw;
                color: #fff;
                margin-bottom: 10px;
              }
                .frame-data{
                  position: relative;
                  display: block;
                  padding: 0.5vw 1vw;
                  border-radius: 7px;
                  margin-bottom: 10px;
                  color: #fff;
                  font-family: 'Inter Regular';
                }
                  .box-kuota{
                    background-color: #fff;
                    border-radius: 10px;
                    padding: 5px;
                    text-align: center;
                    color: #000;
                    font-family: 'Inter SemiBold';
                  }

}

/*Laptop / Desktop*/
@media only screen
and (min-width: 1280px) {
	
}


/*Desktop 1366*/
@media only screen
and (min-width: 1366px) {
	
}


/*Desktop MAC*/
@media only screen
and (min-width: 1440px) {
	
}


/*Desktop Full HD*/
@media only screen
and (min-width: 1680px) {
	
}


/*Desktop Full HD*/
@media only screen
and (min-width: 1920px) {
	
}