
/* ********************************************************************************************
    Reset
*********************************************************************************************** */

:root {
  --bs-white: #fff;
  --bs-primary: #2E90FA;
  --bs-primary-dark: #2F73F2;
  --bs-primary-light: #EFF8FF;
  --bs-primary-100: #1570EF;
  --bs-primary-200: #4A88FC;
  --bs-secondary: #FF7BE2;
  --bs-dark: #344054;
  --bs-gray-100: #475467;
  --bs-gray-200: #D0DAF5;
  --bs-gray-300: #667085;
  --bs-gray-400: #98A2B3;
  --bs-muted: #D0D5DD;
  --bs-body-color: #102D47;
  --bs-body-bg: #f5f7fa;
  --bs-border-color: #CDE0E7;
  --bs-border-light-color: #E2F7FE;
  --bs-primary-rgb: 46, 144, 250;
  --bs-black-rgb: 0, 0, 0;
  --bs-white-rgb: 255, 255, 255;
  --bs-muted-rgb: 208, 213, 221;
  --bs-gray-200-rgb: 208, 218, 245;
  --bs-font-sans-serif: "Poppins", system-ui, -apple-system, "Segoe UI", roboto,
    "Helvetica Neue", arial, "Noto Sans", "Liberation Sans", sans-serif,
    "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --bs-body-font-family: var(--bs-font-sans-serif);
}

html,
body {
    width: 100%;
    height: 100%;
    -webkit-font-smoothing: antialiased;
}

body {
    font-family: var(--bs-body-font-family);
    font-size: 1.125rem;
    color: var(--bs-body-color);
    background-color: var(--bs-white);
}

img {
    max-width: 100%;
}

a:hover {
    color: var(--bs-primary);
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    font-weight: 600;
    color: var(--bs-body-color);
}

.h1, h1 {
    font-size: 3.125rem;
    line-height: 4.375rem;
}

.h2, h2 {
    font-size: 2.875rem;
    line-height: 4.125rem;
}

.h3, h3 {
    font-size: 2.188rem;
}

a {
    text-decoration: none;
}

a:hover {
    color: var(--bs-primary);
}

p {
    line-height: 2rem;
}

.max-width-675 {
    max-width: 42.188rem;
    margin-left: auto;
    margin-right: auto;
}

.max-width-875 {
    max-width: 54.688rem;
    margin-left: auto;
    margin-right: auto;
}

/**********************************************************************************************
	Color & BG Color
**********************************************************************************************/

.text-secondary {
    color: var(--bs-secondary) !important;
}

.text-gray-100 {
    color: var(--bs-gray-100);
}

.text-white-80 {
    color: rgba(var(--bs-white-rgb), 0.8);
}

a.text-white-80:hover {
    color: var(--bs-white);
}

.bg-primary-light {
    background-color: var(--bs-primary-light);
}

.bg-primary-100 {
    background-color: var(--bs-primary-100);
}

/**********************************************************************************************
	Button
**********************************************************************************************/

.btn {
    font-size: 1.063rem;
    font-weight: 600;
    padding: 0.625rem 1.188rem;
    line-height: normal;
    border-radius: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
}

.btn-primary {
    background-color: var(--bs-primary-dark);
    border-color: var(--bs-primary-dark);
    color: var(--bs-white);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: transparent !important;
    border-color: var(--bs-primary-dark) !important;
    color: var(--bs-primary-dark) !important;
}

.btn-rounded {
    font-size: 1rem;
    border-radius: 6.25rem;
    -webkit-border-radius: 6.25rem;
    -moz-border-radius: 6.25rem;
    -ms-border-radius: 6.25rem;
    -o-border-radius: 6.25rem;
    margin: 0 auto;
    text-transform: uppercase;
    min-width: 14.375rem;
}

.btn-submit {
    min-width: 10rem;
    padding: 0.75rem 1.188rem;
}

/**********************************************************************************************
	Form 
**********************************************************************************************/

.form-group .form-label {
  color: var(--bs-gray-300);
  margin-bottom: 0.625rem;
}

