/*
Theme Name: Astra Child
Template: astra
Version: 1.0
*/

/*
Theme Name: Astra Child
Template: astra
Version: 1.0
*/
@import url('https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600;700&family=Roboto:wght@300;400;500;700&display=swap');
/* HERO */
.blog-hero {
    background: #22534e;
    color: #fff;
    padding: 70px 0 0;
    position: relative;
}

.blog-hero .hero-inner {
    max-width: 1200px;
    margin: auto;
    display: grid;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
    grid-template-columns: 1fr 1fr;
}

.hero-left h1 {
color: #ffffff;
    font-size: 64px;
    font-weight: 700;
    font-style: normal;
    line-height: 65px;
    text-align: left;
    margin: 0 0 25px;
}

.hero-left p {
    max-width: 530px;
    color: #ffffff;
    font-size: 20px;
    font-style: normal;
    line-height: 30px;
    text-align: left;
    margin-bottom: 30px;
}

.hero-sub {
    color: #3cb4e5;
    font-size: 16px;
    font-weight: 300;
    font-style: normal;
    letter-spacing: 2px;
    text-align: left;
    display: block;
    margin-bottom: 20px;
}

.hero-right img {
    width: 100%;
	 max-width: 480px;
	margin: auto;
}

/* FILTER */
.blog-filter {
    text-align: center;
    margin: 0 0 50px;
}

.blog-filter button {
    padding: 8px 14px;
    margin: 2px 0;
    border: 1px solid rgba(60, 180, 229, 0.11);
    background: #fff;
    cursor: pointer;
    border-radius: 3px;
    font-size: 14px;
    font-weight: 300;
    padding-top: 7px;
    padding-bottom: 7px;
    padding-left: 15px;
    padding-right: 15px;
    margin-right: 15px;
    border-width: 1px;
    border-style: solid solid solid solid;
    color: #979797;
}
.blog-hero svg {
    width: 100%;
    transform: scaleY(-1) scaleX(-1);
    height: 100px;
    margin-bottom: -10px;
}
.blog-filter button.active {
background-color: #3cb4e5;
    color: #ffffff;
    border-color: #5890e5;
}
.blog-meta span.blog-date {
    color: #3cb4e5 !important;
    font-size: 14px !important;
    font-weight: 400;
    margin: 0 0 15px !important;
    display: block !important;
    padding: 13px 0 !important;
}
/* GRID */
.custom-blog-container {
    max-width: 1200px;
    margin: auto;
    padding: 60px 20px 80px;
}

.section-title {
    text-align: center;
    margin-bottom: 30px;
}

.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}

.blog-card {
    transition: 0.3s;
}

.blog-card:hover {
    transform: translateY(-5px);
}

.blog-image img {
    width: 100%;
    object-fit: cover;
}

.blog-content {
    padding: 15px;
}

.blog-content h3 {
    font-size: 18px;
    margin-bottom: 10px;
}

.blog-content p {
    font-size: 14px;
    color: #555;
}

/* PAGINATION */
.pagination {
    text-align: center;
    margin-top: 40px;
}
.page-template-page-blog-custom .ast-container {
    display: block;
}

.page-template-page-blog-custom .blog-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    max-width: 1200px;
    margin: auto;
    gap: 25px;
}

.page-template-page-blog-custom .blog-content h3 {
    color: #4d4d4d;
    font-size: 24px;
    font-weight: 700;
    line-height: 27px;
    margin-bottom: 13px;
    font-family: rubik;
}

.page-template-page-blog-custom .blog-content {
    padding: 40px 0  20px;
}

.page-template-page-blog-custom .blog-content p {
    font-size: 16px;
    font-weight: 300;
    line-height: 25px;
    display: block;
    margin-bottom: 25px;
    color: #4d4d4d;
}

.page-template-page-blog-custom .blog-image img {
    width: 100%;
    border-radius: 10px;
	    height: auto;
}
.blog-card.blog.inactive {
    opacity: 0.4;
    pointer-events: none;
}
.custom-blog-container h2.section-title {
    font-size: 37px;
    font-weight: 700;
    line-height: 38px;
    margin-bottom: 50px;
    color: rgb(70, 72, 75);
}


