@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* System Font Override */
body, body * {
    font-family: 'Poppins', sans-serif !important;
}

.remove-elective-subject {
    position: absolute;
    right: 20px;
    margin-top: 3px;
}

#external-events {
    z-index: 2;
    width: 150px;
    padding: 0 10px;
    border: 1px solid #ccc;
    background: #eee;
}

#external-events .fc-event {
    cursor: move;
    margin: 3px 0;
    height: 45px;
    display: flex;
    align-items: center;
    padding-left: 10px;
}

.fc-customButton-button {
    font-size: 13px !important;
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateY(-50%);
}


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

.form-group > label {
    margin-bottom: 10px;
}

#delete-modal .modal-footer > .btn {

    border-radius: 3px !important;
    padding: 0 8px !important;
    font-size: 15px;
}

.fc-scroller {
    overflow-y: hidden !important;
}

.context-menu {
    position: absolute;
    z-index: 1000;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
    padding: 5px;
}

.context-menu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.context-menu ul > li {
    display: block;;
    padding: 5px 15px;
    list-style-type: none;
    color: #333;
    cursor: pointer;
    margin: 0 auto;
    transition: 0.10s;
    font-size: 13px;
}

.context-menu ul > li:hover {
    color: #fff;
    background-color: #007bff;
    border-radius: 2px;
}

/*.fa, .fas {*/
/*    font-size: 13px;*/
/*    margin-right: 4px;*/
/*}*/

.no-header-toolbar .fc-header-toolbar.fc-toolbar {
    margin-top: 0;
    margin-bottom: 0;
}

.fc-h-event {
    border: none;
}

.remove-timetable {
    padding: 2px 3px;
}

.remove-timetable:hover {
    background: white;
    color: black;
    border-radius: 10px;
}

label.filter-menu {
    font-size: 13px;
    color: #7c7c7c;
    font-weight: 500;
    position: absolute;
    top: -8px;
    /*left: 27px;*/
    /*left: 1%;*/
    background: #fff;
    /*margin-bottom: 0;*/
    margin-left: 5px;
    padding: 0 5px;
    z-index: 99;
    border-radius: 20px;
}

/* Keep calendar picker above floating labels/inputs */
.datepicker,
.datepicker-dropdown,
.datepicker.dropdown-menu {
    z-index: 10050 !important;
}

/*.select2-container--default.select2-container--focus .select2-selection--multiple {*/
/*    height: 45px;*/
/*}*/

/*.select2-container .select2-selection--multiple {*/
/*    min-height: 45px;*/
/*}*/

.w-fit-content {
    width: fit-content;
}

.select2-container--default .select2-selection--single {
    padding: 0.94rem 0.6rem !important;
}

.select2-container--default .select2-selection--multiple {
    padding: 0.34rem 0.6rem !important;
}

.select2-search__field::placeholder {
    color: #444;
    font-size: 0.8125rem;
}

.asColorPicker-alpha {
    display: none;
}

.remove-number-increment::-webkit-inner-spin-button,
.remove-number-increment::-webkit-outer-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
}

.total_paidable_amount {
    background-color: lightgray;
}
.dashboard-description {
    font-size: 13px;
}
.v-scroll {
    height: 385px;
    overflow-y: scroll;
}
.custom-card-body {
    padding: 1.25rem !important;
}
.image-tile img {
    height: 200px;
    object-fit: cover;
}
.text-wrap div {
    white-space: normal !important;
}

.package-type-badge {
    position: absolute;
    left: auto;
    right: -10px;
    clip-path: polygon(50% 0%,100% 0%,100% 100%,0% 100%,14% 52%,0% 0%);
    width: 130px;
    height: 38px;
    top: 8px;
    color: white !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}
.package-type-badge{
    right: -2px;
}

.postpaid-color {
    background: var(--primary-color);
}
.prepaid-color {
    background: var(--secondary-color);
}