.form-control-lg,
.form-select-lg {
  font-size: 1rem;
  color: var(--bs-body-color);
  border: 0.063rem solid var(--bs-border-color);
  background-color: var(--bs-white);
  padding: 0.75rem 1.375rem;
  border-radius: 0;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
}

.form-control:focus,
.form-select:focus {
  color: var(--bs-body-color);
  background-color: var(--bs-white);
  border-color: var(--bs-primary);
  box-shadow: none;
}

input::placeholder,
textarea::placeholder,
select::placeholder {
  color: var(--bs-gray-400) !important;
}

input:-moz-placeholder,
textarea:-moz-placeholder,
select:-moz-placeholder {
  color: var(--bs-gray-400) !important;
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder,
select::-webkit-input-placeholder {
  color: var(--bs-gray-400) !important;
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder,
select:-ms-input-placeholder {
  color: var(--bs-gray-400) !important;
}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

/* Firefox */
input[type="number"] {
  appearance: textfield;
}

/* Autocomplete style */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  background-color: var(--bs-white) !important;
  -webkit-text-fill-color: var(--bs-body-color) !important;
  transition: background-color 5000s ease-in-out 0s;
}

.subscribe-form .form-control-lg {
    padding: 1.375rem 13rem 1.375rem 2.5rem;
    border-radius: 6.25rem;
    -webkit-border-radius: 6.25rem;
    -moz-border-radius: 6.25rem;
    -ms-border-radius: 6.25rem;
    -o-border-radius: 6.25rem;
}

.subscribe-form .subscribe-btn {
    position: absolute;
    top: 0.688rem;
    right: 0.875rem;
    font-size: 1rem;
    min-width: 10.5rem;
    text-transform: uppercase;
}

/**********************************************************************************************
	Navbar
**********************************************************************************************/

.navbar {
    padding: 1.25rem 0;
    background-color: var(--bs-primary-light);
}

.nav-link {
    color: var(--bs-body-color);
}

.nav-link:focus, .nav-link:hover {
    color: var(--bs-primary);
}

.navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
    color: var(--bs-primary);
}

/**********************************************************************************************
	Layout
**********************************************************************************************/

section {
    padding: 6.25rem 0;
}

/**********************************************************************************************
	Card
**********************************************************************************************/

.card {
    background-color: var(--bs-white);
    border: 0.063rem solid var(--bs-border-color);
    border-radius: 0.75rem;
    -webkit-border-radius: 0.75rem;
    -moz-border-radius: 0.75rem;
    -ms-border-radius: 0.75rem;
    -o-border-radius: 0.75rem;
}

.card-body {
    padding: 1.875rem;
}

.card-footer {
    padding: 1.875rem 0;
    margin: 0 1.875rem;
    background-color: var(--bs-white);
    border-top: 0.063rem solid var(--bs-border-light-color);
}

/**********************************************************************************************
	Others
**********************************************************************************************/

.services-box .card {
    min-height: 19rem;
}

.services-box h4,
.why-choose-box h4 {
    font-size: 1.125rem;
    font-weight: 500;
}

.services-box p,
.services-box ul li {
    font-size: 0.938rem;
    line-height: 1.5rem;
    color: var(--bs-white);
}

.services-box .card:hover .services-icon {
    opacity: 0;
}

.services-box .hover-card {
    position: absolute;
    top: 0;
    left: 0;
    padding: 1.5rem 1.875rem;
    height: 100%;
    width: 100%;
    opacity: 0;
    z-index: 1;
    border-radius: 0.75rem 0.75rem 0 0;
    -webkit-border-radius: 0.75rem 0.75rem 0 0;
    -moz-border-radius: 0.75rem 0.75rem 0 0;
    -ms-border-radius: 0.75rem 0.75rem 0 0;
    -o-border-radius: 0.75rem 0.75rem 0 0;
    background-image: url("../images/services-bg.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
}

.services-box .hover-card::before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    height: 100%;
    width: 100%;
    z-index: -1;
    background-color: rgba(var(--bs-primary-rgb), 0.9);
    border-radius: 0.75rem 0.75rem 0 0;
    -webkit-border-radius: 0.75rem 0.75rem 0 0;
    -moz-border-radius: 0.75rem 0.75rem 0 0;
    -ms-border-radius: 0.75rem 0.75rem 0 0;
    -o-border-radius: 0.75rem 0.75rem 0 0;
}

