/* @override 
	https://www.tentoten.co.uk/clients/david-drennan/wp-content/themes/tentoten/style.css?*
	http://www.tentoten.co.uk/clients/david-drennan/wp-content/themes/tentoten/style.css?* */

/*

Theme Name: Ten to Ten V2
Theme URI: https://www.tentoten.co.uk
Description: A Theme Framework
Author: Dare to Think
Author URI: https://www.daretothink.co.uk
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-X.X.html
Version: 1.2
Tags: one-column, two-columns, grid-layout, featured-images
Text Domain: tentoten

*/

/* Table of Contents
 *
 * 1.0 - Reset
 * X.X - Repeatable Patterns
 * 3.0 - Basic Structure
 * 4.0 - Header
 * 4.0 - Sidebar
 *   7.1 - Widgets
 *   7.2 - Content Sidebar Widgets
 * 4.0 - Footer 
 * 5.0 - Navigation
 * 6.0 - Content
 *   6.1 - Post Thumbnail
 *   6.2 - Entry Header
 *   6.3 - Entry Meta
 *   6.4 - Entry Content
 *   6.5 - Galleries
 *   6.6 - Post Formats
 *   6.7 - Post/Image/Paging Navigation
 *   6.8 - Attachments
 *   6.9 - Archives
 *   6.10 - Contributor Page
 *   6.11 - 404 Page
 *   6.12 - Full-width
 *   6.13 - Singular
 *   6.14 - Comments
 * 8.0 - Footer
 * 9.0 - Featured Content
 * 10.0 - Multisite
 * 11.0 - Media Queries
 * 1X.X - Print
 * -----------------------------------------------------------------------------
 */

/* ------------ X.X CSS Reset
 *
 * Resetting and rebuilding styles have been helped along thanks to the fine
 * work of Eric Meyer, Nicolas Gallagher, Jonathan Neal, and Blueprint.
 *
 * -----------------------------------------------------------------------------
 */

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, font, 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 { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: transparent; } body { line-height: 1; } ol, ul { list-style: none; } blockquote, q { quotes: none; } blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; } :focus { outline: 0; } ins { text-decoration: none; } del { text-decoration: line-through; } table { border-collapse: collapse; border-spacing: 0; }

.cf:before,
.cf:after {
	content: " ";
    display: table;
}

.cf:after {
	clear: both;
}

* {
	box-sizing: border-box;
}

*:before,
*:after {
	box-sizing: border-box;
}

/* ------------ X.X Basic Structure
 * -----------------------------------------------------------------------------
 */

html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;}

html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}

body,html {
	width: 100%;
	height: 100%;
}

html body {
	display: flex;
	flex-direction: column;
}

html #container {
	flex: 1 0 auto;
}

body,
input,
textarea {
	font: 62.5% "Source Serif 4", serif;
	background: #fff;
	color: #444;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body {
	background: #fff url('images/site-bg.png') no-repeat left top;
	background-size: 100% auto;
	background-attachment: fixed;
}

.hidden { 
	display: none; 
}

.alignleft { 
	float: left; 
}

.alignright { 
	float: right; 
}

.aligncenter {
	margin-left: auto;
	margin-right: auto;
	display: block;
	clear: both;
}

.clear {
	clear: both;
	display: block;
	font-size: 0;
	height: 0;
	line-height: 0;
	width:100%;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}

.padt1 {
	padding-top: 50px;
}

.padb1 {
	padding-bottom: 50px;
}

.padtb1 {
	padding: 50px 0;
}

.wrapper.sz1 {
	margin: auto;
	max-width: 1024px;
}

.pagesize-1,
.post-wrapper.st1 {
	width: 100%;
	max-width: 1024px;
	margin: auto;
}

/* ------------ X.X Grid
 * -----------------------------------------------------------------------------
 */

.c_12 {
	max-width: 1600px;
	padding-right: 20px;
	padding-left: 20px;
	margin-left: auto;
	margin-right: auto;
}

.g_1,.g_2,.g_3,.g_4,.g_5,.g_6,.g_7,.g_8,.g_9,.g_10,.g_11,.g_12 {
	display: inline;
	float: left;
	padding-right: 20px;
	padding-left: 20px;
	position: relative;
}

.negative {
	margin-left: -20px;
	margin-right: -20px;
}

