/*---------------------------------------------------------------------------------
 Theme Name:   Divi Fabricate
 Theme URI:
 Description:  Bespoke Divi framework with easy customisability.
 Author:       MJS Media
 Author URI:   https://mjsmedia.co.uk
 Template:     Divi
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
------------------------------ ADDITIONAL CSS HERE ------------------------------*/

.et_pb_code_inner{
    container-type: inline-size;
}

.inline-buttons .et_pb_button_module_wrapper {
    display: inline-block;
}

.heading-hero{
    display: block;
    position: relative;
    background-color: #094349;
}
.heading_container{
    display: grid;
    position: relative;
    width: 100%;
    max-width: 1420px;
    margin: 0 auto;
    padding: 0 50px;
    grid-template-columns: 2fr 1fr;
    column-gap: 50px;
}
.heading_body{
    display: block;
    position: relative;
    width: 100%;
    padding: 100px 0;
    padding-top: 150px;
    align-self: center;
}
.heading_body h1{
    display: block;
    position: relative;
    font-size: 3.8rem;
    line-height: 1.1;
    font-weight: 900;
    color: #fff;
}
.heading_artwork .portrait{
    display: block;
    position: relative;
    width: 100%;
    padding-top: 130%;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    transform: translateY(50px);
    border-radius: 20px;
}
@media (max-width : 1450px){
    .heading_body h1{
        font-size: 3.2rem;
    }
}
@media (max-width : 1220px){
    .heading_body h1{
        font-size: 2.8rem;
    }
}
@media (max-width : 1060px){
    .heading_container{
        grid-template-columns: 1fr;
    }
    .heading_body{
        padding: 0;
        padding-top: 100px;
        text-align: center;
    }
    .heading_artwork{
        width: 60%;
        margin: 0 auto;
    }
    .heading_artwork .portrait{
        padding-top: 100%;
    }
}
@media (max-width : 820px){
    .heading_body h1{
        font-size: 2.6rem;
    }
    .heading_artwork{
        width: 80%;
    }
}
@media (max-width : 660px){
    .heading_body h1{
        font-size: 2.2rem;
    }
    .heading_artwork{
        width: 90%;
    }
}
@media (max-width : 500px){
    .heading_body h1{
        font-size: 1.8rem;
    }
    .heading_artwork{
        width: 100%;
    }
}

.page-heading{
    background-color:#0A4349;
}
.page-heading .heading_container{
    grid-template-columns:1fr;
    max-width: 1000px;
}
.page-heading .heading_body{
    text-align:center;
    padding:100px 0;
}
.page-heading .heading_body p{
	display:block;
	position:relative;
	font-size:22px;
	line-height:1.2em;
	color:white;
}
.page-heading .heading_body span{
	display:block;
	position:relative;
	font-size:22px;
	line-height:1.2em;
	font-weight:600;
	color:white;
	margin-bottom:10px;
}

.heading_image{
	display:block;
	position:relative;
	width:100%;
	margin-left:auto;
	margin-right:auto;
	padding-top:40%;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
}

