:root {
  /* Brand Color */
  --color-primary-base: #3B82F5;
  --color-primary-1: #CCE0FF;
  --color-primary-2: #A6C8FF;
  --color-primary-3: #80B0FF;
  --color-primary-4: #5796FA;
  --color-primary-5: #3B82F5;
  --color-primary-6: #3070D9;
  --color-primary-7: #245AB2;
  --color-primary-8: #19458C;
  --color-primary-9: #0F3166;

  /* Background Color */
  --bg-primary: #1A1C1F;
  --bg-secondary: #F5F9FE;

  /* Text Color */
  --text-light-primary: #F2F2F2;
  --text-light-secondary: #BFBFBF;
  --text-light-tertiary: #8C8C8C;
  --text-light-disabled: #595959;

  --text-dark-primary: #1A1C1F;
  --text-dark-secondary: #3A3D42;
  --text-dark-tertiary: #6B6E73;
  --text-dark-disabled: #A0A4AA;

  /* Success Color */
  --success-base: #43BF77;
  --success-1: #CCFFE1;
  --success-2: #A6FFCB;
  --success-3: #80FFB5;
  --success-4: #59E39A;
  --success-5: #43BF77;
  --success-6: #3AA66A;
  --success-7: #2F8C5A;
  --success-8: #24724A;
  --success-9: #1A593A;

  /* Warning Color */
  --warning-base: #F2B233;
  --warning-1: #FFE0B3;
  --warning-2: #FFC966;
  --warning-3: #FFB31A;
  --warning-4: #F5A300;
  --warning-5: #F2B233;
  --warning-6: #D99A2E;
  --warning-7: #B37724;
  --warning-8: #8C5A1A;
  --warning-9: #664010;

  /* Danger Color */
  --danger-base: #D93A3A;
  --danger-1: #FFD6D6;
  --danger-2: #FFADAD;
  --danger-3: #FF8585;
  --danger-4: #E85C5C;
  --danger-5: #D93A3A;
  --danger-6: #BF3333;
  --danger-7: #992929;
  --danger-8: #7A2121;
  --danger-9: #5C1818;

  /* Announcement Color */
  --announcement-base: #A855F7;
  --announcement-1: #E6CCFF;
  --announcement-2: #CC99FF;
  --announcement-3: #B366FF;
  --announcement-4: #A64DF2;
  --announcement-5: #A855F7;
  --announcement-6: #944DCC;
  --announcement-7: #7A3FB2;
  --announcement-8: #663399;
  --announcement-9: #4D2673;
}

/* Default Spacing */
a, p, span, strong, h1, h2, h3, h4, h5, h6 {
    margin: 0;
}

/* Loading screen */
#loadingScreen {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

/* Message alert */
#messageAlert {
    position: absolute;
    bottom: 18px;
    right: 18px;
    border-radius: 12px;
    border: 1px solid var(--announcement-base);
    background-color: var(--announcement-1);
    color: var(--text--dark-primary);
    font-weight: 400;
    z-index: 9999;
}

#messageAlert .btn-close,
#messageAlert .btn-close:focus,
#messageAlert .btn-close:active,
#messageAlert .btn-close:hover {
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
}

/* Button */
.btn {
    outline: none;
    border: none;
    padding: 8px 12px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 16px;
    box-sizing: border-box;
    text-decoration: none;
    font-weight: 400 !important;
}

.sm-btn {
    outline: none;
    border: none;
    padding: 6px 10px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 12px;
    box-sizing: border-box;
    text-decoration: none;
    font-weight: 400 !important;
}

.action-buttons {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 4px;
}

.primary-btn {
    background-color: var(--color-primary-base) !important;
    color: var(--text-light-primary) !important;
    text-decoration: none !important;
}

.primary-btn:hover,
.primary-btn:active {
    background-color: var(--color-primary-6) !important;
    color: var(--text-light-primary) !important;
}

.secondary-btn {
    background-color: var(--success-base) !important;
    color: var(--text-light-primary) !important;
    text-decoration: none !important;
    padding: 7px 12px !important;
}

.secondary-btn:hover,
.secondary-btn:active {
    background-color: var(--success-6) !important;
    color: var(--text-light-primary) !important;
    text-decoration: none !important;
}

.danger-btn {
    background-color: var(--danger-base) !important;
    color: var(--text-light-primary) !important;
    text-decoration: none !important;
}