.c_12 .g_1 {width: 8.25252525252533%;}
.c_12 .g_2 {width: 16.6666667%;}
.c_12 .g_3 {width: 25%;}
.c_12 .g_4 {width: 33.2525252525253%;}
.c_12 .g_5 {width: 41.6666667%;}
.c_12 .g_6 {width: 50%;}
.c_12 .g_7 {width: 58.2525252525253%;}
.c_12 .g_8 {width: 66.6666666%;}
.c_12 .g_9 {width: 75%;}
.c_12 .g_10 {width: 83.2525252525253%;}
.c_12 .g_11 {width: 91.6666666%;}
.c_12 .g_12 {width: 100%;}

/* ------------ X.X Fonts
 * -----------------------------------------------------------------------------
 */


p {
	font-size: 1.125rem;
	line-height: 1.5;
}

li {font-size: 1.125rem}

li p {
	font-size: 1.125rem
}

li li {font-size: 1.125rem}

h1 {
	font-size: 2.8rem;
}

h2 {
	font-size: 2.4rem;
}

h3 {
	font-size: 2rem;
}

h4 {
	font-size: 1.6rem;
}

.title.st1 {
	font-weight: 500;
}

.title.sz1 {
	font-size: clamp(1.75rem, 5vw, 2rem);
	line-height: 1.2;
}

.title.sz2 {
	font-size: clamp(1.5rem, 5vw, 1.5rem);
	line-height: 1.2;
	text-wrap: pretty;
}

.title.sz3 {
	font-size: clamp(1.25rem, 5vw, 1.5rem);
	line-height: 1.2;
}

.btn.st1 {
	display: inline-block;
	border-radius: 100px;
	border-style: solid;
	border-width: 2px;
	text-decoration: none;
	line-height: 1;
	font-family: "Nunito Sans", sans-serif;
}

.btn.sz1 {
	padding: 10px 20px;
	font-size: 1rem;
	font-weight: 700;
}

.btn.cl1 {
	background: #fff;
	border-color: #FF9547;
	color: inherit;
}

.btn.cl1:hover {
	background: #FF9547;
	border-color: #FF9547;
	color: #fff;
	cursor: pointer;
}

.wp-block-button.is-style-bespoke .wp-block-button__link {
	font-family: "Nunito Sans", sans-serif;
    display: inline-block;
	border-radius: 100px;
	border-style: solid;
	border-width: 2px;
	text-decoration: none;
	line-height: 1;
	padding: 10px 20px;
	font-size: 1rem;
	font-weight: 700;
	background: #fff;
	border-color: #FF9547;
	color: inherit;
}

.wp-block-button.is-style-bespoke .wp-block-button__link:hover {
	background: #FF9547;
	border-color: #FF9547;
	color: #fff;
	cursor: pointer;
}


/* ------------ X.X Content Styles
 * -----------------------------------------------------------------------------
 */

.wp-caption {
	
}

.wp-caption-text {
	
}

.gallery-caption {
	
}

.bypostauthor {
	
}

.sticky {
	
}

.title-section.v1 .wrapper {
	padding: 50px 0;
	position: relative;
	border-bottom: 2px solid #ff9547;
}

.title-section.v1.st2 .wrapper {
	border: none;
}

.title-section.v1 div.title {
	width: 33.3333%;
	display: inline;
	float: left;
	padding-right: 20px;
}

.title-section.v1 div.intro {
	width: 66.6666%;
	display: inline;
	float: left;
	padding-left: 20px;
}

/* ------------ X.X Main Content Areas
 * -----------------------------------------------------------------------------
 */
 
.entry-content a {
	color: #ff9547;
	font-weight: 600;
}

.entry-content strong {
	font-weight: 600;
}

.entry-content p {
	margin-bottom: 20px;
}

.entry-content .wp-block-gallery a {
	border: none;
}

.entry-content p,
.entry-content li,
.entry-content table {
	font-size: 1.125rem;
}

.entry-content hr {
	border: none;
	margin: 25px 0;
}

.entry-content hr {
	height: 2px;
	background-color: #ccc;
	width: 100%;
	display: inline-block;
	border: none;
}

.entry-content hr.sep.st1 {
	height: 1px;
	background-color: #ff6ad2;
	width: 100%;
	display: inline-block;
	border: none;
	margin: 25px 0;
}

.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	line-height: 1.2;
	margin-bottom: 15px;
	margin-top: 30px;
	font-weight: 500;
}

div > h2:first-child {
  margin-top: 0;
}

h1.page-title {
	text-wrap: pretty;
}

.entry-content div > h1:first-child {
	margin-top: 0;
}

.entry-content h2 {
	font-size: 1.5rem;
}

