/*  
Theme Name: Sharon Bennett Family Law Theme
Theme URI: http://sww.co.nz/
Description: Custom WordPress theme by Stellar Web Works
Version: 1.0
Author: Aidan Curran
Author URI: http://sww.co.nz/
*/

/* 
   Contents:
   0. Variables
   1. Basics
   2. Header
   3. Sticky Header
   4. Navigation Menus
   5. Dropdown Menu
   6. Lists
   7. Blockquotes
   8. Style classes for use in Editor
   9. Sections (Groups)
   10. Columns
   11. Cover Block
   12. Call to action
   14. Photo Layout
   15. Hero Section
   16. Breadcrumbs
   17. Buttons and more links
   18. Blog Styles
   19. Comments   
   20. Footer
   21. Gutenberg overrides and workarounds
   22. Other

   R. Responsive Elements
   R1. Defaults
   R2. MEDIUM-WIDE SCREEN (max-width: 1200px)
   R3. MEDIUM-SMALL SCREEN (max-width: 1000px)
   R4. SMALL SCREEN (max-width: 700px)

*/

/* -------------------------------------------------------------------------------------------------------------------- 
   0. Variables
*/
:root {
   /* colour shortcuts */
   --color1: var(--wp--preset--color--color-1);
   --color2: var(--wp--preset--color--color-2);
   --dark-green: var(--wp--preset--color--dark-green);
   --light-grey: var(--wp--preset--color--light-grey);
   --grey: var(--wp--preset--color--grey);
   --dark-grey: var(--wp--preset--color--dark-grey);
   --grey-tint: var(--wp--preset--color--grey-tint);
   --green-tint: var(--wp--preset--color--green-tint);
   --dark: var(--wp--preset--color--dark);

   /* font size shortcuts */
   --xs: var(--wp--preset--font-size--x-small); /* 15-17px */
   --sm: var(--wp--preset--font-size--small); /* 17-22px */
   --m: var(--wp--preset--font-size--medium); /* 18-24px */
   --l: var(--wp--preset--font-size--large); /* 24-32px */
   --xl: var(--wp--preset--font-size--x-large); /* 32-48px */
   --xx: var(--wp--preset--font-size--xx-large); /* 32-64px */
   --xxl: var(--wp--preset--font-size--xxx-large); /* 16-64px */
   --xxxl: var(--wp--preset--font-size--xxxx-large); /* 16-64px */

   /* spacing shortcuts */
   --sp1: var(--wp--preset--spacing--10); /* 8-16px */
   --sp2: var(--wp--preset--spacing--20); /* 16-32px */
   --sp3: var(--wp--preset--spacing--30); /* 24-48px */
   --sp4: var(--wp--preset--spacing--40); /* 32-64px */
   --sp5: var(--wp--preset--spacing--50); /* 48-96px */
   --sp6: var(--wp--preset--spacing--60); /* 70-140px */
   --sp7: var(--wp--preset--spacing--70); /* 80-160px */

   --header-height-full: 150px;
   --header-height-mobile-full: 100px;
   --sticky-height: 80px;
}


/* -------------------------------------------------------------------------------------------------------------------- 
   1. Basics
*/
/* set a reasonable absolute max width for the entire site (for massive screens) */
body {
   max-width: 3000px;
   margin-left: auto;
   margin-right: auto;
   min-width: 300px;
}
/* Set content width as percentage when max width is not in play (because styles > spacing > padding does not get applied to content inside a full width block ) */
body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
   width: 90%;
}
/* cancel out above rule affecting image alignment block editor */
.block-editor-block-list__layout figure {
   width: auto;
}
h3 a {
   text-decoration: none;
   color: var(--dark);
}
h3 a:hover {
   color: var(--color2);
}


