/**
 * All of the CSS for your public-facing functionality should be
 * included in this file.
 */

/* GENERAL STYLING */
.pl_property-template-default .ast-container{
    width: 90%;
    max-width: 100%;
}

.clear{
    clear:both;
}

.pl-button{
    font-family: "Roboto", Sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 4px;
    fill: var( --e-global-color-primary );
    color: var( --e-global-color-primary );
    background-color: var( --e-global-color-secondary );
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    padding: 12px 24px;
    border-color: var( --e-global-color-secondary );
    transition: all .3s;
    margin-right: 20px;
}

.pl-button:hover{
    color: var( --e-global-color-secondary );
    background-color: var( --e-global-color-primary );
    border-color: var( --e-global-color-secondary );
}


.pl-button-secondary:hover{
    color: var( --e-global-color-primary );
    background-color: var( --e-global-color-secondary );
    border-color: var( --e-global-color-secondary );
}

.pl-button-secondary{
    margin-left: 20px;
    font-family: "Roboto", Sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 4px;
    fill: var( --e-global-color-secondary );
    color: var( --e-global-color-secondary );
    background-color: var( --e-global-color-primary );
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    padding: 12px 24px;
    border-color: var( --e-global-color-secondary );
    transition: all .3s;
}

/* AGENT PAGE */

.pl-wrapper.agent-wrapper{
    margin: 40px auto;
    text-align: center;
}

.pl-agent-name {
    color: var( --e-global-color-primary );
    font-family: var( --e-global-typography-primary-font-family ), Sans-serif;
    font-size: var( --e-global-typography-primary-font-size );
    font-weight: var( --e-global-typography-primary-font-weight );
    margin: 20px 0;
}

/* .pl-wrapper ul{
        list-style: none;
margin: auto;
}

.pl-wrapper li{
    display: inline-block;
margin: 0 20px;
} */

.pl-wrapper ul li a i{
    margin-right: 15px;
}

.pl-agent-title {
    color: var( --e-global-color-primary );
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
    margin: 20px 0;
}

.pl-wrapper p {
    color: var( --e-global-color-text );
    font-family: var( --e-global-typography-text-font-family ), Sans-serif;
    font-size: var( --e-global-typography-text-font-size );
    font-weight: var( --e-global-typography-text-font-weight );

}


.pl-agent-contact a{
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
    color: var( --e-global-color-primary );
}

.pl-agent-featured-img img{
    height: 600px;
    width: auto;
}



/* DETAILED PROPERTY PAGE */


.pl-wrapper.property-wrapper ul li{
    color: var( --e-global-color-text );
    font-family: var( --e-global-typography-text-font-family ), Sans-serif;
    font-size: var( --e-global-typography-text-font-size );
    font-weight: var( --e-global-typography-text-font-weight );
}


.pl-wrapper-info{
    width: 80%;
    margin: 100px auto;
}

.pl-wrapper-info .intro{
    max-width: 1140px;
    margin: auto;
}

.pl-wrapper-info .intro h2{
    color: #000;
    margin: 50px 0 20px;
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
}

.pl-wrapper.property-wrapper .pl-property-featured-img{
    margin: auto;
    width: 100%;
    height: 80vh;
    object-fit: cover;
    object-position: center;
    overflow: hidden;
}

img.pl-property-featured.wp-post-image{
    width:100%;
}

.property-wrapper .pl-property-agent{
    width: 40%;
    float: right;
    border-radius: 30px;
    background-color: var( --e-global-color-primary );
    text-align: center;
    padding: 50px 20px 50px 20px;
}


.property-wrapper img.pl-property-agent.wp-post-image{
    border-radius: 100%;
    width: 151px;
    padding: 0;
    float: none;
}

.pl-property-catch{
    margin-bottom: 20px;
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
}

.pl-property-address{
    color: var( --e-global-color-primary );
    font-family: var( --e-global-typography-primary-font-family ), Sans-serif;
    font-size: var( --e-global-typography-primary-font-size );
    font-weight: var( --e-global-typography-primary-font-weight );
    float: left;
    padding-right: 30px;
}

.pl-property-price{
    font-family: var( --e-global-typography-secondary-font-family ), Sans-serif;
    font-size: var( --e-global-typography-secondary-font-size );
    font-weight: var( --e-global-typography-secondary-font-weight );
    color: var( --e-global-color-primary );
    display: inline-block;
    margin-top: 5px;
}

.pl-property-type{
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
    margin: 30px 0px 20px 0px;

}

.pl-property-agent .pl-propety-agent-name{
    margin: 20px 0;
    color: var( --e-global-color-secondary );
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
}

.pl-property-intro{
    width: 60%;
    float: left;
    margin-top: 100px;
}

.pl-property-features {
    width: 100%;
    margin: 80px 0;
    height: 120px;
}

.pl-feature {
    display: inline-block;
    width: 25%;
    float: left;
    text-align: center;
    border-right: 1px solid #000;
    margin-top: 35px;
}

.pl-feature h2{
    display: inline-block;
    padding: 10px;
    color: #000;
}