.entry-content h3 {
	font-size: 1.375rem;
}

.entry-content h4 {
	font-size: 1.25rem;
}

.entry-content h5 {
	font-size: 1.125rem;
}

.entry-content h6 {
	font-size: 1rem;
}

.entry-content p:last-child {
	margin-bottom: 0;
}

.entry-content ol,
.entry-content ul {
	margin-bottom: 20px;
	margin-top: 10px;
}

.entry-content ol li {
	list-style-type: decimal;
	margin-left: 30px;
	line-height: 1.5;
	margin-bottom: 20px;
}


.entry-content ul li {
	list-style-type: circle;
	margin-left: 20px;
	line-height: 1.5;
	margin-bottom: 5px;
}

.entry-content ul li ul,
.entry-content ol li ol {
	margin-top: 5px;
	margin-bottom: 0;
}

.entry-content img {
	max-width: 100%;
	height: auto;
	display: block;
}

.entry-content blockquote {
	margin-bottom: 25px;
}

.entry-content blockquote cite {
	display: block;
	margin-top: -10px !important;
	font-size: 0.875rem;
	color: #555;
}

.entry-content blockquote cite:before {
	content: "- ";
}

.entry-content table {
	border-bottom: 1px solid #efebe8;
	font-size: 1rem;
	line-height: 2;
	margin: 0 0 24px;
	margin: 0 0 1.714285714rem;
	width: 100%;
}
.entry-content table caption {
	font-size: 1rem;
	margin: 24px 0;
	margin: 1.714285714rem 0;
}
.entry-content td,
.entry-content th {
	border-top: 1px solid #efebe8;
	padding: 6px 10px 6px 0;
}

.entry-content caption,
.entry-content th,
.entry-content td {
	font-weight: normal;
	text-align: left;
	line-height: 1.5;
}

.entry-content pre {
	font-size: 1rem;
}

.entry-content .wp-block-button.is-style-cta-button {
	margin-right: 10px;
}

.entry-content .is-style-cta-button a.wp-block-button__link {
	text-align: center;
	font-weight: 600;
	display: inline-block;
	-webkit-appearance: none;
	border-radius: 0;
	background-color: #f55c3d;
	color: #fff;
	border: 1px solid #f55c3d;
	font-size: 1rem;
	padding: 8px 20px;
	width: 100%;
	margin-bottom: 5px;
}

.entry-content .is-style-cta-button a.wp-block-button__link:hover {
	cursor: pointer;
	background-color: #fff;
	color: #f55c3d;
}

/* Media ------------------------------------- */

figure {
	display: block;
	margin: 0;
}

iframe {
	display: block;
	max-width: 100%;
}

video {
	display: block;
}

svg,
img,
embed,
object {
	display: block;
	height: auto;
	max-width: 100%;
}

figcaption,
.wp-caption-text {
	color: #6d6d6d;
	display: block;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.2;
	margin-top: 1.5rem;
}

/* ------------ X.X Images
 * -----------------------------------------------------------------------------
 */


.size-auto, 
.size-full,
.size-large,
.size-medium,
.size-thumbnail {
	max-width: 100%;
	height: auto;
}

.wp-block-image {
	margin-bottom: 20px;
}

.single-book .wp-block-image {
	margin-bottom: 50px;
}

/* ------------ X.X Header
 * -----------------------------------------------------------------------------
 */
 
header#site-header {
	width: 100%;
	z-index: 999;
	height: 100px;
	transition: opacity 0.4s ease;
	opacity: 1;
}

body.nav-up header#site-header {
	opacity: 0;
	pointer-events: none;
}

body.nav-down header#site-header {
	opacity: 1;
}

body.home header {
	box-shadow: none;
}

header #site-nav {
	border-bottom: 2px solid #ff9547;
	height: 100px;
}

/* Main navigation styling with Flexbox */
nav.main ul {
    display: flex;
    justify-content: flex-end; /* Align items to the right */
    list-style: none;
    margin: 0;
    padding: 0;
}

nav.main li {
    position: relative;
    font-size: 1.25rem;
	font-weight: 500;
}

nav.main li a {
    display: inline-block;
    padding: 50px 15px 20px;
    color: inherit;
    text-decoration: none;
}

nav.main li:last-child a {
	padding-right: 0;
}

nav.main li:hover > a {
	color: #F18041;
}