/* -------------------------------------------------------------------------------------------------------------------- 
   2. Header
*/
header.wp-block-group {
   background-color: transparent;
   padding: 0;
}
#header-container {
   height: var(--header-height-full);
   display: flex;
   justify-content: space-between;
   align-items: center;
}
#headerleft {
   flex-grow: 0;
   flex-shrink: 1;
   position: relative;
   flex-basis: 300px;
}
#headerright {
   flex-grow: 1;
}
header #logo {
   display: block;
   max-width: 366px;
   width: 20vw;
   min-width: 200px;
   height: auto;
   transition: all 0.25s;
}
header #logo img {
   width: 100%;
   height: 100%;
   object-fit: contain;
   overflow: hidden;
   transition: all 0.2s;
}
header #logo img:hover {
   scale: 1.02;
}
header #headertext {
   float: right;
   padding-bottom: 20px;
}
header #headertext a {
   text-decoration: none;
}
header #headertext .phone {
   font-size: 26px;
   font-weight: bold;
   color: var(--color1);
}
header #headertext .email {
   margin: 0;
}
header #headertext .social {
   font-size: 32px;
   text-align: right;
}


/* --------------------------------------------------------------------------------------------------------------------
   3. Sticky Header
*/
/* The sticky class is added to the header with JS when it reaches its scroll position */
#header-sticky.sticky {
   position: fixed;
   top: 0;
   width: 100%;
   z-index: 10;
   /*height: var(--sticky-height);*/
   box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.1);
   background-color: rgba(255,255,255,0.9);
}
#header-sticky.sticky a {
   color: #000;
}
#header-sticky.mobile-menu-open {
   /*position: static;*/
   height: auto;
}
#header-sticky.sticky #header-container {
   max-height: var(--sticky-height);
}
#header-sticky.mobile-menu-open #header-container {
   max-height: var(--header-height-mobile-full);
}
.admin-bar #header-sticky {
   top: 32px;
}
@media screen and (max-width: 782px) {
   .admin-bar #header-sticky {
      top: 46px;
   }
}
@media screen and (max-width: 600px) {
   .admin-bar #header-sticky {
      top: 0;
   }
}
#header-sticky.sticky #logo {
   width: 130px;
}
#header-sticky.sticky #headertext {
   display: none;
}
/* Add some top padding to the page content to prevent sudden quick movement (as the header gets a new position at the top of the page (position:fixed and top:0) */
/* this should be equal to the initial header height */
#header-sticky.sticky + * {
   XXXpadding-top: var(--header-height-full);
}


/* --------------------------------------------------------------------------------------------------------------------
   4. Navigation Menus
*/
nav {
   text-align: center;
}
#topnav {
   float: right;
   clear: right;
   line-height: 30px;
}
nav a {
   margin: 0 var(--sp2);
   padding: 5px 0;
   text-decoration:none;
   font-weight: normal;
   font-size: var(--sm);
   display: inline-block;
   color: var(--dark);
   transition: all 0.4s ease;
}
#topnav a:hover, 
nav li.current_page_item > a,
nav li.current-page-ancestor > a {
   color: var(--color2);
}
#topnav a {
   position: relative;
}
#topnav a::before {
   height: 5px;
   position: absolute;
   content: '';
   transition: all 0.4s ease;
   background-color: var(--color2);
   width: 0;
   top: 0;
   left: 0;
}
#topnav a:hover::before,
#topnav .current_page_item > a::before,
#topnav .current-page-ancestor > a::before {
   width: 100%;
}
#topnav li:first-child a {
   padding-left: 0;
   margin-left: 0;
}
#topnav li:last-child a {
   padding-right: 0;
   margin-right: 0;
}
nav ul, #subnav ul, footer nav ul {
   list-style: none;
   margin: 0;
   padding: 0;
}
nav li, #subnav li, footer nav li {
   display: inline;
   list-style: none;
   margin: 0;
   padding: 0;
   background: none;
}