.feature-boxes{
    display: grid;
    position: relative;
    width: 100%;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 30px;
    row-gap: 30px;
}
.feature-box{
    display: flex;
    position: relative;
    width: 100%;
    padding: 50px 30px;
    background-color: #E5F7F9;
    border-radius: 20px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.feature-box h3{
    display: block;
    position: relative;
    font-size: 28px;
    line-height: 1.2;
    font-weight: 900;
    color: #00AFC3;
    text-align: center;
    margin: 0;
    padding: 0;
}
.feature-box p{
    display: block;
    position: relative;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 400;
    color: #094349;
    text-align: center;
    margin: 0;
    padding: 0;
    margin-top: 20px;
}
.feature-box a{
    display: block;
    position: relative;
    padding: 14px 28px;
    background-color: rgba(0, 175, 195, 0.1);
    margin-top: 20px;
    font-size: 18px;
    line-height: 1;
    border-radius: 20px;
    z-index: 1;
    transition: all 0.3s ease;
}
.feature-box a:hover{
    background-color: rgba(0, 175, 195, 0.3);
}

@container (max-width: 1070px) {
    .feature-boxes{
        grid-template-columns: repeat(3, 1fr);
        row-gap:15px;
        column-gap: 15px;
    }
    .feature-box h3{
        font-size: 28px;
    }
}
@container (max-width: 940px) {
    .feature-box h3{
        font-size: 24px;
    }
    .feature-box p{
        font-size: 18px;
    }
}
@container (max-width: 830px) {
    .feature-boxes{
        grid-template-columns: repeat(1, 1fr);
        row-gap:15px;
        column-gap: 15px;
    }
    .feature-box{
        padding: 30px;
    }
}

.masonry-grid{
	display: grid;
	grid-template-columns: repeat(3,1fr);
	grid-column-gap:30px;
}
.masonry-item{
	margin-bottom:30px;
}

@container (max-width: 980px) {
	.masonry-grid{
		grid-template-columns: repeat(2,1fr);
	}
	.masonry-col--3{
		display:none;
	}
}
@container (max-width: 670px) {
	.masonry-grid{
		grid-template-columns: repeat(1,1fr);
	}
	.masonry-col--2{
		display:none;
	}
}


.blog-post{
	display:block;
	position:relative;
	background-color:#00AFC3;
	border-radius:20px;
	color:white;
}
.blog-post__image{
	display:block;
	position:relative;
	width:100%;
	padding-top:60%;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
	border-top-left-radius:20px;
	border-top-right-radius:20px;
}
.blog-post__image::after{
	content:'';
	display:block;
	position:absolute;
	width:100%;
	height:30px;
	bottom:0;
	left:0;
	background: rgb(0,175,195);
	background: linear-gradient(180deg, rgba(0,175,195,0) 0%, rgba(0,175,195,1) 100%);
}
.blog-post__content{
	display:block;
	position:relative;
	padding:20px;
}
.blog-post__content span{
	display:block;
	position:relative;
	margin:0;
	padding:0;
	font-size:16px;
	line-height:1.1em;
	font-weight:600;
	color:white;
}
.blog-post__content h4{
	display:block;
	position:relative;
	margin:0;
	padding:0;
	font-size:20px;
	line-height:1.1em;
	font-weight:700;
	color:white;
	margin-top:5px;
}
.blog-post__content p{
	display:block;
	position:relative;
	margin:0;
	padding:0;
	font-size:16px;
	line-height:1.1em;
	font-weight:500;
	color:white;
	margin-top:10px;
}



.content-section{
    padding: 100px 0;
}
.content-section + .content-section{
    padding-top:0;
}

.content-section p{
    font-size:18px;
    line-height:1.3em;
    font-weight: 400;
}

.content-section.--image{
    margin-left:-50px;
    margin-right:-50px;
}
.content-section.--image a:hover{
    cursor:zoom-in;
}
.content-section.--image img{
    display:block;
    position:relative;
    width:100%;
    height:auto;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
}
.content-section.--image p{
    text-align:left;
    margin-top:10px;
    font-style:italic;
    padding:0 50px;
}

.content-section.--gallery{
    margin-left:-50px;
    margin-right:-50px;
}
.content-section .content-gallery{
    display:grid;
    position:relative;
    grid-template-columns: repeat(4,1fr);
    column-gap:30px;
    row-gap:30px;
}
.content-section .content-gallery a{
    display:block;
    position:relative;
    width:100%;
    padding-top:100%;
    background-color:#F2ECEA;
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
}
.content-section .content-gallery a:hover{
    cursor:zoom-in;
}
@media (max-width : 780px){
	.content-section{
		padding: 80px 0;
	}
	.content-section.--image{
		margin-left:-20px;
		margin-right:-20px;
	}
	.content-section.--gallery{
		margin-left:-20px;
		margin-right:-20px;
	}
	.content-section .content-gallery{
		grid-template-columns: repeat(2,1fr);
	}
}
@media (max-width : 530px){
	.content-section.--image{
		margin-left:-10px;
		margin-right:-10px;
	}
	.content-section.--gallery{
		margin-left:-10px;
		margin-right:-10px;
	}
	.content-section .content-gallery{
		row-gap:15px;
		column-gap:15px;
	}
}

  .icon-link {
    display: inline-flex;
    align-items: center;
    color: white;
    text-decoration: none;
    margin-right: 20px;
  }

  .icon-link img {
    width: 20px;
    height: auto;
    margin-right: 5px;
  }

@media (max-width: 480px) {
    .icon-link span {
      font-size: 16px;
    }
  }