.addon-border-primary {
    overflow: hidden;
}
.addon-ribbon {
    font: bold 15px 'Poppins', sans-serif;
    color: #333;
    text-align: center;
    -webkit-transform: rotate(-45deg);
    -moz-transform:    rotate(-45deg);
    -ms-transform:     rotate(-45deg);
    -o-transform:      rotate(-45deg);
    position: absolute;
    padding: 7px 0;
    top: 15px;
    left: -30px;
    width: 120px;
    background-color: #ff0000;
    color: #fff;
}
.sidebar .nav .nav-item .nav-link i.menu-icon {
    margin-left: 5px !important;
    width: 30px;
}
.sidebar .nav .nav-item {
    padding: 0 1.25rem !important;
}
@media (min-width: 992px) {
    .sidebar-icon-only .sidebar .nav .nav-item {
        position: relative;
        padding: 0 !important;
    }
}
.sidebar .nav .nav-item .nav-link i.menu-arrow {
    font-size: 1.5rem !important;
}
.student-id-card-demo {
    position: fixed;
    width: -webkit-fill-available;
    margin-right: 20px;
}

.action-column-dropdown-menu {
    left: -2rem !important;
}
.action-column-menu {

    /* position: absolute; */
    /* transform: translate(-50%, -50%); */

    /* position: absolute;
    transform: translate(-50%, -50%);
    white-space: nowrap;
    z-index: 1000; */

    /* top: 50%;
    left: 50%; */
}

.action-td-cell {
    /* position: absolute; */
    /* border: 0px !important; */
    /* top: 40px; */
}

/* Global Font Customization */
body, h1, h2, h3, h4, h5, h6, .content-wrapper {
    font-family: 'Poppins', sans-serif !important;
}

/* Sidebar Font Customization */
.sidebar .nav .nav-item .nav-link .menu-title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600; /* Normal weight */
    font-size: 0.9375rem; /* Standard size, adjust if needed */
}

/* Hover Scale Effect */
.hover-scale {
    transition: transform 0.2s ease;
}
.hover-scale:hover {
    transform: scale(1.2);
}

/* Hover Shadow Effect */
.hover-shadow {
    transition: box-shadow 0.3s ease;
}
.hover-shadow:hover {
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
}

/* Sidebar Sub-menu Items - Remove Bold */
.sidebar .nav .sub-menu .nav-item .nav-link,
.sidebar .nav .sub-menu .nav-item .nav-link .menu-title {
    font-weight: 400 !important;
}

/* =========================================
   Liquid Hover Animation (Refined)
   ========================================= */
.sidebar .nav .sub-menu .nav-link {
    position: relative;
    overflow: hidden;
}

/* Apply liquid effect to ALL nav links including submenu */
.sidebar .nav .nav-link {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: 8px;
    background: transparent !important;
    display: block;
    width: 100%;
    margin: 0;
}

.sidebar .nav .nav-link::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    width: 0%;
    background: rgba(181,207,81,0.18);
    transition: width .32s cubic-bezier(.4,0,.2,1), opacity .2s ease;
    z-index: 0;
    opacity: 0;
    pointer-events: none;
}

.sidebar .nav .nav-link * {
    position: relative;
    z-index: 1;
}

.sidebar .nav .nav-item:not(.active) > .nav-link:hover::before {
    width: var(--liquid-width);
    opacity: 1;
}

.sidebar .nav .nav-link * {
    position: relative;
    z-index: 1;
}

/* Text & Icon Color Change on Hover (Fixing Red -> Green) */
.sidebar .nav .nav-item:not(.active) > .nav-link:hover i.menu-icon,
.sidebar .nav .nav-item:not(.active) > .nav-link:hover .menu-title,
.sidebar .nav .nav-item:not(.active) > .nav-link:hover .menu-arrow {
    color: #e60000 !important;
}

/* Sidebar Sub-menu Hover Effect */
.sidebar .nav .sub-menu .nav-item .nav-link:hover {
    color: #e60000 !important;
    background-color: transparent !important;
    transform: none !important;
    padding-left: 2.5rem !important; /* Adjust padding to compensate/look better if needed, or just keep scale */
}

