/*
 Theme Name:   Whitestone
 Theme URI:    https://whitestone.co.nz
 Description:  Theme for Whitestone
 Author:       Weave Digital Studio
 Author URI:   https://weave.co.nz
 Template:     page-builder-framework
 Version:      1.0.3
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
*/

/*

CONTENTS:
1. GLOBAL
	1.1 Theme Colour Variables
	1.2 Fonts
	1.3 Layouts
	1.4 Headings
	1.5 Text
	1.6 Lists
	1.7 Blockquote
	1.8 Links & Buttons
	1.8 Icons
	1.9 Misc
2. HEADER
	2.1 Pre-Header
3. COMPONENTS
4. FUNERALS
	4.1 Pricing
5. SEARCH RESULTS
6. MISC
	5.1 Custom Module
	5.2 Feedback Management Principles
7. STYLES TEMPLATE

*/


/*/////////////////////////////////////////////////////*/
/* 1. GLOBAL */
/*/////////////////////////////////////////////////////*/

/* ---------------------- */
/* THEME COLOUR VARIABLES */
/* ---------------------- */

:root {
	--Sirocco: #707272;
	--Pumice: #B2B4B2;
	--IndianKhaki: #B1A357;
	--SorrellBrown: #C4B681;
	--Akaroa: #D1C69E;

	--error: #ff4e7a;
}

/* ---------------------- */
/* FONTS */
/* ---------------------- */

/*
.woff2 		=> 	Super Modern Browsers
.woff 		=> 	Modern Browsers
.ttf 		=> 	Safari, Android, iOS
.eot 		=> 	IE9 Compat Modes
.eot?#iefix 	=> 	IE6-IE8
*/