/* --------------------------------------------------------------------------------------------------------------------
   5. Dropdown Menu
*/
#topnav ul.sub-menu { 
	display: none; 
	position: absolute; 
	top: 30px;
   left: 0;
	min-width: 150px;
	z-index: 21;
   background-color: white;
   box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.1);
   padding: 3px 20px;
}
.sticky #topnav ul.sub-menu { 
   background-color: rgba(250,250,250,0.9);
}
/* second sub level */
#topnav ul.sub-menu ul.sub-menu { 
   position: static;
   padding: 0 0 0 15px;
}
#topnav ul.sub-menu ul.sub-menu a { 
   padding: 0;
   margin: 0;
}
#topnav ul.sub-menu ul.sub-menu a::before { 
   content: " - ";
}
#topnav ul.sub-menu > li.menu-item-has-children > a {
   margin-bottom: 0;
}
#topnav ul.sub-menu li { 
   display: block;
   text-align: left;
}
#topnav ul.sub-menu.open {
	display: block;
}
#topnav ul.sub-menu a {
   opacity: 0.9;
}
#menu-main-menu > li {
	position: relative;
}
#menu-main-menu > li::before { /* to create hover buffer around menu item */
	position: absolute;
   content: '';
   width: 100%;
   height: 60px;
   top: -10px;
   left: 0;
   z-index: -1;
}
#topnav ul.sub-menu li { 
   margin:0;
}
#topnav ul.sub-menu a { 
   display: inline-block;
   padding: 2px 0;
   margin: 10px 0;
}
/*give the dropdowns an indicator arrow */
#topnav ul:not(.sub-menu) > li.menu-item-has-children > a:after {
   font-family: 'icomoon';
	content: '\e90e';
   font-size: 14px;
	display: inline-block;
	padding-left: 10px;
}
.sticky #topnav ul:not(.sub-menu) > li.menu-item-has-children > a:after {
   color: initial;
}
@media screen and (max-width: 700px) {
   #topnav ul:not(.sub-menu) > li.menu-item-has-children > a:after {
      color: initial;
   }
      
}

/* --------------------------------------------------------------------------------------------------------------------
   6. Lists
*/
ul.is-style-fancy,
ul.is-style-checkmark {
   list-style-type: none;
   padding-left: 20px;
}
ul.is-style-fancy li,
ul.is-style-checkmark li {
   margin: 15px 0;
   padding-left: 30px;
   position: relative;
}
ul.is-style-fancy li::before,
ul.is-style-checkmark li::before {
   font-family: 'icomoon';
   content: '\ea1e';
   color: var(--color1);
   padding-right: 10px;
   position: absolute;
   left: 0;
   top: 3px;
}
ul.is-style-fancy li a {
   text-decoration: none;
}
ul.is-style-fancy li a:hover {
   text-decoration: underline;
}
ul.is-style-checkmark li {
   padding-left: 2rem;
}
ul.is-style-checkmark li::before {
   content: '\ea52';
   top: 4px;
}

