:root {
--default-font:"Euclid Circular B",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";
--heading-font:Poppins,sans-serif;
--nav-font:Roboto,sans-serif;
--background-color:#fff;
--default-color:#1e2021;
--heading-color:#111212;
--accent-color:#1f211f;
--surface-color:#fff;
--contrast-color:#fff;
--nav-color:#1e2021;
--nav-hover-color:#1f211f;
--nav-mobile-background-color:#fff;
--nav-dropdown-background-color:#fff;
--nav-dropdown-color:#1e2021;
--nav-dropdown-hover-color:#1f211f
}

.light-background {
--background-color:#fafcfc;
--surface-color:#fff
}

.dark-background {
--background-color:#060606;
--default-color:#fff;
--heading-color:#fff;
--surface-color:#252525;
--contrast-color:#fff
}

:root {
scroll-behavior:smooth
}

body {
color:var(--default-color);
background-color:var(--background-color);
font-family:var(--default-font);
font-weight:500;
font-size:16px
}

a {
color:var(--accent-color);
text-decoration:none;
transition:.3s
}

a:hover {
color:color-mix(in srgb,var(--accent-color),transparent 25%);
text-decoration:none
}

h1,h2,h3,h4,h5,h6 {
color:var(--heading-color);
font-family:var(--heading-font)
}

.php-email-form .error-message {
display:none;
background:#df1529;
color:#fff;
text-align:left;
padding:15px;
margin-bottom:24px;
font-weight:600
}

.php-email-form .sent-message {
display:none;
color:#fff;
background:#059652;
text-align:center;
padding:15px;
margin-bottom:24px;
font-weight:600
}

.php-email-form .loading {
display:none;
background:var(--surface-color);
text-align:center;
padding:15px;
margin-bottom:24px
}

.php-email-form .loading:before {
content:"";
display:inline-block;
border-radius:50%;
width:24px;
height:24px;
margin:0 10px -6px 0;
border:3px solid var(--accent-color);
border-top-color:var(--surface-color);
animation:php-email-form-loading 1s linear infinite
}

@keyframes php-email-form-loading {
0% {
transform:rotate(0deg)
}

100% {
transform:rotate(360deg)
}
}

.portfolio-container {
margin-top:50px
}

.portfolio-nav {
text-align:center;
margin-bottom:30px
}

.portfolio-nav ul {
list-style:none;
padding:0;
display:flex;
flex-wrap:wrap;
justify-content:center;
gap:10px
}

.portfolio-nav li {
display:inline-block
}

.portfolio-nav a {
text-decoration:none;
padding:10px 15px;
border:1px solid #ccc;
border-radius:5px;
color:#333;
transition:all .1s ease
}

.portfolio-nav a:hover,.portfolio-nav a.active {
background-color:#000;
color:#fff
}

.custom-card {
box-shadow:0 2px 5px #0000001a;
border:none
}

.custom-card img {
height:200px;
object-fit:cover
}

.custom-card-body {
text-align:center
}

@media (max-width: 576px) {
.custom-card img {
height:150px
}

.portfolio-nav a {
font-size:14px;
padding:8px 10px;
padding-top:5px
}
}

.project-card .custom-card {
cursor:pointer
}

.nav-pills .nav-link {
color:#000;
background-color:transparent;
border:1px solid #ddd;
margin:2px
}

.nav-pills .nav-link.active {
background-color:#343a40;
color:#fff;
border:none
}

.nav-pills .nav-link:hover {
color:#fff;
background-color:#354f52
}

.header {
color:var(--default-color);
background-color:var(--background-color);
padding:20px 0;
transition:all .5s;
z-index:997
}

.header .logo {
line-height:1
}

.header .logo img {
max-height:70px;
margin-right:8px
}

.header .logo h1 {
font-size:30px;
margin:0;
font-weight:300;
color:var(--heading-color)
}

.scrolled .header {
box-shadow:0 0 18px #0000001a
}

h1,h3,h4,h5 {
text-transform:uppercase
}

@media (min-width: 1200px) {
.navmenu {
padding:0
}

.navmenu ul {
margin:0;
padding:0;
display:flex;
list-style:none;
align-items:center
}

.navmenu li {
position:relative
}

.navmenu ul li a:hover {
color:#fff;
background-color:#000;
padding:10px 15px;
border-radius:10px;
transition:background-color .3s ease,color .3s ease
}

.navmenu a,.navmenu a:focus {
color:var(--nav-color);
padding:18px 15px;
font-size:16px;
font-family:var(--nav-font);
font-weight:400;
display:flex;
align-items:center;
justify-content:space-between;
white-space:nowrap;
transition:.3s
}

.navmenu a i,.navmenu a:focus i {
font-size:12px;
line-height:0;
margin-left:5px;
transition:.3s
}

.navmenu li:last-child a {
padding-right:0
}

.navmenu .dropdown ul {
margin:0;
padding:10px 0;
background:var(--nav-dropdown-background-color);
display:block;
position:absolute;
visibility:hidden;
left:14px;
top:130%;
opacity:0;
transition:.3s;
border-radius:4px;
z-index:99;
box-shadow:0 0 30px #0000001a
}

.navmenu .dropdown ul li {
min-width:200px
}

.navmenu .dropdown ul a {
padding:10px 20px;
font-size:15px;
text-transform:none;
color:var(--nav-dropdown-color)
}

.navmenu .dropdown ul a i {
font-size:12px
}

.navmenu .dropdown ul a:hover,.navmenu .dropdown ul li:hover>a {
background-color:#000;
color:#fff
}

.navmenu .dropdown ul .active:hover {
color:#000
}

.navmenu .dropdown:hover>ul {
opacity:1;
top:100%;
visibility:visible
}

.navmenu .dropdown .dropdown ul {
top:0;
left:-90%;
visibility:hidden;
padding:18px
}

.navmenu .dropdown .dropdown:hover>ul {
opacity:1;
top:0;
left:-100%;
visibility:visible
}
}

