/**
 * Theme Name:     webflow dotsquares child
 * Author:         dotsquares
 * Template:       twentytwentyone
 * Text Domain:	   webflow-dotsquares-child
 * Description:    Twenty Twenty-One is a blank canvas for your ideas and it makes the block editor your best brush. With new block patterns, which allow you to create a beautiful layout in a matter of seconds, this theme’s soft colors and eye-catching — yet timeless — design will let your work shine. Take it for a spin! See how Twenty Twenty-One elevates your portfolio, business website, or personal blog.
 */

@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&display=swap');

 :root {
    --primary: #F58123;
    --secondary: #2C437D;
    --black: #000000;
    --dark: #414141;
    --gray:#5D5D5D;
    --bordercolor:#E6E6E6;
    --white:#ffffff;
    --textlight:#C8C8C8;
    --bglight:#F1F6FF;



    --text-primary: #ff7300;
    --globalfamily :"Nunito", sans-serif;


    --timeline-content-gap: 1.5rem;
    --timeline-entry-padding: 2rem;
    --timeline-title-font-size: 2rem;
    --timeline-content-font-size: 1.2rem;
    --timeline-circle-size: 24px;
    --timeline-border-width: 5px;
}

body {
    font-family: var(--globalfamily);
    font-optical-sizing: auto;
    font-weight: normal;
    color: var(--gray);
    box-sizing: border-box;
    font-size: 16px;
}
h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5,h6,.h6 {
    font-family: var(--globalfamily);
    color: var(--black);
    font-weight: bold;
}

h1{
    font-size: 45px;

    padding-bottom: 10px;
    color: var(--white);
}
h2{
    font-size: 40px;
    padding-bottom: 10px;
}

h2 strong{
    font-family: var(--globalfamily);
    color: var(--primary);
}
h3{
    font-size: 22px;
    padding-bottom: 10px;
}
h4{
    font-size: 20px;
}
h5{
    font-size: 18px;
}
a{
    color: var(--primary);
}
a:hover {
    color: var(--secondary);
}

p{
    line-height: inherit;
}
.entry-content, .entry-summary {
    font-family: var(--globalfamily);
}
.has-background-white .site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    color: var(--primary);
    background: transparent;
}

.site .button:not(:hover):not(:active):not(.has-background), button:not(:hover):not(:active):not(.has-background), input[type=submit]:not(:hover):not(:active):not(.has-background), input[type=reset]:not(:hover):not(:active):not(.has-background), .wp-block-search .wp-block-search__button:not(:hover):not(:active):not(.has-background), .wp-block-button .wp-block-button__link:not(:hover):not(:active):not(.has-background), .wp-block-file a.wp-block-file__button:not(:hover):not(:active):not(.has-background), .btn-primary {
    background-color: var(--primary);
    background-image: none;
    border: none;
    border-radius: 30px;
    padding: 10px 25px;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
}
.vc_btn3-container .vc_btn3.vc_btn3-color-grey.vc_btn3-style-modern {
    color: #fff;
    background-color: var(--primary);
    background-image: none;
    border: none;
    border-radius: 30px;
    padding: 10px 25px;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
}
.site .vc_btn3.vc_btn3-color-grey.vc_btn3-style-modern:focus, .site .vc_btn3.vc_btn3-color-grey.vc_btn3-style-modern:hover, .btn-primary:hover, .btn-primary:focus, .btn-primary:active, .btn:focus-visible {
    color: var(--white);
      border: none;
    background-color: #2C437D;
     border-radius: 30px;
     background-image: none;
     padding: 10px 25px;
        font-size: 16px;
    font-weight: 600;
     text-transform: uppercase;
}


.site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    outline: none;
    text-decoration: none;
    text-decoration-skip-ink: none;
}

