html {
    margin: 0;
    padding: 0;
    scroll-behavior: smooth;
}

body {
    background: #fff;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    font-family: Poppins;
    color: #1c1917;
    box-sizing: border-box;
}

ul {
    padding-left: 0;
    list-style: none;
    margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
}

p {
    margin: 0;
    color: #6c757d;
    font-size: 14px;
    font-weight: 500;
    line-height: 22px;
}

.py-90 {
    padding-top: 70px;
    padding-bottom: 70px;
}

.pt-50 {
    padding-top: 70px;
}

.pb-90 {
    padding-bottom: 70px;
}

.my-90 {
    margin-top: 90px;
    margin-bottom: 90px;
}

.mr-16 {
    margin-right: 16px;
}

.container-fluid {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding-right: 15px;
    padding-left: 15px;
}

.top-header-sec {
    background: #2270fd;
    color: #fff;
    padding: 7px 0;
}

.top-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.left-section {
    display: flex;
    align-items: center;
    gap: 60px;
    font-size: 15px;
}

.left-section .item {
    display: flex;
    align-items: center;
    gap: 6px;
}

.item .icon {
    width: 30px;
    height: 30px;
    background: #ffffff;
    border-radius: 50%;
    text-align: center;
    line-height: 27px;
}

.divider {
    width: 1px;
    height: 20px;
    background: rgba(255, 255, 255, 0.5);
}

.right-section {
    display: flex;
    align-items: center;
    gap: 8px;
}

.left-section a.text-decoration-none {
    color: #fff;
}

.right-section select.form-select {
    background-color: transparent;
    border: 0px;
    color: #fff;
    font-size: 15px;
    padding: 6px 33px 6px 6px;
}

.form-select:focus {
    border-color: #86b7fe;
    outline: 0;
    box-shadow: none;
}

.right-section select.form-select option {
    color: #2f2f2f;
}

.right-section .flag {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    object-fit: cover;
}

.header-section {
    background: #ffffff;
    transition: all 0.3s ease;
    height: 76px;
    padding: 16px 0px;
    box-shadow: 2px 1px 16px #9999994a;
}

.header-section.fixed {
    background: #fff;
    transition-duration: 0.5s;
    transition: all 0.3s ease;
    box-shadow: 2px 1px 16px #9999994a;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 99;
    padding: 20px 0px;
    height: 80px;
}

img.nav-logo {
    max-height: 45px;
}

.header-section a.navbar-brand {
    padding: 0;
    margin: 0;
}

span.navbar-toggler-icon {
    color: #fff;
    padding-top: 4px;
    font-size: 20px;
}

button.navbar-toggler {
    background: black;
    padding: 2px 10px;
}

.navbar-toggler:focus {
    text-decoration: none;
    outline: 0;
    box-shadow: none;
}

ul.navbar-nav.headerSlot {
    display: flex;
    justify-content: end;
    width: 100%;
    align-items: center;
    padding: 0;
}

ul.navbar-nav li.nav-item {
    margin-left: 0;
    position: relative;
}

ul.navbar-nav li.nav-item a.nav-link.fixed {
    color: #000;
}

ul.navbar-nav li.nav-item a.nav-link:hover {
    color: #989898;
}
a.nav-link.applyBtn {
    background: #1c1917 !important;
    color: #fff !important;
}
a.navbar-brand.logoTxt {
    font-size: 22px;
    letter-spacing: 2px;
    color: #1c1917;
    font-family: 'Cormorant Garamond', serif;
}
ul.navbar-nav li.nav-item a.nav-link {
    font-size: 16px;
    color: #1c1917;
    font-weight: 500;
    padding: 10px 28px;
    border-radius: 0px;
    text-decoration: none;
    transition: all 0.3s ease;
}
form.header-right {
    width: 50%;
    justify-content: flex-end;
}

a.nav-link.menu-icon img {
    max-height: 22px;
}