@font-face {
    font-family: 'Argesta Headline';
    src: url('fonts/argestaheadline-regular-webfont.woff2') format('woff2'),
        url('fonts/argestaheadline-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Argesta Headline';
    src: url('fonts/argestaheadline-regularitalic-webfont.woff2') format('woff2'),
        url('fonts/argestaheadline-regularitalic-webfont.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Sofia Pro';
    src: url('fonts/sofia_pro_light.woff2') format('woff2'),
        url('fonts/sofia_pro_light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Sofia Pro';
    src: url('fonts/sofia_pro_regular.woff2') format('woff2'),
        url('fonts/sofia_pro_regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Sofia Pro';
    src: url('fonts/sofia_pro_medium.woff2') format('woff2'),
        url('fonts/sofia_pro_medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Sofia Pro';
    src: url('fonts/sofia_pro_bold.woff2') format('woff2'),
        url('fonts/sofia_pro_bold.woff') format('woff');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* ---------------------- */
/* LAYOUTS */
/* ---------------------- */


/* ---------------------- */
/* HEADINGS */
/* ---------------------- */

p+:is(h1,h2,h3,h4,h5,h6), 
ul+:is(h1,h2,h3,h4,h5,h6), 
ol+:is(h1,h2,h3,h4,h5,h6) {
	margin-top: 1em;
}

/* ---------------------- */
/* TEXT */
/* ---------------------- */

.starter-no-margin-b p, 
p.starter-no-margin-b {
	margin-bottom: 0;
}

/* ---------------------- */
/* LISTS */
/* ---------------------- */

#content .fl-builder-content li {
	margin-bottom: .75em;
}

/* ---------------------- */
/* BLOCKQUOTE */
/* ---------------------- */

blockquote {
	margin: 4em 0;
	padding: 20px 30px;
	font-style: normal;
	font-weight: 300;
	color: inherit;
	border-left: 2px solid #e7e7e7;
}
blockquote p {
	margin-bottom: 0;
	font-size: 24px;
}

/* --- RESPONSIVE --- */

@media (max-width: 810px) {
	blockquote {
		padding: 20px;
	}
	blockquote p {
		font-size: 20px;
	}
}

/* ---------------------- */
/* LINKS & BUTTONS */
/* ---------------------- */

a:not([href]):hover {
	cursor: default;	
}
#content a, 
#content a *,
.fl-builder-content a, 
.fl-builder-content a *, 
#content .fl-button, 
#content .fl-button *, 
button.wpbf-button, 
a.wpbf-button, 
button.facetwp-load-more {
	transition: all 0.15s ease-out;
}
button.wpbf-button, 
a.wpbf-button, 
button.facetwp-load-more {
	padding: 15px 45px;
	background-color: transparent;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 1.2px;
}
.fl-builder-content .fl-button i {
	font-size: 1.1em;
}

*:focus {
	outline: none;
}
*:focus-visible {
	outline: 1px dotted rgba(0,0,0,.6);
}
.starter-no-link {
	pointer-events: none;
}

.wds-btn input[type="submit"] {
	text-transform: uppercase;
	font-weight: 500;
	border: 1px solid #b8aa75;
}

/* --- RESPONSIVE --- */

@media (max-width: 1080px) {
	button.wpbf-button, 
	a.wpbf-button, 
	button.facetwp-load-more {
		padding: 13px 35px;
		font-size: 13px;
	}
}
@media (max-width: 810px) {
	button.wpbf-button, 
	a.wpbf-button, 
	button.facetwp-load-more {
		padding: 11px 25px;
		font-size: 12px;
	}
}

/* ---------------------- */
/* ICONS */
/* ---------------------- */


/* ---------------------- */
/* MISC */
/* ---------------------- */

hr {
	margin: 2em 0;
	border: none;
	border-top: 1px solid #e7e7e7;
}


/*/////////////////////////////////////////////////////*/
/* 2. HEADER */
/*/////////////////////////////////////////////////////*/

/* ---------------------- */
/* PRE-HEADER */
/* ---------------------- */

.ws-pre-header .ws-pre-header-phone span {
	display: inline-block;
}
.ws-pre-header .ws-pre-header-phone .ws-separator {
	margin: 0 .5em;;
}
.ws-pre-header .ws-pre-header-buttons .fl-col-content {
	flex-direction: row;
	justify-content: flex-end;
}

.ws-pre-header .ws-pre-header-buttons.left .fl-col-content {
	flex-direction: row;
	justify-content: flex-start;
}
.ws-pre-header .ws-pre-header-buttons .fl-module {
	width: auto;
}
.ws-pre-header .ws-pre-header-buttons .fl-module, 
.ws-pre-header .ws-pre-header-buttons .fl-module-content, 
.ws-pre-header .ws-pre-header-buttons .pp-button-wrap, 
.ws-pre-header .ws-pre-header-buttons .pp-button { 
	height: 100%;
}
.ws-pre-header .ws-pre-header-buttons .fl-module a {
	display: flex;
	align-items: center;
}
.pp-search-form--lightbox-close {
	top: 38px;
	right: 5px;
}
[pseudo="-webkit-input-placeholder"], 
input[type="search" i]::-webkit-search-cancel-button {
	display: none;
}

/* Hidden PP Search module for mobile search */

body:not(.fl-builder-edit) .ws-hide {
	position: absolute;
	bottom: 0;
	/* z-index: -1; */
}
body:not(.fl-builder-edit) .ws-hide .pp-search-form__toggle {
	visibility: hidden;
}


/*/////////////////////////////////////////////////////*/
/* 3. COMPONENTS */
/*/////////////////////////////////////////////////////*/


/*/////////////////////////////////////////////////////*/
/* 4. FUNERALS */
/*/////////////////////////////////////////////////////*/

/* ---------------------- */
/* HK FUNERAL SUITE: 
   PRICING ACCORDION */
/* ---------------------- */

/* VARIABLES */

.hk-pricing-accordion {
	--button-extras-font: 'Sofia Pro',Verdana,Arial,sans-serif;
	--border-color: var(--Akaroa);
}

/* ACCORDION LAYOUT */

/* .hk-pricing-accordion .pp-accordion-item {
	border-radius: 18px;
	overflow: hidden;
} */
.hk-pricing-accordion .pp-accordion-item, 
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon {
	transition: all 0.3s ease-out;
} 
.hk-pricing-accordion .pp-accordion-item:hover, 
.hk-pricing-accordion .pp-accordion-item-active {
	box-shadow: 0 10px 40px rgba(0,0,0,.1);
}

/* ACCORDION TITLE */

.hk-pricing-accordion .pp-accordion-button {
	justify-content: space-between;
	align-items: flex-start;
	gap: 20px;
}
.hk-pricing-accordion .pp-accordion-button-label {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
	align-items: flex-start;
	flex-basis: 75%;
    gap: .6em;
    text-align: left;
}
.hk-pricing-accordion .pp-accordion-button-label .hk-item-num {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 1.8em;
    height: 1.8em;
	margin-right: .5em;
	padding: .5em;
	background-color: rgba(255,255,255,.3);
	font-family: var(--button-extras-font);
	font-size: 75%;
	color: var(--Sirocco);
    border-radius: 100%;
	transition: all .3s ease-out;
}
.hk-pricing-accordion .pp-accordion-button:hover .pp-accordion-button-label .hk-item-num, 
.hk-pricing-accordion .pp-accordion-item-active .pp-accordion-button-label .hk-item-num {
	color: var(--Sirocco);
}
.hk-pricing-accordion .pp-accordion-button-label .hk-item-description {
	margin-left: 1em;
	padding-left: 3%;
	font-size: 20px;
	font-family: var(--button-extras-font);
	font-weight: 300;
	line-height: 1.4;
	text-transform: none;
	letter-spacing: 0;
	color: var(--Sirocco);
	border-left: 2px solid rgba(255,255,255,.3);
}
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon {
	background-color: rgba(255,255,255,.3);
    color: var(--Sirocco);
    justify-content: center;
    align-items: center;
    border-radius: 4px;	
}
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button:hover .pp-accordion-button-icon { 
	background-color: white;
    color: var(--Sirocco);
}
.hk-pricing-accordion .pp-accordion-item.pp-accordion-item-active .pp-accordion-button-icon {
    color: var(--Sirocco);
}
.hk-pricing-accordion .pp-accordion-item:not(.pp-accordion-item-active) .pp-accordion-button-icon.pp-accordion-open, 
.hk-pricing-accordion .pp-accordion-item.pp-accordion-item-active .pp-accordion-button-icon.pp-accordion-close {
    display: flex;
}
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-open { 
    width: auto;
	padding: 1em 1.5em;
}
.hk-pricing-accordion .pp-accordion-item:not(.pp-accordion-item-active) .pp-accordion-button-icon.pp-accordion-open::before { 
	content: "Learn more";
	font-family: var(--button-extras-font);
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
	white-space: nowrap;
}
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close { 
	width: 2.8em;
	height: auto;
	aspect-ratio: 1/1;
}
.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close::before { 
	content: "X";
	font-family: sans-serif;
	font-size: 1.1em;
	font-weight: 400;
}

/* ACCORDION CONTENT */

.hk-pricing-accordion .pp-accordion-item .pp-accordion-content {
	position: relative;
	padding-top: 40px;
	padding-right: 15vw;
}
/* .hk-pricing-accordion .pp-accordion-content::before {
	content: "";
	position: absolute;
	top: 0;
	display: block;
	width: calc(100%  - 80px);
	border-top: 1px solid var(--border-color);
} */
.hk-pricing-accordion .pp-accordion-content hr {
	margin-bottom: 1.5em;
	background: none;
	border: none;
	border-top: 1px solid var(--border-color);
}
.hk-pricing-accordion .pp-accordion-content .hk-item-price-container {
	display: block;
	margin-top: 2.5em;
	padding-top: 1.5em;
	border-top: 1px solid var(--border-color);
}
.hk-pricing-accordion .pp-accordion-content .hk-item-price {
	margin: 0 .15em;
	font-size: 180%;
	color: var(--IndianKhaki);
}

/* --- RESPONSIVE --- */

@media (max-width: 1080px) {
	.hk-pricing-accordion .pp-accordion-item {
		margin-bottom: 30px;
	}
	.hk-pricing-accordion .pp-accordion-button-label .hk-item-description {
		font-size: 18px;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-open { 
		padding: .75em 1.2em;
	}
	.hk-pricing-accordion .pp-accordion-item:not(.pp-accordion-item-active) .pp-accordion-button-icon.pp-accordion-open::before { 
		font-size: 13px;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close { 
		width: 2.4em;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close::before { 
		font-size: 1em;
	}
}
@media (max-width: 810px) {
	.hk-pricing-accordion .pp-accordion-item {
		/* border-radius: 12px; */
		margin-bottom: 20px;
	} 
	.hk-pricing-accordion .pp-accordion-button-label .hk-item-description {
		margin-left: .75em;
		font-size: 16px;
	}
	.hk-pricing-accordion .pp-accordion-button {
		flex-direction: column;
		align-items: flex-start;
		gap: 20px;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-open { 
		padding: .5em 1em;
	}
	.hk-pricing-accordion .pp-accordion-item:not(.pp-accordion-item-active) .pp-accordion-button-icon.pp-accordion-open::before { 
		font-size: 11px;
		white-space: wrap;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close { 
		width: 2em;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-button-icon.pp-accordion-close::before { 
		font-size: .9em;
	}
	.hk-pricing-accordion .pp-accordion-item.pp-accordion-item-active .pp-accordion-button-icon.pp-accordion-close { 
		display: none;
	}
	.hk-pricing-accordion .pp-accordion-item .pp-accordion-content {
		padding-top: 20px;
		padding-right: 20px;
	} 
}


/*///////////////////////////////*/
/* 5. SEARCH RESULTS */
/*///////////////////////////////*/

.search-results [data-node] .pp-content-post .pp-post-image {
	width: 20%;
}
.search-results [data-node] .pp-content-post .pp-content-body {
	width: 80%;
}
.relevanssi-query-term {
    position: relative;
    z-index: 0;
    padding-bottom: .25em;
}
.relevanssi-query-term::after {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    right:0;
    bottom: 0;
    left: 0;
    border-bottom: 2px solid var(--green);
}

/* --- RESPONSIVE --- */

@media (max-width: 810px) {
	.search-results .rs-posts.rs-grid .pp-content-post {
		margin-bottom: 0;
	}
	.search-results [data-node] .pp-content-post .pp-post-image {
		max-width: 160px;
		width: auto;
	}
	.search-results [data-node] .pp-content-post .pp-content-body {
		width: 100%;
		padding-left: 0;
	}
}


/*/////////////////////////////////////////////////////*/
/* 6. MISC */
/*/////////////////////////////////////////////////////*/

.fl-builder-block-thumbnail {
    display: none;
}

/* --- responsive embed --- */
.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.embed-container iframe, .embed-container object, .embed-container embed, .embed-container video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* ---------------------- */
/* CUSTOM MODULE */
/* ---------------------- */

.calout-with-f2bg .fl-callout-title {
	padding-bottom: 25px;
}
.calout-with-f2bg .fl-callout-text-wrap {
	min-height: 225px;
    background: #f2f2f2;
    padding: 25px;
}
.calout-with-f2bg-cancel-fh .fl-callout-text-wrap {
	min-height: unset;
}

/* ---------------------- */
/* FEEDBACK MANAGEMENT PRINCIPLES */
/* ---------------------- */

/*INV Feedback Grid*/
.parent {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-column-gap: 10px;
  grid-row-gap: 10px;
}

.child {
  padding: 10px;
}

.number {
  font-size: 36px;
}

/*Responsive*/
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .parent {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media only screen and (max-width: 767px) {
  .parent {
    grid-template-columns: repeat(1, 1fr);
  }
}


/*/////////////////////////////////////////////////////*/
/* 7. STYLES TEMPLATE */
/*/////////////////////////////////////////////////////*/

[class*="av-demo-font-"] {
    font-size: 24px;
}
[class*="av-demo-font-"] h2, 
[class*="av-demo-font-"] h3 {
    margin-bottom: .75em; 
}
.av-demo-font-1, 
.av-demo-font-1 h2, 
.av-demo-font-1 h3 {
    font-family: "Font 1"; 
}
.av-demo-font-2, 
.av-demo-font-2 h2, 
.av-demo-font-2 h3 {
    font-family: "Font 2"; 
}