.site .button:hover, .site .button:active, button:hover, button:active, input[type=submit]:hover, input[type=submit]:active, input[type=reset]:hover, input[type=reset]:active, .wp-block-search .wp-block-search__button:hover, .wp-block-search .wp-block-search__button:active, .wp-block-button .wp-block-button__link:hover, .wp-block-button .wp-block-button__link:active, .wp-block-file a.wp-block-file__button:hover, .wp-block-file a.wp-block-file__button:active {
    background-color: var(--secondary);
    background-image: none;
    border: none;
    border-radius: 30px;
    padding: 10px 25px;
    font-size: 16px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--white);
}
.site .button:focus, button:focus, input[type=submit]:focus, input[type=reset]:focus, .wp-block-search .wp-block-search__button:focus, .wp-block-button .wp-block-button__link:focus, .wp-block-file a.wp-block-file__button:focus {
    outline-offset:0;
    outline: none;
}
.site-main > * {
    margin-top: 0;
    margin-bottom: 0;
}
.navbar-brand {
    max-width: 204px;
    display: block;
}
.navbar-brand img {
    width: 100%;
}
.site-main .vc_row{
    margin: 0;
}
.container {
    max-width: 1430px;    
    margin: 0 auto !important;
    float: none !important;
    padding-left: 15px;
    padding-right: 15px;
}
.container2 {
    max-width: 1230px;    
    margin: 0 auto !important;
    float: none !important;
    padding-left: 15px;
    padding-right: 15px;
}
.site-footer, .site-header{
    max-width: 1430px;
     margin-left: auto;
    margin-right: auto;
}

.widget-area, .pagination, .comments-pagination, .post-navigation, .alignwide, .wide-max-width {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
}
.entry-content > *:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.is-style-wide) {
      max-width: 1400px;
      width: 100%;
}
.post-thumbnail, .entry-content .wp-audio-shortcode, .entry-content > *:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.wp-block-separator), *[class*=inner-container] > *:not(.entry-content):not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.wp-block-separator), .default-max-width {
    max-width: 1400px;
    width: 100%;
}


.site-header{
    position: relative;
    z-index: 9;
}
.site-header, .site-main, .widget-area, .site-footer {
    padding-top: 0;
    padding-bottom: 0;
}
.site-header {
    padding: 15px 15px;
}
.site-logo {
    margin: 0;
}
.site-logo .custom-logo {
    max-width: 200px;
    max-height: 100%;
}
.site-branding {
    margin-top: 0;
}
.site-header .primary-navigation {
     margin-left: 0;
    flex-grow: 1;
}
.primary-navigation > div > .menu-wrapper {
    justify-content: center;
}

.site-header .primary-navigation a {
    font-family: var(--globalfamily);
    font-size: 18px;
}
.primary-navigation .primary-menu-container > ul > .menu-item > a {
    padding:8px 18px;
}
.primary-navigation .primary-menu-container > ul > .menu-item > a:hover {
    color: var(--primary);
    text-decoration: none;
}
    .primary-navigation .primary-menu-container .sub-menu-toggle:after{
    content: "\f078";
    position: absolute;
    right: 0;
    top: 6px;
    font-family: "Font Awesome 7 Free";
    font-weight: 900;
}

@media (min-width:768px) {

    .primary-navigation > div > .menu-wrapper .sub-menu-toggle .icon-plus, .primary-navigation > div > .menu-wrapper .sub-menu-toggle .icon-minus {
        display: none;
    }
    .primary-navigation > div > .menu-wrapper .sub-menu-toggle[aria-expanded=true] .icon-minus {
        display: none;
    }
.primary-navigation > div > .menu-wrapper > li > .sub-menu {
    border: 1px solid #ccc;
    border-radius: 5px;
    padding: 10px 0;
    background-color: #fff;
}
.primary-navigation > div > .menu-wrapper > li > .sub-menu:after {
    border-color: #fff transparent;
}
.primary-navigation > div > .menu-wrapper > li > .sub-menu:before {
    border-color: #ccc transparent;
}
.primary-navigation .sub-menu .menu-item > a {
    padding: 10px 15px;
}
}