.form-control:focus {
    color: #262626;
    background-color: #fff;
    border-bottom: 1px solid #b26fae !important;
    outline: 0;
    box-shadow: none;
}

.rightSIde a.nav-link {
    background: #3751ff;
    color: #fff !important;
    padding: 8px 25px !important;
}

.rightSIde a.nav-link.account {
    background: none;
    color: #1e266d !important;
    border: 0px;
}

.text-right {
    text-align: right !important;
}

.dropdown-menu-category {
    display: none;
    position: absolute;
    left: 0%;
    top: 73px;
    margin: 0;
    padding: 0;
    z-index: 9;
    background: #ffffff;
    box-shadow: 0 4px 24px 12px #0000001a;
    border-radius: 5px;
    width: 200px;
    height: auto;
    list-style: none;
    z-index: 99;
}

.overlay-triangle {
    position: absolute;
    left: 24%;
    top: -23px;
    z-index: 3;
    margin-top: 6px;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 0 16px 17px 16px;
    border-color: transparent transparent #ffffff transparent;
    transform: rotate(0);
}

ul.navbar-nav li.nav-item:hover .dropdown-menu-category {
    display: block;
}

ul.navbar-nav li.nav-item .dropdown-menu-category li a.nav-link {
    padding: 9px 0;
    border-bottom: 1px solid #b2b2b29c;
    border-radius: 0;
    font-size: 14px;
    font-weight: 500;
}

ul.mega-menulist {
    padding: 10px;
}

.content-slider h6 {
    font-size: 13px;
    color: #fff;
    margin: 0;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 2px;
}

.content-slider h2 {
    color: #ffffff;
    font-size: 64px;
    font-weight: 900;
    margin: 0;
    line-height: normal;
    padding: 0 0 10px;
    font-family: 'Cormorant Garamond', serif;
}
.content-slider {
    text-align: center;
    z-index: 9;
    position: relative;
}
.content-imgs {
    width: 40%;
}

.content-imgs img.hero-section {
    width: 100%;
}

.content-slider p {
    color: #ffffff;
    line-height: 24px;
    font-size: 16px;
}

section.video-section {
    position: relative;
    padding: 190px 0px;
    background: url(../images/hero_bg001.jpg);
    align-items: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
}

.brand-logo {
    position: absolute;
    bottom: 55px;
    right: 55px;
    gap: 45px;
    display: flex;
    z-index: 9;
}

.btn-primary {
    color: #fff;
    background-color: #2270fd;
    border-color: #2270fd;
}

.btn-primary:hover {
    background-color: #ff0040;
    border-color: #ff0040;
}

.btn-check:focus + .btn-primary,
.btn-primary:focus {
    color: #fff;
    background-color: #2270fd;
    border-color: #2270fd;
    box-shadow: none;
}

.btn-secondary {
    color: #fff;
    background-color: #1c1917;
    border-color: #1c1917;
}

.btn-secondary:hover {
    color: #fff;
    background-color: #2270fd;
    border-color: #2270fd;
}

.btn-check:focus + .btn-secondary,
.btn-secondary:focus {
    color: #fff;
    background-color: #1c1917;
    border-color: #1c1917;
    box-shadow: none;
}

ul.navbar-nav li.nav-item .btn {
    padding: 8px 26px;
}

.btn {
    padding: 12px 28px;
    border-radius: 0px;
    font-size: 14px;
    text-transform: uppercase;
}

.btn-outline-primary {
    color: #1c1917;
    border-color: #1c1917;
}
.btn-check:focus + .btn,
.btn:focus {
    outline: 0;
    box-shadow: none;
}