/* --------------------------------------------------------------------------------------------------------------------
   7. Blockquotes
*/
blockquote.is-style-fancy {
   position: relative;
}
blockquote.is-style-fancy::before {
   content: "";
   position: absolute;
   display: block;
   width: 100%;
   height: 100%;
   top: 0;
   left: 0;
   background: url(images/quotes.svg) left center no-repeat;
}
.has-dark-background-color blockquote.is-style-fancy {
   background-image: linear-gradient(to right, #191919, rgba(0,0,0,0), rgba(0,0,0,0), rgba(0,0,0,0));
   color: var(--light-grey);
}
.has-dark-background-color blockquote.is-style-fancy-dark::before {
   background: url(images/quotes-dk.svg) left center no-repeat;
}


/* --------------------------------------------------------------------------------------------------------------------
   8. Style classes for use in Editor
*/
/* icons */
.fb-icon::before {
   font-family: 'icomoon';
   content: '\e904';
   display: inline-block;
   padding-right: 6px;
}
.phone-icon::before {
   font-family: 'icomoon';
   content: '\e942';
   display: inline-block;
   padding-right: 6px;
}
.mobile-icon::before {
   font-family: 'icomoon';
   content: '\e91c';
   display: inline-block;
   padding-right: 6px;
}
.mail-icon::before {
   font-family: 'icomoon';
   content: '\e903';
   display: inline-block;
   padding-right: 6px;
}
/* .plain-links */
.plain-links a {
   text-decoration: none;
   color: black;
}
.plain-links a:hover {
   color: var(--color1);
}
/* rotated heading */
.rotated {
    writing-mode: vertical-rl;
    text-orientation: sideways-right;
    font-style: normal !important;
    transform: rotate(180deg);
    text-transform: uppercase;
    font-size: var(--xxxl);
    font-weight: 300;
}
/* Contact details */
.contact-details a {
   text-decoration: none;
}

/* --------------------------------------------------------------------------------------------------------------------
   9. Sections (Groups)
*/

.wp-block-group.is-style-no-padding {
   padding: 0;
}


/* --------------------------------------------------------------------------------------------------------------------
   10. Columns
*/
@media (max-width: 781px) {
   .wp-block-columns.is-style-2col-image-right {
        flex-direction: column-reverse;
   }
   .wp-block-columns.is-style-2col-image-right .wp-block-column > figure,
   .wp-block-columns.is-style-2col-image-left .wp-block-column > figure {
      max-width: 400px;
      margin:auto;
   }
}


/* --------------------------------------------------------------------------------------------------------------------
   11. Cover Block
*/
.wp-block-cover.topheader {
   padding: 0;
   min-height: clamp(150px, 80px + 8vw, 330px);
   background: #284A4C;
   background: linear-gradient(90deg,#284A4C 0%, #192d2f 100%);   
}
.wp-block-cover.topheader .wp-block-cover__background {
   background-color: transparent !important;
   background: url(images/bg2.jpg) left bottom no-repeat;
   background-size: cover;
   mix-blend-mode: multiply;
   width: 100%;
   height: 100%;
   opacity: 1;
}
.wp-block-cover.topheader h1 {
   font-size: var(--xx);
   font-weight: 400;
   color: white;
   padding: 5px 15px;
}
.wp-block-cover.topheaderplain, .topheaderplain {
   min-height: 200px;
}

/* --------------------------------------------------------------------------------------------------------------------
   12. Call to action
*/
.wp-block-cover.cta {
   padding-top: var(--sp7);
   padding-bottom: var(--sp7);
}
.wp-block-cover.cta p {
   font-size: var(--xl);
   border-left: var(--sp3) solid var(--color1);
   padding-left: var(--sp3);
   text-shadow: 0 0 10px black; 
}
.wp-block-group.cta {
   background: url(images/bg3.jpg) 0 0 no-repeat;
   background-size: cover;
}
@media screen and (max-width: 600px) {
   .cta .wp-block-group-is-layout-flex {
      flex-wrap: wrap;
      justify-content: center;
   }
}

/* --------------------------------------------------------------------------------------------------------------------
   15. Hero Section
*/
.wp-block-cover.hero {
   padding: 0;
   background: #284A4C;
   background: linear-gradient(90deg,#284A4C 0%, #192d2f 100%);   
}
.wp-block-cover.hero .wp-block-cover__background {
   background-color: transparent !important;
   background: url(images/bg2.jpg) left bottom no-repeat;
   background-size: cover;
   mix-blend-mode: multiply;
   width: 100%;
   height: 100%;
   opacity: 1;
}
.wp-block-cover.hero h2 {
   font-weight: 400;
   font-size: var(--xxl);
}
.wp-block-cover.hero h1 {
   font-size: var(--xxl);
   margin-top: 0;
}
.wp-block-cover.hero p {
   font-size: var(--l);
}
.wp-block-cover.hero .wp-block-buttons {
   margin-top: var(--sp4);
}

@media screen and (max-width: 782px) {
   .wp-block-cover.hero .portrait {
      max-width: 330px;
   }
   .wp-block-cover.hero .col1 {
      padding: var(--sp4) var(--sp3) 0 var(--sp3) !important;
   }   
   .wp-block-cover.hero .col2 {
      padding-top: 0 !important;
      margin-top: -100px;
   }
}
@media screen and (max-width: 500px) {
   .wp-block-cover.hero .portrait {
      float:none !important;
      margin: 0 auto !important;
   }
   .wp-block-cover.hero .col2 {
      margin-top: 0;
   }   
}

/* --------------------------------------------------------------------------------------------------------------------
   16. Breadcrumbs
       Remove if not used
*/
.breadcrumbs {
   font-size: var(--xs);
   background-color: var(--grey-tint);
   padding: 7px 0;
}
.breadcrumbs a {
   text-decoration: none;
}


/* --------------------------------------------------------------------------------------------------------------------
   17. Buttons and more links
*/
.wp-block-button a {
   transition: all 0.25s;
}
.wp-block-button a:hover {
   scale: 1.03;
}
.wp-block-buttons.special {
   display: grid;
   grid-template-columns: 1fr 1fr 1fr;
}
.wp-block-buttons.special .wp-block-button__link {
   font-size: var(--sm);
   padding-top: var(--wp--preset--spacing--20);
   padding-bottom: var(--wp--preset--spacing--20);
   padding-right: var(--wp--preset--spacing--10);
   padding-left: var(--wp--preset--spacing--10);
   min-height: 103px;
}
.wp-block-buttons.special .wp-block-button:nth-child(odd) .wp-block-button__link {
   border-top-left-radius: 30px;
   border-bottom-right-radius: 30px;
   background-color: var(--color2);
}
.wp-block-buttons.special .wp-block-button:nth-child(even) .wp-block-button__link {
   border-top-right-radius: 30px;
   border-bottom-left-radius: 30px;
}
@media screen and (max-width: 1050px) {
   .wp-block-buttons.special {
      grid-template-columns: 1fr 1fr;
   }
}
@media screen and (max-width: 782px) {
   .wp-block-buttons.special {
      grid-template-columns: 1fr 1fr 1fr;
   }
}
@media screen and (max-width: 460px) {
   .wp-block-buttons.special {
      grid-template-columns: 1fr 1fr;
   }
}

/* --------------------------------------------------------------------------------------------------------------------
   18. Blog Styles
       Remove if not used
*/
#blog-posts,
#single-blog-post,
#category-heading {
   padding-top: var(--sp4);
}
#featured-image {
   height: 500px;
   max-height: 50vh;
   overflow: hidden;
}
#featured-image img {
   object-fit: cover;
   object-position: 50% 20%;
   height: 100% !important;
   width: 100%;
}
.postmeta {
   color: #808080;
   font-size: 16px;
   margin: 2px 0;
}
div.postmeta {
   margin-top: 50px;
   padding-top: 20px;
   border-top: 1px solid #ccc;
}
.postdate {
   color: #808080;
   font-size: 16px;
}
/* blog categories list */
#blog-categories {
   background-color: #f9f9f9;
   padding: 30px 0;
}
#blog-categories ul {
   list-style: none;
   margin: 0;
   padding: 0;
}
#blog-categories li {
   display: inline;
   list-style: none;
   margin: 0 20px 0 0;
   padding: 0;
   background: none;
   color: #ccc;
}
#blog-categories li.current-cat a {
   font-weight: bold;
}
#blog-posts article {
   position: relative;
   display: flex;
   min-height: 360px;
   margin-bottom: 50px;
   box-shadow: 0 6px 24px rgba(11, 11, 11, 0.05);
   border: 1px solid #eeeeef;
   border-radius: 4px;
}
#blog-posts article .article-image {
   flex-basis: 50%;
   flex-grow: 1;
   flex-shrink: 1;
   overflow: hidden;
}
#blog-posts article .article-summary {
   flex-basis: 50%;
   flex-grow: 1;
   flex-shrink: 1;
   padding: 30px;
   align-self: center;
}
#blog-posts .article-summary h2 {
   font-size: var(--l);
   font-weight: bold;
   margin-top: 0;
   transition: all 0.3s;
}
#blog-posts .article-summary h2 a {
   text-decoration: none;
   color: black;
}
#blog-posts .article-summary h2 a:hover {
   color: var(--color1);
}
#blog-posts article .article-image img {
   object-fit: cover;
   height: 100%;
   width: 100%;
   transition: all 300ms linear 0ms;
}
#blog-posts article .article-image img:hover {
   transform: scale(1.1);
}
#blog-posts article::after {
   content: "";
   display: block;
   clear: both;
}
@media screen and (max-width: 900px) {
   #blog-posts article {
      flex-direction: column;
   }
   #blog-posts article .article-image {
      aspect-ratio: 120/63;
   }
}
@media screen and (max-width: 500px) {
   #blog-posts .article-summary h2 {
      font-size: 22px;
   }
}
#blog-posts a.more-link {
   text-decoration: none;
   font-weight: bold;
   color: var(--color2);
}
#blog-posts a.more-link:hover {
   transform: scale(1.05);
   color: var(--color1);
}
#blog-posts a.more-link::after {
   font-family: 'icomoon';
   content: '\e90a';
   display: inline-block;
}
div.back {
   margin: 30px 0;
   text-align: center;
}
div.back a {
   font-size: 24px;
   text-decoration: none;
}
div.back a::before {
   font-family: 'icomoon';
   content: '\e90d';
   padding-right: 5px;
}