.pl-feature i{
    font-size: 25px;
    margin-left: 10px;
    color: #000;
}

.pl-feature:last-child {
    border-right: 0px solid #000;
}

/* GALLERY */
/*.grid-item { width: 33%; }*/

/*.grid {*/
/*display: grid;*/
/*grid-template-columns: repeat(4,1fr);*/
/*grid-auto-rows: minmax(min-content,max-content);*/
/*gap: 20px;*/
/*}*/

/*.grid-item.landscape {*/
/*grid-column: span 2/auto;*/
/*height: 100%;*/
/*}*/

/*.grid-item.portrait {*/
/*grid-column: span 1/auto;*/
/*}*/

/** {*/
/*margin: 0 auto;*/
/*padding: 0;*/
/*max-width: 100%;*/
/*}*/

.grid {
    margin: 0 auto;
    padding: 0;
    max-width: 100%;
}


/* Step 3: how big should the gap be between grid items? remember that the total gap between two items would be double what you set here since both would have that amount set as their individual padding. Also add box-sizing:border-box to make sure the padding doesn't affect the total widh of the item */


.grid-item {
    padding: 5px;
    box-sizing: border-box;
    display:inline;
}

img.gallery-img {
    max-width: 100%;
}

.ajax-gallery .grid-item {
    padding: 5px;
    box-sizing: border-box;
    display:inline;
    cursor: pointer;
}

.ajax-gallery-popup {
       display: none;
    width: 50%;
    margin: 0 auto;
    position: fixed;
    top: 50px;
    z-index: 999;
    background: #fff;
    position: fixed;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.ajax-gallery-popup .close{
  position: absolute;
    top: 0;
    right: 0;
    padding: 5px 15px;
    background-color: #fff;
    cursor: pointer;
}

.ajax-gallery-popup .close:after{
       content: "\00d7";
    display: inline-block;
    fill: #002e45;
    color: #002e45;
    font-size: 30px;
}

.ajax-gallery-popup .readmore {
       font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
    background: #002e45;
    color: var( --e-global-color-astglobalcolor5 );
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    border-color: #002e45;
    text-decoration: none;
    display: inline-block;
    line-height: 1;
    padding: 12px 24px;
    border-radius: 3px;
    text-align: center;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
     text-decoration: none!important;
}

.ajax-gallery-popup .gallery-popup-image {
    width: 60%;
    float: left;
}

.ajax-gallery-popup .gallery-popup-image img {
    width: 100%;
    height: auto;
}

.ajax-gallery-popup .gallery-popup-text {
    width: 40%;
    padding: 50px;
    float: right;
}

.ajax-gallery-popup .gallery-popup-text h2{
       font-family: var( --e-global-typography-primary-font-family ), Sans-serif;
    font-size: var( --e-global-typography-primary-font-size );
    font-weight: var( --e-global-typography-primary-font-weight );
    color: #002E45;
}

.ajax-gallery-popup .gallery-popup-text p{
    color: var( --e-global-color-text );
    font-family: var( --e-global-typography-text-font-family ), Sans-serif;
   font-size: var( --e-global-typography-text-font-size );
}

.ajax-gallery-popup-underlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0,0,0,0.75);
    z-index: 99;
}

.gallery-control {
    width: 100%;
    margin-top: 50px;
    text-align: center;
}

.gallery-control a.button.loadmore {
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-family: var( --e-global-typography-accent-font-family ), Sans-serif;
    font-size: var( --e-global-typography-accent-font-size );
    font-weight: var( --e-global-typography-accent-font-weight );
    text-transform: var( --e-global-typography-accent-text-transform );
    letter-spacing: var( --e-global-typography-accent-letter-spacing );
    background: #002e45;
    color: var( --e-global-color-astglobalcolor5 );
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    border-color: #002e45;
    text-decoration: none;
    display: inline-block;
    line-height: 1;
    padding: 12px 24px;
    border-radius: 3px;
    text-align: center;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
    text-decoration: none!important;
}

.clear {
    clear: both;
}



/* Step 4: Add media queries (subjective) to make the whole grid resposive. */

@media (min-width: 500px) {
    .grid-item {
        width: 50%;
    }
}

@media (min-width: 1000px) {
    .grid-item {
        width: 33.333%;
    }
}

@media (min-width: 1700px) {
    .grid-item {
        width: 25%;
    }
}

@media (min-width: 2100px) {
    .grid-item {
        width: 20%;
    }
}



/* CUSTOMISATION. */

@media only screen and (max-width: 1500px) {
    .ajax-gallery-popup {
        width: 80%;
    }
    .ajax-gallery-popup .gallery-popup-image{
        width: 50%;
    }
    .ajax-gallery-popup .gallery-popup-text {
    width: 50%;
}
}

@media only screen and (max-width: 900px) {
     .ajax-gallery-popup {
        width: 90%;
    }
    .ajax-gallery-popup .gallery-popup-image{
        width: 100%;
    }
    .ajax-gallery-popup .gallery-popup-text {
    width: 100%;
}
}