.btn-submit.activeBtn {
    background-color: #1c1917;
}
.btn-submit {
    position: relative;
    overflow: hidden;
    color: #1c1917;
    border-color: #1c1917;
}
.btn-submit span {
    color: #fff;
    z-index: 9;
    position: relative;
}
.btn-submit:hover span.text-color {
    color: #fff;
}
.btn-submit span.text-color {
    color: #1c1917;
}
.content-slider .btn-submit span.text-color {
    color: #ffffff;
}
.content-slider .btn-submit {
    position: relative;
    overflow: hidden;
    color: #ffffff;
    border-color: #ffffff;
}
.content-slider .btn-submit.activeBtn {
    background-color: #ffffff;
}
.content-slider .btn-submit.activeBtn:hover span {
    color: #fff;
}
.content-slider .btn-submit span {
    color: #1c1917;
    z-index: 9;
    position: relative;
}
.btn-submit:after {
    content: '';
    position: absolute;
    top: 0px;
    left: -100%;
    width: 100%;
    background: #1c1917;
    height: 100%;
    transition: all 0.5s;
}
.btn-submit:hover:after {
    left: 0%;
}
.card-bxs-body:hover {
    box-shadow: 0px 0px 20px #cccccca1;
    border: 0px;
}
.card-bxs-body {
    background: #ffffff;
    padding: 22px 25px;
    border: 0.5px solid #d6d0c4;
    text-align: center;
    width: 33.33%;
    border-radius: 5px;
}
.card-bxs-body h4 {
    font-size: 36px;
}
.card-bxs-body .ssd {
    font-size: 14px;
    color: #6b6560;
}
.card-bxs {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.fc-quote h5 {
    font-size: 30px;
    line-height: 34px;
    margin-bottom: 16px;
    font-family: 'Cormorant Garamond', serif;
}
/* Title */
.main-title {
    font-size: 34px;
    line-height: 1.3;
    font-weight: 400;
    margin-bottom: 16px;
    font-family: 'Cormorant Garamond', serif;
}

/* Subtitle */
.subtitle {
    font-size: 14px;
    color: #6f6a64;
    line-height: 1.6;
    max-width: 650px;
    margin-bottom: 30px;
}
.program-item .content {
    width: 100%;
}
/* Divider */
hr {
    border: none;
    border-top: 1px solid #ddd5cc;
    margin: 20px 0;
}

/* Program Items */
.program-item:hover {
    background-color: #e9e9e9;
}
.program-item {
    display: flex;
    gap: 30px;
    align-items: flex-start;
    border-bottom: 0.5px solid #d6d0c4;
    padding: 20px 20px;
}

/* Number */
.program-item .number {
    font-size: 16px;
    color: #a39a91;
    width: 40px;
    height: 40px;
    background: #e9e9e9;
    text-align: center;
    border-radius: 30px;
    line-height: 40px;
}
.program-item:hover .number {
    background: #000;
    color: #fff;
}

/* Content */
.program-item .content h3 {
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 7px;
    font-family: 'Cormorant Garamond', serif;
}

.program-item .content p {
    font-size: 13px;
    color: #6f6a64;
}
.category-card {
    padding: 30px;
    background: #fff;
    box-shadow: -1px 1px 20px #cccccc66;
    margin-bottom: 20px;
    /* border-radius: 5px; */
    overflow: hidden;
    position: relative;
}
.category-card:after {
    content: '';
    position: absolute;
    top: 0px;
    left: -100%;
    width: 100%;
    background: #1c1917;
    height: 100%;
    transition: all 0.5s;
}
.category-card:hover:after {
    left: 0%;
}
.category-card .category {
    color: #9f9f9f;
    font-size: 12px;
    letter-spacing: 3px;
}

.category-card h5 {
    font-size: 20px;
    margin: 9px 0px 10px;
    font-family: 'Cormorant Garamond', serif;
}
.category-card:hover .category,
.category-card:hover h5,
.category-card:hover p {
    color: #fff;
    z-index: 9;
    position: relative;
}

.compounding-bg {
    position: relative;
    height: auto;
    background: url('../images/bg-003.jpg');
    align-items: center;
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left;
}
ul.research-fc {
    background-color: #ffffff;
    padding: 30px 40px;
    z-index: 9;
    position: relative;
}
ul.research-fc li {
    margin-bottom: 12px;
    border-bottom: 0.5px solid #d6d0c4;
    padding-bottom: 12px;
}
ul.research-fc li h6 {
    font-size: 23px;
    font-family: 'Cormorant Garamond', serif;
    margin-bottom: 6px;
}
/* Light overlay for faded look */
.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgb(0 0 0 / 44%); /* soft beige overlay */
}
.pricing-table {
    background-color: #fff;
    border-radius: 10px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    box-shadow: 0px 10px 50px rgba(0, 0, 0, 0.07);
    position: relative;
    overflow: hidden;
    text-align: center;
    height: 370px;
}