/* Submenu styling */
nav.main ul li.menu-item-has-children > ul {
    position: absolute;
    top: 100%; /* Position the submenu directly below the parent */
    left: 0;
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s ease-in-out;
    z-index: 2;
    margin-top: -1px;
    box-shadow: 0 2px 2px rgba(0,0,0,.5);
    padding: 10px 0;
    flex-direction: column; /* Stack submenu items vertically */
	border-top: 0;
	background: #FFCD52;
	border-radius: 0 0 4px 4px;
}

nav.main ul li.menu-item-has-children > ul a {
	color: #333;
}

nav.main ul li.menu-item-has-children > ul.sub-menu:before {
    display: block;
    position: absolute;
    top: -7px;
    left: 30px;
    border-bottom: 8px solid #FFCD52;
    border-left: 8px dashed transparent;
    border-right: 8px dashed transparent;
    content: ''
}

nav.main ul li.cat-money > ul.sub-menu:before {
	border-bottom-color: var(--brand-money);
}

nav.main ul li.cat-health > ul.sub-menu:before {
	border-bottom-color: var(--brand-health);
}

nav.main ul li.cat-community > ul.sub-menu:before {
	border-bottom-color: var(--brand-community);
}

nav.main ul li.cat-purpose > ul.sub-menu:before {
	border-bottom-color: var(--brand-purpose);
}

body.smaller nav.main ul li.menu-item-has-children > ul.sub-menu:before {
    border-bottom: 8px solid #FFCD52;
}

nav.main ul li.menu-item-has-children > ul ul {
	opacity: 1;
}

nav.main ul li.menu-item-has-children:hover > ul,
nav.main ul li.menu-item-has-children > ul[aria-expanded="true"] {
    opacity: 1;
    pointer-events: all;
    display: flex; /* Show the dropdown on hover */
}

nav.main ul ul li {
    display: block; /* Ensure submenu items are block-level */
}

nav.main ul ul li a {
    font-size: 1rem;
    line-height: 1.5;
    padding: 5px 20px;
    width: 220px;
    height: auto;
    color: #333;
    text-decoration: none;
}

nav.main ul ul li a:hover span {
	text-decoration: underline;
}

nav.main ul li.menu-item-has-children > ul ul {
    margin: 0;
    position: relative;
    border: 0;
    box-shadow: none;
    padding: 0;
}

nav.main ul li.menu-item-has-children > ul li li a {
    font-size: .875rem;
}

nav.main ul li.menu-item-has-children > ul ul li a:before {
    content: "- ";
}

nav.main li.menu-item-has-children ul a:after {
    content: "";
}

nav.main li.menu-item-has-children ul a {
    padding-right: 15px;
}

/* Accessibility improvements */
nav.main li.menu-item-has-children > a {
    aria-haspopup: true;
    aria-expanded: false;
}

nav.main li.menu-item-has-children:hover > a,
nav.main li.menu-item-has-children > a:focus {
    aria-expanded: true;
}

/* Optional: Style changes for open/close state if needed */
nav.main li.menu-item-has-children > a[aria-expanded="true"]:after {
    content: '\e902'; /* Assuming this is the open dropdown icon */
}
 
a#branding {
	float: left;
	font-size: 2.25rem;
	font-weight: 500;
	text-decoration: none;
	display: inline-block;
	margin-top: 23px;
	color: inherit;
	position: relative;
	overflow: hidden;
	transition: all 0.2s ease-in-out;
	line-height: 1;
}

a#branding span {
	display: block;
	font-size: 1.25rem;
}

a#branding:hover {
	transform: scale(1.1);
	cursor: pointer;
}

.toggle-nav {
    position: absolute;
    bottom: 20px;
    right: 20px;
    cursor: pointer;
	display: none;
}

.nav-icon {
    width: 28px;
    height: 28px;
    position: relative;
    transition: transform 0.5s ease;
}

.nav-icon span {
    display: block;
    height: 2px;
    width: 100%;
    background: #333;
    transition: all 0.25s ease;
}

body.home.smaller .nav-icon span {
	background: #333;
}

body .nav-icon span:nth-child(1) {
    transform: translate(0, 3px); /* Adjusted translate values */
}

body .nav-icon span:nth-child(2) {
    transform: translate(0, 11px); /* Adjusted translate values */
}

body .nav-icon span:nth-child(3) {
    transform: translate(0, 19px); /* Adjusted translate values */
}

body.nav-open .nav-icon span:nth-child(1) {
    transform: rotate(45deg) translate(9px, 9px); /* Adjusted translate values */
}

body.nav-open .nav-icon span:nth-child(2) {
    opacity: 0;
    width: 0;
}