/* Explicitly trigger liquid animation for sub-menus (redundant but safe) */
.sidebar .nav .sub-menu .nav-item .nav-link:hover::before {
    width: var(--liquid-width);
    opacity: 1;
}

.sidebar .nav .sub-menu .nav-item .nav-link::before {
    border-radius: inherit;
}
/* Sidebar Hover Effect (Generic Cleanup) */
.sidebar .nav .nav-item .nav-link {
    transition: color 0.3s ease;
    transform-origin: left center;
}

/* Sidebar active state customization */
.sidebar .nav .nav-item.active > .nav-link i,
.sidebar .nav .nav-item.active > .nav-link .menu-icon {
    color: #e60000 !important;
}

.sidebar .nav .sub-menu .nav-item > .nav-link.active::before {
    width: var(--liquid-width);
    opacity: 1;
}

.sidebar .nav .sub-menu .nav-item.active > .nav-link::before {
    width: var(--liquid-width);
    opacity: 1;
}

.sidebar .nav .nav-item:not(.active) > .nav-link:hover {
    background-color: transparent !important;
    color: #e60000 !important;
    transform: none !important;
}

/* Sidebar Separator Line */
.sidebar {
    border-right: none !important;
    box-shadow: 24px 0 80px rgba(0, 0, 0, 0.04);
    --liquid-width: 240px;
}

/* Keep active item covered by green overlay */
.sidebar .nav .nav-item.active > .nav-link::before {
    width: var(--liquid-width);
    opacity: 1;
}

/* If a parent has an active submenu item, remove the parent's green overlay */
.sidebar .nav .nav-item.active:has(.sub-menu .nav-link.active) > .nav-link::before,
.sidebar .nav .nav-item.active:has(.sub-menu .nav-item.active) > .nav-link::before {
    width: 0 !important;
    opacity: 0 !important;
}
/* Global Dashboard-like Design */
.content-wrapper,
.footer,
.main-panel {
    background: #f9fafb !important;
}

.card {
    background: #ffffff;
    position: relative;
    border: 1px solid #e0e0e0;
    box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.15);
    border-radius: 10px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px 0 rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.05);
}

/* Global Table Hover Effect */
.table tbody tr:hover {
    background-color: #f9fafb !important;
    transition: background-color 0.2s ease;
}

/* Remove Circle Background from Operate Icons in Tables */
.table .btn-icon, .bootstrap-table .btn-icon {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    transition: transform 0.2s ease;
}

/* Global Button Hover Effect - Add Shadow */
.btn:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(-2px);
    transition: all 0.3s ease;
}

/* Exclude transparent table icons from box-shadow, use filter drop-shadow instead if desired, or just none */
.table .btn-icon:hover, .bootstrap-table .btn-icon:hover {
    box-shadow: none !important;
    transform: scale(1.2); /* Keep the scale effect */
    background: transparent !important;
    /* Optional: Add a shadow to the icon itself since background is gone */
    filter: drop-shadow(0 4px 4px rgba(0,0,0,0.3));
}

.table .btn-icon i, .bootstrap-table .btn-icon i {
    font-size: 1.2rem; /* Ensure icons are visible enough */
}

/* Restore icon colors based on original gradient classes */
.table .btn-icon.btn-gradient-primary,
.table .btn-icon.btn-gradient-primary i,
.table .btn-icon.btn-inverse-primary,
.table .btn-icon.btn-inverse-primary i {
    color: #b66dff !important;
}

.table .btn-icon.btn-gradient-secondary,
.table .btn-icon.btn-gradient-secondary i,
.table .btn-icon.btn-inverse-secondary,
.table .btn-icon.btn-inverse-secondary i {
    color: #c3bdbd !important;
}