.get-quote .btn {
    padding: 7px 20px;
    text-transform: none;
}
.get-quote .btn-primary:focus {
    background-color: var(--secondary) !important;
    color: var(--white) !important;
}

.primary-navigation .primary-menu-container > ul > .menu-item > a + .sub-menu-toggle {
    background-color: transparent;
    padding: 0;
    height: auto;
    width: 15px; 
}
.primary-navigation .current-menu-item > a:first-child, .primary-navigation .current_page_item > a:first-child {
    text-decoration: none;
}
.primary-navigation .sub-menu .menu-item > a:hover {
    color: var(--primary);
    text-decoration: none;
}
.primary-navigation > div > .menu-wrapper .sub-menu-toggle:focus {
    outline: none;
}



.webflow-banner {
    color: #fff;
    padding: 20px 0;
    margin: 0;
}
.banner-cont h1{
    padding-bottom: 10px;
}
.banner-cont h4 {
    color: #ff9138;
    font-size: 24px;
}
.HomeBanner_teachLogos {
    display: flex;
    padding-top: 10px;
}
.brands-logo {
    padding-top: 30px;
    padding-bottom: 20px;
}

.wp-listing ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
    color: var(--black);
}
.wp-listing ul li{
    padding-left: 30px;
    position: relative;
    padding-bottom: 10px;
    font-weight: 500;
}
.wp-listing ul li:after{
    content: "\f058";
    position: absolute;
    left: 0;
    top: 1px;
    font-family: "Font Awesome 7 Free";
    font-weight: 400;
    color: var(--primary);
}

.webflow-services-sec{
    padding-top: 20px;
    padding-bottom: 50px;
}
.services-list ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
}
.services-list ul li{
    display: flex;
    width: 100%;
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px solid var(--bordercolor);
    line-height: 24px;
    font-size: 15px;
}
.services-list ul li:last-child{
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom:none;
}
.services-list-icon {
    width: 60px;
    min-width: 60px;
    height: 60px;
    border-radius: 5px;
    background-color: var(--secondary);
    display: flex;
    align-items: center;
    justify-content: center;
}
.services-list-cont{
    padding-left: 20px;
}
.services-list-cont h4{
    font-size: 22px;
}

.list-color .services-list-icon {
    background-color: var(--primary);
}

.why-choose-dots {
    padding: 30px 0;
    color: var(--textlight);
}

.why-choose-dots h2{
    color: var(--white);
}
.process-sec {
    padding-top: 50px;
    padding-bottom: 50px;
}
.process-heading{
    text-align: center;
}
.process-block{
    padding-bottom: 30px;
}
.process-block>.vc_column-inner>.wpb_wrapper{
    position: relative;
    border: 1px solid var(--secondary);
    min-height: 100%;
    padding: 30px;
    border-radius: 30px;
}
.process-no {
    position: absolute;
    right: 30px;
    top: 30px;
    font-size: 50px;
    line-height: 40px;
    color: #fbe6d2;
}

.solutions-apart-sec {
    padding-bottom: 110px;
}
.solutions-apart-left {
    background-color: var(--black);
    color: var(--textlight);
    font-size: 20px;
}
.solutions-apart-left h2{
    color: var(--white);
}
.solutions-apart-left>.vc_column-inner>.wpb_wrapper {
    max-width: 670px;
    margin-left: auto;
    padding-right: 100px;
}
.solutions-apart-right {
    background-color: var(--white);
}
.solutions-apart-right.vc_column_container>.vc_column-inner{
    padding: 0;
}
.solution-point>.vc_column-inner>.wpb_wrapper{
    position: relative;
    background-color: var(--bglight);
    min-height: 100%;
    padding: 30px 30px 50px 30px;
    border-bottom: 2px solid var(--primary);
    color: var(--black);
}
.solution-point.vc_column_container>.vc_column-inner {
    padding-left: 0;
    padding-right: 0;
}
.solutions-apart-right .solution-point {
    padding: 0 5px;
}