/* --------------------------------------------------------------------------------------------------------------------
   19. Comments
       Remove if not used
*/
#comments {
   margin-top: 100px;
   color: #333;
   background: #f3f3f3;
   padding: 10px 20px;
   clear:both;
}
#comments .navigation {
	padding: 0 0 18px 0;
}
h3#comments-title,
h3#reply-title {
	color: #000;
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 0;
}
h3#comments-title {
	padding-bottom: 24px;
}
.commentlist {
	list-style: none;
	margin: 0;
   padding: 0;
}
.commentlist li.comment {
	border-bottom: 1px solid #e7e7e7;
	line-height: 24px;
	margin: 0 0 24px 0;
	padding: 0 0 0 56px;
	position: relative;
}
.commentlist li:last-child {
	border-bottom: none;
	margin-bottom: 0;
}
#comments .comment-body ul,
#comments .comment-body ol {
	margin-bottom: 18px;
}
#comments .comment-body p:last-child {
	margin-bottom: 6px;
}
#comments .comment-body blockquote p:last-child {
	margin-bottom: 24px;
}
.commentlist ol {
	list-style: decimal;
}
.commentlist .avatar {
	position: absolute;
	top: 4px;
	left: 0;
}
.comment-author cite {
	color: #000;
	font-style: normal;
	font-weight: bold;
}
.comment-author .says {
	font-style: italic;
}
.comment-meta {
	font-size: 14px;
	margin: 0 0 18px 0;
}
.comment-meta a:link,
.comment-meta a:visited {
	color: #888;
	text-decoration: none;
}
.comment-meta a:active,
.comment-meta a:hover {
	color: #ff4b33;
}
.reply {
	font-size: 14px;
	padding: 0 0 24px 0;
}
.reply a,
a.comment-edit-link {
	color: #888;
}
.reply a:hover,
a.comment-edit-link:hover {
	color: #ff4b33;
}
.commentlist .children {
	list-style: none;
	margin: 0;
}
.commentlist .children li {
	border: none;
	margin: 0;
}
.nopassword,
.nocomments {
	display: none;
}
#comments .pingback {
	border-bottom: 1px solid #e7e7e7;
	margin-bottom: 18px;
	padding-bottom: 18px;
}
.commentlist li.comment+li.pingback {
	margin-top: -6px;
}
#comments .pingback p {
	color: #888;
	display: block;
	font-size: 14px;
	line-height: 18px;
	margin: 0;
}
#comments .pingback .url {
	font-size: 14px;
	font-style: italic;
}
/* Comments form */
#respond {
	border-top: 1px solid #e7e7e7;
	margin: 24px 0;
	overflow: hidden;
	position: relative;
}
#respond p {
	margin: 0;
}
#respond .comment-notes {
	margin-bottom: 1em;
   font-style: italic;
   color: #999;
}
.form-allowed-tags {
	line-height: 1em;
}
.children #respond {
	margin: 0 48px 0 0;
}
h3#reply-title {
	margin: 18px 0;
}
#comments-list #respond {
	margin: 0 0 18px 0;
}
#comments-list ul #respond {
	margin: 0;
}
#cancel-comment-reply-link {
	font-size: 14px;
	font-weight: normal;
	line-height: 18px;
}
#respond .required {
	display:none;
}
#respond label {
	color: #888;
	font-size: 14px;
   width: 80px;
   display: block;
   float: left;
   text-align: right;
   padding-right: 10px;
}
#respond input {
	margin: 0 0 9px;
	width: 500px;
}
#respond textarea {
	width: 500px;
}
#respond .form-allowed-tags {
	color: #888;
	font-size: 14px;
	line-height: 18px;
}
#respond .form-allowed-tags code {
	font-size: 14px;
}
#respond .form-submit {
	margin: 12px 0;
}
#respond .form-submit input {
	font-size: 14px;
	width: auto;
}


