/*************************************************
Ensure Correct Colour Contrast Ratio for Accessability Score
*************************************************/
/*************************************************
GLOBAL CSS VARIABLES
*************************************************/
:root {
	--primary-colour:#325543;
	--secondary-colour:#85ab65;
	--background-colour:#eaecef;
	--primary-font-family:"Josefin Sans", Sans-serif;
}
/*************************************************
SCROLL BAR STYLES
*************************************************/
/* Firefox */
html {
  scrollbar-color: var(--primary-colour) white;
}
/* WebKit and Chromiums */
::-webkit-scrollbar {
  width: 10px;
  background-color: white;
}
::-webkit-scrollbar-thumb {
  background: var(--primary-colour);
  border-radius: 10px;
}
/*************************************************
GLOBAL STYLES
*************************************************/
::selection {
  background: var(--primary-colour);
}
a {
	color:var(--primary-colour, #333);
}
a:hover {
	color:var(--secondary-colour, #666);
}
[type="button"]:focus, [type="button"]:hover, [type="submit"]:focus, [type="submit"]:hover, button:focus, button:hover {
	background-color:var(--primary-colour, #333);
}
.page-overlay, .mobile-menu-overlay {
	width:100%;
	height:100%;
	background-color:rgba(0,0,0,0.5);
	position:fixed;
	top:0;
	left:0;
	z-index:2;
	opacity:0;
	visibility:hidden;
    transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
    -webkit-transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
    -moz-transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
    -ms-transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
    -o-transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}
/*************************************************
HEADER STYLES
*************************************************/
#site-header {
	width:100%;
	position:relative;/*fixed for sticky*/
	top:0;
	z-index:9;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
#site-header-container {	
	max-width:1200px;
	margin:0 auto;
	display: flex;
	align-items:center;
	padding:25px;
}
.site-branding {
	line-height:0;
}
.site-branding #logo {}
.site-branding #logo img {
	height: auto;
    width: auto;
    display: block;
	max-height:100px;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
.header-section {
	margin-left:auto;
}
#site-header .site-social {
	display: flex;
	align-items:center;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
#site-header .site-social span {
	margin-right:15px;
	color:#fff;
}
#site-header .site-social ul {
	list-style-type:none;
	display: flex;
	flex-direction: row;
    flex-wrap: wrap;
	margin:0 0 0 30px;
	padding:0;
}
#site-header .site-social ul li a {
	width:35px;
	height:35px;
	margin-left:10px;
	background-color:#000000;
	display: flex;
	align-items: center;
	justify-content: center;
}
#site-header .site-social ul li i {
	color:#ffffff;
	display: flex;
	align-items: center;
}
body.menu-active .mobile-menu-overlay {
	opacity:1;
	visibility:visible;
	position:fixed;
	cursor:pointer;
}
/*************************************************
HEADER 1 STYLES
*************************************************/
.header-1 {}
.header-1 nav.site-navigation {
	float:right;
}
.header-1 .site-navigation ul.menu li a {
	color:#fff;
}
#site-header.header-1 {
	position:absolute;
}
/*************************************************
HEADER 2 STYLES
*************************************************/
.header-2 {
	background-color:#fff;
	display:flex;
	align-items:center;
}
#site-header.header-2 {
	padding:15px 50px;
}
#site-header.header-2 .site-social span {
	color:var(--primary-colour);
}
.header-2 .site-branding #logo img {
	max-height:80px;
    height: auto;
    width: auto;
    display: block;
}
.header-2 nav.site-navigation {
	margin-left:auto;
}
.header-2 nav.site-navigation .menu-main-menu-container {}