@media (max-width: 1199px) {
.mobile-nav-toggle {
color:var(--nav-color);
font-size:28px;
line-height:0;
margin-right:10px;
cursor:pointer;
transition:color .3s
}

.navmenu {
padding:0;
z-index:9997
}

.navmenu ul {
display:none;
list-style:none;
position:absolute;
inset:60px 20px 20px 20px;
padding:10px 0;
margin:0;
border-radius:6px;
background-color:var(--nav-mobile-background-color);
overflow-y:auto;
transition:.3s;
z-index:9998;
box-shadow:0 0 30px #0000001a
}

.navmenu a,.navmenu a:focus {
color:var(--nav-color);
padding:10px 20px;
font-family:var(--nav-font);
font-size:17px;
font-weight:500;
display:flex;
align-items:center;
justify-content:space-between;
white-space:nowrap;
transition:.3s
}

.navmenu a i,.navmenu a:focus i {
font-size:12px;
line-height:0;
margin-left:5px;
width:30px;
height:30px;
display:flex;
align-items:center;
justify-content:center;
border-radius:50%;
transition:.3s;
background-color:color-mix(in srgb,var(--accent-color),transparent 90%)
}

.navmenu a i:hover,.navmenu a:focus i:hover {
background-color:var(--accent-color);
color:var(--contrast-color)
}

.navmenu a:hover,.navmenu .active,.navmenu .active:focus {
color:var(--nav-hover-color)
}

.navmenu .active i,.navmenu .active:focus i {
background-color:var(--accent-color);
color:var(--contrast-color);
transform:rotate(180deg)
}

.navmenu .dropdown ul {
position:static;
display:none;
z-index:99;
padding:10px 0;
margin:10px 20px;
background-color:var(--nav-dropdown-background-color);
border:1px solid color-mix(in srgb,var(--default-color),transparent 90%);
box-shadow:none;
transition:all .5s ease-in-out
}

.navmenu .dropdown ul ul {
background-color:#2125291a
}

.navmenu .dropdown ul a {
color:var(--nav-dropdown-color)
}

.navmenu .dropdown ul a:hover,.navmenu .dropdown ul .active:hover,.navmenu .dropdown ul li:hover>a {
color:var(--nav-dropdown-hover-color)
}

.navmenu .dropdown>.dropdown-active {
display:block;
background-color:#21252908
}

.mobile-nav-active {
overflow:hidden
}

.mobile-nav-active .mobile-nav-toggle {
color:#fff;
position:absolute;
font-size:32px;
top:15px;
right:15px;
margin-right:0;
z-index:9999
}

.mobile-nav-active .navmenu {
position:fixed;
overflow:hidden;
inset:0;
background:#212529cc;
transition:.3s
}

.mobile-nav-active .navmenu>ul {
display:block
}
}

.carousel-item {
position:relative
}

.carousel-item img {
width:100%;
height:100%;
object-fit:contain
}

@keyframes leafToRight {
from {
transform:translateX(-50px);
opacity:0
}

to {
transform:translateX(0);
opacity:1
}
}

@keyframes rightToLeft {
from {
transform:translateX(50px);
opacity:0
}

to {
transform:translateX(0);
opacity:1
}
}

@keyframes bottomToTop {
from {
transform:translateY(50px);
opacity:0
}

to {
transform:translateY(0);
opacity:1
}
}

@keyframes fadeIn {
from {
opacity:0
}

to {
opacity:1
}
}

.contact-widgets {
position:fixed;
bottom:80px;
right:10px;
display:flex;
flex-direction:column;
gap:10px;
z-index:1000
}

.contact-widgets .widget {
width:45px;
height:45px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
background-color:#000;
color:#fff;
font-size:24px;
box-shadow:0 4px 8px #0003;
transition:transform .3s ease,box-shadow .3s ease
}

.contact-widgets .widget:hover {
transform:scale(1.1);
box-shadow:0 6px 12px #0000004d
}

.footer {
background-color:#121212;
color:#f5f5f5;
padding:60px 0;
font-size:14px;
border-top:1px solid #fff3
}

.footer a {
color:#fff!important
}

.footer a:hover {
color:#e0e0e0
}

.footer .copyright {
margin-top:50px;
position:relative;
padding-top:20px;
border-top:1px solid #fff3
}

.footer .copyright p,.footer .copyright .credits {
margin:2px 0
}

.footer .btn-learn-more {
background-color:#ffffff1a;
border-radius:30px;
padding:8px 30px;
border:2px solid #fff3;
transition:.3s all ease-in-out;
font-size:14px;
color:#fff!important
}

.footer .btn-learn-more:hover {
border-color:#ffffff80;
background-color:#fff3;
color:#fff!important
}

.footer .widget .widget-heading {
font-size:15px;
color:#f5f5f5;
margin-bottom:20px
}

.footer .widget ul li {
margin-bottom:10px;
line-height:1.5
}

.footer .widget ul li a {
color:#ffffffb3
}

.footer .widget ul li a:hover {
text-decoration:none;
color:#fff
}

.footer .widget .footer-blog-entry .date {
color:#fff9;
font-size:12px
}

.footer .social-icons li {
display:inline-block
}

.footer .social-icons li a {
display:inline-block;
width:40px;
height:40px;
position:relative;
border-radius:50%;
background:#ffffff1a
}

.footer .social-icons li a span {
color:#f5f5f5;
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
transition:.3s all ease-in-out
}

.footer .social-icons li a:hover {
background:#fff3
}