/* MAIN CONTAINER */
.single-post .single-blog-container
 {
    max-width: 1200px;
    margin: auto;
    padding: 0;
}
.single-post div#content .ast-container hr {
    margin: 0;
}
.single-post .blog-nav {
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
    padding-left: 4%;
    padding-right: 4%;
    padding-bottom: 50px;
    padding-top: 50px;
    border-top: 1px solid;
    border-color: rgb(238, 238, 238);
    border-width: 1px;
    border-right-style: hidden;
    border-bottom-style: hidden;
    border-left-style: hidden;
}
.single-post .blog-nav .blog_nav_in {
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: auto;
}
/* SEARCH */
.single-post .blog-search {
    display: flex;
    margin-bottom: 30px;
}

.single-post .blog-search input {
    background-color: #fff;
    color: #4d4d4d;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 15px;
    padding-right: 15px;
    border-color: #22534e;
    border-width: 1px;
    border-style: solid solid solid solid;
	 width: 75%;
	margin-right: 5px;
}

.single-post .blog-search button {
    padding: 10px 20px;
    border: none;
    background-color: #22534e;
    border-radius: 3px;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 20px;
    text-transform: none;
    width: 24%;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 15px;
    padding-right: 15px;
    border-color: #22534e;
    font-family: rubik;
}

/* TITLE */
.single-post .blog-title {
margin: 60px 0 50px;
    font-size: 65px;
    font-weight: 600;
    line-height: 70px;
    text-align: left;
    text-transform: none;
    font-family: Rubik;
    max-width: 990px;
}

/* META */
.single-post .blog-meta {
    color: #777;
    margin-bottom: 20px;
    font-size: 14px;
}
.blog-content p, .blog-content ul, .blog-content ol {
    margin-bottom: 25px;
    font-size: 16px;
    font-weight: 300;
    font-family: "Roboto";
    font-style: normal;
    line-height: 27px;
    text-align: justify;
    color: rgb(65, 72, 77);
}
/* CONTENT */
.single-post .blog-content {
    padding: 0;
}

.single-post .blog-content h2 {
    margin-top: 0;
    font-size: 31px;
    font-weight: 700;
    font-family: "Roboto";
    font-style: normal;
    line-height: 38px;
    text-align: left;
    margin-bottom: 20px;
    color: rgb(70, 72, 75);
}
.blog-content h3,
.blog-content h4{
    font-size: 18px;
    margin-bottom: 10px;
    color: #22353a;
    font-size: 18px;
    font-weight: 700;
    font-family: "Open Sans";
    font-style: normal;
    line-height: 22px;
    text-align: left;
}
.blog-nav a {
    background-color: rgba(0, 0, 0, 0);
    border-radius: 10px;
    padding-top: 12px;
    padding-bottom: 12px;
    padding-left: 18px;
    padding-right: 18px;
    display: inline-block;
    color: #3cb4e5;
    font-size: 17px;
    font-style: normal;
    font-weight: 300;
    font-family: "Roboto";
    border-color: #3cb4e5;
    border-width: 1px;
    border-style: solid solid solid solid;
}
.single-post .more-blogs {
    background: #22534e;
    padding: 280px 20px;
    color: #fff;
    position: relative;
}
.more-blog-divider svg {
    display: block;
    position: relative;
    left: -1px;
    width: calc(100% + 2px);
}
/* SHARE */
.single-post .blog-share {
    margin-top: 30px;
}

.single-post .blog-share a {
    margin-right: 10px;
}

/* NAV */
.single-post .blog-nav {
    display: flex;
    justify-content: space-between;
    margin-top: 40px;
}

/* MORE BLOGS SECTION */
.single-post .more-blogs {
    background: #1f5d55;
    padding: 280px 20px;
    color: #fff;
}
.blog-meta {
    display: flex;
}

.blog-meta > span:first-child {
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    margin: 8px;
    color: #22353a;
}
.single-post .more-blogs h2 a {
    color: #3cb4e5;
    font-size: 16px;
    font-weight: 300;
}
.single-post .more-blogs h2 {
    text-align: left;
    color: #ffffff;
    font-size: 37px;
    font-weight: 600;
    line-height: 38px;
    max-width: 1200px;
    margin: auto auto 50px;
    font-family: rubik;
    display: flex;
    gap: 15px;
}