.free-consultation-sec {
    border-radius: 30px;
    color: var(--white);
    padding: 0 50px;
    font-size: 18px;
}

.free-consultation-sec h2{
    color: var(--white);
}

.lets-talk-image {
    margin-top: -90px;
}

.industries-sec {
    padding-top: 30px;
    padding-bottom: 30px;
}



.wpls-logo-showcase .slick-arrow {
    line-height: 19px;
}
.wpls-logo-showcase .slick-arrow:hover {
    background-color: var(--primary);
}
.industries-sec .wpls-logo-showcase .slick-slide .logo-title {
    color: #000;
    font-size: 20px;
}

.industries-sec .wpls-logo-showcase .wpls-logo-cnt.slick-slide {
   box-shadow: 0 3px 6px rgba(0,0,0,0.16);
   border-radius: 30px;
   padding: 20px;
   text-align: center;
   margin: 10px;
}

.wpls-logo-showcase .slick-dots {
    display: none !important;
}
.wpls-logo-showcase {
    padding: 0 30px 0px 30px;
}

.brands-logo h2 {
    font-size: 24px;
    padding-bottom: 20px;
}
.client-say-sec {
    padding-top: 30px;
    padding-bottom: 30px;
}
.technologies-sec {
    background-color: var(--bglight);
    padding: 50px 0;
    margin-bottom: 0;
}


ul.techtabs {
    display: flex;
    list-style-type: none;
    padding: 0;
    margin: 0;
    border-bottom: 1px solid #BFBFBF;
    flex-wrap: wrap;
}
ul.techtabs li {
    padding: 0 10px;
        margin-top: 10px;
}
ul.techtabs .tech-button {
    font-size: 18px;
    font-weight: 500;
    color: #3A3A3A;
    text-decoration: none;
    padding: 5px 25px;
    display: inline-flex;
}
ul.techtabs .tech-button.active, ul.techtabs .tech-button:hover {
    border-bottom: 3px solid var(--primary);
    color:var(--primary);
}
.technologies-tabs .techtab-content {
  /*  display: block;*/
    padding: 25px;
}
.technologies-tabs .tab-content.active {
    display: block;
}
/*tab css*/

.techtab-content {
    display: none;
}
.techtab-content.active {
    display: block;
}
.technologies-tabs {
    padding-top: 20px;
}
.technology-block {
    display: flex;
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
}
.technology-info{
    padding: 10px 15px;
    text-align: center;
    min-width: 120px;
}
.technology-logo {
    text-align: center;
    padding-bottom: 10px;
}
.technology-info h6{
    font-size: 16px;
}

.case-studies-sec {
    margin-top: 0;
    padding: 30px 0;
}

.case-studies-sec h2{
    color: var(--white);
}
.case-studies-sec .case-cat{
    margin-top: 15px;
    margin-bottom: 0;
}
.case-study-grid {
    display:flex;
    gap: 20px;
    width: 100%;
}
.case-study-item {
    width: 33.33%;
    color: var(--white);
    padding-top: 20px;
}
.case-study-item img {
    max-width: 100%;
    height: auto;
}
.case-study-item h5 {
    margin: 15px 0 10px;
    color: var(--white);
}
.case-study-item .full-desc {
    font-size: 14px;
    line-height: 1.5;
}
.case-cat {
    border: 1px solid var(--primary);
    border-radius: 30px;
    padding: 5px 10px;
    display: inline-flex;
    text-decoration: none;
    margin-bottom: 10px;
    font-size: 12px;
}
.case-cat:hover {
    background-color: var(--primary);
    color: var(--white);
}
.pagination, .comments-pagination {
    margin: 0;
    border: none;
}
.has-background-white .site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) .meta-nav {
    color: #000000;
}
.faq-sec {
    background-color: var(--bglight);
    padding: 70px 0;
}