.footer .social-icons li a:hover span {
color:#fff
}

.footer .footer-subscribe form {
position:relative
}

.footer .footer-subscribe .form-control {
font-size:14px;
height:42px;
border:2px solid #fff6;
background:none;
color:#f5f5f5;
padding-right:40px
}

.footer .footer-subscribe .form-control:focus {
border-color:#fffc;
box-shadow:none
}

.footer .footer-subscribe .form-control::placeholder {
color:#fff9
}

.footer .footer-subscribe .btn-link {
padding:0;
margin:0;
font-size:1.5rem;
background-color:none;
border-color:none;
position:absolute;
line-height:0;
color:#fff9;
top:20px;
right:10px;
transform:translateY(-50%) rotate(0deg)
}

.footer .footer-subscribe .btn-link:hover,.footer .footer-subscribe .btn-link:focus,.footer .footer-subscribe .btn-link:active {
text-decoration:none
}

#preloader {
position:fixed;
inset:0;
z-index:999999;
overflow:hidden;
background:var(--background-color);
transition:all .6s ease-out
}

#preloader:before {
content:"";
position:fixed;
top:calc(50% - 30px);
left:calc(50% - 30px);
border:6px solid #fff;
border-color:var(--accent-color) transparent;
border-radius:50%;
width:60px;
height:60px;
animation:animate-preloader 1.5s linear infinite
}

@keyframes animate-preloader {
0% {
transform:rotate(0deg)
}

100% {
transform:rotate(360deg)
}
}

.scroll-top {
position:fixed;
visibility:hidden;
opacity:0;
right:15px;
bottom:15px;
z-index:99999;
background-color:var(--accent-color);
width:40px;
height:40px;
border-radius:4px;
transition:all .4s
}

.scroll-top i {
font-size:24px;
color:var(--contrast-color);
line-height:0
}

.scroll-top:hover {
background-color:color-mix(in srgb,var(--accent-color),transparent 20%);
color:var(--contrast-color)
}

.scroll-top.active {
visibility:visible;
opacity:1
}

@media screen and (max-width: 768px) {
[data-aos-delay] {
transition-delay:0!important
}
}

.page-title {
color:var(--default-color);
background-color:var(--background-color);
padding:20px 0;
position:relative
}

.page-title h1 {
font-size:24px;
font-weight:300;
margin:0 0 5px
}

.page-title .breadcrumbs ol {
display:flex;
flex-wrap:wrap;
list-style:none;
padding:0;
margin:0;
font-size:14px;
font-weight:400
}

.page-title .breadcrumbs ol li+li {
padding-left:10px
}

.page-title .breadcrumbs ol li+li::before {
content:"/";
display:inline-block;
padding-right:10px;
color:color-mix(in srgb,var(--default-color),transparent 70%)
}

section,.section {
color:var(--default-color);
background-color:var(--background-color);
padding:60px 0;
scroll-margin-top:100px;
overflow:clip
}

@media (max-width: 1199px) {
section,.section {
scroll-margin-top:66px
}
}

.section-title {
text-align:center;
padding-bottom:60px;
position:relative
}

.section-title h2 {
font-size:22px;
font-weight:500;
margin-bottom:0
}

.section-title p {
font-size:15px;
margin-bottom:10px
}

.about {
padding-top:2px
}

.about .btn-get-started {
background-color:var(--accent-color);
color:var(--contrast-color);
border-radius:30px;
padding:8px 30px;
border:2px solid transparent;
transition:.3s all ease-in-out;
font-size:14px
}

.about .btn-get-started:hover {
border-color:var(--accent-color);
background-color:transparent;
color:var(--accent-color)
}

.about h1 {
color:var(--heading-color);
font-size:30px
}

.about p {
line-height:1.7;
color:var(--default-color)
}

.about .swiper-pagination {
position:absolute;
bottom:30px
}

.about .swiper-pagination .swiper-pagination-bullet {
margin:0 5px;
background:#fff;
opacity:.3
}

.about .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
background:var(--accent-color);
opacity:1
}

.about .section-subtitle {
font-size:15px;
margin-bottom:10px;
display:block;
color:var(--default-color)
}

.about-2 .content {
background-color:var(--surface-color);
padding-top:50px;
padding-bottom:50px
}

.about-2 .content-subtitle {
font-size:15px;
margin-bottom:10px;
display:block;
color:var(--default-color)
}

.about-2 .content-title {
color:var(--heading-color);
font-size:22px;
margin-bottom:30px
}

.about-2 p {
line-height:1.7;
color:var(--default-color)
}

.about-2 .btn-get-started {
background-color:var(--accent-color);
color:var(--contrast-color);
border-radius:30px;
padding:8px 30px;
border:2px solid transparent;
transition:.3s all ease-in-out;
font-size:14px
}

.about-2 .btn-get-started:hover {
border-color:var(--accent-color);
background-color:transparent;
color:var(--accent-color)
}

.about-2 .lead {
line-height:1.6;
font-size:17px;
font-weight:regular;
color:var(--default-color)
}

.features-cards {
--default-color:#555;
--heading-color:#333
}

.features-cards .feature-box {
height:100%;
padding:40px 30px;
border-radius:10px
}

.features-cards .feature-box i {
font-size:44px;
display:inline-block;
line-height:0;
color:var(--accent-color);
margin-bottom:20px
}

.features-cards .feature-box h2 {
font-size:20px;
font-weight:700;
margin:0 0 10px;
color:#f8f9fa
}

.features-cards .feature-box p {
font-size:15px;
margin-bottom:0;
color:#f8f9fa
}

.features-cards .feature-box.orange {
background-color:#252422
}

.features-cards .feature-box.orange i {
color:#f8f9fa
}

