/*RESPONSIVE MENU*/
.responsive_btn{ display: none; cursor: pointer; text-align: center; width: 40px; height: 40px; float: right; position: relative; z-index: 20; -moz-transition: all 300ms ease-in-out 0s; -webkit-transition: all 300ms ease-in-out 0s; transition: all 300ms ease-in-out 0s; }
.responsive_btn span{ border-radius: 6%; display: block; height: 2px; width: 20px; position: relative; top: 50%; margin: -1px auto; }
.responsive_btn span:before, .responsive_btn span:after{ height: 100%; width: 100%; position: absolute; content: ""; display: inline; left: 0; }
.responsive_btn span:before{top: -6px;}
.responsive_btn span:after{bottom: -6px;}
.responsive_btn span, .responsive_btn span:before, .responsive_btn span:after{background: #ffffff; -moz-transition: all 300ms ease-in-out 0s; -webkit-transition: all 300ms ease-in-out 0s; transition: all 300ms ease-in-out 0s; }
.responsive_btn:hover span, .responsive_btn:hover span:before, .responsive_btn:hover span:after{background: #7128ac;}
.responsive_nav{ position: fixed; left: -280px; top: 0; bottom: 0; width: 280px; min-height: 100%; z-index: 20; background: #7128ac; padding: 0px; -webkit-transition: all 500ms ease 0s; transition: all 500ms ease 0s; }
.responsive_nav ul { margin: 0; padding: 0; text-align: left; }
.responsive_nav ul li { border-top: 1px solid rgba(255, 255, 255, 0.2); list-style-type: none; margin: 0; padding: 0; position: relative; text-transform: capitalize; font-size: 15px; line-height: 20px; color: #fff; }
.responsive_nav ul li:first-child{border-top: none;}
.responsive_nav ul li > a { display: block; padding: 10px; color: inherit; position: relative; z-index: 1; }
.responsive_nav ul li > a::before{ content: ''; position: absolute; background: #fa6a2b; top: 0; left: 0; width: 0%; height: 100%; z-index: -1; -moz-transition: all 300ms ease-in-out; -webkit-transition: all 300ms ease-in-out; transition: all 300ms ease-in-out; }
.responsive_nav ul li:hover a::before{width: 100%;}
.responsive_nav ul li a:hover, .responsive_nav ul li a:focus, .responsive_nav ul li.active > a, .responsive_nav ul li.opened > a {color: #ffffff;}
.responsive_nav ul li a .fa, .responsive_nav ul li > a .icon-angle-down{display: none;}
.responsive_nav .subarrow { display: block; position: absolute; top: 5px; right: 5px; width: 30px; height: 30px; line-height: 30px; background: #fa6a2b; }
.responsive_nav .subarrow:hover { background: #7128ac; }
.responsive_nav ul ul{margin: 1px 0 0 15px; display: none;}
.bodyOverlay{ position: fixed; left: 0; top: 0; right: 0; bottom: 0; z-index: 20; transform: none; background: rgba(0,0,0,0.6); opacity: 0; visibility: hidden; -webkit-transition: all 500ms ease 0s; transition: all 500ms ease 0s; }
html.responsive, .responsive body{overflow-y: hidden;}
.responsive .wrapper{ -webkit-transform: translate(-280px,0) !important; transform: translate(-280px,0) !important; }
.responsive .bodyOverlay {opacity: 1; visibility: visible;}
.responsive .responsive_nav {left: 0;}
.responsive .responsive_btn{pointer-events: none;}
.responsive .responsive_btn span{-webkit-transform: rotate(45deg); transform: rotate(45deg);}
.responsive .responsive_btn span:after{-webkit-transform: rotate(270deg); transform: rotate(270deg); top: 0;}
.responsive .responsive_btn span:before{opacity: 0;}

/*1200px*/
@media only screen and (max-width: 1400px) {
    .nav_menu > ul{font-size: 16px;}
    .sticky .nav_menu > ul{font-size: 14px;}
}

/*1170px*/
@media only screen and (max-width: 1199px){
}

/*992px*/
@media only screen and (max-width: 1169px) {
    .nav_menu > ul{font-size: 14px; margin-right: 0;}
    .header_main .logo{max-width: 200px;}
    .sideleft.blogsingle .heading{font-size: 28px;}
    .post_image { width: auto; max-width: 50%; margin-left: 15px; }
    .sticky .nav_menu > ul{font-size: 12px;}
    .sticky .nav_menu > ul > li{margin: 0;}
    .sticky .nav_menu > ul > li > a{padding: 0 3px;;}
    .footer_top{padding: 30px 0;}
    .banner_text .headtitle { font-size: 32px; line-height: 40px; }
    .about_us .abt_detail .heading { font-size: 30px; margin-bottom: 10px; }
}

/*768px*/
@media only screen and (max-width: 991px) {
    .responsive_btn { display: block; background: #fa6a2b; -webkit-border-radius: 5px; border-radius: 5px; }
    .sticky .responsive_btn {width: 34px;height: 34px;}
    .nav_wrapper{display: none;}
    .header_main .header_right .h_cntct{padding-left: 60px;}
    .htop {padding: 10px 0;}
    .h_cntct li.call a {margin-bottom: 0px;}
    .h_cntct span, .h_cntct a{font-size: 16px;}
    .header_right { margin-left: 0; justify-content: space-between; width: 100%; }
    .header_main .logo { max-width: 170px; position: absolute; top: 90px; left: 15px; z-index: 9; }
    .hbottom{padding: 12px 0;}
    .heading { font-size: 32px; }
    .wpcf7-form .row [class*="col-"] { -webkit-box-flex: 0; -ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%; }
    .wpcf7-form .row [class*="col-"]:first-child { display: flex; flex-wrap: wrap; margin: 0 -10px; padding-right: 0; }
    .wpcf7-form .row [class*="col-"]:first-child span{ flex: 0 0 50%; max-width:50%; padding: 0 10px; }
    .wpcf7-form .row [class*="col-"]:first-child span:last-child{ flex: 0 0 100%; max-width: 100%; }
    .contact_info .f_cntct .add, .contact_info .f_cntct .ph { margin-bottom: 20px; }
    .contact_map{padding-left: 0; margin-bottom: 0;}
    .contact_info { max-width: 100%; position: static; margin-bottom: 30px; }
    .contact_info .f_cntct i{font-size: 20px; width: 20px;}
    .map{height: 300px;}
    .footer_top .row{margin-bottom: -30px;}
    .footer_top [class*="col-"]{ flex: 0 0 50%; max-width:50%; padding: 0 10px; margin-bottom: 30px; }
    .footer_top [class*="col-"]:first-child{ -webkit-box-flex: 0; -ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%; }
    .f_menu ul { column-count: 2; }
    .copyright p:first-of-type, .copyright p:last-of-type{float: none;}
    .copyright p{text-align: center;}
    .otgs-development-site-front-end{padding: 10px 0 !important;}    
    .blog_list .row{margin: 0 -10px;}
    .blog_list [class*="col-"] { -ms-flex: 0 0 50%; flex: 0 0 50%; max-width: 50%; padding: 0 10px; }
    .widget_recent_entries{padding-bottom: 0;}
    .about_img { width: 100%; float: none; padding-left: 0; padding-bottom: 0; margin-left: 0; }
    .sticky .header_main .logo { max-width: 140px; top: 10px; }
    #secondary{padding-bottom: 0;}
    .widget-area .widget.widget_recent_entries .widget-title{margin-bottom: 15px;}
    .services .service_img{margin-bottom: 0;}
    .service_detail { padding: 10px 15px 15px; border: 1px solid #4799b1; border-top: none; -webkit-border-radius: 0 0 5px 5px; border-radius: 0 0 5px 5px; }
    .service_slider{padding: 0;}
    .service_slider.owl-carousel .owl-nav{display: none;}
    .common_banner{max-height: 100%;}
    .home_banner .banner .banner_text { position: static; transform: none; padding: 30px 0; background: #4799b1; }
    .banner_below, .abt_detail p{ font-size: 18px; }
    .about_us .row { flex-direction: column-reverse; text-align: center; }
    .about_us .abt_img{margin-bottom: 15px;}
    .service_list_img { height: 280px; width: 280px; }
    .service_list  ul { min-height: 440px; margin: 50px auto 0; font-size: 16px; line-height: 24px; }
    .service_list_img::before { top: -35px; left: -35px; width: 350px; height: 350px; }
    .service_list_img::after { width: 430px; height: 430px; top: -75px; left: -75px; }
    .service_list ul li:nth-child(3) { padding-right: 30px; }
    .service_list ul li:nth-child(4) { padding-left: 30px; }
    .service_list ul li figure { width: 50px; height: 50px; margin-right: 10px; }
    .section { padding: 40px 0; }
}

/*600px*/
@media only screen and (max-width: 767px) {
    .contact_info { max-width: 100%; position: static; margin-bottom: 30px; }
    .sideleft.blogsingle .heading{font-size: 24px; margin-bottom: 10px;}
    .service-list .row{margin: 0 -10px -30px;}
    .service-list [class*="col-"] { -ms-flex: 0 0 50%; flex: 0 0 50%; max-width: 50%; padding: 0 10px; }
    .banner_text .headtitle { font-size: 26px; line-height: 34px; margin-bottom: 15px; }
    .home_banner .banner_text p{font-size: 21px;}
    .about_us .abt_detail .heading{font-size: 26px;}
}

/*480px*/
@media only screen and (max-width: 599px) {
    .header_main .header_right .h_cntct{padding-left: 30px;}
    .h_cntct li{padding-left: 28px;}
    .h_cntct li::before{font-size: 18px;}
    .wpml-ls-legacy-dropdown a {line-height: 22px;height: 36px;}
    .wpml-ls-legacy-dropdown a.wpml-ls-item-toggle::before{height: 32px;}
    .banner .banner_img{min-height: 100px;}
    .heading {font-size: 26px;margin-bottom: 20px;}
    .header_main .logo {top: 85px;}
    .contact_info{padding: 30px; margin-bottom: 15px;}
    .map {height: 220px;}
    .footer_top .row{margin-bottom: -15px;}
    .footer_top [class*="col-"] { flex: 0 0 100%; max-width: 100%; margin-bottom: 15px; }
    .f_head{margin-bottom: 15px;}
    .f_cntct{width: auto;}
    footer .f_cntct .ph{margin-top: 15px;}
    .b_text .b_title { font-size: 18px; line-height: 24px; }
    .post_image { max-width: 100%; margin: 0 0 15px; float: none; }
    .breadcrumb{font-size: 14px;}
    input[type="text"], input[type="password"], input[type="datetime"], input[type="datetime-local"], input[type="date"], input[type="month"], input[type="time"], input[type="week"], input[type="number"], input[type="email"], input[type="url"], input[type="search"], input[type="tel"], input[type="color"], input[type="file"], select, textarea { height: 36px; font-size: 13px; }
    .contact_form textarea{height: 96px;}
    .post_content {text-align: justify;}
    .about_cntnt h4, .subheading{font-size: 18px;}
    body{font-size: 15px;}
    .banner .banner_text { position: static; transform: none; padding: 30px 0; background: #4799b1; }
    .banner_text p { font-size: 20px; line-height: 26px; }
    .banner_below, .abt_detail p { font-size: 16px; line-height: 30px; }
    [type="submit"], [type="reset"], [type="button"], button, .btn{height: 40px; line-height: 40px;}
    .service_list ul li{flex: 0 0 50%; max-width: 50%; display: block; text-align: center !important; margin-bottom: 20px; padding: 0 10px !important;}
    .service_list ul li:nth-child(even){margin-left: 0;}
    .service_list ul{min-height: auto; margin: 30px -10px -20px;}
    .service_list ul li figure {margin: 0 auto 10px !important;}
    .service_list_img{display: none;}
}

/*360px*/
@media only screen and (max-width: 479px) {
    .header_main .header_right .h_cntct { padding: 0; display: flex; align-items: center; max-width: 40%; width: 100%; justify-content: center; }    .h_cntct span, .h_cntct a{font-size: 0;}
    .h_cntct li::before{display: none;}
    .h_cntct li.call { letter-spacing: normal; word-spacing: normal; margin: 0 10px 0 0; }
    .h_cntct li a{position: relative;}
    .h_cntct li a::before{ content: "\f095"; position: absolute; font-family: 'FontAwesome'; font-size: 22px; color: #4799B1; top: 50%; left: 0; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
    .h_cntct li.mail a::before{content: '\f0e0';}
    .responsive_btn { width: 34px; height: 34px; }
    .header_main .logo { top: 80px; max-width: 140px; }
    .wpcf7-form .row [class*="col-"]:first-child span { flex: 0 0 100%; max-width: 100%; }
    .btn_wr { float: none; margin-top: 10px; display: block; text-align: center; }
    [type="submit"], [type="reset"], [type="button"], button, .btn { line-height: 40px; height: 40px; }
    .captcha_img{float: none;}
    .f_cntct .add, .f_cntct .ph{margin-bottom: 15px;}
    .f_cntct span{font-size: 14px;}
    .copyright { padding: 10px 0; font-size: 12px; }
    .footer_top{padding-bottom: 30px;}
    .f_menu ul { column-count: 1; }
    .footer_top .f_cntct i { font-size: 20px; width: 20px; }
    .footer_top .f_cntct .ph i{font-size: 18px;}
    footer .f_cntct .ph{margin-left: -33px;}
    .blog_list [class*="col-"] { -ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%; margin-bottom: 15px; }
    .blog_box p{height: auto;}
    .sideleft.blogsingle .heading{font-size: 21px;}
    .section {padding: 30px 0;}
    .service-list [class*="col-"]{ -ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%; }
    .home_banner .banner .banner_text { padding: 20px 0; } .banner_text .headtitle { font-size: 22px; line-height: 30px; }
    .home_banner .banner_text p { font-size: 18px; }
    .about_us .abt_detail .heading, .banner_below .heading{ font-size: 20px; line-height: 30px; margin-bottom: 10px; }
    .banner_below p { text-align: justify !important; }
}

/*320px*/
@media only screen and (max-width: 359px) {
    .heading {font-size: 22px;margin-bottom: 10px;}
    .banner_text p{font-size: 18px;}
}