/*
Theme Name: Grace House Care Home
Theme URI: https://www.gracehousefarnham.co.uk/
DESCRIPTION: Grace House Care Home custom Wordpress theme
Version: 1.0
Author: Tonya Lawrence / tjldesigns.com
Author URI: https://tjldesigns.com
Tags: Grace House Care Home
*/

/** reset **/
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video,button{border:0;outline: none;font-size:100%;font:inherit;background: transparent; vertical-align:baseline;margin:0;padding:0}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
body{line-height:1; -webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
ol,ul{list-style:none}
blockquote,q{quotes:none}
blockquote:before,blockquote:after,q:before,q:after{content:''; content:none;}
table{border-collapse:collapse;border-spacing:0}

@font-face {
    font-family: 'Omnes';
    font-style: normal;
    font-weight: bold;
    src: url('/wp-content/themes/gracehousefarnham/fonts/Omnes SemiBold.woff') format('woff');
}

@font-face {
    font-family: 'Omnes';
    font-style: italic;
    font-weight: bold;
    src: url('/wp-content/themes/gracehousefarnham/fonts/Omnes SemiBold Italic.woff') format('woff');
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Bold.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-BoldItalic.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Italic.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Light.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-LightItalic.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Regular.woff2') format('woff2'),
        url('/wp-content/themes/gracehousefarnham/fonts/Inter18pt-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
  --grey-bkg: #f1f7f7;
  --grey: #504f57;
  --green: #235f47;
  --green-light: #71b089;
  --white: #fff;
  --omnes:"Omnes", sans-serif;
  --inter:"Inter", sans-serif;
}

/* general */

@view-transition {navigation: auto;}

#overall-wrapper { overflow:hidden; }
#overall-wrapper.noscroll { /** height: 100vh; **/ overflow: hidden; }
html.noscroll, html.noscroll body { overflow: hidden; position: relative; /** height: 100%; **/ }

html,body { /** overflow-x: hidden; **/   -webkit-tap-highlight-color: rgba(0,0,0,0); }
html { /** overflow-y: scroll; **/  overflow-y: scroll; }

body::-webkit-scrollbar, body *::-webkit-scrollbar { width: 10px; }
body::-webkit-scrollbar-thumb, body *::-webkit-scrollbar-thumb { background-color: var(--green); }
body::-webkit-scrollbar-track, body *::-webkit-scrollbar-track { background: var(--grey-bkg); }
body *::-webkit-scrollbar { width: 5px; }

/** below copied to wp-admin.css - START **/

body { font: 1rem/150% var(--inter); background: var(--grey-bkg); color: var(--grey); }

* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;        text-underline-offset: 3px; }
img, canvas, figure { max-width: 100%; height: auto; }

strong { font-weight: bold; }
em { font-style: italic; }

h1, h2, h3, h4, h5, h6, p { padding: 0 0 25px 0; }
h1, h2, h3, h4, h5, h6, .h1_styler, .h2_styler, .h3_styler { font-family: var(--omnes); color: var(--green) }
h1, .h1_styler { font-size: 3.4rem; line-height: 105%; } 
h2, .h2_styler { font-size: 2rem; font-size: 3rem; line-height: 105%; padding: 0 0 20px 0; } 
h3, .h3_styler { font-size: 1.4rem; line-height: 110%; padding: 0 0 20px 0; } 
h4 { font-size: 1.2rem; line-height: 110%; padding: 0 0 20px 0; }
h5 {  }
p {  }
a { color: var(--grey); text-decoration: underline; transition: all .3s ease; -o-transition: all .3s ease; -moz-transition: all .3s ease; -webkit-transition: all .3s ease;    -webkit-font-smoothing: antialiased; }
a:hover { text-decoration: none; }
	/** a[href^="tel:"] { text-decoration: none !important; cursor: default; } **/

ul, ol { margin: 0 0 0 14px; padding: 0 0 20px 0; }
ul { list-style: disc; margin: 0 0 0 20px; }
ol { list-style: decimal; margin: 0 0 0 18px; }
ul li, ol li { padding: 0 0 10px 0; margin: 0;  padding: 0 0 5px 0; }
ul ul { padding: 10px 0 0 0; }
ul ul li { padding: 0 0 10px 0; }

table { margin: 0 0 15px 0; }
table td, table th { padding: 10px 5px; }

hr {  }

::-moz-selection { background-color: var(--green); color: #fff; }
::selection { background-color: var(--green); color: #fff; }

.clearfix { zoom: 1; }
.clearfix:before, .clearfix:after { content: "\0020"; display: block; height: 0; overflow: hidden; }
.clearfix:after { clear: both; }

.large_text {  }
.button_cta { display:inline-block; font:1rem/120% var(--omnes); background: var(--green-light); color: var(--white); padding:10px 25px; text-align:center; text-decoration: none; border: 2px solid var(--green-lightr); -webkit-border-radius: 50px; -moz-border-radius: 50px; border-radius: 50px; }
.button_cta:hover { background:var(--green); border-color:var(--green); }
.button_cta.button_call { font-size:1.5rem; line-height:105%; padding: 10px 25px; white-space: nowrap; }
.list_ticks { margin:0; padding:0; list-style: none; list-style-image: none; display: flex; justify-content: center; gap: 20px 35px; flex-wrap: wrap; }
.list_ticks li { margin: 0; padding:0 0 0 33px; background: url(/wp-content/themes/gracehousefarnham/images/icon-tick.png) 0 0 no-repeat; font-weight: bold; font-size: 1.4rem; background-size: 23px auto;}
.radius { border-radius: 25px;}

/** below copied to wp-admin.css - END **/

/** general layout **/

.container { margin: 0 auto; width: 100%; padding: 0 40px; }
.container_capped { max-width:1920px; max-width: 1630px; }

input, textarea, .builder_boxes_list_grid article .builder_boxes_hover p, .post-thumbnail img, .button_cta, #header_main nav { transition: all .3s ease; -o-transition: all .3s ease; -moz-transition: all .3s ease; -webkit-transition: all .3s ease; }

a.view-article { display: none; }

.clear { clear: both; }
.float_left, .alignleft { float: left; margin: 5px 35px 10px 0; }
.float_right, .alignright { float: right; margin: 5px 0 10px 35px; }
.no_padding { padding: 0; }

.embed-container { position: relative; height: 0; overflow: hidden; padding-bottom: 56.25%; /* 16x9 Aspect Ratio */  max-width: 100%; height: auto; }
.embed-container-4x3 { padding-bottom: 75%; /* 4x3 Aspect Ratio */ }
.embed-container-square { padding-bottom: 100%; }
.embed-container-mobile { padding-bottom: 132%; }
.embed-container iframe, .embed-container object, .embed-container embed { position: absolute; top:0; left: 0; width: 100%; height: 100%; }
    .embed-container-wrapper { margin-top: 20px; margin-bottom: 40px; }

.disable_select { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; -o-user-select: none; user-select: none; }

.pag_nav { display: block; clear: both; text-align: center; }
.pag_nav a { text-decoration: none; }

/** general form styles **/

form { margin: 0; }

input { outline: none !important; }
input, select, textarea { -webkit-border-radius: 0px; -moz-border-radius: 0px; border-radius: 0px; font: inherit; }
input.text, select, textarea,  .sf-field-search input { padding: 10px 15px; margin: 0; border: 1px solid #fff; outline: none; background-color: #fff;  }
select { /** min-height: 43px; padding: 0 10px; **/ }
label {  }
input.text, textarea, select { -webkit-appearance: none; -moz-appearance: none; appearance: none; }
input[type='submit'] { -webkit-appearance: none; -moz-appearance: none; appearance: none; }

::-webkit-input-placeholder { color: #333F48 !important; }
:-moz-placeholder { /* Firefox 18- */ color: #333F48 !important; }
::-moz-placeholder {  /* Firefox 19+ */ color: #333F48 !important; }
:-ms-input-placeholder { color: #333F48 !important; }

/** contact form **/

.form_list { margin: 0 auto; padding: 0; list-style: none; list-style-image: none; /** max-width: 380px;  **/ }
.form_list li { margin: 0; padding: 0 0 19px 0; display: block; }
.form_list li label {  }
.form_list li .text, .form_list li textarea, .form_list li select { width: 100%; display: block; }
.form_list li .text.wpcf7-not-valid { border-color: #E30428 !important; }
.form_list li textarea { height: 120px; }
.form_list li.form_button { padding: 0; }
.form_list li.form_button input {  }

.form_list li select, .searchandfilter select { -webkit-appearance: none; -moz-appearance: none; appearance: none; display: block; width: 100%; background: url(/wp-content/themes/osbornes/images/arrow-down-select.png) 100% 50% no-repeat #fff; background-size: auto 9px; padding-right: 35px; }
.form_list li select::-ms-expand, .searchandfilter select::-ms-expand { display: none; }

.wpcf7-not-valid-tip { display: block; padding: 5px 0 0 0;  display: none !important; }
.wpcf7-not-valid-tip, .wpcf7-not-valid-tip * {  }
form.invalid .wpcf7-not-valid { /** background: #fbe122;  border: 1px solid #fbe122; -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; **/ }

.wpcf7 form .wpcf7-response-output { clear: both; border: none; margin: 0; color: #269FC7; padding: 20px 0 0 0; text-align: left; font-weight: bold; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output { color: #E10600; font-weight: bold; }

.form-hidden-fields { display: none !important; }
.ajax-loader { display: none !important; }

/* Slider */
.slick-slider { position: relative; display: block; box-sizing: border-box; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-touch-callout: none; -khtml-user-select: none;
    -ms-touch-action: pan-y; touch-action: pan-y; -webkit-tap-highlight-color: transparent;  padding: 0; margin: 0; }
.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0; }
.slick-list:focus { outline: none; }
.slick-list.dragging { cursor: pointer; cursor: hand; }
.slick-slider .slick-track, .slick-slider .slick-list { -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); -o-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }
.slick-track { position: relative; top: 0; left: 0; display: block; }
.slick-track:before, .slick-track:after { display: table; content: ''; }
.slick-track:after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }
.slick-slide { display: none; float: left; height: 100%; min-height: 1px;  padding: 0; margin: 0; }
[dir='rtl'] .slick-slide { float: right; }
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none; }
.slick-slide.dragging img { pointer-events: none; }
.slick-initialized .slick-slide { display: block; }
.slick-loading .slick-slide { visibility: hidden; }
.slick-vertical .slick-slide { display: block; height: auto; border: 1px solid transparent; }
.slick-arrow.slick-hidden { display: none; }

.slick-arrow { z-index: 10; z-index: 3; background: url(/wp-content/themes/exagen/images/scroller-left.svg) center no-repeat; background-size: 50px 50px; border: none; outline: none; text-indent: -9999px; width: 50px; height: 50px; cursor: pointer;  transition: all .3s ease; -o-transition: all .3s ease; -moz-transition: all .3s ease; -webkit-transition: all .3s ease; }
.slick-arrow:hover {  }
.slick-prev.slick-arrow {  }
.slick-next.slick-arrow { background-image: url(/wp-content/themes/exagen/images/scroller-right.svg); }
.slick-prev.slick-arrow.slick-disabled { background-image: url(/wp-content/themes/exagen/images/scroller-left-inactive.svg); }
.slick-next.slick-arrow.slick-disabled { background-image: url(/wp-content/themes/exagen/images/scroller-right-inactive.svg); }

.slick-dots { margin: 0; padding: 35px 0 0 0; list-style: none; list-style-image: none; display:flex; align-items:center; justify-content:center; gap: 0 14px; }
.slick-dots li { margin: 0; padding: 0 !important; width: auto !important; float: none !important; }
.slick-dots li button { cursor: pointer; background: rgba(255,255,255,0.3); text-indent: -9999px; outline: none; border: none; padding: 0; width: 10px; height: 10px; line-height: 10px; -webkit-border-radius: 10px; -moz-border-radius: 10px; border-radius: 10px; transition: all .3s ease; -o-transition: all .3s ease; -moz-transition: all .3s ease; -webkit-transition: all .3s ease; }
.slick-dots li button:hover, .slick-dots li.slick-active button { background: var(--cian); }


.wobble { -webkit-animation: wobble 2.5s ease-out; -webkit-animation-iteration-count: infinite; }
@-webkit-keyframes wobble {
    0% {-webkit-transform: translate3d(0, 0, 0); }
    50% {-webkit-transform: translate3d(0, -10px, 0); }
    100% {-webkit-transform: translate3d(0, 0, 0); }    
}

    .hamburger { padding: 0; display: flex; display: none; gap: 0 10px; align-items: center; cursor: pointer; transition-property: opacity, filter; transition-duration: 0.15s; transition-timing-function: linear; font: inherit; color: inherit; text-transform: none; background-color: transparent; border: 0; margin: 0; overflow: visible; }
    .hamburger:hover { /** opacity: 0.7; **/ }
    .hamburger.is-active {  }

    .hamburger-box { width: 26px; height: 11px; top: 1px; display: inline-block; position: relative; }

    .hamburger-inner { display: block; top: 50%; }
    .hamburger-inner, .hamburger-inner::after, .hamburger-inner::before { width: 26px; height: 2px; background-color: var(--green-light); position: absolute; transition-property: transform; transition-duration: 0.15s; transition-timing-function: ease; }
    .hamburger-inner::after { content: ""; display: block; }
    .hamburger-inner::after { bottom: -8px; }
    .hamburger-inner::before { content: ""; display: block; }
    .hamburger-inner::before { top: -8px; }

    .hamburger--spin .hamburger-inner { transition-duration: 0.22s; transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
    .hamburger--spin .hamburger-inner::after { transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19); }
    .hamburger--spin .hamburger-inner::before { transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in; }

    .hamburger--spin.is-active .hamburger-inner { transform: rotate(225deg); transition-delay: 0.12s; transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
    .hamburger--spin.is-active .hamburger-inner::after { bottom: 0 !important; transform: rotate(-90deg); transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .hamburger--spin.is-active .hamburger-inner::before { top: 0; opacity: 0; transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out; }

    .hamburger-label { color: #fff; font-size:17px; line-height: 17px; font-weight:400; font-weight:300; letter-spacing: -0.01em; }

/** header **/

#header_main { background: var(--white); position: fixed; top:0; left: 0; right: 0; width: 100%; z-index: 99;}
#header_main .container { display: flex; justify-content: space-between; align-items: center; gap: 20px 50px; min-height: 100px; position: relative;}
#header_main #logo_gracehouse { width: 260px; min-width: 260px; display: block; line-height: 7px;}
#header_main nav ul { margin:0; padding:0; list-style: none; list-style-image: none; display: flex; justify-content: center; gap: 5px 1.75vw; flex-wrap: wrap;}
#header_main nav ul li { margin:0; padding:0; font: 1.3rem/130% var(--omnes); }
#header_main nav ul li a { text-decoration: none; color: var(--green);}
#header_main nav ul li a:hover { color: var(--green-light);}
#header_main nav ul li.current-menu-item a { text-decoration: underline;}

.scrolling #header_main { -webkit-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.12); -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.12); box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.12); background: rgba(255, 255, 255, 0.95); -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); }

#section_main { padding: 100px 0 0 0;}

#page_banner { background-position: center; background-size: cover;}
#page_banner_plain { padding: 45px 0 0 0;}
#page_banner_plain h1 { padding:0; text-align: center;}

#page_banner .container { min-height: 60svh;}

#home_intro { display: flex; flex-direction: column-reverse;}
#home_intro #page_banner .container { display: flex; align-items: flex-end; justify-content: flex-end; }
#home_intro #page_banner, #home_intro #home_intro_base { width: 100%;}
#home_intro #home_intro_base { padding: 0 0 45px 0;}
#home_intro_base_flex { display: flex; justify-content: space-between; align-items: flex-start;}
#home_intro_base_flex_info { width: 66.66666666666667%; padding: 45px 50px 0 0; }
#home_intro_base_flex_info_cols { column-count: 2; column-gap: 40px; }
#home_intro_base_flex_img, #page_banner_intro { width: 33.33333333333333%; }
#home_intro_base_flex_img { padding: 0 10px 10px 10px; border-radius: 0 0 25px 25px; line-height: 7px; background: var(--white); }
#home_intro_base_flex_img img { width: 100%; height: auto; border-radius: 25px;}
#page_banner_intro { padding: 30px 30px 5px 30px; background: var(--white); border-radius: 25px 25px 0 0; }
#page_banner_intro h2 { font-size: 2rem; line-height: 105%; }
#page_banner_intro p { font-size: 0.9rem; line-height: 150%;}
#home_intro_base_wide { width: 100%; padding: 35px 0 0 0;}

#page_banner.page_banner_standard .container { display: flex; justify-content: center; align-items: center; min-height: 40svh; }
#page_banner.page_banner_standard .container h1 { color: var(--white); padding: 45px 0; text-align: center; }
h1 time { font-size: 1.2rem; line-height: 125%; display: block; padding: 0 0 5px 0;}

.margin_adjust { display: block; margin: 0 0 -25px 0;}
.builder { padding: 45px 0; }
.builder_cols .container { column-count: 2; column-gap: 50px;  }
.builder_cols.builder_cols_3 .container { column-count: 3; column-gap: 50px; }
.builder_cols .container h2, .builder_cols .container h3, .builder_cols .container p, .builder_cols .container li {break-inside: avoid;  page-break-inside: avoid; }
.builder_basic { padding-bottom: 35px; max-width: 1200px; margin: 0 auto;}
.builder_basic h2 { font-size: 2rem;}
.builder .builder_basic:last-of-type { padding-bottom: 0;}

.builder_banner { position: relative; background-position: center; background-size: cover; }
.builder_banner .container { display: flex;  min-height: 65svh; padding-top: 65px !important; padding-bottom: 65px !important; }
.builder_banner h2 { padding:0; max-width: 350px; max-width: 520px; color: var(--white);}

.builder_boxes_list_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 45px;     padding: 10px 0 10px 0; }
.builder_boxes_list_grid article { text-align: center; display: flex; flex-direction: column;}
.builder_boxes_list_grid article h3 {  }
.builder_boxes_list_grid article .builder_boxes_hover { text-decoration: none; flex-grow: 1; border-radius: 25px; background-position: center; background-size: cover; overflow: hidden; }
.builder_boxes_list_grid article .builder_boxes_hover p { font-size: 1.2rem; line-height: 155%; min-height: 350px; color: var(--white); background: rgba(35,95,71,0.65); opacity: 0; pointer-events: none; display: flex; align-items: center;justify-content: center; padding: 45px; width: 100%; height: 100%;}
.builder_boxes_list_grid article:hover .builder_boxes_hover p { opacity: 1;}

.builder_gallery_list, .builder_reviews_list, .news_grid { margin:0; padding:0; list-style: none; list-style-image: none; display: grid; grid-template-columns: repeat(5, 1fr); gap: 25px;     padding: 15px 0 15px 0; }
.builder_gallery_list li, .builder_reviews_list li, .news_grid li { margin:0; padding:0;}
.builder_gallery_list li a { display: block; line-height: 7px; border-radius: 12px; overflow: hidden; background-position: center; background-size: cover;}
.builder_gallery_list li img { width: 100%; height: auto;}

.builder_reviews_list { grid-template-columns: repeat(3, 1fr); }
.builder_reviews_list li article { border-radius: 25px; border: 1px solid #cccccc; padding: 30px; background: var(--white); height: 100%; display: flex; flex-direction: column; justify-content: space-between; }
.builder_reviews_list li article > div { width: 100%;}
.builder_reviews_list li article h3 { padding: 0 0 30px 0; font: bold 1rem/140% var(--inter); color: var(--grey);}
.builder_reviews_list li article .builder_reviews_list_testimonial img:nth-child(1) { display: inline-block; margin: 0 4px 0 -15px; width: 40px; }
.builder_reviews_list li article .builder_reviews_list_testimonial img:nth-child(2) { display: inline-block; margin: 0 0 -16px 4px; width: 40px; }
.builder_reviews_list li article .builder_reviews_list_stars { display: flex; gap: 10px; padding:0; }
.builder_reviews_list li article .builder_reviews_list_stars img { width: 20px; height: 20px;}

/** news **/

.news_grid { grid-template-columns: repeat(4, 1fr); gap: 45px; padding: 35px 0 55px 0; }
.news_grid li article { border-radius: 25px; overflow: hidden; position: relative;     -webkit-box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.07); -moz-box-shadow: 0px 0px 12px 0px rgba(0,0,0,0.07); box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.07);}
.post-thumbnail { line-height: 7px; overflow: hidden;}
.post-thumbnail img { height: 250px; width: 100%; object-fit: cover;}
.post-info { background: var(--white); padding: 30px;}
.post-info h2 { font-size: 1.8rem; padding: 0 0 15px 0;}
.post-info time { display: block; font-weight: bold; padding: 0 0 5px 0;}
.post-info p { padding:0 0 20px 0;}
.post-info p:last-of-type { padding:0;}
.news_grid li article a { display: block; text-indent: -9999px; overflow: hidden; width: 100%; height: 100%; position: absolute; inset: 0; }
.news_grid li article:hover img { transform: scale(1.1); }
.news_grid li article:hover .button_cta { background: var(--green); border-color: var(--green);}

.pagination-container { padding: 0 0 55px 0; font-size: 0.9rem; display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap;}
.pagination-container a { text-decoration: none; font-weight: bold;}
.pagination-container a:hover { text-decoration: underline;}
.pagination-container .page-numbers:not(.next):not(.prev) { font-size: 0.8rem; border-radius: 50px; background: var(--green-light); color: var(--white); display: flex; align-items: center; justify-content: center; width: 26px; height: 26px;}
.pagination-container .page-numbers.page-numbers.current { font-weight: bold; background: var(--green);}

/** footer **/

#site_footer { background: var(--green); padding: 60px 0 25px 0;}
#site_footer * { color: var(--white);}
#site_footer_flex { display: flex; justify-content: space-between; }
#site_footer_flex_map { width: 30%; line-height: 7px;}
#site_footer_flex_map iframe { width: 100%; height: 220px; border-radius: 20px; border: 3px solid var(--white); }
#site_footer_flex_cols { width: 70%; display: grid; grid-template-columns: repeat(3, 1fr); }
#site_footer_flex_cols > div { padding: 0 30px; border-left: 1px solid var(--white);}
#site_footer_flex_cols > div:nth-child(1) { border: none;}
#site_footer_flex_cols > div * { font-size: 0.9rem;}
#site_footer_flex_cols > div * strong { font-size: 1rem; }
#site_footer_flex_cols > div p:last-child { padding:0;}
#site_footer_flex_cols a { text-decoration: none;}
#site_footer_flex_cols a:hover { text-decoration: underline;}
#site_footer nav { display: flex; border-bottom: 1px solid var(--white); padding: 55px 0 25px 0; gap: 10px 30px; flex-wrap: wrap;}
#site_footer nav ul, #site_footer small ul { margin:0; padding:0; list-style: none; list-style-image: none; display: flex; gap: 5px 20px; flex-wrap: wrap;}
#site_footer nav ul li, #site_footer small ul li { margin:0; padding:0; font-size: 0.9rem;}
#site_footer nav ul li a, #site_footer small ul li a { text-decoration: none;}
#site_footer nav ul li a:hover, #site_footer small ul li a:hover { text-decoration: underline;}
#site_footer small { display: flex; gap: 0 20px; padding: 10px 0 0 0; justify-content: flex-end; flex-wrap: wrap; }
#site_footer small, #site_footer small * { font-size: 0.8rem; }
#site_footer small ul { gap: 0 10px; }

@media all and (min-width: 0px) and (max-width : 1800px) {



}

@media all and (min-width: 0px) and (max-width : 1600px) {

}

@media all and (min-width: 0px) and (max-width : 1540px) {
    #header_main nav ul li { font-size: 1.1rem; }
    #header_main .container { gap: 20px 35px; }
}

@media all and (min-width: 0px) and (max-width : 1500px) {



}

@media all and (min-width: 0px) and (max-width : 1420px) {

}

@media all and (min-width: 0px) and (max-width : 1400px) {

    #header_main nav ul li { font-size: 1rem; }

}

@media all and (min-width: 0px) and (max-width : 1380px) {

    .news_grid { grid-template-columns: repeat(3, 1fr); gap: 40px; }

}

@media all and (min-width: 0px) and (max-width : 1320px) {


}

@media all and (min-width: 0px) and (max-width : 1200px) {

    .builder_boxes_list_grid { grid-template-columns: repeat(2, 1fr); }


}

@media all and (min-width: 0px) and (max-width : 1140px) {

    .builder_gallery_list {grid-template-columns: repeat(4, 1fr); }


}

@media all and (min-width: 0px) and (max-width : 1100px) {

    h1, .h1_styler { font-size: 3rem;}
    h2, .h2_styler { font-size: 2.7rem;}

    #header_main nav { position: absolute; top: 100%; background: var(--white); left: 0; right: 0; padding: 20px; opacity: 0;     -webkit-box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.10); -moz-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.10); box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.10);}
    .open-menu #header_main nav { opacity: 1; }
    #header_main nav ul { gap: 5px 20px;}
    .hamburger { display: flex; position: absolute; right:40px; top: 50%; margin-top: -13px; height: 26px;}
    #header_main .button_cta.button_call { margin-right: 60px;}

    #home_intro_base_flex_info_cols { column-count: 1; }

    .builder_cols.builder_cols_3 .container { column-count: 2;}


}

@media all and (min-width: 0px) and (max-width : 1024px) {


}

@media all and (min-width: 0px) and (max-width : 1000px) {

    #site_footer_flex { flex-direction: column; gap: 40px 0; }
    #site_footer_flex_map iframe { height: 360px;}
    #site_footer_flex_map { width: 100%; }
    #site_footer_flex_cols { width: 100%;}
    #site_footer_flex_cols > div:nth-child(1) { padding-left: 0;}
    #site_footer_flex_cols > div:nth-child(3) { padding-right: 0;}

}

@media all and (min-width: 0px) and (max-width : 950px) {

    .builder_gallery_list {grid-template-columns: repeat(3, 1fr); }

}

@media all and (min-width: 0px) and (max-width : 900px) {

    #page_banner_intro { width: 100%; padding: 25px 20px 5px 20px;}
    #home_intro_base_flex { flex-direction: column; gap: 40px 0;}
    #home_intro_base_flex_info { width: 100%; padding-right: 0;}
    #home_intro_base_flex_img { width: 100%; border-radius: 25px; }


}

@media all and (min-width: 0px) and (max-width : 880px) {

    .news_grid { grid-template-columns: repeat(2, 1fr); }

}

@media all and (min-width: 0px) and (max-width : 800px) {

    .builder_reviews_list { grid-template-columns: repeat(1, 1fr); }

    #header_main nav { left: auto; width: 300px; padding: 20px 40px 20px 20px;}
    #header_main nav ul { gap: 10px 0;flex-direction: column; align-items: center; align-items: flex-end;}
    #header_main nav ul li { font-size: 1.4rem;}

}

@media all and (min-width: 0px) and (max-width : 780px) {

}

@media all and (min-width: 0px) and (max-width : 760px) {

    .builder_cols.builder_cols_3 .container, .builder_cols .container { column-count: 1;}

}

@media all and (min-width: 0px) and (max-width : 720px) {

    body {  }

    h1, .h1_styler { font-size: 2.5rem; }
    h2, .h2_styler, #page_banner_intro h2 { font-size: 1.8rem; line-height: 115%; }
    h3, .h3_styler { font-size: 1.2rem; line-height: 120%; }
    h4 { font-size: 1rem;}

    .container { padding: 0 25px; }

    .button_cta, .button_cta.button_call { padding: 10px 15px; }

    .button_cta.button_call { font-size: 1.25rem;}

    #header_main .container { gap: 20px 25px; min-height: 75px; }
    #section_main { padding: 75px 0 0 0;}

    #header_main #logo_gracehouse { width: 180px; min-width: 180px;}
    .hamburger { right: 25px;}
    #header_main .button_cta.button_call { margin-right: 50px;}

    .list_ticks li { font-size: 1.2rem; }

    #page_banner .container { min-height: 45svh;}

    #home_intro_base_flex_info { padding-top: 35px;}
    #page_banner_intro { padding: 25px 10px 5px 10px;}
    .builder { padding: 35px 0;}

    .builder_boxes_list_grid { grid-template-columns: repeat(1, 1fr); gap: 35px; }
    .builder_boxes_list_grid article .builder_boxes_hover p { opacity: 1; height: auto; min-height: unset; padding: 20px 25px; font-size: 1rem; line-height: 140%; }
    .builder_boxes_list_grid article .builder_boxes_hover { min-height: 350px; display: flex; align-items: flex-end; }

    .builder_gallery_list, .builder_reviews_list { padding: 10px 0; }

    .builder_banner .container { padding-top: 35px !important; padding-bottom: 35px !important; }

    #site_footer { padding-top: 45px;}

    .news_grid { grid-template-columns: repeat(1, 1fr); gap: 25px; }

    #header_main nav { left: auto; width: 300px; padding: 20px 25px 20px 20px;}

}

/** mobile **/

@media all and (min-width: 0px) and (max-width : 670px) {

    .builder_gallery_list {grid-template-columns: repeat(2, 1fr); gap: 20px; }

}

@media all and (min-width: 0px) and (max-width : 650px) {



}

@media all and (min-width: 0px) and (max-width : 600px) {

    #site_footer_flex_cols { grid-template-columns: repeat(1, 1fr); gap: 25px 0; }
    #site_footer_flex_cols > div { padding: 0; border: none;}
    #site_footer_flex_cols > div:nth-child(2) { border-top: 1px solid var(--white); border-bottom: 1px solid var(--white); padding: 25px 0; }

}

@media all and (min-width: 0px) and (max-width : 580px) {



}

@media all and (min-width: 0px) and (max-width : 540px) {



}

@media all and (min-width: 0px) and (max-width : 510px) {

    #header_main .button_cta.button_call span { display: none;}


}

@media all and (min-width: 0px) and (max-width : 470px) {



}

@media all and (min-width: 0px) and (max-width : 450px) {

    .builder_gallery_list {grid-template-columns: repeat(1, 1fr); }

    #header_main nav { width: 100%;}
    #header_main nav ul { align-items: center;}

}

@media all and (min-width: 0px) and (max-width : 400px) {


}

@media all and (min-width: 0px) and (max-width : 380px) {

    #header_main #logo_gracehouse {width: 115px; min-width: 115px; }

}

@media all and (min-width: 0px) and (max-width : 360px) {

}

.grecaptcha-badge { visibility: hidden; }