

    .login-container {
      /* min-height: 93vh; */
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px;
    }

    .login-card {
      background: #e3eaf5;
      border-radius: 15px;
      box-shadow: 0 8px 24px rgba(13, 59, 102, 0.3);
      color: #0d3b66;
      max-width: 900px;
      width: 100%;
      display: flex;
      overflow: hidden;
      animation: fadeInUp 0.8s ease forwards;
    }

    .login-form-container {
      flex: 1.2;
      padding: 40px 30px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      background: #f9f9f9;
      border-left: 5px solid #145bc7;
      box-shadow: inset 0 0 10px rgba(244, 144, 12, 0.15);
    }

    .login-container-2 { 
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 20px;
    }

    .login-card-2 {
      background: #e3eaf5;
      border-radius: 15px;
      box-shadow: 0 8px 24px rgba(13, 59, 102, 0.3);
      color: #0d3b66;
      max-width: 900px;
      width: 100%;
      display: flex;
      overflow: hidden;
      animation: fadeInUp 0.8s ease forwards;
    }

    .login-form-container-2 {
      flex: 1.2;
      padding: 40px 30px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      background: #f9f9f9; 
      box-shadow: inset 0 0 10px rgba(244, 144, 12, 0.15);
    }

    .login-container-3 { 
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 20px;
    }

    .login-card-3 {
      background: #e3eaf5;
      border-radius: 15px;
      box-shadow: 0 8px 24px rgba(13, 59, 102, 0.3);
      color: #0d3b66; 
      width: 100%;
      display: flex;
      overflow: hidden;
      animation: fadeInUp 0.8s ease forwards;
    }

    .login-title {
      font-weight: 700;
      font-size: 1.6rem;
      margin-bottom: 10px;
      color: #0d3b66;
      text-align: center;
      user-select: none;
    }

    .login-title-sub {
      font-weight: 700;
      font-size: 1rem;
      margin-bottom: 10px;
      color: #0d3b66;
      text-align: center;
      user-select: none;
    }

    .login-subtitle {
      font-weight: 400;
      font-size: 1rem;
      color: #145bc7;
      margin-bottom: 30px;
      text-align: center;
      user-select: none;
    }

    .form-control {
      background: #f9f9f9;
      border: 2px solid #5d8be7;
      border-radius: 10px;
      color: #0d3b66;
      padding-left: 45px;
      transition: border-color 0.3s ease;
    }
    
    .form-publik .form-control {
      padding-left:0px!important;
    }
    
    .card-aplikasi {
      background: linear-gradient(180deg, #EFF1FF 0%, #FFFFFF 100%);
    }

    .form-control::placeholder {
      color: #a2b4d3;
    }

    .form-control:focus {
      border-color: #f4900c;
      box-shadow: 0 0 8px #f4900c;
      color: #0d3b66;
    }

	.input-pass {
		position: absolute;
		top: 50%;
		right: 15px;
		transform: translateY(-50%);
		color: #000000; 
		font-size: 1.2rem;
		cursor: pointer;
	}
    .input-icon {
      position: absolute;
      top: 50%;
      left: 15px;
      transform: translateY(-50%);
      color: #145bc7;
      pointer-events: none;
      font-size: 1.2rem;
    }
    .input-icon-textarea {
      position: absolute;
      top: 20%;
      left: 15px;
      transform: translateY(-50%);
      color: #145bc7;
      pointer-events: none;
      font-size: 1.2rem;
    }

    .form-check-label {
      user-select: none;
      color: #5d8be7;
    }

    .form-check-input:checked + .form-check-label {
      color: #f4900c;
    }

    .btn-login {
      background: #145bc7;
      border: none;
      border-radius: 50px;
      padding: 10px 0 11px 0;
      font-weight: 700;
      font-size: 1.1rem;
      transition: background-color 0.3s ease;
      box-shadow: 0 4px 15px #145bc7cc;
      user-select: none;
      color: white;
    }

    .btn-login:hover {
      background-color: #0c3c85;
      box-shadow: 0 6px 20px #0c3c85cc; 
	  color:#FFF;
    } 

    .btn-login-sm {
      background: #145bc7;
      border: none;
      border-radius: 50px;
      padding: 6px 0 7px 0;
      font-weight: 700;
      font-size: 1.1rem;
      transition: background-color 0.3s ease;
      box-shadow: 0 4px 15px #145bc7cc;
      user-select: none;
      color: white;
    }

    .btn-login-sm:hover {
      background-color: #0c3c85;
      box-shadow: 0 6px 20px #0c3c85cc; 
	  color:#FFF;
    } 

    .btn-absen {
      background: #1e233d;
      border: none;
      border-radius: 50px;
      padding: 10px 0 11px 0;
      font-weight: 700;
      font-size: 1.1rem;
      transition: background-color 0.3s ease;
      box-shadow: 0 4px 15px #1e233dcc;
      user-select: none;
      color: white;
    }

    .btn-absen:hover {
      background-color: #060810;
      box-shadow: 0 6px 20px #060810cc;
	  color:#FFF;
    }

    @media (max-width: 768px) {
      .login-card {
        flex-direction: column;
      }
      .login-image {
        min-height: 200px;
        width: 100%;
      }
    }

    @keyframes fadeInUp {
      0% {
        opacity: 0;
        transform: translateY(30px);
      }
      100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .pre-loader {
      position: fixed;
      width: 100%;
      height: 100%;
      /* background: #145bc7; */
	  background: linear-gradient(135deg, #0d3b66, #5d8be7);
      display: flex;
      justify-content: center;
      align-items: center;
      z-index: 9999;
      flex-direction: column;
      color: #fff;
      font-weight: 600;
      font-size: 1.2rem;
      user-select: none;
    }

    .pre-loader.hidden {
      animation: fadeOut 0.8s forwards;
    }

    @keyframes fadeOut {
      to {
        opacity: 0;
        visibility: hidden;
      }
    }

    
    /* Tabel lebih kecil & rapat */
    .table-smaller table {
        font-size: 12px;
    }

    .table-smaller th,
    .table-smaller td {
        padding: 6px !important;
        white-space: nowrap; /* tetap rapi tapi tidak melebar */
    }

    /* Tabel responsif agar tidak melebar terlalu jauh */
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Header lebih kecil */
    .table-smaller thead th {
        font-weight: 600;
        font-size: 13px;
    }

    /* Untuk layar sangat kecil */
    @media (max-width: 480px) {
        .table-smaller table {
            font-size: 11px;
        }

        .table-smaller th,
        .table-smaller td {
            padding: 4px !important;
        }
    } 

     /* GLOBAL LOADING OVERLAY */
    #globalLoader {
        position: fixed;
        top: 0; left: 0;
        width: 100%; height: 100%;
        background: rgba(255,255,255,0.7);
        z-index: 9999;
        display: none;
        align-items: center;
        justify-content: center;
    }