.features-cards .feature-box.blue {
background-color:#252422
}

.features-cards .feature-box.blue i {
color:#f8f9fa
}

.features-cards .feature-box.green {
background-color:#252422
}

.features-cards .feature-box.green i {
color:#f8f9fa
}

.features-cards .feature-box.red {
background-color:#252422
}

.features-cards .feature-box.red i {
color:#f8f9fa
}

.services {
padding-top:5px;
padding-bottom:5px
}

.services .services-item .services-icon {
color:var(--accent-color);
margin-bottom:20px
}

.services .services-item .services-icon i {
font-size:38px
}

.services .services-item h2 {
font-size:20px;
font-weight:400;
color:var(--heading-color)
}

.services .services-item p {
color:#000
}

.toggle-btn:hover + .collapse {
display:block;
width:100%
}

.service-heading:hover h6 {
color:#fff
}

.stats .stats-item {
background-color:var(--surface-color);
box-shadow:0 0 30px #0000001a;
padding:30px
}

.stats .stats-item i {
color:var(--accent-color);
font-size:42px;
line-height:0;
margin-right:20px
}

.stats .stats-item span {
color:var(--heading-color);
font-size:36px;
display:block;
font-weight:600
}

.stats .stats-item p {
padding:0;
margin:0;
font-family:var(--heading-font);
font-size:16px
}

.blog-posts .title-wrap {
padding-bottom:30px
}

.blog-posts .content-subtitle {
font-size:15px;
margin-bottom:10px;
display:block;
color:var(--default-color)
}

.blog-posts .content-title {
color:var(--heading-color);
font-size:22px;
margin-bottom:30px
}

.blog-posts .post-entry .thumb {
margin-bottom:20px
}

.blog-posts .post-entry .thumb img {
transition:.3s all ease
}

.blog-posts .post-entry .thumb:hover img {
opacity:.8
}

.blog-posts .post-entry .meta {
font-size:12px;
margin-bottom:20px
}

.blog-posts .post-entry .meta .cat {
text-transform:uppercase;
font-weight:400;
color:var(--heading-color)
}

.blog-posts .post-entry .meta .date {
color:color-mix(in srgb,var(--default-color),transparent 25%)
}

.blog-posts .post-entry .post-content {
padding-left:30px;
padding-right:30px
}

.blog-posts .post-entry .post-content h3 {
font-size:18px;
line-height:1.2
}

.blog-posts .post-entry .post-content h3 a {
color:var(--heading-color)
}

.blog-posts .post-entry .post-content h3 a:hover {
color:var(--accent-color)
}

.blog-posts .author .pic {
flex:0 0 50px;
margin-right:20px
}

.blog-posts .author .author-name {
line-height:1.3
}

.blog-posts .author .author-name strong {
color:var(--heading-color);
font-weight:400
}

.blog-posts .author .author-name span {
font-size:14px;
color:color-mix(in srgb,var(--default-color),transparent 25%)
}

.tabs .service-item .service-icon {
display:flex;
align-items:center;
justify-content:center;
width:40px;
height:40px;
flex:0 0 40px;
border-radius:4px;
position:relative;
color:var(--accent-color);
background-color:color-mix(in srgb,var(--default-color),transparent 95%);
margin-right:20px;
font-size:16px
}

.tabs .service-item .service-contents h3 {
font-size:15px;
margin-top:14px;
color:var(--heading-color)
}

.tabs .service-item.link {
padding:20px;
margin-bottom:10px;
border-radius:7px
}

.services-item {
color:#343a40;
transition:all .3s ease;
padding:20px;
border-radius:0
}

.services-item:hover {
background-color:#000;
color:#fff;
box-shadow:0 6px 8px #0003
}

.services-item .services-icon i {
font-size:24px;
display:block;
margin-bottom:10px
}

.services-item:hover .services-icon i {
color:#fff
}

.services-item h2 {
color:#000;
font-size:20px;
margin-bottom:10px
}

.services-item:hover h2 {
color:#fff
}

.services-item:hover p {
color:#fff
}

.tabs .service-item.link .service-contents {
color:var(--default-color)
}

.tabs .service-item.link .service-contents :last-child {
margin-bottom:0
}

.tabs .service-item.link:hover {
background:color-mix(in srgb,var(--default-color),transparent 96%)
}

.tabs .service-item.link:hover .service-icon {
background-color:color-mix(in srgb,var(--default-color),transparent 90%);
color:var(--default-color)
}

.tabs .service-item.link.active {
background:var(--surface-color)
}

.tabs .service-item.link.active .service-icon {
background-color:var(--accent-color);
color:var(--contrast-color)
}

.services-2 {
padding-top:30px;
padding-bottom:2px
}

.services-2 .content-subtitle {
font-size:15px;
margin-bottom:10px;
display:block;
color:var(--default-color)
}

.services-2 .content-title {
color:var(--heading-color);
font-size:22px;
margin-bottom:30px
}

.services-2 p {
line-height:1.7;
color:var(--default-color)
}

.services-2 .lead {
line-height:1.6;
font-size:18px;
font-weight:400;
color:var(--default-color)
}

.services-2 .btn-get-started {
background-color:var(--accent-color);
color:var(--contrast-color);
border-radius:30px;
padding:8px 30px;
border:2px solid transparent;
transition:.3s all ease-in-out;
font-size:14px
}

.services-2 .btn-get-started:hover {
border-color:var(--accent-color);
background-color:transparent;
color:var(--accent-color)
}

.services-2 .services-item .services-icon {
color:var(--accent-color);
margin-bottom:20px
}

.services-2 .services-item .services-icon i {
font-size:48px
}

.services-2 .services-item h3 {
font-size:17px;
font-weight:400;
color:var(--heading-color)
}