/*************************************************
BREADCRUMB STYLES
*************************************************/
#breadcrumbs {
	text-align:center;
	color:#fff;
	padding-bottom:35px;
}
#breadcrumbs .separator {
	margin:0 10px;
	height: 35px;
	font-size: 20px;
}
/*************************************************
STICKY HEADER STYLES
*************************************************/
body.sticky-active .site-branding #logo img {
	max-height:50px;
}
body.sticky-active .header-section .site-social {
	margin-top:-70px;
}
body.sticky-active #site-header {
	background-color:#fff;
}
/*************************************************
SUB HEADER STYLES
*************************************************/
#sub-header-wrapper {
	position:relative;
}
/* https://www.shapedivider.app */
.shape-divider-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}
.shape-divider-bottom svg {
    position: relative;
    display: block;
    width: calc(120% + 1.3px);
    height: 120px;
	left:50%;
	-webkit-transform:translateX(-50%);
	-ms-transform:translateX(-50%);
	transform:translateX(-50%)
}
.tilt-divider {
	-webkit-transform:rotate(180deg);
	-ms-transform:rotate(180deg);
	transform:rotate(180deg);
}
.shape-divider-bottom .shape-fill {
    fill: #FFFFFF;
}
#sub-header {
	min-height:500px;
	background-color:#ccc;
	background-image:url(../images/default-subheader.jpg);
	background-position:center;
	background-size:cover;
	overflow:hidden;
	position:relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
#sub-header:after {
	position:absolute;
	content:"";
	top:0;
	left:0;
	width:100%;
	height:100%;
	background-color:rgba(0,0,0,0.5);
}
body.home #sub-header {
	background-color:inherit;
}
header.sub-header {
	padding-top:50px;
	position:relative;
	z-index:1;
}
header.sub-header .entry-title span {
	font-size:15px;
	color:var(--secondary-colour);
	text-align:left;
	font-weight:bold;
	text-transform:uppercase;
}
header.sub-header .entry-title h1, header.sub-header .entry-title h2.page-subtitle {
	text-align:left;
	font-weight:bold;
	color:#000;
	font-size:44px;
}
header.sub-header .entry-title p.excerpt {
	text-align:center;
	color:#fff;
	font-family:var(--primary-font-family);
}
/*************************************************
FOOTER STYLES
*************************************************/
footer {
	clear:both;
}
footer a[href^="tel"], footer a[href^="mailto"] {
	color:#fff;
}
.menu a:focus {}
.sub-menu {
    display: none;
    position: absolute;
    left: 0;
    top: 100%;
    z-index: 99;
}
.menu-item-has-children > a[aria-expanded="true"] + .sub-menu {
    display: block;
}
.menu-item-has-children:hover > .sub-menu,
.menu-item-has-children:focus-within > .sub-menu {
    display: block;
}
/*************************************************
BLOG STYLES
*************************************************/
body.blog main#content .page-content,
body.archive main#content .page-content,
body.search main#content .page-content {
	display: flex;
	flex-wrap: wrap;
	padding: 0 15px;
	margin:50px 0;
}
main#content .page-content article.post {
	flex: calc(33.333% - 40px);
	max-width: calc(33.333% - 40px);
	padding: 0px;
	margin:20px;
	-webkit-box-shadow: 0 0 15px 0 rgba(0,0,0,0.2);
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.2);
	background-color:#fff;
	-webkit-border-radius: 20px 0 20px 0;
	border-radius: 20px 0 20px 0;
	overflow:hidden;
}
main#content .page-content article.post .post-date {
	margin:10px 30px;
	font-size:14px;
	display:block;
}
main#content .page-content article.post h2 {
	font-size:18px;
	font-weight:bold;
	padding: 15px 30px 0 30px;
}
main#content .page-content article.post h2 a {
	color:#000;
}
main#content .page-content article.post h2 a:hover {
	color:var(--secondary-colour);
}
main#content .page-content article.post p {
	font-size:16px;
	padding:0 30px;
}
main#content .page-content article.post a.button {
	display:block;
	font-size:16px;
	font-weight:bold;
	padding:0px 0 30px 30px;
	color:#000;
	text-decoration:none;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
