:root { --primary-color: #40618D; --secondary-color: #000; --text-color: #505050; --primary-font: 'CircularStd'; --bs-box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1); }

/* Fonts */
@font-face { font-family: 'CircularStd'; font-style: normal; font-weight: 400; src: url(../webfonts/CircularStd/CircularStd-Book.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'CircularStd'; font-style: normal; font-weight: 500; src: url(../webfonts/CircularStd/CircularStd-Medium.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'CircularStd'; font-style: normal; font-weight: 700; src: url(../webfonts/CircularStd/CircularStd-Bold.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'CircularStd'; font-style: normal; font-weight: 800; src: url(../webfonts/CircularStd/CircularStd-Black.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
body { overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-family: var(--primary-font); font-size: 16px; color: var(--text-color); }
.light { font-weight: 300 !important; }
.normal { font-weight: 400 !important; }
.medium { font-weight: 500 !important; }
.semi { font-weight: 600 !important; }
.bold { font-weight: 700 !important; }
.ebold { font-weight: 800 !important; }
.f-black { font-weight: 900 !important; }
.fs-10 { font-size: 10px !important; }
.fs-12 { font-size: 12px !important; }
.fs-14 { font-size: 14px !important; }
.fs-18 { font-size: 18px !important; }
.title-font { font-family: var(--title-font); }
.primary-font { font-family: var(--primary-font); }
h1, h2, h3, h4, h5, h6 { margin-top: 0; font-style: normal; font-weight: 400; text-transform: normal; }
.clear { clear: both; }
a, button { color: var(--primary-color); outline: medium none;text-decoration: none; }
a:focus, .button:focus { text-decoration: none; outline: none; }
a:hover { color: var(--secondary-color); }
button:focus, input:focus, input:focus, textarea, textarea:focus { outline: 0; }
input:focus::-moz-placeholder { opacity: 0; -webkit-transition: 0.4s; -o-transition: 0.4s; transition: 0.4s; }
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a { color: inherit; }
.primary-color { color: var(--primary-color) !important; }
.bg-primary-color { background-color: var(--primary-color) !important; }
.border-primary-color { border-color: var(--primary-color) !important; }
.secondary-color { color: var(--secondary-color) !important; }
.bg-secondary-color { background-color: var(--secondary-color) !important; }
.border-secondary-color { border-color: var(--secondary-color) !important; }
.text-dark { color: #333 !important; }
.bg-f0 { background: #f0f0f0 !important; }
.bg-f4 { background: #f4f4f4 !important; }
.bg-f5 { background: #f5f5f5 !important; }
.bg-none { background: none !important; }
.btn { background: var(--primary-color); color: #fff; -moz-user-select: none; cursor: pointer; display: inline-block; font-weight: 500; padding: 10px 20px; border-radius: 4px; border: 1px solid var(--primary-color); }
.btn:hover { color: var(--primary-color); background: transparent; border-color: var(--primary-color); }
.btn-outline { color: var(--primary-color); background: transparent; border-color: var(--primary-color); }
.btn-outline:hover { color: #fff; background: var(--primary-color); border-color: var(--primary-color); }
.btn-white { color: #fff; background: transparent; border-color: #fff; border-width: 2px }
.btn-white:hover { background: #fff; border-color: #fff; }
.btn.focus, .btn:focus { outline: 0; box-shadow: none; }
.btn-sm { padding: .25rem .5rem; font-size: .875rem; }
.btn.min-width { min-width: 200px; }
.link { border-bottom: 1px solid currentColor; }

/* Scrollbars */
.theme-scrollbar { overflow-x: hidden; overflow-y: auto; scrollbar-color: #D1D5DB #fff; scrollbar-width: thin; }
.theme-x-scrollbar { overflow-x: auto; overflow-y: hidden; padding-right: 0; margin-right: 0; }
.theme-scrollbar::-webkit-scrollbar-track { -webkit-box-shadow: none; background-color: transparent; }
.theme-scrollbar::-webkit-scrollbar { width: 4px; background-color: transparent; }
.theme-scrollbar::-webkit-scrollbar-thumb { background-color: #D1D5DB; border-radius: 3px; }
.br-0 { border-radius: 0px !important; }
.br-5 { border-radius: 5px !important; }
.br-8 { border-radius: 8px !important; }
.br-10 { border-radius: 10px !important; }
.br-15 { border-radius: 15px !important; }
.br-20 { border-radius: 20px !important; }
.alert { padding: 8px 0; font-size: 14px; }
.alert-dismissible .btn-close { padding: 0 1rem; height: 100%; color: #fff; background: none !important; opacity: 1; }

/* BACK TO TOP */
#scrollUp { background: var(--primary-color); height: 50px; width: 50px; right: 31px; bottom: 0px; color: #fff; font-size: 20px; text-align: center; border-radius: 50%; line-height: 48px; border: 2px solid transparent; position: fixed; visibility: hidden; opacity: 0; cursor: pointer; z-index: 999; display:flex; align-items:center; justify-content:center; }
#scrollUp.active { bottom: 30px; visibility: visible; opacity: 1; }
@media (max-width:767px) {
    #scrollUp { right: 16px; }
    #scrollUp { width: 40px; height: 40px; line-height: 38px; }
}
#scrollUp:hover { color: #000; }
.g-2rem { --bs-gutter-x: 2rem; --bs-gutter-y: 2rem; }
.gx-2rem { --bs-gutter-x: 2rem; }
.gy-2rem { --bs-gutter-y: 2rem; }
.g-2-5rem { --bs-gutter-x: 2.5rem; --bs-gutter-y: 2.5rem; }
.br-0 { border-radius: 0 !important; }
.img-thumbnail { padding: .5rem; }
.form-control { border-color: #9A9F9C; border-radius: 5px; height: 46px; }
.form-control:focus { box-shadow: none; outline: none; border-color: var(--primary-color); }
.input-group .wpcf7-form-control-wrap .form-control { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.input-group > .btn.input-group-text { border-top-right-radius: 4px !important; border-bottom-right-radius: 4px !important; height: 46px; }
.wpcf7-spinner { position: absolute }
.modal .btn-close { position: absolute; top: -15px; right: -15px; background-color: #fff; box-shadow: 0 0 15px rgba(0, 0, 0, .2); border-radius: 50%; width: 30px; height: 30px; opacity: 1; }
.swiper-button-next, .swiper-button-prev { font-size: 26px; }
.swiper-button-next::after, .swiper-button-prev::after { display: none; }
.swiper-button-prev, .swiper-rtl .swiper-button-next { left: 0 }
.swiper-button-next, .swiper-rtl .swiper-button-prev { right: 0; }
.arrow svg path { stroke: var(--primary-color); stroke-dasharray: 1; stroke-dashoffset: 1; opacity: 0; }
.arrow.animated svg path { opacity: 1; animation: nectarStrokeAnimation 1.3s cubic-bezier(0.65, 0, 0.35, 1) forwards; animation-duration: 1.3s; }
@keyframes nectarStrokeAnimation {
    0% { stroke-dashoffset: 1; opacity: 0; }
    1% { opacity: 1; }
    100% { stroke-dashoffset: 0; }
}

/* Header
------------------- */
header { position: relative; left: 0; right: 0; z-index: 999; padding: 20px 0; }
.sticky-bar { left: 0; padding: 10px 0; margin: auto; position: fixed; top: 0; width: 100%; -webkit-animation: 300ms ease-in-out 0s normal none 1 running fadeInDown; animation: 300ms ease-in-out 0s normal none 1 running fadeInDown; background: #fff; box-shadow: 0 8px 20px rgba(0, 0, 0, .1); }
header .navbar { position: unset; }
.navbar-collapse ul.navbar-nav { position: relative; }
.navbar-expand-lg .navbar-nav .nav-item { padding: 0; }
.navbar-expand-lg .navbar-nav .nav-link { color: var(--secondary-color); font-size: 16px; padding: 8px 18px; position: relative; }
.navbar-expand-lg .navbar-nav .nav-link:hover, .navbar-expand-lg .navbar-nav .nav-item:hover .nav-link, .navbar-expand-lg .navbar-nav .nav-link:focus, .navbar-expand-lg .navbar-nav .current-menu-item > .nav-link { color: var(--primary-color); }
header .dropdown-menu { border: 0; border-radius: 0; padding: 20px; background: #F8F7F7; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.2); }
header .dropdown-menu li { padding: 0px 0 10px; display: block; }
header .dropdown-menu li:last-child { padding: 0; }
header .dropdown-menu li a { font-size: 14px; color: #333; padding: 0px; display: block; }
header .dropdown-menu li a:hover { color: var(--primary-color); }
.dropdown-toggle::after { content: "\f078"; font-family: "Font Awesome 5 Pro"; font-weight: 700; margin-left: 2px; border: 0 !important; vertical-align: middle; font-size: 12px; color: var(--primary-color); transform: rotate(0deg); transition: transform 0.4s; }
.dropdown:hover .dropdown-toggle::after { color: var(--primary-color); transform: rotate(180deg); transition: transform 0.4s; }
@media (min-width:1024px) {
    .navbar-nav .dropdown-menu { position: absolute; display: block; transform: scaleY(0); transform-origin: 0 0; transition: transform 0.4s; left: 0; top: 100%; padding: 30px; min-width: 300px; }
    .navbar-nav .dropdown:hover > .dropdown-menu { display: block; transform: scaleY(1); transition: transform 0.4s; }
    .navbar-nav .dropdown:hover > .dropdown-menu { margin: 0 !important; }
}

/* Footer
------------------- */
footer { padding: 100px 0; background: var(--secondary-color); font-size: 14px; color: #fff; position: relative; z-index: 2; overflow: hidden; }
.footer-tittle h4 { font-weight: 900; font-size: 16px; margin-bottom: 10px; }
.footer-tittle ul { list-style: none; padding-left: 0; }
.footer-tittle ul li { padding: 5px 0px; }
.footer-tittle ul li a, footer a { color: #fff; line-height: normal; padding: 0; transition: color 0.4s; }
.footer-tittle ul li a:hover, footer a:hover { color: var(--primary-color); transition: color 0.4s; }
.social-icon ul li a { margin-right: 10px; border-radius: 50px; display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: #fff; color: var(--primary-color); }
.social-icon ul li a:hover { background: var(--primary-color); color: #fff; }
.colored-icon ul li a { color: var(--primary-color); }
.footer-col-3 { column-count: 3; }

/* Home
------------------ */
.banner-area { position: relative; z-index: 1; background-size: cover; background-repeat: no-repeat; }
.banner-area:after { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: #000; z-index: -2; opacity: .3 }
.banner-area .section-title p { font-size: 20px; }
.section-title * { line-height: 1; color: var(--secondary-color); }
.section-title h1 { font-size: 64px; font-weight: 700; }
.section-title h2 { font-size: 54px; font-weight: 700; }
.section-title h3 { font-size: 34px; font-weight: 700; }
.section-title h4 { font-size: 24px; font-weight: 700; }
.section-title h5 { font-size: 18px; font-weight: 700; }
.welcome-p { font-size: 20px; }
.main-sect .card-img-top {width: 100%; height: 250px;vertical-align: bottom;-o-object-fit: cover; object-fit: cover;}
.main-sect .card:hover img { opacity: 0.5;}
.card-body {--bs-card-spacer-y: 1.5rem; --bs-card-spacer-x: 1.5rem}

/* PORTFOLIO */
.port_project_gallery .grid-item { width: 33.33%; clear: both; position: relative; border-radius: 3px; overflow: hidden; padding: 0 15px; margin-bottom: 30px; text-align: left; }
.port_project_gallery .grid_img:before { /*content: "";*/ position: absolute; background: #00000087; top: 0; left: 0; bottom: 0; right: 0; width: 100%; height: 100%; opacity: 0; visibility: hidden; -webkit-transition: all 0.4s; -moz-transition: all 0.4s; -ms-ttransition: all 0.4s; -o-transition: all 0.4s; transition: all 0.4s; z-index: 1; }
.port_project_gallery .grid-content { position: absolute; left: 40px; bottom: 20px; color: white; z-index: 1; -webkit-transition: all 0.3s; -moz-transition: all 0.3s; -ms-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; opacity: 0; visibility: hidden; }
.port_project_gallery .grid-content h3 { font-size: 22px; color: #ffffff; }
.port_project_gallery .grid-item:hover .grid-content { opacity: 1; visibility: visible; }
.port_project_gallery .grid-item:hover .grid_img:before { opacity: 1; visibility: visible; }
.port_project_gallery .grid_img img {opacity: .8; max-width: 100%; transition: all 700ms ease; -webkit-transition: all 700ms ease; -moz-transition: all 700ms ease; -ms-transition: all 700ms ease; -o-transition: all 700ms ease; }
.port_project_gallery .grid-item:hover .grid_img img { transform: scale(1.1, 1.1); }
.port_project_gallery .port_project_gallery_view a { z-index: 0; }
.port_project_gallery .grid_img { overflow: hidden; position: relative; }
.port_project_gallery { display: block; width: 100%; }
.port_project_gallery .gallery_nav ul { list-style: none; padding: 0 15px; margin: 0 0 38px 0; }
.port_project_gallery .gallery_nav ul li { display: inline-block; cursor: pointer; margin-right: 30px; color: var(--secondary-color); position: relative; padding: 5px 0; text-transform: uppercase; font-size: 16px; font-weight: 600; }
.port_project_gallery .gallery_nav ul li a {color: var(--secondary-color)}
.port_project_gallery .gallery_nav ul li a:after { content: ""; width: 0%; left: 0; right: 0; bottom: 0; margin: auto; height: 2px; position: absolute; -webkit-transition: ease all 0.55s; -moz-transition: ease all 0.55s; -ms-transition: ease all 0.55s; -o-transition: ease all 0.55s; transition: ease all 0.55s; background: var(--primary-color); }
.port_project_gallery .gallery_nav ul li a.gallery_active:after { width: 100%; }
.port_project_gallery .gallery_nav ul li .gallery_active { color: var(--primary-color); }
.mfp-bg { top: 0; left: 0; width: 100%; height: 100%; z-index: 1042; overflow: hidden; position: fixed; background: #0b0b0b; opacity: 0.8; }

/* CTA */
.content {  background-color: rgba(255, 255, 255, 1); border-radius: 10px;}

/* MEDIA
------------------------ */
@media (max-width:1300px) and (min-width:1024px) {
    body { font-size: 14px; }
    header .container { max-width: 100%; }
}
@media (min-width:1200px) {
	.checkout-section {background-attachment: fixed;}
}
@media (min-width:1400px) {
    .container { max-width: 1150px; }
}
@media (max-width:1024px) {
    html, body { overflow-x: hidden; font-size: 14px; }
    .container { max-width: 100%; }
    .section-title h1 { font-size: 32px; }
    .section-title h2 { font-size: 24px; }
    .section-title h3 { font-size: 20px; }
    .section-title h4 { font-size: 18px; }
    .section-title h5 { font-size: 16px; }
    .banner-title h2 { font-size: 22px; }
    .section-title p, .welcome-p, .banner-area .section-title p { font-size: 14px; }
}
@media (min-width:768px) and (max-width:1024px) { }
@media (max-width:992px) {
    html, body { overflow-x: hidden; font-size: 14px; }
    .menushow { overflow: hidden; }
    header { padding: 10px 0; position: relative !important; animation: none; }
    .navbar-toggler { display: flex; border-radius: 0; }
    .mobile-toggle { width: 35px; height: 35px; margin: 0; background: #fff; cursor: pointer; z-index: 999; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0; border: 0 }
    .mobile-toggle.show { background: transparent; }
    .mobile-toggle svg { fill: var(--primary-color); width: 50px; height: 50px; margin-left: 10px; margin-right: 30px; }
    .line { fill: none; stroke: var(--primary-color); stroke-width: 4; transition: stroke-dasharray .6s cubic-bezier(.4, 0, .2, 1), stroke-dashoffset .6s cubic-bezier(.4, 0, .2, 1); }
    .line1 { stroke-dasharray: 60 207; }
    .show .line1 { stroke-dasharray: 90 207; stroke-dashoffset: -134; }
    .line2 { stroke-dasharray: 60 60; }
    .show .line2 { stroke-dasharray: 1 60; stroke-dashoffset: -30; }
    .line3 { stroke-dasharray: 60 207; }
    .show .line3 { stroke-dasharray: 90 207; stroke-dashoffset: -134; }
    .main-menu { color: var(--primary-color); background: #fff; z-index: 999; top: 0px; margin-left: -15px; margin-right: -15px; flex-basis: 100%; flex-grow: 1; position: relative; display: block; padding: 20px 0; }
    .main-menu ul.navbar-nav { margin: 0; flex-direction: column; align-items: flex-start !important; width: 100%; padding: 0px 0; }
    header ul.navbar-nav > li { padding: 0px; }
    .main-menu ul.navbar-nav > li { display: block; width: 100%; }
    header .navbar-expand-lg .right-menu .navbar-nav li > .nav-link { font-weight: normal; padding: 0 !important; }
    header .navbar-expand-lg .navbar-nav li > .btn { margin: 0 20px; }
    header .navbar-expand-lg .navbar-nav li > .nav-link { font-size: 14px; padding: 10px 20px !important; display: flex; justify-content: space-between; align-items: center; }
    header .navbar-nav .nav-link:hover, .navbar-nav .nav-link:focus, header .navbar-nav .nav-link.active { background: transparent; color: var(--primary-color); }
    .dropdown-toggle.show::after { color: var(--primary-color); transform: rotate(180deg); transition: transform 0.4s; }
    header .navbar-nav .dropdown { position: relative; }
    header .navbar-nav .dropdown-menu { box-shadow: none; padding: 15px; }
    header .navbar-nav .dropdown-menu ul { margin-bottom: 20px; }
    header .navbar-nav .dropdown-toggle.show { color: var(--primary-color); }
    header .dropdown-menu li { padding: 0 0 5px; }
    .megamenu-ttl { font-size: 14px; margin: 0 0 5px !important; }
    header ul > li > .nav-link { line-height: normal; }
}
@media (max-width:767px) {
    .mobile-hide { display: none; }
    .navbar-brand img { height: 40px; }
    footer { padding: 60px 0; font-size: 13px; }
    .footer-tittle h4 { min-height: auto; }
    .footer-tittle ul { margin-bottom: 25px; }
    .port_project_gallery .grid-item { width: 50%; }
    .port_project_gallery .gallery_nav ul li {margin-right: 20px;}
}
@media (max-width:480px) {
    .port_project_gallery .grid-item { width: 100%; }
}