body.nav-open .nav-icon span:nth-child(3) {
    transform: rotate(-45deg) translate(-6px, 7px); /* Adjusted translate values */
}

#container:before {
    display: block;
    content: "";
    width: 100%;
    height: 0;
    position: fixed;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, .4);
    opacity: 0;
    z-index: 100;
    -webkit-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: opacity 300ms ease, height 1ms 300ms ease
}

#sidemenu {
	width: 100%;
	height: 100%;
	background: #fff;
	position: fixed;
	top: 0;
	right: -100%;
	z-index: 998;
	overflow-y: scroll;
	padding: 130px 20px 20px;
	transition: all 0.2s ease-in-out;
	box-shadow: 0 0px 2px rgba(0,0,0,.2);
}

#sidemenu form {
	margin: 0 0 20px;
}

#sidemenu nav.side li a {
	color: #333;
	padding: 5px 0;
	display: block;
	line-height: 1;
}

#sidemenu nav.side li a:hover {
	color: #d99186;
}

#sidemenu nav.side > ul > li {
	margin-bottom: 10px;
	font-weight: 600;	
	font-size: 1rem;	
}

#sidemenu nav.side > ul > li > ul > li {
	text-transform: none;
	font-weight: 300;
	
}

#sidemenu nav.side > ul > li > ul > li a::before {
	content: "- ";
}

#sidemenu nav.side > ul > li > ul > li > ul > li a::before {
	content: "- ";
}

#sidemenu nav.side > ul > li > ul > li > ul > li a {
	font-size: .875rem;
}

#home-feature {
	margin-top: 50px;
}

#home-feature .wrapper {
	padding-top: 500px;
	position: relative;
	background-color: #1d828a;
	border-radius: 6px;
	overflow: hidden;
	background: url('images/O4YIQ31.svg') no-repeat center;
	background-size: cover;
}

#home-feature .profile-pic {
	position: absolute;
	right: 0;
	bottom: 0;
	height: 460px;
}

#home-feature .centered-content {
	position: absolute;
	bottom: 0;
	left: 0;
	max-width: 50%;
	padding: 0 0 40px 50px;
	color: #fff;
}

#home-feature .title {
	font-size: clamp(3rem, 5vw, 3.5rem);
	font-weight: 700;
	line-height: 1.1;
}

#home-feature .bg-image {
    height: 100%;
    width: 100%;
    background-size: cover;
	overflow: hidden;
}

.home-books .cta {
	border-bottom: 2px solid #ff9547;
	padding: 50px 0;
	text-align: center;
}

.home-articles .cta {
	text-align: center;
}

.home-books li {
	padding: 5px;
}

.home-books img {
	box-shadow: 0 0 5px rgba(0,0,0,.5);
}

/* ------------ X.X Footer
 * -----------------------------------------------------------------------------
 */
 
footer#site-footer {
	margin-top: 50px;
}

footer#site-footer .wrapper {
	border-top: 2px solid #ff9547;
	padding: 10px 0;
}

footer#site-footer a {
	text-decoration: none;
	color: inherit;
}

.site-links {
	float: left;
}

footer .site-links li {
	list-style-type: none;
	display: inline-block;
	font-size: .875rem;
}

footer .site-links li:after {
	content: "/";
	margin-right: 10px;
	margin-left: 10px;
}

footer .site-links li:last-child:after {
	margin-right: 0;
	content: "";
}

.site-name {
	float: right;
	font-size: .875rem;
}

.featured-in-ctn {
	border-top: 2px solid #ff9547;
	padding: 50px 0;
}

.page-id-77 .featured-in-ctn {
	display: none;
}

.featured-in-ctn .title {
	text-align: center;
	margin-bottom: 25px;
}

.featured-in-wrapper {
	background: #f1f0ef;
	padding: 25px 0 10px;
}

.featured-in-ctn ul li {
	text-align: center;
}

.featured-in-ctn ul li img {
	height: 100px;
	width: auto !important;
	display: block;
	margin: auto;
}

/* ------------ X.X Post styling
 * -----------------------------------------------------------------------------
 */
 
.post-list a {
	text-decoration: none;
}

.post-list.v1 .post {
	width: 33.3333%;
	display: flex;
	margin: 0;
}

.post-list.owl-carousel .post {
	padding: 0 !important;
	width: 100% !important;
}

.post-list.v1 .post .block {
	position: relative;
	margin-bottom: 20px;
	width: 100%;
	padding: 20px;
	border-radius: 6px;
	transition: all 0.2s ease-in-out;
}