.faq-left{
    font-size: 20px;
    color: var(--black);
}
.faq-left h2{
    padding-bottom: 15px;
}

.sp-easy-accordion .ea-header {
    padding: 0;
}

.sp-easy-accordion .sp-ea-single .ea-header a {
    border-bottom: 1px solid #c7c7c7;    
    font-weight: 500;
    
}

.sp-easy-accordion .sp-ea-single .ea-header a .ea-expand-icon {
    border: 1px solid #707070;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    line-height: 32px;
    background-color: var(--white);
}

.faq-sec .faq-right{
    padding-left: 50px;
}

.tc {
    text-align: center;
}

.first-step-sec{
    background-color: var(--bglight);
    padding: 70px 0;
}
.step-left-block{
    font-size: 20px;
    color: var(--black);
}
.social-icon ul{
    padding: 0;
    margin: 0;
    display: flex;
    list-style-type: none;
}
.social-icon ul li{
    padding-right: 10px;
    font-size: 30px;
}
.first-step-sec .quote-form {
    padding-left: 50px;
}
.quote-form h2{
    font-size: 30px;
    font-weight: 600;
}

.quote-form  form p{
    margin-bottom: 20px;
}
input[type=text], input[type=email], input[type=url], input[type=password], input[type=search], input[type=number], input[type=tel], input[type=date], input[type=month], input[type=week], input[type=time], input[type=datetime], input[type=datetime-local], input[type=color], .site textarea {
    border: 1px solid #DCDCDC;
    border-radius: 10px;
    color: var(--black);
    line-height: var(--global--line-height-body);
    padding: 10px 20px;
    margin: 0;
    max-width: 100%;
}
input[type=text]:focus, input[type=email]:focus, input[type=url]:focus, input[type=password]:focus, input[type=search]:focus, input[type=number]:focus, input[type=tel]:focus, input[type=date]:focus, input[type=month]:focus, input[type=week]:focus, input[type=time]:focus, input[type=datetime]:focus, input[type=datetime-local]:focus, input[type=color]:focus, .site textarea:focus {
    outline-offset: 0;
    outline: none;
}

.quote-form .btn{
    min-width: 176px;
}
.related-development-sec {
        padding-top: 70px;
        padding-bottom: 50px;
}
.related-development-sec h2{
    padding-bottom: 25px;
}
.related-develop{
    padding-top: 25px;
}
.related-develop .wpb_single_image {
    background-color: var(--primary);
    border-radius: 50%;
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    top: -26px;
    position: absolute;
}
.related-develop>.vc_column-inner>.wpb_wrapper {
    position: relative;
    background-color: var(--black);
    color: var(--white);
    border-radius: 24px;
    padding: 45px 30px 30px 30px;
    min-height: 100%;
}
.related-develop h5{
    color: var(--white);
}

.blog-sec {
    padding-top: 70px;
    padding-bottom: 70px;
}
.posts-sec {
    display: flex;
    gap: 30px;
}

.post-item {
    width: 33.33%;
    box-shadow: 0px 1px 3px rgba(0,0,0,0.16);
    border-radius: 10px;
    overflow: hidden;
}
.post-item-cont {
    padding:15px 20px 25px 20px;
}
.post-date{
    position: relative;
    padding-left: 25px;
    color: #5D5D5D;
    padding-bottom: 15px;
}
.post-date:before{
    content:'\f073';
    position: absolute;
    left: 0;
    top: 0;
    font-family: "Font Awesome 7 Free";
    font-weight: 400;
    font-size: 18px;
}


.post-item h3{
    font-size: 20px;
}
.post-item h3 a{
    color: var(--black);
    text-decoration: none;
}
.post-item h3 a:hover{
    color: var(--primary);
}
.read-more{
    padding-top: 15px;
}
.read-more a {
    border: 1px solid var(--primary);
    border-radius: 20px;
    padding: 5px 20px;
    text-decoration: none;
    color: var(--primary);
    display: inline-flex;
}
.read-more a:hover {
    background-color: var(--primary);
    color: var(--white);
}

