/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/*
    Add your custom styles here
*/



/* general codes */
p:last-child{
	margin: 0 !important;
}



/* header navigation */
.header-menu ul{
    row-gap: 10px;
}
@media(min-width: 1025px){
	.header-menu a{
		transition: ease-out 0.3s !important;
	}
	.header-menu a:hover,
	.header-menu .current_page_item a{
		padding-top: 3px !important;
		padding-bottom: 9px !important;
	}
	.header-menu a:after{
		content: "";
		position: absolute;
		width: 100%;
		height: 0;
		background: var( --e-global-color-secondary );
		left: 0;
		bottom: 0;
		transition: ease-out 0.3s;
	}
	.header-menu a:hover:after,
	.header-menu .current_page_item a:after{
		height: 3px;
	}
	.header-menu .contact-btn a{
		background-color: var(--e-global-color-secondary);
		color: #fff !important;
        text-transform: uppercase;
		border-radius: 8px;
		padding: 10px 30px !important;
		margin-top: -4px !important;
		margin-bottom: -4px !important;
	}
	.header-menu .contact-btn a:after{
		display: none !important;
	}
	.header-menu .contact-btn a:hover{
		background: #fff;
        color: var(--e-global-color-secondary) !important;
	}
}



/* home */
.info-box .elementor-icon svg *{
    transition: ease-out 0.3s;
}
.info-box:hover .elementor-icon svg *{
    fill: var(--e-global-color-primary);
}
/* banner slider */
.home-slider .swiper-slide{
    overflow: hidden !important;
}
.home-slider .elementor-slide-button{
	margin-top: 30px !important;
}
.home-slider .swiper-pagination{
    bottom: 15px !important;
}
.home-slider .swiper-pagination-bullet{
    vertical-align: middle;
}
.home-slider .swiper-pagination-bullet:not(.swiper-pagination-bullet-active){
    width: 10px !important;
    height: 10px !important;
}
/* info summary */
.info-summary .elementor-icon-box-title{
    margin-top: 0 !important;
}
/* store list */
.store-list a{
	text-decoration: none !important;
}
.stlp-image{
    position: relative;
    top: 0;
    transition: ease-out 0.3s;
}
.store-list article:hover .stlp-image{
    top: -10px;
}
.stlp-image img{
    box-shadow: none;
    transition: ease-out 0.3s;
}
.store-list article:hover .stlp-image img{
    box-shadow: 0 4px 10px rgba(0,0,0,0.25);
}



/* about page */
.phase-item:before{
    content: "";
    position: absolute;
    width: 24px;
    height: 24px;
    background: var(--e-global-color-primary);
    border-radius: 100%;
    top: -43px;
    left: 50%;
    transform: translateX(-50%);
}
.active-phase:before{
    background: var(--e-global-color-secondary);
}