.image-college img {
width:150px;
height:150px;
object-fit:cover;
border:2px solid #fff;
border-radius:8px;
transition:transform .3s ease
}

.image-college img:hover {
transform:scale(1.5);
cursor:pointer
}

.content-section {
margin-top:40px
}

.points {
list-style:none;
padding:0
}

.points li {
margin-bottom:10px;
padding:10px;
border-radius:5px
}

.header {
text-align:center;
margin-bottom:40px
}

.header h1 {
font-size:2.5rem;
color:#000
}

.card {
position:relative;
background:#fff;
border:none;
overflow:hidden;
text-align:center;
transition:transform .3s ease,box-shadow .3s ease
}

.card:hover {
transform:translateY(-15px)
}

.card .icon {
font-size:2rem;
margin-bottom:10px;
color:#000
}

.card .card-content {
position:absolute;
bottom:-100%;
left:0;
width:100%;
padding-top:1rem;
padding-left:1rem;
padding-right:1rem;
background:#ffffffe6;
transition:bottom .3s ease
}

.card:hover .card-content {
bottom:0;
background-color:#000;
color:#fff
}

.scrolling-wrapper {
display:flex;
overflow-x:auto;
scroll-behavior:smooth;
padding:20px 0;
gap:20px;
flex-wrap:wrap
}

.scrolling-wrapper::-webkit-scrollbar {
display:none
}

.video-banner {
position:relative;
width:100%;
overflow:hidden
}

.ratio {
width:100%;
height:auto
}

.client-logo-img {
width:250px;
height:200px;
object-fit:contain;
transition:transform .3s ease,opacity .3s ease;
padding-left:20px
}

.client-logo-img:hover {
transform:scale(1.1);
opacity:.9
}

@media (max-width: 768px) {
.client-logo-img {
width:180px;
height:90px
}
}

@media (max-width: 480px) {
.client-logo-img {
width:150px;
height:75px
}
}

.faq .content-subtitle {
font-size:15px;
margin-bottom:10px;
display:block;
color:var(--default-color)
}

.faq .content-title {
color:var(--heading-color);
font-size:22px;
margin-bottom:30px
}

.faq p {
line-height:1.7;
color:var(--default-color)
}

.faq .custom-accordion .accordion-item {
background-color:var(--surface-color);
margin-bottom:0;
position:relative;
border-radius:0;
overflow:hidden
}

.faq .custom-accordion .accordion-item .btn-link {
display:block;
width:100%;
padding:15px 0;
text-decoration:none;
text-align:left;
color:var(--default-color);
border:none;
padding-left:40px;
border-radius:0;
position:relative;
background-color:color-mix(in srgb,var(--default-color),transparent 94%)
}

.faq .custom-accordion .accordion-item .btn-link:before {
content:"\f282";
display:inline-block;
font-family:"bootstrap-icons"!important;
font-style:normal;
font-weight:400!important;
font-variant:normal;
text-transform:none;
line-height:1;
vertical-align:-.125em;
-webkit-font-smoothing:antialiased;
position:absolute;
top:50%;
transform:translateY(-50%);
left:15px
}

.faq .custom-accordion .accordion-item .btn-link[aria-expanded=true] {
color:var(--accent-color)
}

.faq .custom-accordion .accordion-item .btn-link[aria-expanded=true]:before {
font-family:"bootstrap-icons"!important;
content:"\f286";
position:absolute;
color:var(--accent-color);
top:50%;
transform:translateY(-50%)
}

.faq .custom-accordion .accordion-item .accordion-body {
padding:20px;
color:var(--default-color)
}

.portfolio .portfolio-filters {
padding:0;
margin:0 auto 20px;
list-style:none;
text-align:center
}

.portfolio .portfolio-filters li {
cursor:pointer;
display:inline-block;
padding:8px 20px 10px;
margin:0;
font-size:15px;
font-weight:500;
line-height:1;
margin-bottom:5px;
border-radius:50px;
transition:all .3s ease-in-out;
font-family:var(--heading-font)
}

.portfolio .portfolio-filters li:hover,.portfolio .portfolio-filters li.filter-active {
color:var(--contrast-color);
background-color:var(--accent-color)
}

.portfolio .portfolio-filters li:first-child {
margin-left:0
}

.portfolio .portfolio-filters li:last-child {
margin-right:0
}

@media (max-width: 575px) {
.portfolio .portfolio-filters li {
font-size:14px;
margin:0 0 10px
}
}

.portfolio .portfolio-item {
position:relative;
overflow:hidden
}

.portfolio .portfolio-item .portfolio-info {
opacity:0;
position:absolute;
left:12px;
right:12px;
bottom:-100%;
z-index:3;
transition:all ease-in-out .2s;
background:color-mix(in srgb,var(--background-color),transparent 10%);
padding:15px
}

.portfolio .portfolio-item .portfolio-info h4 {
font-size:18px;
font-weight:600;
padding-right:50px
}

.portfolio .portfolio-item .portfolio-info p {
color:color-mix(in srgb,var(--default-color),transparent 30%);
font-size:14px;
margin-bottom:0;
padding-right:50px
}

.portfolio .portfolio-item .portfolio-info .preview-link,.portfolio .portfolio-item .portfolio-info .details-link {
position:absolute;
right:50px;
font-size:24px;
top:calc(50% - 14px);
color:color-mix(in srgb,var(--default-color),transparent 30%);
transition:.3s;
line-height:0
}

.portfolio .portfolio-item .portfolio-info .preview-link:hover,.portfolio .portfolio-item .portfolio-info .details-link:hover {
color:var(--accent-color)
}

.portfolio .portfolio-item .portfolio-info .details-link {
right:14px;
font-size:28px
}