.table .btn-icon.btn-gradient-success,
.table .btn-icon.btn-gradient-success i,
.table .btn-icon.btn-inverse-success,
.table .btn-icon.btn-inverse-success i {
    color: #1bcfb4 !important;
}

.table .btn-icon.btn-gradient-info,
.table .btn-icon.btn-gradient-info i,
.table .btn-icon.btn-inverse-info,
.table .btn-icon.btn-inverse-info i {
    color: #198ae3 !important;
}

.table .btn-icon.btn-gradient-warning,
.table .btn-icon.btn-gradient-warning i,
.table .btn-icon.btn-inverse-warning,
.table .btn-icon.btn-inverse-warning i {
    color: #fed713 !important;
}

.table .btn-icon.btn-gradient-danger,
.table .btn-icon.btn-gradient-danger i,
.table .btn-icon.btn-inverse-danger,
.table .btn-icon.btn-inverse-danger i {
    color: #fe7c96 !important;
}

.table .btn-icon.btn-gradient-light,
.table .btn-icon.btn-gradient-light i,
.table .btn-icon.btn-inverse-light,
.table .btn-icon.btn-inverse-light i {
    color: #f8f9fa !important;
}

.table .btn-icon.btn-gradient-dark,
.table .btn-icon.btn-gradient-dark i,
.table .btn-icon.btn-inverse-dark,
.table .btn-icon.btn-inverse-dark i {
    color: #3e4b5b !important;
}

/* Hide sidebar submenu hover triangle icons */
.sidebar .nav .sub-menu .nav-item .nav-link:hover::after {
    content: none !important;
    display: none !important;
}

/* Remove sidebar submenu scrollbar */
.sidebar .nav .sub-menu {
    overflow: hidden !important;
    max-height: none !important;
}

/* Allow sidebar submenu text to wrap */
.sidebar .nav .sub-menu .nav-item,
.sidebar .nav .sub-menu .nav-link {
    overflow: visible !important;
    white-space: normal !important;
    text-overflow: clip !important;
    height: auto !important;
}

/* Remove duplicate wrapper definition */
.todo-content-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex: 1;
    margin-left: 15px;
    min-width: 0;
}

/* Count Circle */
.todo-count {
    width: 45px;
    height: 45px;
    background-color: #e55353;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

/* Text */
.todo-text {
    color: #3c4b64;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* View */
.view-link {
    color: #e55353;
    font-weight: 600;
    margin-left: 10px;
    white-space: nowrap;
}

/* Hover */
.todo-list-item-hover {
    transition: all 0.25s ease;
}

.todo-list-item-hover:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.1) !important;
}

/* Remove link underline */
.todo-link-wrapper {
    text-decoration: none;
    color: inherit;
}

/* Mobile */
@media (max-width: 768px) {
    .todo-content-wrapper {
        flex-direction: column;
        align-items: flex-start;
    }

    .view-link {
        margin-left: 0;
        margin-top: 4px;
    }
}

/* Custom Pagination Design */
.pagination {
    display: flex;
    gap: 8px;
    align-items: center;
    font-family: system-ui;
    border: none !important;
}

.pagination .page-item .page-link {
    min-width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px !important;
    color: #4a5568 !important;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
    border: none !important;
    margin: 0 !important;
    background: transparent;
}

.pagination .page-item.active .page-link {
    background-color: #b5cf51 !important;
    color: white !important;
    font-weight: 600;
    border-color: #b5cf51 !important;
}

.pagination .page-item:not(.active) .page-link:hover {
    background-color: #e0f0b5 !important;
    color: #4a5568 !important;
    transform: translateY(-2px);
    z-index: 2;
}

/* Previous/Next Buttons Styling */
.pagination .page-item:first-child .page-link,
.pagination .page-item:last-child .page-link {
    background-color: #f7fafc !important;
    border: 1px solid #e2e8f0 !important;
    padding: 0 12px;
}

/* Disabled State */
.pagination .page-item.disabled .page-link {
    background-color: #f7fafc !important;
    color: #a0aec0 !important;
    opacity: 0.7;
}