.site-footer {
    max-width: 100%;
    background-color: var(--black);
    color: var(--white);
    padding-top: 60px;
    background-image: url(images/footer-map.png);
    background-position: right top;
    background-repeat: no-repeat;
    margin-top: 50px;
}
.widget a:link, .widget a:visited, .widget a:active, .widget a {
     color: var(--white);
     text-decoration: none;
}
.footer-info, .footer-menu {
    padding-bottom: 20px;
}

.site-footer .social-icon{
    padding: 10px 0;
}
.site-footer .social-icon h5{
    color: var(--white);
    padding-bottom: 5px;
}
.site-footer .social-icon ul li {
    padding-right: 6px;
    line-height: 30px;
}
.site-footer .social-icon ul li a{
    color: var(--primary);
}

.footer-info img{
    width: auto !important;
}
.footer-info .widget {
    padding-bottom: 20px;
}
.footer-info .widget .textwidget strong{
    color: var(--primary);
}

.site-footer .widget h4 {
    font-size: 20px;
    font-weight: 600;
    color: var(--white);
    text-transform: uppercase;
    margin: 0;
    padding-bottom: 20px;
}
.site-footer .widget nav{
    margin: 0;
}
.site-footer .footer-menu ul li{
    padding-bottom: 3px;
}
.site-footer .footer-menu ul li a{
   color: var(--white);
   text-decoration: none;
}

.site-footer .footer-menu ul li a:hover{
   color: var(--primary);
}

.footer-bottom {
    border-top: 1px solid #333333;
    padding: 10px 0;
    margin: 0;
}


.footer-link ul li {
    display: inline-flex;
    border-right: 1px solid #ccc;
    padding-right: 10px;
    line-height: 20px;
     margin-right: 10px;
}
.footer-link ul li:last-child {
    border-right:none;
    padding-right: 0;
    margin-right: 0;
}

.footer-link ul {
    display: flex;
    justify-content: end;
}
.footer-link ul li a:hover{
   color: var(--primary);
}

.footer-address .textwidget{
    line-height: 34px;
    margin: 0;
}


.conatct-info {
    display: flex;
    border: 1px solid var(--primary);
    margin-bottom: 10px;
    border-radius: 5px;
    padding: 10px 20px;
}
.c-icon {
    width: 35px;
    font-size: 20px;
    color: var(--primary);
}
.conatct-info-inner p {
    margin: 0;
}

 h4{
    padding-bottom: 15px;
}
.contact-us-block .wpcf7-form-control-wrap{ 
    padding-bottom: 20px;
    display: block;
}
.singular .entry-header, .pagetitle-bg {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
    background-color: #999;
    max-width: 100%;
    text-align: center;
    padding: 50px 0;
    background-image: url(images/all-page-background.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.singular .entry-title {
    font-size: 45px;
    color: var(--white);
    font-weight: 600;
}

.contact-us-block {
    padding-top: 30px;
    padding-bottom: 20px;
}
.development-service-block{
    padding-bottom: 30px;
}
.development-service-block>.vc_column-inner>.wpb_wrapper {
    position: relative;
    background-color: var(--bglight);
    min-height: 100%;
    padding: 30px 30px 0 30px;
    border-bottom: 2px solid var(--primary);
    color: var(--black);
}
.development-services-sec{
    padding-bottom: 60px;
}

.development-agency-sec {
        background-color: var(--bglight);
    padding: 70px 0;
}
.service-why-choose-block{
    padding-bottom: 30px;
}
.service-why-choose-block>.vc_column-inner>.wpb_wrapper {
    position: relative;
    border: 1px solid var(--secondary);
    min-height: 100%;
    padding: 30px 30px 0 30px;
    border-radius: 30px;
    background-color: var(--white);
}
.service-why-choose-block .wpb_single_image{
    margin-bottom: 20px;
}

.how-build-sec{
    padding: 70px 0;
    background-color: #000;
    color: var(--white);
}
.how-build-sec h2{
    color: var(--white);
}

#timeline {
  position: relative;
  padding-top: 20px;
}

/* LIST is the flex column now (restores gap + align-self behaviour) */
.timeline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--timeline-gap);
}