.portfolio .portfolio-item:hover .portfolio-info {
opacity:1;
bottom:0
}

.portfolio-details .portfolio-details-slider img {
width:100%
}

.portfolio-details .swiper-wrapper {
height:auto
}

.portfolio-details .swiper-button-prev,.portfolio-details .swiper-button-next {
width:48px;
height:48px
}

.portfolio-details .swiper-button-prev:after,.portfolio-details .swiper-button-next:after {
color:#fffc;
background-color:#00000026;
font-size:24px;
border-radius:50%;
width:48px;
height:48px;
display:flex;
align-items:center;
justify-content:center;
transition:.3s
}

.portfolio-details .swiper-button-prev:hover:after,.portfolio-details .swiper-button-next:hover:after {
background-color:#0000004d
}

@media (max-width: 575px) {
.portfolio-details .swiper-button-prev,.portfolio-details .swiper-button-next {
display:none
}
}

.portfolio-details .swiper-pagination {
margin-top:20px;
position:relative
}

.portfolio-details .swiper-pagination .swiper-pagination-bullet {
width:10px;
height:10px;
background-color:color-mix(in srgb,var(--default-color),transparent 85%);
opacity:1
}

.portfolio-details .swiper-pagination .swiper-pagination-bullet-active {
background-color:var(--accent-color)
}

.portfolio-details .portfolio-info h3 {
font-size:22px;
font-weight:700;
margin-bottom:20px;
padding-bottom:20px;
position:relative
}

.portfolio-details .portfolio-info h3:after {
content:"";
position:absolute;
display:block;
width:50px;
height:3px;
background:var(--accent-color);
left:0;
bottom:0
}

.portfolio-details .portfolio-info ul {
list-style:none;
padding:0;
font-size:15px
}

.portfolio-details .portfolio-info ul li {
display:flex;
flex-direction:column;
padding-bottom:15px
}

.portfolio-details .portfolio-info ul strong {
text-transform:uppercase;
font-weight:400;
color:color-mix(in srgb,var(--default-color),transparent 50%);
font-size:14px
}

.portfolio-details .portfolio-info .btn-visit {
padding:8px 40px;
background:var(--accent-color);
color:var(--contrast-color);
border-radius:50px;
transition:.3s
}

.portfolio-details .portfolio-info .btn-visit:hover {
background:color-mix(in srgb,var(--accent-color),transparent 20%)
}

.portfolio-details .portfolio-description h2 {
font-size:26px;
font-weight:700;
margin-bottom:20px
}

.portfolio-details .portfolio-description p {
padding:0
}

.portfolio-details .portfolio-description .testimonial-item {
padding:30px 30px 0;
position:relative;
background:color-mix(in srgb,var(--default-color),transparent 97%);
margin-bottom:50px
}

.portfolio-details .portfolio-description .testimonial-item .testimonial-img {
width:90px;
border-radius:50px;
border:6px solid var(--background-color);
float:left;
margin:0 10px 0 0
}

.portfolio-details .portfolio-description .testimonial-item h3 {
font-size:18px;
font-weight:700;
margin:15px 0 5px;
padding-top:20px
}

.portfolio-details .portfolio-description .testimonial-item h4 {
font-size:14px;
color:#354f52;
margin:0
}

.portfolio-details .portfolio-description .testimonial-item .quote-icon-left,.portfolio-details .portfolio-description .testimonial-item .quote-icon-right {
color:color-mix(in srgb,var(--accent-color),transparent 50%);
font-size:26px;
line-height:0
}

.portfolio-details .portfolio-description .testimonial-item .quote-icon-left {
display:inline-block;
left:-5px;
position:relative
}

.portfolio-details .portfolio-description .testimonial-item .quote-icon-right {
display:inline-block;
right:-5px;
position:relative;
top:10px;
transform:scale(-1,-1)
}

.portfolio-details .portfolio-description .testimonial-item p {
font-style:italic;
margin:0;
padding:0
}
/*--------------------------------------------------------------
# Table pricing
--------------------------------------------------------------*/
    .pricing-table {
      margin: 50px auto;
      max-width: 1200px;
    }
    .table th, .table td {
      vertical-align: middle;
      text-align: center;
    }

    .table .check {
      color: green;
      font-size: 1.5rem;
    }
    .table .cross {
      color: red;
      font-size: 1.5rem;
    }
    .plan-title-basic {
      background-color: #225387 !important;
      color: white !important;
    }
    .plan-title-standard {
      background-color: #030f80 !important; 
      color: white !important;
    }
    .plan-title-premium {
      background-color: #dc3545 !important;
      color: white !important;
    }
    
    .plan-title {
      font-size: 1.25rem;
      font-weight: bold;
    }
    .unit-price {
      font-size: 1rem;
      font-weight: normal;
      margin-top: 5px;
  }
    .enquiry-button {
      border-radius: 25px;
      padding: 8px 20px;
      font-size: 1rem;
      font-weight: bold;
      color: white;
      border: none;
    }
    
.
/*--------------------------------------------------------------
# Blog Posts 2 Section
--------------------------------------------------------------*/
.blog-posts-2 article {
height:100%
}

.blog-posts-2 .post-img {
max-height:440px;
overflow:hidden
}

.blog-posts-2 .title {
font-size:20px;
font-weight:700;
padding:0;
margin:5px 0
}

.blog-posts-2 .title a {
color:var(--heading-color);
transition:.3s
}

.blog-posts-2 .title a:hover {
color:var(--accent-color)
}

.blog-posts-2 .meta-top {
margin-top:10px;
color:color-mix(in srgb,var(--default-color),transparent 40%)
}

.blog-posts-2 .meta-top ul {
display:flex;
flex-wrap:wrap;
list-style:none;
align-items:center;
padding:0;
margin:0
}