.services-box .card:hover .hover-card {
    opacity: 1;
}

.circle-box {
    height: 5rem;
    width: 5rem;
    text-align: center;
    line-height: 5rem;
    border-radius: 100%;
    background-color: var(--bs-primary-light);
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    -ms-border-radius: 100%;
    -o-border-radius: 100%;
    margin-left: auto;
    margin-right: auto;
}

.why-choose-box h4 {
    font-size: 1.25rem;
    line-height: normal;
}

.why-choose-box p {
    font-size: 1rem;
    line-height: normal;
    color: var(--bs-gray-100);
}

.bg-cta,
.bg-support-cta {
    background-image: url("../images/bg-cta.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
}

.bg-support-cta {
    background-image: url("../images/bg-support-cta.png");
    margin-bottom: -0.125rem;
}

.subscribe-form {
    max-width: 43.75rem;
    margin: 0 auto;
}

.custom-list,
.connect-slider p {
    font-size: 1.063rem;
}

.custom-list span {
    position: relative;
    display: inline-block;
    padding-right: 1.25rem;
}

.custom-list span::before {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    height: 0.25rem;
    width: 0.25rem;
    border-radius: 100%;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    -ms-border-radius: 100%;
    -o-border-radius: 100%;
    background-color: var(--bs-gray-100);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    content: "";
    display: block;
}

.right-column .custom-list span {
    padding-right: 1.25rem;
    padding-left: 1.25rem;
}

.right-column .custom-list span::before {
    right: auto;
    left: 0;
}

.custom-list.white-dot span::before {
    background-color: var(--bs-white);
}

.connect-slider {
    padding-bottom: 2.75rem;
}

.connect-slider .carousel-indicators {
    margin-bottom: 0;
    bottom: 0;
}

.connect-slider .carousel-indicators [data-bs-target] {
    background-color: var(--bs-border-color);
    width: 3.125rem;
    height: 0.625rem;
    opacity: 1;
    border: none;
    margin-right: 0.313rem;
    margin-left: 0.313rem;
    border-radius: 6.25rem;
    -webkit-border-radius: 6.25rem;
    -moz-border-radius: 6.25rem;
    -ms-border-radius: 6.25rem;
    -o-border-radius: 6.25rem;
}

.connect-slider .carousel-indicators .active {
    background-color: var(--bs-secondary);
}

.contact-form {
    padding: 3.75rem 4.375rem;
    background-color: var(--bs-white);
}

.contact-form .form-group {
    margin-bottom: 1.5rem;
}

textarea {
    resize: none;
}

.contact-us-section {
    position: relative;
    z-index: 1;
}

.contact-us-section::before {
    position: absolute;
    top: 0;
    right: 0;
    width: 25%;
    z-index: -1;
    height: 100%;
    display: block;
    content: "";
    background-color: var(--bs-secondary);
}

.contact-item {
    padding-bottom: 1.875rem;
    margin-bottom: 1.875rem;
    border-bottom: 0.063rem solid var(--bs-primary-200);
}

/**********************************************************************************************
	Footer
**********************************************************************************************/

footer {
    background-color: var(--bs-dark);
}

footer a {
    color: var(--bs-muted);
}

.footer-top {
    border-bottom: 0.063rem solid var(--bs-gray-100);
}

.copy-right-text {
    font-size: 1rem;
    color: rgba(var(--bs-muted-rgb), 0.75);
}

.social-icons a {
    height: 2.188rem;
    width: 2.188rem;
    line-height: 2.1rem;
    text-align: center;
    border-radius: 100%;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    -ms-border-radius: 100%;
    -o-border-radius: 100%;
    border: 0.063rem solid rgba(var(--bs-gray-200-rgb), 0.1);
}

.social-icons a:hover {
    background-color: var(--bs-primary-dark);
    color: var(--bs-white);
}

/**********************************************************************************************
	Transition
**********************************************************************************************/
a,
.btn,
.services-box .services-icon,
.services-box .hover-card {
  transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
}