.danger-btn:hover,
.danger-btn:active {
    background-color: var(--danger-6) !important;
    color: var(--text-light-primary) !important;
}

.disabled-btn {
    background-color: var(--text-dark-disabled) !important;
    color: var(--text-dark-secondary) !important;
    opacity: 0.7;
    cursor: not-allowed;
}

.disabled-btn:hover,
.disabled-btn:active {
    background-color: var(--text-dark-disabled) !important;
    color: var(--text-dark-secondary) !important;
    opacity: 0.7;
    cursor: not-allowed;
}

/* Input */
.form-group {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.input-label {
    color: var(--text-dark-secondary);
    font-weight: 400;
    font-size: 14px;
}

.input-box {
    width: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
}

.input-box input,
.input-box textarea,
.input-box select {
    width: 100%;
    padding: 8px 40px 8px 12px; 
    border-radius: 8px;
    border: 1px solid var(--text-light-secondary);
    outline: none;
    font-size: 16px;
    box-sizing: border-box;
    background: var(--bg-secondary);
    color: var(--text-dark-primary);
    font-weight: 300;
    transition: 0.2s ease;
}

.input-box input:focus,
.input-box textarea:focus {
    border-color: var(--color-primary-base);
}

.input-box i {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    color: var(--text-dark-disabled);
    transition: 0.2s ease;
}

.input-box i:hover {
    color: var(--text-dark-tertiary);
}

/* Pending badges */
.pending-badge {
    background-color: var(--warning-base);
    color: var(--text-light-primary);
}

/* Pending badges */
.accepted-badge {
    background-color: var(--color-primary-base);
    color: var(--text-light-primary);
}

/* Revoked badges */
.revoked-badge {
    background-color: var(--danger-base);
    color: var(--text-light-primary);
}

/* Rejected badges */
.rejected-badge {
    background-color: var(--danger-base);
    color: var(--text-light-primary);
}

/* Cancelled badges */
.cancelled-badge {
    background-color: var(--success-base);
    color: var(--text-light-primary);
}

/* Primary modal */
.primary-modal .modal-dialog {
    max-width: 400px !important;
}

.primary-modal .modal-content {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.primary-modal .modal-header,
.primary-modal .modal-body,
.primary-modal .modal-footer {
    border: none !important;
    background-color: transparent !important;
    padding: 0 !important;
}

.primary-modal .modal-header .btn-close,
.primary-modal .modal-header .btn-close:focus,
.primary-modal .modal-header .btn-close:active,
.primary-modal .modal-header .btn-close:hover {
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
}

.primary-modal .modal-title {
    color: var(--color-primary-base) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.primary-modal .modal-content .modal-body .message {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.primary-modal .modal-content .modal-body .message i {
    color: var(--color-primary-base) !important;
    font-size: 78px !important;
}

.primary-modal .modal-content .modal-body .message h5 {
    color: var(--color-primary-base) !important;
}

.primary-modal .modal-content .modal-body .message p {
    color: var(--text-dark-secondary) !important;
}

.primary-modal .modal-content .modal-body .message p span {
    color: var(--color-primary-base) !important;
}

.primary-modal .modal-body p {
    color: var(--text-dark-secondary) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-body form {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.primary-modal .modal-body .form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.primary-modal .modal-body .form-group label {
    color: var(--text-secondary) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-body .input-box input:focus,
.primary-modal .modal-body .input-box textarea:focus,
.primary-modal .modal-body .input-box select:focus {
    border-color: var(--color-primary-base) !important;
}

.primary-modal .modal-body .action-buttons {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
}

.primary-modal .modal-body .action-buttons form,
.primary-modal .modal-body .action-buttons .btn {
    width: 100% !important;
}

.primary-modal .modal-body .primary-btn {
    background-color: var(--color-primary-base) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-body .primary-btn:hover {
    background-color: var(--color-primary-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-content .modal-body .secondary-btn {
    border: 1px solid var(--color-primary-base) !important;
    background-color: transparent !important;
    color: var(--color-primary-base) !important;
    font-weight: 400 !important;
}

.primary-modal .modal-content .modal-body .secondary-btn:hover {
    border: 1px solid var(--color-primary-base) !important;
    background-color: var(--color-primary-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

/* Success modal */
.success-modal .modal-dialog {
    max-width: 400px !important;
}

.success-modal .modal-content {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.success-modal .modal-content .modal-header,
.success-modal .modal-content .modal-body,
.success-modal .modal-content .modal-footer {
    border: none !important;
    background-color: transparent !important;
    padding: 0 !important;
}

.success-modal .modal-content .modal-header .btn-close,
.success-modal .modal-content .modal-header .btn-close:focus,
.success-modal .modal-content .modal-header .btn-close:active,
.success-modal .modal-content .modal-header .btn-close:hover {
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
}

.success-modal .modal-content .modal-header .modal-title {
    color: var(--success-base) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.success-modal .modal-content .modal-body .message {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.success-modal .modal-content .modal-body .message i {
    color: var(--success-base) !important;
    font-size: 78px !important;
}

.success-modal .modal-content .modal-body .message h5 {
    color: var(--success-base) !important;
}

.success-modal .modal-content .modal-body .message p {
    color: var(--text-dark-secondary) !important;
}

.success-modal .modal-content .modal-body .message p span {
    color: var(--success-base) !important;
}

.success-modal .modal-content .modal-body p {
    color: var(--text-dark-secondary) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body form {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.success-modal .modal-content .modal-body .form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.success-modal .modal-content .modal-body .form-group label {
    color: var(--text-secondary) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body .form-group .input-box input:focus,
.success-modal .modal-content .modal-body .form-group .input-box textarea:focus,
.success-modal .modal-content .modal-body .form-group .input-box select:focus {
    border-color: var(--success-base) !important;
}

.success-modal .modal-body .action-buttons {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
}

.success-modal .modal-body .action-buttons form,
.success-modal .modal-body .action-buttons .btn {
    width: 100% !important;
}

.success-modal .modal-content .modal-body .primary-btn {
    background-color: var(--success-base) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body .primary-btn:hover {
    background-color: var(--success-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body .secondary-btn {
    border: 1px solid var(--success-base) !important;
    background-color: transparent !important;
    color: var(--success-base) !important;
    font-weight: 400 !important;
}

.success-modal .modal-content .modal-body .secondary-btn:hover {
    border: 1px solid var(--success-base) !important;
    background-color: var(--success-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

/* Danger modal */
.danger-modal .modal-dialog {
    max-width: 400px !important;
}

.danger-modal .modal-content {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.danger-modal .modal-content .modal-header,
.danger-modal .modal-content .modal-body,
.danger-modal .modal-content .modal-footer {
    border: none !important;
    background-color: transparent !important;
    padding: 0 !important;
}

.danger-modal .modal-content .modal-header .btn-close,
.danger-modal .modal-content .modal-header .btn-close:focus,
.danger-modal .modal-content .modal-header .btn-close:active,
.danger-modal .modal-content .modal-header .btn-close:hover {
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
}

.danger-modal .modal-content .modal-header .modal-title {
    color: var(--danger-base) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}

.danger-modal .modal-content .modal-body .message {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.danger-modal .modal-content .modal-body .message i {
    color: var(--danger-base) !important;
    font-size: 78px !important;
}

.danger-modal .modal-content .modal-body .message h5 {
    color: var(--danger-base) !important;
}

.danger-modal .modal-content .modal-body .message p {
    color: var(--text-dark-secondary) !important;
    text-align: center !important;
}

.danger-modal .modal-content .modal-body .message p span {
    color: var(--danger-base) !important;
}

.danger-modal .modal-content .modal-body p {
    color: var(--text-dark-secondary) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body form {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.danger-modal .modal-content .modal-body .form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.danger-modal .modal-content .modal-body .form-group label {
    color: var(--text-secondary) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body .form-group .input-box input:focus,
.danger-modal .modal-content .modal-body .form-group .input-box textarea:focus,
.danger-modal .modal-content .modal-body .form-group .input-box select:focus {
    border-color: var(--danger-base) !important;
}

.danger-modal .modal-body .action-buttons {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
}

.danger-modal .modal-body .action-buttons form,
.danger-modal .modal-body .action-buttons .btn {
    width: 100% !important;
}

.danger-modal .modal-content .modal-body .primary-btn {
    background-color: var(--danger-base) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body .primary-btn:hover {
    background-color: var(--danger-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body .secondary-btn {
    border: 1px solid var(--danger-base) !important;
    background-color: transparent !important;
    color: var(--danger-base) !important;
    font-weight: 400 !important;
}

.danger-modal .modal-content .modal-body .secondary-btn:hover {
    border: 1px solid var(--danger-base) !important;
    background-color: var(--danger-6) !important;
    color: var(--text-light-primary) !important;
    font-weight: 400 !important;
}