.blog-posts-2 .meta-top i {
font-size:24px;
line-height:0;
color:color-mix(in srgb,var(--default-color),transparent 50%)
}

.blog-posts-2 .meta-top a {
color:color-mix(in srgb,var(--default-color),transparent 40%);
font-size:14px;
display:inline-block;
line-height:1
}

.blog-pagination {
padding-top:0;
color:color-mix(in srgb,var(--default-color),transparent 40%)
}

.blog-pagination ul {
display:flex;
padding:0;
margin:0;
list-style:none
}

.blog-pagination li {
margin:0 5px;
transition:.3s
}

.blog-pagination li a {
color:color-mix(in srgb,var(--default-color),transparent 40%);
padding:7px 16px;
display:flex;
align-items:center;
justify-content:center
}

.blog-pagination li a.active,.blog-pagination li a:hover {
background:var(--accent-color);
color:var(--contrast-color)
}

.blog-pagination li a.active a,.blog-pagination li a:hover a {
color:var(--contrast-color)
}

.blog-details {
padding-bottom:30px
}

.blog-details .article {
background-color:var(--surface-color);
padding:30px;
box-shadow:0 4px 16px #0000001a
}

.blog-details .post-img {
margin:-30px -30px 20px;
overflow:hidden
}

.blog-details .title {
color:var(--heading-color);
font-size:28px;
font-weight:700;
padding:0;
margin:30px 0
}

.blog-details .content {
margin-top:20px
}

.blog-details .content h3 {
font-size:22px;
margin-top:30px;
font-weight:700
}

.blog-details .content blockquote {
overflow:hidden;
background-color:color-mix(in srgb,var(--default-color),transparent 95%);
padding:60px;
position:relative;
text-align:center;
margin:20px 0
}

.blog-details .content blockquote p {
color:var(--default-color);
line-height:1.6;
margin-bottom:0;
font-style:italic;
font-weight:500;
font-size:22px
}

.blog-details .content blockquote:after {
content:"";
position:absolute;
left:0;
top:0;
bottom:0;
width:3px;
background-color:var(--accent-color);
margin-top:20px;
margin-bottom:20px
}

.blog-details .meta-top {
margin-top:20px;
color:color-mix(in srgb,var(--default-color),transparent 40%)
}

.blog-details .meta-top ul {
display:flex;
flex-wrap:wrap;
list-style:none;
align-items:center;
padding:0;
margin:0
}

.blog-details .meta-top ul li+li {
padding-left:20px
}

.blog-details .meta-top i {
font-size:16px;
margin-right:8px;
line-height:0;
color:color-mix(in srgb,var(--default-color),transparent 40%)
}

.blog-details .meta-top a {
color:color-mix(in srgb,var(--default-color),transparent 40%);
font-size:14px;
display:inline-block;
line-height:1
}

.blog-details .meta-bottom {
padding-top:10px;
border-top:1px solid color-mix(in srgb,var(--default-color),transparent 90%)
}

.blog-details .meta-bottom i {
color:color-mix(in srgb,var(--default-color),transparent 40%);
display:inline
}

.blog-details .meta-bottom a {
color:color-mix(in srgb,var(--default-color),transparent 40%);
transition:.3s
}

.blog-details .meta-bottom a:hover {
color:var(--accent-color)
}

.blog-details .meta-bottom .cats {
list-style:none;
display:inline;
padding:0 20px 0 0;
font-size:14px
}

.blog-details .meta-bottom .cats li {
display:inline-block
}

.blog-details .meta-bottom .tags {
list-style:none;
display:inline;
padding:0;
font-size:14px
}

.blog-details .meta-bottom .tags li {
display:inline-block
}

.blog-details .meta-bottom .tags li+li::before {
padding-right:6px;
color:var(--default-color);
content:","
}

.blog-details .meta-bottom .share {
font-size:16px
}

.blog-details .meta-bottom .share i {
padding-left:5px
}

.blog-comments {
padding:10px 0
}

.blog-comments .comments-count {
font-weight:700
}

.blog-comments .comment {
margin-top:30px;
position:relative
}

.blog-comments .comment .comment-img {
margin-right:14px
}

.blog-comments .comment .comment-img img {
width:60px
}

.blog-comments .comment h5 {
font-size:16px;
margin-bottom:2px
}

.blog-comments .comment h5 a {
font-weight:700;
color:var(--default-color);
transition:.3s
}

.blog-comments .comment h5 a:hover {
color:var(--accent-color)
}

.blog-comments .comment h5 .reply {
padding-left:10px;
color:color-mix(in srgb,var(--default-color),transparent 20%)
}

.blog-comments .comment h5 .reply i {
font-size:20px
}

.blog-comments .comment time {
display:block;
font-size:14px;
color:color-mix(in srgb,var(--default-color),transparent 40%);
margin-bottom:5px
}

.blog-comments .comment.comment-reply {
padding-left:40px
}

.comment-form {
padding-top:10px
}

.comment-form form {
background-color:var(--surface-color);
margin-top:30px;
padding:30px;
box-shadow:0 4px 16px #0000001a
}

.comment-form form h4 {
font-weight:700;
font-size:22px
}

.comment-form form p {
font-size:14px
}

.comment-form form input {
background-color:var(--surface-color);
color:var(--default-color);
border:1px solid color-mix(in srgb,var(--default-color),transparent 70%);
font-size:14px;
border-radius:4px;
padding:10px
}

.comment-form form input:focus {
color:var(--default-color);
background-color:var(--surface-color);
box-shadow:none;
border-color:var(--accent-color)
}

.comment-form form input::placeholder {
color:color-mix(in srgb,var(--default-color),transparent 50%)
}