/* Edit Modal Shadow */
.modal-content, #editModal .modal-content {
    -webkit-box-shadow: 0 0 150px 50px rgba(0, 0, 0, 0.7) !important;
    box-shadow: 0 0 150px 50px rgba(0, 0, 0, 0.7) !important;
    border: 1px solid rgba(0, 0, 0, 0.2);
}

:root { 
     /* 主色调 - 你的颜色 */ 
     --green-primary: #b5cf51;      /* 活跃 - 绿色 */ 
     --pink-primary: #e34d55;        /* 删除 - 粉色 */ 
     
     /* 新增 - 灰色系用于未激活 */ 
     --gray-light: #e9eef2;          /* 浅灰背景 */ 
     --gray-medium: #94a3b8;         /* 中灰文字 */ 
     --gray-dark: #64748b;            /* 深灰边框 */ 
     
     /* 辅助色 */ 
     --green-light: #e0f0b5;          /* 浅绿背景 */ 
     --pink-light: #ffe9ea;            /* 浅粉背景 */ 
     --gray-soft: #f1f5f9;             /* 软灰背景 */ 
 } 

 /* 标签组容器 */ 
 .status-tabs { 
     display: flex; 
     gap: 0; 
     margin-bottom: 0; 
     padding: 0; 
     background: white; 
     border: 1px solid rgba(100, 116, 139, 0.35);
     border-radius: 9999px; 
     overflow: hidden;
     width: fit-content; 
     box-shadow: 0 2px 4px rgba(0,0,0,0.02); /* 轻微阴影增加立体感 */
 } 

 /* 基础标签样式 */ 
 .status-tab { 
     padding: 10px 28px; 
     border-radius: 0; 
     font-weight: 500; 
     font-size: 14px; 
     cursor: pointer; 
     transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                 color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
                 transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1); /* 添加平滑过渡 */
     border: none; 
     display: flex; 
     align-items: center; 
     gap: 0; 
     letter-spacing: 0.3px;
     text-decoration: none !important; /* Ensure no underline for links */
     justify-content: center;
     min-width: 120px;
     white-space: nowrap;
     user-select: none;
     -webkit-user-select: none;
     -ms-user-select: none;
 } 

 .status-tabs > b {
     display: flex;
     margin: 0;
     padding: 0;
     font-weight: inherit;
 }


 .status-tabs:not([data-fluid="1"]) > :not(:first-child) .status-tab {
    border-left: 1px solid rgba(100, 116, 139, 0.18);
}
 
 .status-tabs .status-tab .icon {
     display: none !important;
 }
 
 /* 计数徽章 */ 
 .status-tab .badge { 
     display: inline-flex; 
     align-items: center; 
     justify-content: center; 
     min-width: 24px; 
     height: 24px; 
     padding: 0 6px; 
     border-radius: 30px; 
     font-size: 12px; 
     font-weight: 600; 
     background: rgba(255,255,255,0.9); 
     transition: transform 0.3s ease;
 } 

 /* ===== ACTIVE - 绿色系 ===== */ 
.tab-active { 
    background: white; 
    color: var(--gray-dark); 
} 

.tab-active .badge { 
    background: var(--gray-medium); 
    color: white; 
} 

.tab-active.active { 
    background: var(--green-primary); 
    color: white; 
} 

.tab-active.active .badge { 
    background: white; 
    color: var(--green-primary); 
} 

.tab-active:hover:not(.active) { 
    background: var(--gray-soft); 
    color: var(--green-primary);
} 

/* ===== INACTIVE - 灰色系 (Optional, if used elsewhere) ===== */ 
.tab-inactive { 
    background: white; 
    color: var(--gray-dark); 
} 

.tab-inactive .badge { 
    background: var(--gray-medium); 
    color: white; 
} 

.tab-inactive.active { 
    background: var(--gray-medium); 
    color: white; 
} 