/* --------------------------------------------------------------------------------------------------------------------
   20. Footer
*/
footer {
   background: var(--color1);
   background: linear-gradient(180deg,#284A4C 0%, #192d2f 100%);   
   color: #fff;
   overflow: hidden;
   position: relative;
}
footer .footer-overlay {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: url(images/bg2.jpg) left bottom no-repeat;
   background-size: cover;
   mix-blend-mode: multiply;
}  

#footer-container {
   padding: var(--sp5) 0;
   position: relative;
}
#footerlogo {
   text-align: center;
}
#footerlogo img {
   width: 20vw;
   max-width: 366px;
   min-width: 260px;
   height: auto;   
   padding: 0; 
   z-index: 10;
}
footer h4 {
   color: #fff;
   margin-bottom: 5px;
}
footer a {
   color: #fff;
   text-decoration:none;
}
.footercols {
   display: flex;
   align-items: center;
}
.footercol {
   flex-basis: 50%;
}
.footercol .contents {
   width: fit-content;
}
footer nav ul {
   text-align: center;
}
footer nav li {
   display: block;
   padding: 0;
   text-align: left;
   line-height: 1.5em;
}
footer nav li a {
   font-size: 20px;
   padding: 0;
   margin: 0;
   font-weight: normal;
}
footer nav li.current_page_item > a {
   color: var(--color2);
}
footer .phone {
   font-size: 24px;
   font-weight: bold;
   margin: 1em 0;
}
footer .email {
   font-size: 20px;
   font-weight: bold;
   margin: 1em 0;
}
footer .social-icons {
   font-size: 40px;
   display: flex;
   justify-content: space-evenly;
}
footer .social-icons a {
   transition: all 0.2s;
}
footer .social-icons a:hover {
   scale: 1.05;
}
#credits {
   text-align: center;
   font-size: 14px;
   color: #999;
   background-color: var(--dark-green);
   padding: 10px 0;
   width: 100%;
}
#credits a {
   text-decoration: none;
   color: #999;
}
#credits a:hover {
   text-decoration: underline;
}
a.scrollup {
	width: 67px;
	height: 67px;
	position: fixed;
	bottom: 25px;
	right: 25px;
	display: none;
	text-indent: -9999px;
	background: url('images/top.png') no-repeat;
	opacity: 0.3;
}
@media screen and (max-width: 750px) {
   .footercols {
      flex-direction: column;
      text-align: center;
      gap: 20px;
   }
   .footercols ul {
      width: fit-content;
      margin: auto;
   }
}