.comment-form form textarea {
background-color:var(--surface-color);
color:var(--default-color);
border:1px solid color-mix(in srgb,var(--default-color),transparent 70%);
border-radius:4px;
padding:10px;
font-size:14px;
height:120px
}

.comment-form form textarea:focus {
color:var(--default-color);
box-shadow:none;
border-color:var(--accent-color);
background-color:var(--surface-color)
}

.comment-form form textarea::placeholder {
color:color-mix(in srgb,var(--default-color),transparent 50%)
}

.comment-form form .form-group {
margin-bottom:25px
}

.comment-form form .btn-primary {
border-radius:4px;
padding:10px 20px;
border:0;
background-color:var(--accent-color);
color:var(--contrast-color)
}

.comment-form form .btn-primary:hover {
color:var(--contrast-color);
background-color:color-mix(in srgb,var(--accent-color),transparent 20%)
}

.contact .info {
background-color:var(--surface-color);
padding:40px;
box-shadow:0 2px 15px #0000001a;
overflow:hidden
}

.contact .info h3 {
font-weight:600;
font-size:24px
}

.contact .info p {
color:color-mix(in srgb,var(--default-color),transparent 40%);
margin-bottom:30px;
font-size:15px
}

.contact .info-item+.info-item {
padding-top:20px;
margin-top:20px;
border-top:1px solid color-mix(in srgb,var(--default-color),transparent 90%)
}

.contact .info-item i {
font-size:24px;
color:var(--accent-color);
transition:all .3s ease-in-out;
margin-right:20px
}

.contact .info-item h4 {
padding:0;
font-size:18px;
line-height:24px;
font-weight:600;
margin-bottom:5px
}

.contact .info-item p {
padding:0;
margin-bottom:0;
font-size:14px;
color:color-mix(in srgb,var(--default-color),transparent 40%)
}

.contact .php-email-form {
width:100%
}

.contact .php-email-form .form-group {
padding-bottom:8px
}

.contact .php-email-form input[type=text],.contact .php-email-form input[type=email],.contact .php-email-form textarea {
color:var(--default-color);
background-color:var(--surface-color);
border-radius:0;
box-shadow:none;
font-size:14px;
border-color:color-mix(in srgb,var(--default-color),transparent 80%)
}

.contact .php-email-form input[type=text]:focus,.contact .php-email-form input[type=email]:focus,.contact .php-email-form textarea:focus {
border-color:var(--accent-color)
}

.contact .php-email-form input[type=text]::placeholder,.contact .php-email-form input[type=email]::placeholder,.contact .php-email-form textarea::placeholder {
color:color-mix(in srgb,var(--default-color),transparent 70%)
}

.contact .php-email-form input[type=text],.contact .php-email-form input[type=email] {
height:48px;
padding:10px 15px
}

.contact .php-email-form textarea {
padding:10px 12px;
height:290px
}

.contact .php-email-form button[type=submit] {
background:var(--accent-color);
color:var(--contrast-color);
border:0;
padding:13px 50px;
transition:.4s;
border-radius:4px
}

.contact .php-email-form button[type=submit]:hover {
background:color-mix(in srgb,var(--accent-color) 90%,black 15%)
}

.widgets-container {
margin:60px 0 30px
}

.widget-title {
color:var(--heading-color);
font-size:20px;
font-weight:600;
padding:0 0 0 10px;
margin:0 0 20px;
border-left:4px solid var(--accent-color)
}

.widget-item {
margin-bottom:30px;
background-color:color-mix(in srgb,var(--default-color),transparent 98%);
border:1px solid color-mix(in srgb,var(--default-color),transparent 90%);
padding:30px;
border-radius:5px
}

.widget-item:last-child {
margin-bottom:0
}

.blog-author-widget img {
max-width:160px
}

.blog-author-widget h4 {
font-weight:600;
font-size:24px;
margin:15px 0 0;
padding:0;
color:color-mix(in srgb,var(--default-color),transparent 20%)
}

.blog-author-widget .social-links {
margin:5px 0
}

.blog-author-widget .social-links a {
color:color-mix(in srgb,var(--default-color),transparent 60%);
margin:0 3px;
font-size:18px
}

.blog-author-widget .social-links a:hover {
color:var(--accent-color)
}

.blog-author-widget p {
font-style:italic;
color:color-mix(in srgb,var(--default-color),transparent 30%);
margin:10px 0 0
}

.recent-posts-widget .post-item {
display:flex;
flex-direction:column;
margin-bottom:20px
}

.recent-posts-widget .post-item:last-child {
margin-bottom:0
}

.recent-posts-widget .post-item h4 {
font-size:16px;
font-weight:600;
margin-bottom:5px
}

.recent-posts-widget .post-item h4 a {
color:var(--default-color);
transition:.3s
}

.recent-posts-widget .post-item h4 a:hover {
color:var(--accent-color)
}

.recent-posts-widget .post-item time {
display:block;
font-style:italic;
font-size:14px;
color:color-mix(in srgb,var(--default-color),transparent 50%)
}

.tags-widget ul {
list-style:none;
padding:0;
margin:0
}

.tags-widget ul li {
display:inline-block
}

.tags-widget ul a {
background-color:color-mix(in srgb,var(--default-color),transparent 94%);
color:color-mix(in srgb,var(--default-color),transparent 30%);
border-radius:50px;
font-size:14px;
padding:5px 15px;
margin:0 6px 8px 0;
display:inline-block;
transition:.3s
}

.tags-widget ul a:hover {
background:var(--accent-color);
color:var(--contrast-color)
}

.tags-widget ul a span {
padding-left:5px;
color:color-mix(in srgb,var(--default-color),transparent 60%);
font-size:14px
}