/* store page */
.store-div:after{
    content: "";
    position: absolute;
    width: 2px;
    height: 100%;
    background: #ddd;
    top: 0;
    right: -41px;
}
/* store contact info */
.store-contact-details{
	margin-top: 30px;
	display: flex;
    flex-direction: column;
    gap: 15px;
	align-items: center;
}
.store-contact-item{
    text-decoration: none !important;
    color: var(--e-global-color-primary) !important;
    transition: ease-out 0.3s;
    font-weight: 500;
}
.store-contact-item:hover{
    color: var(--e-global-color-accent) !important;
}
.store-contact-item i{
    color: var(--e-global-color-accent) !important;
    font-size: 24px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px
}
/* store status */
.store-status{
    width: fit-content;
    padding: 3px 15px;
    border-radius: 5px;
    font-size: 15px;
    margin: 0 auto;
    color: #fff;
}
.status-success{
    background: #06b706;
}
.status-info{
    background: #74b3ff;
}
.status-danger{
    background: #ff2d2d;
}
.status-warning{
    background: #ffaf84;
}
/* store description */
.store-desc ul:not(:last-child){
	margin-bottom: 20px;
}
/* store hours */
.sched-table h4{
    margin: 0 0 10px;
}
.sched-list{
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.sched-item strong{
    text-transform: uppercase;
    font-size: 90%;
    display: inline-block;
    width: 140px;
}
/* hide for now */
.postid-165 .store-hours-wrapper,
.postid-825 .store-hours-wrapper,
.postid-826 .store-hours-wrapper,
.postid-1245 .store-hours-wrapper,
.postid-1254 .store-hours-wrapper,
.postid-1255 .store-hours-wrapper,
.postid-165 .store-status,
.postid-825 .store-status,
.postid-826 .store-status,
.postid-1245 .store-status,
.postid-1254 .store-status,
.postid-1255 .store-status{
	display: none !important;
}



/* centre information page */
.leasing-info .elementor-icon-list-icon{
    background: #fff;
    padding: 4px 0 4px 4px;
    width: 22px;
    height: 22px;
    border-radius: 100%;
}
.leasing-info .elementor-icon-list-text{
    padding-left: 10px !important;
}
.trading-hours .sched-item:not(:last-child){
    border-bottom: 1px solid #A7A7A7;
    padding-bottom: 10px;
    margin-bottom: 5px;
}



/* blog page */
/* single blog page */
.news-content ul:not(:last-child),
.news-content ol:not(:last-child){
	padding-left: 30px;
    margin-bottom: 20px !important;
}
.news-content h2,
.news-content h3,
.news-content h4{
    margin: 0 0 20px;
}
.news-content h2{
    font-size: 32px !important
}
.news-content h3{
    font-size: 24px !important;
}
.news-content h4{
    font-size: 20px !important;
}
.elementor-widget-share-buttons .elementor-grid-item{
	margin: 0 5px 5px !important;
}



/* contact page */
.contact-info .elementor-icon-box-title{
    margin-top: 0;
}
.contact-info a{
	transition: ease-out 0.3s;
}
.contact-info a:hover{
	opacity: 0.6;
}
.contact-info .elementor-icon{
    width: 22px;
    height: 22px;
    border-radius: 100%;
    background: #fff;
    padding: 4px 0 0 4px;
}
/* contact form */
.contact-form .gfield .gfield_label{
    font-weight: 500;
    margin: 0;
}
.contact-form .gfield_required{
    font-size: inherit !important;
    font-style: normal !important;
    text-transform: lowercase !important;
    color: inherit !important;
}
.contact-form .gfield input,
.contact-form .gfield textarea{
    border-radius: 8px;
    padding: 10px 15px !important;
    line-height: 1.5 !important;
    outline: none !important;
    font-size: 16px !important;
}
.contact-form .gfield input:focus,
.contact-form .gfield textarea:focus{
    border-color: var(--e-global-color-secondary);
}
.contact-form .gfield textarea{
    display: block;
}
.contact-form .gfield input{
    height: auto !important;
}
.contact-form .gform_footer{
    padding: 0 !important;
    margin-top: 20px !important;
}
.contact-form #field_submit{
    flex-direction: column;
    justify-content: start;
}
.contact-form .gform_button{
    margin: 0 !important;
    border: none !important;
    line-height: 1 !important;
}
.contact-form .gform_validation_errors{
    margin: 0 0 20px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding-top: 10px;
    padding-bottom: 10px;
}
.contact-form .gform_validation_errors h2{
    font-weight: 600 !important;
}
.contact-form .validation_message{
    font-size: 13px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    line-height: 1 !important;
}
/* subscribe form */
.subscribe-form .gfield input{
    border: none !important;
}
.subscribe-form .gform_footer{
    display: none !important;
}
.subscribe-form .gfield .gform-button{
    background: var( --e-global-color-primary ) !important;
    border: 2px solid var( --e-global-color-primary ) !important;
    padding: 12px 20px 12px 20px !important;
    line-height: 1 !important;
    width: 100%;
}
.subscribe-form .gfield .gform-button:hover{
    background: var( --e-global-color-accent ) !important;
    color: var( --e-global-color-primary ) !important;
    border: 2px solid var( --e-global-color-primary ) !important;
}
.subscribe-form .gform_validation_errors{
    margin-bottom: 10px !important;
}
.subscribe-note a{
    color: #fff !important;
}
.subscribe-note a:hover{
    text-decoration: none;
}