/* GRID */
.single-post .blog-grid {
    display: block;
    gap: 0;
    max-width: 1220px;
    margin: auto;
}

/* CARD */
.single-post .blog-card {
    background: transparent;
    padding: 0 12px;
    border-radius: 10px;
}

.single-post .blog-card img {
    width: 100%;
    object-fit: cover;
    display: block;
    max-width: 100%;
    height: auto;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    margin-bottom: 20px;
}

.single-post .read-more {
    display: block;
    border-radius: 10px;
    color: #3cb4e5;
    font-size: 14px;
    font-weight: 400;
    padding-top: 12px;
    padding-bottom: 12px;
    padding-left: 12px;
    padding-right: 12px;
    border-width: 1px;
    border-style: solid solid solid solid;
    border-color: #3cb4e5;
    max-width: 134px;
    margin: auto;
}
.single-post .blog-card h3 {
    color: #22353a;
    font-size: 21px;
    font-weight: 600;
    line-height: 27px;
    text-align: center;
	  margin-bottom: 13px;
          font-family: rubik;
}
.more-blog-divider {
    position: absolute;
    top: 0;
    left: 0;
}
.single-post .ast-container {
    display: block;
}
.single-post .blog_card_inner {
    background-color: #ffffff;
    padding-top: 30px;
    padding-bottom: 30px;
    padding-left: 40px;
    padding-right: 40px;
    min-height: 290px;
    text-align: center;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
}
.single-post p.blog-excerpt {
    line-height: 22px;
    color: rgb(97, 103, 108);
    font-size: 14px;
    font-weight: 300;
    margin-bottom: 22px;
    font-family: rubik;
}
ul.blog-meta-list {
    display: flex;
    list-style: none;
    margin: 0;
    align-items: center;
    gap: 15px;
    padding: 20px 0;
}

ul.blog-meta-list li.meta-author svg {
    width: 49px;
    height: auto;
}

ul.blog-meta-list li.meta-author {
    display: flex;
    align-items: center;
    gap: 22px;
}

ul.blog-meta-list a {
    color: #3cb4e5;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
}
.single-post div#content .ast-container {
    background: #fff;
}
.single-blog-header {
    max-width: 1200px;
    margin: auto;
    padding: 35px 0 0;
}
/* SEARCH PAGE CARD FIX */
.search .blog-card {
    background: transparent;
    padding: 0 12px;
}

.search .blog-card img {
    width: 100%;
    display: block;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    margin-bottom: 20px;
}

.search .blog_card_inner {
    background-color: #ffffff;
    padding: 30px 40px;
    min-height: 290px;
    text-align: center;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
}

.search .blog-card h3 {
    color: #22353a;
    font-size: 21px;
    font-weight: 600;
    line-height: 27px;
    margin-bottom: 13px;
    text-align: center;
    font-family: rubik;
}

.search .blog-excerpt {
    line-height: 22px;
    color: rgb(97, 103, 108);
    font-size: 14px;
    font-weight: 300;
    margin-bottom: 22px;
}

.search .read-more {
    display: block;
    border-radius: 10px;
    color: #3cb4e5;
    font-size: 14px;
    font-weight: 400;
    padding: 12px;
    border: 1px solid #3cb4e5;
    max-width: 134px;
    margin: auto;
}
/* APPLY BLOG GRID ON SEARCH PAGE */
.search .blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
    max-width: 1200px;
    margin: auto;
    position: relative;
}

/* CARD FIX */
.search .blog-card {
    padding: 0 12px;
}
/* SEARCH FORM (SEARCH PAGE) */
.search .blog-search {
    display: flex;
    max-width: 1200px;
    margin: auto;
    padding-top: 35px;
}

.search .blog-search input {
    background-color: #fff;
    color: #4d4d4d;
    padding: 10px 15px;
    border: 1px solid #22534e;
    width: 75%;
    margin-right: 5px;
}