/* centre spine uses token; sits behind markers */
#timeline::before {
  content: "";
  width: var(--timeline-border-width);
  height: 100%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--primary);
  z-index: 0;
}

.timeline-entry {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  padding: var(--timeline-entry-padding);
  background: var(--black);
  width: 45%;
  box-shadow: 0px 15px 30px -25px rgba(0,0,0,0.5);
  color: var(--textlight);
  border-radius: 10px;
  border: 1px solid var(--primary);
}

/* marker anchored to #timeline (intentional) */
.timeline-entry::after {
  content: "";
  width: var(--timeline-circle-size);
  height: var(--timeline-circle-size);
  border-radius: 50%;
  border-width: var(--timeline-border-width);
  border-style: solid;
  border-color: var(--primary);
  background: var(--white);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1; /* above spine */
}

.timeline-entry h3{ color: var(--white); padding-top: 15px;}
.timeline-entry h4{ color: var(--white); font-weight: 400; padding-top: 10px;}
.timeline-entry svg { color: var(--primary); order: -1; }

/* Desktop zig-zag: even items to the right */
@media (min-width: 768px) {
  .timeline-list .timeline-entry:nth-child(even) {
    align-self: flex-end;
  }
}



/* Accessibility helper for the hidden heading */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

.portfolio-slider{
    padding-top: 70px;
    padding-bottom: 50px;
}
.portfolio-slider h2{
    padding-bottom: 30px;
}

.portfolio-slider #wpls-logo-showcase-slider-2 .wpls-fix-box img.wp-post-image {
    max-height: 450px;
}

.site-main .mb-50 {
    margin-bottom: 100px;
}


.maintenance-info{
    padding-top: 50px;
    font-size: 24px;
    padding-bottom: 30px;
}
.maintenance-info strong{
    color: var(--primary);
}

.maint-service-box{
    padding-bottom: 30px;
}
.maint-service-box>.vc_column-inner>.wpb_wrapper  {
    position: relative;
    border: 1px solid var(--textlight);
    min-height: 100%;
    padding: 25px;
    border-radius: 30px;
    background-color: var(--white);
}
.maint-service-box>.vc_column-inner>.wpb_wrapper  img{
    max-width: 52px !important;
}
.maint-service-box h3{
    color: var(--dark);
    font-size: 20px;
    padding: 0;
}

.maintenance-service-sec {
    padding-bottom: 70px;
    padding-top: 30px;
}

.maintenance-partner-sec {
    padding-top: 70px;
}

.maintenance-partner-block{
    padding-bottom: 30px;
}
.maintenance-partner-block>.vc_column-inner>.wpb_wrapper {
    position: relative;
    border: 1px solid var(--textlight);
    min-height: 100%;
    padding: 30px 30px 0 30px;
    border-radius: 30px;
    background-color: var(--white);
}
.maintenance-partner-block .wpb_single_image{
    margin-bottom: 20px;
}

.benefits-block{
    padding-bottom: 30px;
}
.benefits-block>.vc_column-inner>.wpb_wrapper {
    position: relative;
    border: 1px solid var(--textlight);
    min-height: 100%;
    padding: 30px 30px 0 30px;
    border-radius: 30px;
    background-color: var(--white);
}

.webflow-automation {
    background-color: var(--secondary);
    color: var(--white);
    padding: 30px;
    border-radius: 30px;
}

.webflow-automation h2{
    color: var(--white);
}

.engagement-sec{
    padding-top: 70px;
    padding-bottom: 50px;
}