/* footer */
.footer-menu a{
	width: fit-content;
	margin: 0 auto;
	transition: ease-out 0.3s !important;
}
.footer-menu a:hover,
.footer-menu .current_page_item a{
    padding-top: 3px !important;
    padding-bottom: 9px !important;
}
.footer-menu a:after{
    content: "";
    position: absolute;
    width: 100%;
    height: 0;
    background: var( --e-global-color-secondary );
    left: 0;
    bottom: 0;
    transition: ease-out 0.3s;
}
.footer-menu a:hover:after,
.footer-menu .current_page_item a:after{
    height: 3px;
}
.footer-social i{
    transition: ease-out 0.3s;
}
.footer-contact .elementor-icon-list-text{
	text-align: left;
}
.footer-contact a:hover .elementor-icon-list-text,
.contact-info a:hover .elementor-icon-list-text{
	color: var(--e-global-color-secondary) !important;
}
.scrollTop{
    opacity: 0;
    visibility: hidden;
    transition: ease-out 0.3s;
}
.scrollTop.show{
    opacity: 1;
    visibility: visible;
}



/* MOBILE RESPONSIVENESS */
@media(max-width: 1024px){
	.home-slider .swiper-slide a{
		padding: 12px 35px !important;
	}
	.home-slider .elementor-slide-button{
		margin-top: 20px !important;
	}
	.news-content h2{
		font-size: 28px !important
	}
	.news-content h3{
		font-size: 21px !important;
	}
	.news-content h4{
		font-size: 18px !important;
	}
	.contact-form .gform_button{
		font-size: 16px !important;
		padding: 12px 35px !important
	}
	.store-div:after{
		right: -31px;
	}
	.store-contact-item{
		font-size: 16px;
	}
	.store-contact-item i{
		font-size: 20px;
	}
	.sched-table h4{
		font-size: 21px;
	}
	.sched-list{
		font-size: 16px;
	}
	.footer-menu a:hover,
	.footer-menu .current_page_item a{
		padding-top: 2px !important;
		padding-bottom: 6px !important;
	}
	.footer-menu a:hover:after,
	.footer-menu .current_page_item a:after{
		height: 2px;
	}
}

@media(max-width: 767px){
	.home-slider .elementor-slide-button{
		margin-top: 10px !important;
	}
	.home-slider .swiper-pagination{
		bottom: 5px !important;
	}
	.home-slider .swiper-slide a{
		padding: 10px 20px !important;
	}
	.home-slider .elementor-swiper-button-next{
		right: 0 !important;
	}
	.home-slider .elementor-swiper-button-prev{
		left: 0 !important;
	}
	.news-content h2{
		font-size: 24px !important
	}
	.news-content h3{
		font-size: 18px !important;
	}
	.news-content h4{
		font-size: 16px !important;
	}
	.contact-form .gfield .gfield_label,
	.contact-form .gfield_required,
	.contact-form .gfield input,
	.contact-form .gfield textarea{
		font-size: 14px !important;
	}
	.contact-form .gform_button{
		font-size: 14px !important;
		padding: 10px 20px !important
	}
	.subscribe-form .gfield .gform-button{
		padding: 12px 20px 11px 20px !important;
	}
	.store-div:after{
		display: none;
	}
	.store-contact{
		gap: 10px;
	}
	.store-contact-item{
		font-size: 14px;
	}
	.store-contact-item i{
		font-size: 16px;
		margin-right: 6px
	}
	.store-status{
		padding: 2px 12px;
		font-size: 13px;
	}
	.sched-table h4{
		font-size: 18px;
	}
	.sched-list{
		font-size: 14px;
		gap: 5px;
	}
	.sched-item strong{
		width: 100px;
	}
	.phase-item:before{
		width: 18px;
		height: 18px;
		top: 50%;
		left: -30px;
		transform: translate(0, -50%);
	}
	.trading-hours .sched-table{
		width: 260px;
	}
}

@media(max-width: 640px){
	.subscribe-form .gfield .gform-button {
        padding: 10px 20px !important;
    }
}

@media(max-width: 420px){
	.stlp-item:hover .stlp-image > div{
		padding: 6px;
	}
	.stlp-item:hover .stlp-image > div:after{
		border-width: 4px;
	}
	.contact-form .gform_fields{
		row-gap: 10px !important;
	}
}