.search .blog-search button {
    background-color: #22534e;
    color: #fff;
    border: none;
    width: 25%;
    padding: 10px;
    font-size: 16px;
    font-family: rubik;
}
    .blog-search button:hover,
    .blog-nav a:hover, .single-post .read-more:hover {background-color: #3cb4e5;
    color: #fff;
    border-color: #3cb4e5;
    }
    .blog-content a {
    color: #3cb4e5;}
.more-blogs {
    position: relative;
}
.search-results div#content .ast-container {
    display: block;
    background: #fff;
}
.search-page {
    max-width: 1200px;
    margin: 0 auto 70px;
    padding-top: 35px;
}
.search-results .more-blogs {
    background: #22534e;
    padding-bottom: 80px;
}
.search-results h2.search-title {
    font-size: 45px;
    font-weight: 700;
    font-style: normal;
    text-transform: none;
    letter-spacing: 0px;
    text-align: center;
    margin: 60px 0 70px;
    color: rgb(70, 72, 75);
}
.post-separator {
    grid-column: span 3;
    display: block;
    height: 1px;
    border-bottom: 1px dashed #fff;
    max-width: calc(100% - 24px);
    margin: 10px auto;
    width: 100%;
}
.single-post .blog-content h1 {
    font-size: 31px;
    font-weight: 700;
    font-family: "Roboto";
    font-style: normal;
    line-height: 38px;
    text-align: left;
    margin-bottom: 25px;
}

span.swiper-pagination-bullet {
    background-color: rgba(185, 185, 185, 0.17);
    width: 8px;
    height: 8px;
    margin: 0 7px !important;
    opacity: 1;
}
.swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    position: relative;
    margin: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
}
span.swiper-pagination-bullet.swiper-pagination-bullet-active {
 opacity: 1;
   background-color: rgba(185, 185, 185, 1);
}
/* RESPONSIVE */
@media(max-width: 992px){
    .search .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media(max-width: 600px){
    .search .blog-grid {
        grid-template-columns: 1fr;
    }
}
/* RESPONSIVE */
@media(max-width: 768px){
    .single-post .blog-grid {
        grid-template-columns: 1fr;
    }
}
/* RESPONSIVE */
@media(max-width: 992px){
.page-template-page-blog-custom .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media(max-width: 600px){
.page-template-page-blog-custom .blog-grid {
    grid-template-columns: 1fr;
}
.hero-left {
    margin-top: 38px;
    margin-bottom: 20px;
    padding-left: 55px;
    padding-right: 55px;
}
	.blog-hero {
    padding: 0;
}
	.hero-left p {
    font-size: 16px;
    line-height: 26px;
    text-align: center;
    margin: 0;
}
	.hero-left h1 {
    color: #ffffff;
    font-size: 40px;
    font-weight: 700;
    margin: 0 0 15px;
}
	    .hero-inner {
        text-align: center;
        grid-template-columns: 1fr;
    }
	.hero-sub {
    font-size: 13px;
    text-align: center;
    margin-bottom: 15px;
}
	.blog-filter button {
    font-size: 10px;
    margin-bottom: 5px;
		    margin-right: 5px;
		padding: 5px 12px;
}
	.custom-blog-container h2.section-title {
    font-size: 23px;
    font-weight: 700;
    line-height: 28px;
    margin-bottom: 15px;
}
.post-separator {
    grid-column: span 1;
}
.ast-separate-container #content .ast-container {
        padding-left: 0;
        padding-right: 0;
    }
    .search-page-container {
    padding-left: 4%;
    padding-right: 4%;
}
.single-blog-header {
    padding-left: 4%;
    padding-right: 4%;
}
.single-post .blog-title {
    margin-bottom: 50px;
    font-size: 30px;
    line-height: 36px;
}
ul.blog-meta-list {
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
    padding: 15px 20px;
}
.single-post .blog-content {
    padding: 0 15px;
}
.single-post .blog-nav .blog_nav_in {
    gap: 50px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.single-post .more-blogs h2 {
    font-size: 23px;
    line-height: 27px;
    margin-bottom: 10px;
}
.single-post .blog-card {
    padding: 0;
}
.single-post .more-blogs {
    padding: 280px 15px;
}
.blog-content p, .blog-content ul, .blog-content ol {
    font-size: 14px;
    line-height: 24px;
}
}
@media only screen and (min-width: 651px) and (max-width: 1240px) {
    .hero-inner {
        padding: 0 20px;
    }
}