.post-list.v1 .post a.block:hover {
	background: rgba(255,255,255,.75);
	box-shadow: 0 0 10px rgba(0,0,0,.1);
}

.post-list.owl-carousel .post .block {
	margin-bottom: 0;
}

.post-list.v1 .title {
	margin-bottom: 10px;
	transition: all 0.2s ease-in-out;
	text-wrap: balance;
}

.post-list.v1 li:hover .title {
	color: #ff9547;
}

.post-list.v1 .category-titles {
	margin-top: 10px;
}

a.category-title {
	text-transform: uppercase;
	color: #fff;
	font-size: 0.75rem;
	padding: 0 12px;	
	line-height: 20px;
	font-weight: 600;
	background: #007C77;
	margin: 0px 2px 2px 0;
	display: inline-block;
	border-radius: 100px;
	text-align: center;
	color: #fff !important;
	text-decoration: none;
}

.category-title:hover {
	transform: scale(1.1);
}

.post-list.v1 .entry-meta {
	font-size: .75rem;
	margin-bottom: 15px;
	margin-top: -5px;
}

.post-list.v1 {
	font-size: 0;
	display: flex;
	flex-wrap: wrap;
}

.archive .post-list.v1,
.category .post-list.v1,
.search .post-list.v1 {
	margin-top: 0;
}

.post-list.v1 a {
	color: inherit;
}

#client-list {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
	text-align: center;
}

#client-list li {
	background: #fff;
	padding: 20px;
	border-radius: 6px;
	border: 1px solid #ccc;
	
	display: flex;                /* NEW — make each box a flex container */
	flex-direction: column;       /* stack image + title vertically */
	justify-content: space-between; /* push title to bottom */
	align-items: center;          /* keep image/title centred */
}


#client-list li img {
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 auto 0.5rem;
}

.client-title {
	font-size: clamp(.875rem, 5vw, 1rem);
	line-height: 1.2;
	font-weight: 500;
}

@media (max-width: 1024px) {
  #client-list {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 768px) {
  #client-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  #client-list {
    grid-template-columns: repeat(1, 1fr);
  }
}

/* ------------ X.X Books
 * -----------------------------------------------------------------------------
 */
 
.books-archive {
	margin: auto;
	max-width: 1280px;
	padding: 50px 0;
}

.books-archive .book {
	padding: 50px 0;
}

.books-archive .book:first-child {
	padding-top: 0;
}

.books-archive .book:last-child {
	padding-bottom: 0;
}

.books-archive img {
	width: 100%;
	max-width: 260px;
	box-shadow: 0 15px 15px rgba(0,0,0,.5);
}

.books-archive .title {
	margin-bottom: 15px;
}

.books-archive .btn {
	margin-top: 20px;
	width: 200px;
	text-align: center;
}

/* ------------ X.X Page Styles
 * -----------------------------------------------------------------------------
 */



.header-section.v2 .title-block {
	padding: 50px 0 0;
}

.header-section.v2 .title a {
	color: inherit;
}

.header-section.v2 .category-description {
	padding-top: 25px;
}

.page-intro.st1 {
	padding: 50px 0;
}

.page-intro {
	border-bottom: 2px solid #ff9547;
	padding-bottom: 25px;
	margin-bottom: 25px;
}

.single-book .page-intro {
	border: none;
}

.page-intro .title {
	margin-bottom: 25px;
}

#article-footer {
	border-top: 2px solid #ff9547;
	font-size: 1rem;
	padding: 25px 0;
	margin-top: 25px;
}

#article-footer #entry-meta {
	float: left;
}

#article-footer #article-categories {
	float: right;
}

/* Contact */

.contact-mn.st2 {
	padding: 25px;
	background: #fff;
	border-radius: 6px;
	border: 1px solid #ccc;
}

.contact-mn ::-webkit-input-placeholder { /* Chrome/Opera/Safari */
  color: #232528;
}
.contact-mn ::-moz-placeholder { /* Firefox 19+ */
  color: #232528;
}
.contact-mn :-ms-input-placeholder { /* IE 10+ */
  color: #232528;
}
.contact-mn :-moz-placeholder { /* Firefox 18- */
  color: #232528;
}

.contact-mn .row {
	margin-bottom: 20px;
}

.contact-mn .row:last-child {
	margin-bottom: 0;
}

.contact-mn .row.half {
	width: 50%;
	padding: 0 0.625rem;
}

.contact-mn .row.full {
	margin-left: 10px;
	margin-right: 10px;	
}