.webflow-integration-block {
    background-color: var(--black);
    color: var(--white);
}
.integration-info {
    padding: 50px;

}
.integration-info h2{
    color: var(--white);
}

.integration-info>.vc_column-inner>.wpb_wrapper {
    max-width: 600px;
    margin-left: auto;
    width: 100%;
}

.about-sec-top{
    padding: 50px 0;
}

.about-us-block {
    position: relative;
    background-color: var(--bglight);
    padding: 70px 0;
}

.about-us-info>.vc_column-inner>.wpb_wrapper {
    border: 1px solid #ccc;
    text-align: center;
    border-radius: 10px;
    padding: 30px;
    background-color: var(--white);
    min-height: 100%;
}

.why-webflow-project-sec {
    padding: 70px 0;
}

.webflow-choose-block>.vc_column-inner>.wpb_wrapper {
    text-align: center;
    border-radius: 10px;
    padding: 30px;
    background-color: var(--black);
    min-height: 100%;
    color: var(--white);
}
.webflow-choose-block h3{
    color: var(--white);
}

.values-approach-sec{
    background-color: var(--black);
        color: var(--textlight);
    padding: 70px 0;
}

.values-approach-sec h2{
    color: var(--white);
}

.values-column h3{
    color: var(--white);
}
.values-column ul{
    list-style-type: none;
    padding: 0;
    margin: 0;
}
.values-column ul li{
    padding-bottom: 30px;
    display: flex;
}
.value-left {
    min-width: 72px;
    border: 1px solid var(--primary);
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 5px;
}
.value-left img{
    max-width: 48px;
}
.value-right{
    padding-left: 30px;
}

ul.contlink2.pricacypointli {
    padding-left: 20px;
    margin-top: 30px;
}
ul.contlink2.pricacypointli li {
    margin-bottom: 12px;
}
strong.privacy_head_txt {
    display: block;
    margin-bottom: 5px;
    color: var(--black);
}
.terms-conditions ol {
    padding-left: 20px;
}
.terms-conditions li {
    margin-bottom: 12px;
}

.terms-conditions li ol {
    padding-left: 20px;
}

.terms-conditions h4{
    font-size: 16px;
        padding-bottom: 0;
}

.entry-title a {
    text-underline-offset:0;
    text-decoration: none;
}
.entry-title a:hover {
    color: var(--primary);
}
.entry-title {
    font-size: 22px;
    letter-spacing: 0;
    line-height: var(--heading--line-height-h2);
    margin: 0;
}
.post-thumbnail {
    margin: 0;
}
.post-thumbnail .wp-post-image {
    margin-top: 0;
}
.portfolio-item{
    padding-bottom: 30px;
}
.portfolio-item>.vc_column-inner>.wpb_wrapper{
    border: 1px solid var(--bordercolor);
    padding: 30px;
    border-radius: 5px;
}
.webflow-logo {
    background-image: url(images/webflow-icon.png);
    background-position: center left 10px;
    background-size: 22px;
    background-repeat: no-repeat;
    padding-left: 30px;
    border: 1px solid #ccc;
    padding: 7px 15px;
    display: inline-flex;
    padding-left: 40px;
    border-radius: 40px;
}

nav.navigation.pagination {
    display: none;
}

.post-type-archive-case_study .pagetitle-bg{
    margin-bottom: 30px;
}
.tax-case_study_category .pagetitle-bg{
    margin-bottom: 30px;
}
.category .pagetitle-bg{
    margin-bottom: 30px;
}
.case-studylist .post-item {
  margin-bottom: 20px;
}

.single .site-main > article > .entry-footer {
    margin-top: 0;
    margin-bottom: 0;
    padding-bottom: 0;
    padding-top: 0;
    border-top: none;
    border-bottom: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: calc(2 * var(--global--spacing-horizontal));
}

nav.navigation.post-navigation {
    padding-top: 30px;
}