main#content .page-content article.post a.button:hover {
	color:var(--secondary-colour);
}
main#content nav.pagination .nav-links {
	display:flex;
	justify-content: center;
}
main#content nav.pagination .nav-links .page-numbers {
	background-color:#eee;
	height:40px;
	width:40px;
	display:flex;
	align-items: center;
	justify-content: center;
	margin:5px;
	-webkit-border-radius: 5px 5px 5px 5px;
	border-radius: 5px 5px 5px 5px;
}
main#content nav.pagination .nav-links .page-numbers .pagination-arrow {
	color:#333;
}
main#content nav.pagination .nav-links .page-numbers.current {
	background-color:var(--primary-colour);
	color:#fff;
}
/*************************************************
BLOG STYLES - SINGLE POST
*************************************************/
body.single-post main#content {
	max-width:900px;
	margin-top:50px;
}
.post-meta {
	width:50%;
	display:inline-block;
	float:left;
	margin:50px 0;
}
.post-meta .tag-links a {
	margin-right:15px;
	position:relative;
	text-decoration:none;
	font-size:14px;
}
.post-meta .tag-links a:after {
	content:"";
	position:absolute;
	left:-8px;
	top:3px;
	width:1px;
	height:15px;
	background-color:#ddd;
}
.post-meta .tag-links a:nth-child(1):after {
	display:none;
}
.post-meta .cat-links {}
.post-meta .cat-links a {
	text-decoration:none;
	font-size:14px;
}
/*************************************************
SOCIAL SHARE - SINGLE POST
*************************************************/
.social-box {
	width:50%;
	display:inline-block;
	text-align:right;
	margin:50px 0;
}
.social-box strong {
	margin-bottom:25px;
	display:block;
}
 .social-btn {
	display: block;
}
 a.sbtn span {
     display: none;
	 margin: 0 0 0 15px;
}
 a.sbtn {
     display: inline-flex;
	 text-decoration:none;
     padding: 7px;
     color: #fff;
     margin-left: 10px;
	 font-size:24px;
}
a.sbtn:hover {
	 opacity:0.7;
}
.social-box .social-x {
     background: #000000;
}
.social-box .social-twitter {
     background: #03A9F4;
}
.social-box .social-facebook {
     background: #3F51B5;
}
.social-box .social-linkedin {
     background: #1a7baa;
}
.social-box .social-pinterest {
     background: #bd081c;
}
/*************************************************
MOBILE NAVIGATION STYLES
*************************************************/
.mobile-nav {
	margin-left:auto;
}
.mobile-nav .nav-heading {
	display:inline-block;
	vertical-align:middle;
	font-weight:bold;
	color:var(--primary-colour);
	margin-right:10px;
}

button.burger {
	padding:0;
	position:relative;
	width:50px;
	height:50px;
	z-index:12;
	border:none;
	text-align:center;
	background-color:var(--primary-colour);
	cursor:pointer;
	padding:10px;
	vertical-align:middle;
}
.burger:hover {
	background-color:var(--secondary-colour);
}
.burger span {
	width:50%;
	height:2px;
	border-radius:3px;
	background-color:#fff;
	display:block;
	margin-left:25%;
	-webkit-transition: all 0.3s ease-in-out 0.3s;
	-moz-transition: all 0.3s ease-in-out 0.3s;
	-ms-transition: all 0.3s ease-in-out 0.3s;
	-o-transition: all 0.3s ease-in-out 0.3s;
	transition: all 0.3s ease-in-out 0.3s;
}
.burger span:nth-child(3){
	margin-top:10px;
}
.burger span:nth-child(2){
	width:100%;
	margin-top:10px;
	margin-left:0;
}
body.menu-active .burger span:first-child {
	-webkit-transform: rotate(405deg);
	-moz-transform: rotate(405deg);
	-ms-transform: rotate(405deg);
	-o-transform: rotate(405deg);
	transform: rotate(405deg);
	width:100%;
	margin-left:0;
}
body.menu-active .burger span:last-child {
	-webkit-transform: rotate(-405deg);
	-moz-transform: rotate(-405deg);
	-ms-transform: rotate(-405deg);
	-o-transform: rotate(-405deg);
	transform: rotate(-405deg);
	margin-top: -15px;
	width:100%;
	margin-left:0;
}
body.menu-active .burger span:nth-child(2) {
	-webkit-transform: scale(0);
	-moz-transform: scale(0);
	-ms-transform: scale(0);
	-o-transform: scale(0);
	transform: scale(0);
}
/*************************************************
GLOBAL SITE NAVIGATION STYLES
*************************************************/
.site-navigation ul.menu li {
	display:flex;
	align-items:center;
}
.site-navigation ul.menu li > ul {
	opacity:0;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
	display:inherit;
	visibility:hidden;
}
.site-navigation ul.menu li:hover > ul {
	opacity:1;
	visibility:visible;
}
.site-navigation ul.menu li a {
	font-size:16px;
	text-transform:uppercase;
	font-weight:bold;
	color:#000;
}
.site-navigation ul.menu li a:hover {
	color:var(--primary-colour);
}
.site-navigation ul.menu li a:focus,
.site-navigation ul.menu li a:active,
.site-navigation ul.menu li a:visited {
	border:none;
	outline:none;
}
.site-navigation ul.sub-menu {
	-webkit-border-radius: 4px;
	border-radius: 4px;
	display:flex;
	flex-wrap:wrap;
	flex-flow:column;
	width: max-content; /* Allows the width to expand based on content */
	white-space: nowrap; /* Prevents text from wrapping */
}
.site-navigation ul.sub-menu.active {
	display:block;
	visibility:visible;
	opacity:1;
}
.site-navigation ul.menu li > ul.sub-menu li a {
	color:var(--primary-colour);
}
.site-navigation ul.menu li.menu-item-has-children span.toggle-submenu,
.site-navigation ul.menu li.active ul span.toggle-submenu {
	width:25px;
	height:25px;
	cursor:pointer;
	background-color:transparent;
	-webkit-transition: all 0.2s ease-in-out 0s;
	-moz-transition: all 0.2s ease-in-out 0s;
	-ms-transition: all 0.2s ease-in-out 0s;
	-o-transition: all 0.2s ease-in-out 0s;
	transition: all 0.2s ease-in-out 0s;
	display:block;
	-moz-transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
	-o-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg);
}
.menu-main-menu-container ul li.menu-item-has-children span,
.site-navigation ul.menu li.menu-item-has-children:after {
	display:none;
}
.site-navigation ul.menu li span.toggle-submenu .arrow {
    display: inline-block;
    width: 7px;
    height: 7px;
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	margin:9px 8px;
	border-right: 2px solid rgba(0,0,0,0.3);
    border-top: 2px solid rgba(0,0,0,0.3);
}