.contact-mn input[type="text"],
.contact-mn input[type="email"],
.contact-mn.st2 select,
.contact-mn textarea {
	background: transparent;
	border: 1px solid #ccc;
	padding: 10px;
	border-radius: 4px;
	width: 100%;
	background: #fff;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	font-size: 1.125rem;
	margin-bottom: 20px;
}

.contact-mn.st2 select {
	font-family: "Geologica", sans-serif;
	appearance: none; /* Remove default arrow */
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 100%;
	background-color: #fff;
	background-image: url('data:image/svg+xml;charset=UTF-8,<svg width="12" height="8" viewBox="0 0 12 8" xmlns="http://www.w3.org/2000/svg"><path fill="%23003040" d="M1.41 0L6 4.58 10.59 0 12 1.41 6 7.41 0 1.41z"/></svg>');
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px 8px;
	cursor: pointer;
	font-weight: 300;
	color: #333;
}

.contact-mn ::-webkit-input-placeholder { /* Chrome/Opera/Safari */
  color: #3a3a3a;
}
.contact-mn ::-moz-placeholder { /* Firefox 19+ */
  color: #3a3a3a;
}
.contact-mn :-ms-input-placeholder { /* IE 10+ */
  color: #3a3a3a;
}
.contact-mn :-moz-placeholder { /* Firefox 18- */
  color: #3a3a3a;
}

.contact-mn textarea {
	margin-top: 2px;
}

.contact-mn input[type="text"]:focus,
.contact-mn input[type="email"]:focus,
.contact-mn textarea:focus,
.contact-mn select:focus {
	border-color: #2d9e9b;
	border-bottom-style: solid;
}

.contact-mn input.wpcf7-not-valid,
.contact-mn textarea.wpcf7-not-valid,
.contact-mn select.wpcf7-not-valid {
	border-color: red;
}

.contact-mn input[type="submit"] {
	-webkit-appearance: none;
}

.contact-mn textarea {
	width: 100%;
	height: 160px;
}

.contact-mn span.wpcf7-not-valid-tip {
	display: none !important;
}

.contact-mn .odd,
.contact-mn .even {
	float: left;
}

.contact-mn input[type="checkbox"],
.contact-mn input[type="checkbox"]:focus {
	-webkit-transform: scale(2);
	  -moz-transform: scale(2);
	  -ms-transform: scale(2);
	  -o-transform: scale(2);
	  transform: scale(2);
		display: inline-block;
	margin: 0 10px 0 5px;
} 

.contact-mn .cbox span {
	vertical-align: -4px;
}

span.wpcf7-list-item,
span.wpcf7-list-item input { 
	display: inline-block;
	width: auto;
}

span.wpcf7-list-item {
	margin: 5px 10px 10px 0!important;
}

div.wpcf7-response-output {
	display: block !important;
	clear: both;
	font-size: 1rem;
	border: none!important;
	margin: 0 !important;
	text-align: center;
	margin-top: 20px !important;
	font-weight: 600;
	padding: 0 !important;
}

form#contact-form.invalid div.wpcf7-response-output {
	padding: 0 20px 20px 60px !important;
}

div.wpcf7-validation-errors {
	color: #f33;
}

/*
 * Default jvFloat theme.
 * modify it as you wish!
 */

.jvFloat {
	position: relative;
	display: inline-block;
	width: 100%;
}

.jvFloat .placeHolder.required {
	color: #f33;
}

/* Start CSS3 Animations on supported browser */
.jvFloat .placeHolder {
	position: absolute;
	top: 5px;
	background: #ff9547;
	color: #fff;
	padding: 3px 7px;
	border-radius: 20px;
	left: 10px;
	line-height: 1;
	width: auto;
	font-size: 0.875rem;
	-webkit-transform: translate(0, 0);
	-moz-transform: translate(0, 0);
	-o-transform: translate(0, 0);
	-ms-transform: translate(0, 0);
	transform: translate(0, 0);
	transition:0.2s ease all; 
	-moz-transition:0.2s ease all; 
	-webkit-transition:0.2s ease all;
	opacity: 0;
	visibility: hidden;
	white-space: nowrap;
}

/*Allows textarea floating placeholder to be positioned distinctly from the normal .placeHolder class
 * This is required when working with Multiline text areas
 */
.jvFloat .placeHolder.textarea {
	/*top: 0px;*/
}