.pricing-head {
    padding: 30px 40px 25px;
    border-bottom: 1px dotted #e5e5e5;
}
.pricing-head h6 {
    color: #1c1917;
    font-size: 22px;
    font-weight: 500;
}
.pricing-head h3 {
    font-size: 36px;
    font-weight: 600;
    padding: 20px 0px 0px;
    font-family: 'Cormorant Garamond', serif;
}
.pricing-head h3 span {
    font-size: 16px;
    font-weight: 400;
}
.pricing-body {
    padding: 25px 40px 30px;
}
ul.pricing-list {
    line-height: normal;
}
ul.pricing-list li {
    font-size: 15px;
    margin-bottom: 18px;
    display: block;
    font-weight: 400;
    color: #6c757d;
}
.feather-check-circle.listIcon {
    font-size: 22px;
    /* width: 20px; */
    height: 18px;
    color: #6990ff;
}
.popular-tag {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
    height: 38px;
    text-align: center;
    background-color: #1c1917;
    color: #fff;
    font-weight: 500;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    width: 200px;
    right: -48px;
    top: 35px;
}

.form-control,
.form-select {
    height: 45px;
    font-size: 14px;
    border-radius: 0px;
    color: #6f6a64;
}

label {
    margin-bottom: 5px;
    font-size: 14px;
}

.bottom-bar {
    background: #1c1917;
    padding: 28px 0px;
    margin-top: 70px;
}

/* Container */
.nav-container {
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Logo */
.bottom-logo {
    font-size: 19px;
    letter-spacing: 2px;
    color: #ffffff;
    font-family: 'Cormorant Garamond', serif;
}

/* Menu */
.bottom-menu {
    display: flex;
    gap: 40px;
}

.bottom-menu a {
    text-decoration: none;
    font-size: 14px;
    color: #ffffff !important;
    transition: 0.3s;
}

.bottom-menu a:hover {
    color: #bfbfbf !important;
}

/* Right Info */
.bottom-right-info {
    font-size: 14px;
    color: #ffffff;
}

#loader {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.custom-loader {
    width: 50px;
    height: 50px;
    display: grid;
    border: 3px solid #0000;
    border-radius: 50%;
    border-color: #e66055 #0000;
    animation: s6 1s infinite linear;
}

.custom-loader:before,
.custom-loader:after {
    content: '';
    grid-area: 1/1;
    margin: 2px;
    border: inherit;
    border-radius: 50%;
}

#loader .pWait {
    margin-left: 16px;
    color: #4a4949;
}

.custom-loader:before {
    border-color: #556ee6 #0000;
    animation: inherit;
    animation-duration: 0.5s;
    animation-direction: reverse;
}

.custom-loader:after {
    margin: 8px;
}

@keyframes s6 {
    to {
        transform: rotate(1turn);
    }
}

.left-panel {
    border-right: 1px solid #d0d0d0;
}

.top-left {
    padding: 60px 30px;
}

.top-left h1 {
    font-size: 38px;
    font-weight: 900;
    color: #1a1b1f;
    line-height: 1.3;
}

@media (min-width: 1400px) {
    .container-xxl,
    .container-xl,
    .container-lg,
    .container-md,
    .container-sm,
    .container {
        max-width: 1320px !important;
    }
}