/*************************************************
PAGINATION STYLES
*************************************************/
.pagination-arrow {
  display: inline-block;
  height: 10px;
  position: relative;
  width: 10px;
}
.pagination-arrow::after {
  border-bottom-style: solid;
  border-bottom-width: 1px;
  border-right-style: solid;
  border-right-width: 1px;
  content: "";
  display: inline-block;
  height: 10px;
  left: -2px;
  position: absolute;
  top: -2px;
  width: 10px;
}
.pagination-arrow.is-right {
  -moz-transform: rotate(315deg);
  -ms-transform: rotate(315deg);
  -webkit-transform: rotate(315deg);
  transform: rotate(315deg);
}
.pagination-arrow.is-left {
  -moz-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
/*************************************************
404 PAGE STYLES
*************************************************/
body.error404 .page-content {
	margin:50px 0;
}
body.error404 .page-content p {
	text-align:center;
}
/*************************************************
WordPress Default Gallery Grid
*************************************************/
.gallery {
  display: grid;
  gap: 10px;
  margin: 2em 0;
}
.gallery-columns-1 { grid-template-columns: repeat(1, 1fr); }
.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }
.gallery-columns-5 { grid-template-columns: repeat(5, 1fr); }
.gallery-columns-6 { grid-template-columns: repeat(6, 1fr); }
.gallery-columns-7 { grid-template-columns: repeat(7, 1fr); }
.gallery-columns-8 { grid-template-columns: repeat(8, 1fr); }
.gallery-columns-9 { grid-template-columns: repeat(9, 1fr); }
.gallery-item {
  overflow: hidden;
  border-radius: 6px;
  position: relative;
}
.gallery-icon img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.3s ease, opacity 0.3s ease;
  border-radius: 6px;
}
.gallery-icon img:hover {
  transform: scale(1.05);
  opacity: 0.9;
}
/* Optional: caption styling */
.gallery-caption {
  font-size: 0.85em;
  text-align: center;
  margin-top: 5px;
  color: #666;
}
/* Responsive: collapse to fewer columns on small screens */
@media (max-width: 768px) {
  .gallery {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  .gallery {
    grid-template-columns: repeat(1, 1fr) !important;
  }
}