/* --------------------------------------------------------------------------------------------------------------------
   21. Gutenberg overrides and workarounds
*/
/* fix for fixed cover background issue on ipad */
@supports (-webkit-touch-callout: inherit) {
   .wp-block-cover .has-parallax {
      background-attachment: scroll !important;
   }
}
.wp-block-cover {
   overflow: hidden;
}
main .wp-block-cover .wp-block-cover__image-background {
   margin: auto;
}
.wp-block-spacer {
   margin: 0 !important;
}

/* --------------------------------------------------------------------------------------------------------------------
   22. Other
*/
/* hide Google recaptcha badge */
div.grecaptcha-badge {
    visibility: hidden; 
} 
p.recaptchanote {
    font-size: 14px;
    text-align: center; 
}

/* --------------------------------------------------------------------------------------------------------------------
   R. Responsive Elements
*/

/* R1. Defaults: computer monitors, tablets in landscape, standard and large screens (typically wider than 1024px), old browsers */
#mobile-menu-btn { display: none; }
img {
   max-width: 100%; 
   height: auto; 
}
   
/* R2. MEDIUM-WIDE SCREEN */
/* width 900px - 1200px */
@media screen and (max-width: 1200px) {


}

/* R3. MEDIUM-SMALL SCREEN */
/* width 700px - 1000px */
@media screen and (max-width: 1000px) {	
   header #header-container {
      flex-direction: column;
      align-items: stretch;
      height: var(--header-height-mobile-full);
   }
   #headerleft {
      height: var(--header-height-mobile-full);
      width: 90%;
      margin-left: auto;
      margin-right: auto;
      flex-basis: auto;
      flex-shrink: 0;
      display: flex;
      align-items: center;
   }   
   #topnav {
      background-color: #fff;
   }
   #header-sticky.sticky #headerleft {
      height: var(--sticky-height);
   }
   #header-sticky.sticky + * {
      padding-top: var(--header-height-mobile-full);
   }
   #header-container {
      width: 100%;
   }
   #mobile-menu-btn { 
      display: inline-block;
      width: 32px;
      height: 32px;
      padding: 4px;
      cursor: pointer;
      position: absolute;
      top: -60px;
      right: 30px;
   }
   #mobile-menu-btn::after { 
      font-family: 'icomoon';
      content: '\e910';
      font-size: 36px;
      color: var(--color1);
      display: inline-block;
   }
   header.mobile-menu-open #mobile-menu-btn::after {
      content: '\e911';
   }   
   #topnav { 
      float: none; 
      width: auto; 
      clear: both;
      position: relative;
      z-index: 9999;
   }
   #topnav a::before { 
      display: none;
   }
   #headertext {
      display: none;
   }      
   #header-sticky.sticky #topnav {
      padding-top: 0;
   }   
   #topnav .menu ul { 
      padding-bottom: 15px;
   }
   #topnav ul { display:none; }
   #topnav ul#menu-main-menu.open {  
     width: 100%;  
     display: block;  
     height: auto;  
     padding-top: 0;
     margin-top:0;
     box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.1);
   }  
   #topnav li {  
     width: auto;  
     float: none;  
     position: relative;  
   }  
   #topnav li a {  
     display: block;
     margin: 0;
     padding: 6px 0px;
     text-align: left;  
     width: 100%;  
     text-indent: 25px;  
     line-height: 30px;
     border-left: 15px solid rgba(255,255,255,0);
   }
   #topnav li.current_page_item > a {
      border-left: 15px solid var(--color1);
   }
   #topnav ul.sub-menu { 
      display: block; 
      position: static; 
      background-color: transparent !important;
      padding: 3px 10px;
      box-shadow: none;
   }
   #topnav ul.sub-menu a {
      margin: 0 0 0 10px;
      padding: 0;
   }
   #topnav ul li.menu-item-has-children > a:after {
      content: '';
      padding: 0;
   }

}


/* R4. SMALL SCREEN */
/* width 320px - 700px */
@media screen and (max-width: 700px) {	

}