.jvFloat .placeHolder.active {
	display: block;
	visibility: visible;
	-webkit-transform: translate(0, -1em);
	-moz-transform: translate(0, -1em);
	-o-transform: translate(0, -1em);
	-ms-transform: translate(0, -1em);
	transform: translate(0, -1em);
	-webkit-transition: -webkit-transform 100ms, opacity 120ms, visibility 120ms;
	transition: transform 100ms, opacity 120ms, visibility 120ms;
	opacity: 1;
}
/* End CSS3 */

.wcc-category-list-body {
	margin-top: 20px;
}

body .wcc-preference-btn {
	text-decoration: none !important;
	margin-bottom: 20px;
	color: #fff !important;
	font-weight: 600 !important;
	background: #f79c06 !important;
	border-radius: 100px;
	font-size: .875rem;
	padding: 10px 25px;
	display: inline-block;
}

.book-meta p {
	margin: 0;
}

.entry-content .wp-block-pullquote {
    position: relative;
    font-family: "Nunito Sans", sans-serif;
    font-size: 1.3rem;
    line-height: 1.6;
    font-weight: 500;
    padding: 2rem 2.5rem;
    margin: 2.5rem 0;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.05);
	text-wrap: pretty;
}

.entry-content .wp-block-pullquote blockquote {
    margin: 0;
    padding: 0;
    position: relative;
}

.entry-content .wp-block-pullquote blockquote::before {
    content: "“";
    position: absolute;
    top: -10px;
    left: -20px;
    font-size: 5rem;
    opacity: 0.15;
    line-height: 1;
    font-weight: 700;
    font-family: Georgia, serif;
}

.entry-content .wp-block-pullquote cite {
    display: block;
    margin-top: 1rem;
    font-size: 1rem;
    font-weight: 600;
}

/* Table layout */
.audit-table {
    width: 100%;
    border-collapse: collapse;
    text-align: center;
    font-weight: 400;
}

.audit-table th,
.audit-table td {
    border: 1px solid #ddd;
    padding: 10px;
    vertical-align: middle;
    text-align: center;
}

.audit-table th {
    font-weight: 600 !important;
}

.audit-table .ladder-title {
    font-weight: 600;
    text-align: center;
}

/* Hide real radio, style as tick checkbox */
.audit-table input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 24px;
    height: 24px;
    border: 2px solid #999;
    border-radius: 4px;
    cursor: pointer;

    /* ⭐ Fix centering */
    display: block;
    margin: 0 auto;
    position: relative;
    outline: none;
}

/* Tick when selected */
.audit-table input[type="radio"]:checked::after {
    content: "✓";
    font-size: 22px;
    color: #f79c06;
    position: absolute;
    left: 50%;
    top: 13px;
    transform: translate(-50%, -58%);
    font-weight: 700;
	font-family: "Nunito Sans", sans-serif;
}

/* ------------ X.X Media Queries
 * -----------------------------------------------------------------------------
 */


@media only screen and (max-width: 1600px) {

}

@media only screen and (max-width: 1440px) {

}

@media only screen and (max-width: 840px) {

nav.main {
	display: none;
}

.toggle-nav {
	display: block;
}

.nav-open #container:before {
    transition: opacity 300ms ease;
    height: 100%;
    opacity: 1
}


body.nav-open #sidemenu {
	width: 320px;
	right: 0;
	-webkit-overflow-scrolling: touch;
}

body.nav-open {
	overflow: hidden;
}

}

@media only screen and (max-width: 960px) {

.c_12 {
	padding-right: 10px;
	padding-left: 10px;
}

.g_1,.g_2,.g_3,.g_4,.g_5,.g_6,.g_7,.g_8,.g_9,.g_10,.g_11,.g_12 {
	padding-right: 10px;
	padding-left: 10px;
}

.negative {
	margin-left: -10px;
	margin-right: -10px;
}

.post-list.v1 .post {
	width: 50%;
}

.home-articles .post-list.v1 .post {
	width: 100%;
}

.title-section.v1 .wrapper {
	padding: 25px 0;
}

.title-section.v1 div.title {
	padding: 0;
	margin-bottom: 20px;
}

.title-section.v1 div.intro {
	padding: 0;
}

.flexible-col {
	width: 100% !important;
}

#client-list li {
	padding: 10px;
}

.post-list.v1 .post .block {
	padding: 10px;
}

}

@media only screen and (max-width: 840px) {

}

@media only screen and (max-width: 600px) {

.post-list.v1 .post {
	width: 100%;
}

}

@media only screen and (max-width: 480px) {

}

/* ------------ X.X Print
 * -----------------------------------------------------------------------------
 */


@media print {
	
}