.tab-inactive.active .badge { 
    background: white; 
    color: var(--gray-medium); 
} 

.tab-inactive:hover:not(.active) { 
    background: var(--gray-soft); 
    color: var(--gray-dark);
} 

/* ===== DELETED - 粉色系 ===== */ 
.tab-deleted { 
    background: white; 
    color: var(--gray-dark); 
} 

.tab-deleted .badge { 
    background: var(--gray-medium); 
    color: white; 
} 

.tab-deleted.active { 
    background: var(--pink-primary); 
    color: white; 
} 

.tab-deleted.active .badge { 
    background: white; 
    color: var(--pink-primary); 
} 

.tab-deleted:hover:not(.active) { 
    background: var(--gray-soft); 
    color: var(--pink-primary);
}

.status-tabs[data-fluid="1"] {
    position: relative;
    padding: 4px;
    --status-ink-x: 5px;
    --status-ink-w: calc(50% - 5px);
    --status-ink-color: var(--green-primary);
}

.status-tabs[data-fluid="1"]:has(.tab-deleted.active) {
    --status-ink-x: 50%;
    --status-ink-color: var(--pink-primary);
}

.status-tabs[data-fluid="1"]:has(.tab-inactive.active) {
    --status-ink-color: var(--gray-medium);
}

.status-tabs[data-fluid="1"]::before {
    content: "";
    position: absolute;
    top: 4px;
    left: 0;
    height: calc(100% - 8px);
    width: var(--status-ink-w, 0px);
    transform: translateX(calc(var(--status-ink-x, 0px) - 1px));
    background: var(--status-ink-color, var(--green-primary));
    border-radius: 9999px;
    transition: transform 520ms cubic-bezier(0.22, 1, 0.36, 1), width 520ms cubic-bezier(0.22, 1, 0.36, 1), background-color 180ms ease;
    z-index: 0;
}

.status-tabs[data-fluid="1"] .status-tab {
    position: relative;
    z-index: 1;
}

.status-tabs[data-fluid="1"] .tab-active,
.status-tabs[data-fluid="1"] .tab-active.active,
.status-tabs[data-fluid="1"] .tab-deleted,
.status-tabs[data-fluid="1"] .tab-deleted.active,
.status-tabs[data-fluid="1"] .tab-inactive,
.status-tabs[data-fluid="1"] .tab-inactive.active {
    background: transparent;
}

.status-tabs.from-dashboard-load .tab-inactive.active {
    color: var(--gray-dark);
}
 
 
 /* ===== 带图标的版本 ===== */ 
 .status-tab.with-icon { 
     padding: 10px 24px; 
 } 
 
 .status-tab .icon { 
     font-size: 16px; 
     margin-right: 4px; 
 } 
 
 /* 具体图标内容 */ 
.tab-active .icon::before { 
    content: "✓";  /* 或使用字体图标 */ 
}

/* --- Force Icon Fonts to Override Global Poppins --- */
/* Font Awesome 4 (Legacy) */
.fa { font-family: "FontAwesome" !important; }

/* Font Awesome 6 Free (Solid, Regular) */
.fas, .far, .fal,
.fa-solid, .fa-regular, .fa-light, .fa-thin, .fa-duotone {
    font-family: "Font Awesome 6 Free" !important;
}

/* Font Awesome 6 Brands */
.fab, .fa-brands { font-family: "Font Awesome 6 Brands" !important; }

/* Material Design Icons & Menu Arrows & Checkboxes */
.mdi, [class^="mdi-"], [class*=" mdi-"], .menu-arrow, .input-helper:after, .input-helper:before {
    font-family: "Material Design Icons" !important;
}

/* Remix Icons */
.ri, [class^="ri-"], [class*=" ri-"] { font-family: 'remixicon' !important; }

/* Line Awesome (Free & Brands) */
.la, .las, .lar, .lal, .lab { font-family: "Line Awesome Free" !important; }
.lab { font-family: "Line Awesome Brands" !important; }
