/*
Theme Name: Mindset2026
Description: Custom WordPress theme built on BlankSlate framework with ACF page builder functionality, responsive design, and modern features.
Author: Web Solutions IOM
Author URI: https://www.websolutions.im
Version: 1.0
Requires at least: 5.2
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: mindset2026
Tags: custom-menu, featured-images, threaded-comments, translation-ready, page-builder
*/

/* ========================================
   CSS CUSTOM PROPERTIES FOR CBT THERAPY WEBSITE
   ======================================== */
:root {
  /* Primary Brand Colors - From Growth Mindset Logo */
  --color-primary: #3a9db5; /* Growth Teal */
  --color-primary-dark: #2e7a8a; /* Deep Teal */
  --color-primary-light: #5bb3c4; /* Lighter Teal */

  /* Secondary Colors - Therapeutic Greens */
  --color-secondary: #7db843; /* Mind Tree Green */
  --color-secondary-dark: #5a9030; /* Darker Green */
  --color-secondary-light: #9ac93c; /* BABCP Green */
  --color-accent: #7bb3b0; /* Soft Teal */

  /* Text Colors - Professional & Readable */
  --color-text-primary: #2d2d2d; /* Dark Charcoal */
  --color-text-secondary: #4a4a4a; /* Medium Grey */
  --color-text-light: #666666; /* Light Grey */
  --color-text-muted: #8ba3b5; /* Dusty Blue */
  --color-text-white: #ffffff;
  --color-text-pale: #d5e7fa;

  /* Background Colors - Calm & Clean */
  --color-bg-primary: #fafaf9; /* Warm White */
  --color-bg-secondary: #f2e9d8; /* Warm Beige */
  --color-bg-light: #f5f5f5; /* Light Grey */
  --color-bg-dark: #2e7a8a; /* Deep Teal */
  --color-bg-accent: #e8f4f8; /* Very Light Teal */
  --color-bg-footer: #0d4168;
  --color-bg-copy: #32768b;

  /* Button Colors - Therapeutic Actions */
  --color-button-primary: #3a9db5; /* Growth Teal */
  --color-button-primary-hover: #2e7a8a; /* Deep Teal */
  --color-button-text: #ffffff;
  --color-button-text-alt: #2e7a8a; /* Deep Teal */
  --color-button-border: #3a9db5; /* Growth Teal */

  /* Button Variations - CBT Actions */
  --color-button-blue: #3a9db5; /* Primary Teal */
  --color-button-blue-hover: #2e7a8a; /* Deep Teal */
  --color-button-green: #7db843; /* Success/Book Now */
  --color-button-orange: #e8b4a0; /* Gentle Coral for Alerts */

  /* Contact Form 7 & Form Colors */
  --color-form-bg: #e8f4f8; /* Light Teal Background */
  --color-form-border: #3a9db5; /* Growth Teal Border */
  --color-form-text: #2e7a8a; /* Deep Teal Text */
  --color-form-error: #d9534f; /* Soft Red Error */

  /* Border Colors - Subtle Separations */
  --color-border-light: #e8e8e8; /* Very Light Grey */
  --color-border-medium: #7bb3b0; /* Soft Teal */
  --color-border-dark: #2e7a8a; /* Deep Teal */

  /* Header Colors - Therapeutic Hierarchy */
  --color-header-h1: #2e7a8a; /* Deep Teal - Main Headers */
  --color-header-h2: #3a9db5; /* Growth Teal - Section Headers */
  --color-header-h3: #7db843; /* Mind Tree Green - Sub Headers */
  --color-header-h4: #2e7a8a; /* Text Grey */
  --color-header-h5: #8ba3b5; /* Dusty Blue */
  --color-header-h6: #4a4a4a; /* Text Grey */

  /* Link Colors - Trust Building */
  --color-link: #3a9db5; /* Growth Teal */
  --color-link-hover: #2e7a8a; /* Deep Teal */
  --color-link-footer: #f2f2f2; /* Soft Lavender */
  --color-link-footer-hover: #3a9db5; /* Growth Teal */

  /* Status Colors - Professional Feedback */
  --color-success: #7db843; /* Mind Tree Green */
  --color-warning: #e8b4a0; /* Gentle Coral */
  --color-error: #d9534f; /* Soft Red */
  --color-info: #3a9db5; /* Growth Teal */

  /* BABCP Accreditation */
  --color-babcp: #9ac93c; /* Official BABCP Green */

  /* Psychology Today Verification */
  --color-psych-today: #3a9db5; /* Brand Consistent */

  /* Typography - Font Families */
  --font-body: "Lato", sans-serif; /* Body text font */
  --font-heading: 'Raleway', sans-serif; /* Heading font */
} 
/* ========================================
   BROWSER RESET & NORMALIZE
   ======================================== */

/* CSS 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 {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

/* Base HTML elements */
html { scroll-behavior: smooth; }

nav ul, nav ol { list-style: none; margin: 0; padding: 0; }

blockquote, q { quotes: none; }
blockquote::before, blockquote::after,
q::before, q::after { content: none; }

q { display: inline; font-style: italic; }
q::before, q::after { content: '"'; font-style: normal; }

table { border-collapse: collapse; border-spacing: 0; }
th, td { padding: 2px; }

textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{-webkit-appearance:none;appearance:none;border-radius:0}

button { outline: 0;}
/* Text elements */
big { font-size: 120%; }
small, sup, sub { font-size: 80%; }
sup { vertical-align: super; }
sub { vertical-align: sub; }
dd { margin-left: 20px; }
kbd, tt { font-family: monospace; font-size: 12px; }
ins { text-decoration: underline; }
del, strike, s { text-decoration: line-through; }
dt { font-weight: bold; }
address, cite, var { font-style: italic; }

/* Links */
a { text-decoration-skip-ink: auto; }
a[href^="tel"] { color: inherit; text-decoration: none; }

/* Accessibility */
.screen-reader-text,
.visually-hidden:not(:focus):not(:active),
.form-allowed-tags:not(:focus):not(:active) {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	white-space: nowrap;
}

.screen-reader-text:focus,
.skip-link:focus {
	background: #f7f7f7;
	border-radius: 3px;
	box-shadow: 0 0 2px rgba(0,0,0,.6);
	color: #007acc;
	font-size: .875rem; font-weight: 700;
	line-height: normal;
	padding: 15px 23px 14px;
	position: absolute;
	top: 5px; left: 6px; right: auto;
	width: auto; height: auto;
	z-index: 100000;
}

.skip-link {
	left: -9999rem;
	top: 2.5rem;
	text-decoration: underline;
}


/* ========================================
   BODY & BASE STYLES
   ======================================== */

body {
	line-height: 1.2;
	font-family: var(--font-body);
	font-size: 1.1rem;
	color: var(--color-text-primary);
	background-color: var(--color-bg-primary);
}
#wrapper {
	width: 100%;
	max-width: 2000px;
	margin: 0 auto;
	font-family: var(--font-body);
	font-size: 1.1rem;
}
.content-block {
	width: 100%;
	max-width: 1240px;
	padding: 3em 1em;
	margin: 0 auto;
	box-sizing: border-box;
	overflow: hidden;
	
}
.full-screen .content-block {
	max-width: 2000px;
	padding: 2em 0;
}
.small {
	margin: -4em 0 0 0;
}
blockquote {
	background: #ffffff;
	padding: 2rem;
	border-left: 4px solid var(--color-primary);
	margin: 1.5rem auto;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
	width: 100%;
	max-width: 900px;
	box-sizing: border-box;
	font-style: italic;
	font-size: 1.1rem;
	line-height: 1.6;
	color: var(--color-text-primary);
}
blockquote,q {
	quotes:none;
}
blockquote:before,blockquote:after,q:before,q:after {
	content:'';
	content:none;
	
	
}


table {
	border-collapse:collapse;
	border-spacing:0;
}
article, aside , details , figcaption , figure , footer , header , hgroup , menu , nav , section {
	display:block;
}
.clear {
	clear:both;
}
.screen-reader-text {
	clip:rect(1px, 1px, 1px, 1px);
	position:absolute !important;
}
.aligncenter {
	text-align: center;
	margin: .5em auto;
	display:block;
}
.aligncenter img {
	width: 100%;
	max-width: 600px;
	height: auto;
}
img {	
   max-width: 100%;
   height: auto;
}

/*TEXT STYLING*/

ol,
ul {
	list-style: none;
}

ul , ol {
	list-style: disc;
	line-height: 1.4;
	font-size: 1.1em;
	margin: 1em  0 1em 2em;
	color: var(--color-secondary);
}
ol {
	list-style: decimal;
}
a {
	color: var(--color-link);
	font-weight: bold;
	text-decoration: none;
}

a:hover {
	color: var(--color-link-hover);
	text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
	font-family: var(--font-heading);
	font-weight: 400;
}

h1{
	font-size: clamp(1.8rem, 5.5vw, 2.9rem);
	font-weight: bold;
	margin: .5em 0;
	color: var(--color-header-h1);

}

h2{
	font-size: clamp(1.5rem, 5vw, 2.4rem);
	color: var(--color-header-h2);
	margin-bottom: .5em;

}


h3{
	font-size: clamp(1.8rem, 6vw, 2.7rem);
	/*font-weight: bold; */
	margin-bottom: .3em;
	color: var(--color-header-h3);
}

h4{
	font-size: clamp(1.1rem, 4vw, 1.4rem);
	color: var(--color-header-h4);
	margin-bottom: .1em;
	font-style: italic;
}

h5{
	font-size: clamp(1rem, 3vw, 1.2rem);
	color: var(--color-header-h5);
	font-style: italic;
	line-height: 1.4;
}

h6{
	font-size: clamp(0.6rem, 2.5vw, 0.7rem);
	color: var(--color-header-h6);
}

b, strong {
	font-weight: 600;
}

em,
i {
	font-style: italic;
}

pre {
	padding: 12px;
	letter-spacing: 2px;
	font-style: italic;
	margin: 0.5em;
}


p {
	margin-bottom: 15px;
    line-height: 1.2;
}

/*blockquote {
	border-left: 4px solid  #999;
	background: #F0F0F0;
	font-style: italic;
	font-weight: 300;
	line-height: 1.27em;
	margin-bottom: 14px;
	padding-left: 25px;
} */

.alignright {
	float: right;
	margin: 0 0 .5em .5em;
}

img alignright {
	float: right;
	margin: 0 0 .5em .5em;
}


.aligncenter  img , .aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.alignleft {
	float: left;
	margin: 0 .5em .5em 0;
}

.entry-title {
	font-size: 1.9em;
}

.entry-title ul {
	list-style: none;
}

legend {

	font-size: 1.2em;
	padding: 5px;
	font-weight: bold;
}

.entry-meta {
	display: none;
}

.entry-footer {
	display: none;
}


/* ********** Page Header *********/
#logo {
	text-align: center;
}
.background-black {
	background: rgba(56, 33, 14, .8);
	margin-bottom:  450px;
	
}
.main-logo {
	overflow: hidden;
	text-align: center;
	width: 100%;
	max-width: 500px;
	margin: 0 auto;
}
.main-logo img {
	margin-top: 4em;
	width: 100%;
	max-width: 400px;
	height: auto;
	filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.3));
	transition: transform 0.3s ease;
}
.main-logo img:hover {
	transform: scale(1.05);
}

.main-background {
	  background-image: url(https://growthmindsetcbt.im/wp-content/uploads/2025/08/gmcbt-header-1.jpg);
	  background-position: top center;
	  background-repeat: no-repeat;
	  background-size: cover !important;
	  background-attachment: fixed;
	  
	  /* Perfect centering for logo */
	  display: flex;
	  align-items: center;
	  justify-content: center;
	  height: 95vh;
	  width: 100%;
	  position: relative;
}


#strap-line {
	display: none !important;
}

/* ========================================
   THREE COLUMN HEADER LAYOUT
   ======================================== */
.header-three-column {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem;
	background: var(--color-bg-primary);
	max-width: 1240px;
	margin: 0 auto;
	padding-left: 1em;
	padding-right: 1em;
	box-sizing: border-box;
}

.header-left {
	flex: 0 0 200px;
}

.header-right {
	flex: 0 0 80px;
}

.header-center {
	flex: 1;
	text-align: center;
	padding: 0 2rem;
}

.header-left {
	text-align: left;
}

.header-right {
	text-align: right;
}

/* Three-column header logo (specific to new header layout) */
.header-three-column .main-logo {
	max-height: 85px;
	width: auto;
	transition: transform 0.3s ease;
}

.header-three-column .main-logo:hover {
	transform: scale(1.05);
}

.site-tagline {
	font-family: var(--font-heading);
	font-size: clamp(1.2rem, 2.5vw, 1.8rem);
	font-weight: 600;
	color: var(--color-primary);
	margin: 0;
	line-height: 1.3;
}

.babcp-logo {
	max-height: 70px;
	width: auto;
	transition: opacity 0.3s ease;
}

.babcp-logo:hover {
	opacity: 0.8;
}

/* Mobile Header */
.mobile-header {
	display: none;
	text-align: center;
	padding: 1rem;
	background: var(--color-bg-primary);
	border-bottom: 2px solid var(--color-primary);
}

.mobile-logo {
	max-height: 100px;
	width: auto;
}

#small-strap {
	background: var(--color-bg-dark);
	padding: .7em 0;
	color: var(--color-text-white);
	font-size: 125%;
	/*margin-top: -.5em;
	text-align: right;
	padding-right: 2em;
	*/
}


/** OPENING TIMES  **/
/* ===================================
   Opening Hours Shortcode Styles
   =================================== */

.opening-hours-block {
    margin: 1rem 0;
}

/* Compact Style */
.opening-hours-compact .hours-row {
    margin-bottom: 0.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.opening-hours-compact .days {
    min-width: 120px;
}

.opening-hours-compact .times {
    color: #2e7a8a;
}

.opening-hours-compact .note {
    color: #2e7a8a;
    font-style: italic;
}

/* List Style */
.opening-hours-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.opening-hours-list li {
    margin-bottom: 0.5rem;
    padding: 0.25rem 0;
    border-bottom: 1px solid #f0f0f0;
}

.opening-hours-list li:last-child {
    border-bottom: none;
}

/* Today's Hours Style */
.opening-hours-today {
    background: #f8f9fa;
    padding: 1rem;
    border-radius: 6px;
    border-left: 4px solid #3a9db5;
}

.opening-hours-today h4 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: #2e7a8a;
}

/* Default Style (matches CBT site) */
.opening-hours-default h4 {
    color: #2e7a8a;
    margin-bottom: 1rem;
    font-size: 1.1rem;
}

.opening-hours-default p {
    margin-bottom: 0.5rem;
    line-height: 1.5;
}

.opening-hours-default strong {
    color: #333;
    min-width: 100px;
    display: inline-block;
}

/* Emergency Note */
.opening-hours-emergency {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #eee;
    color: #666;
    font-size: 0.9rem;
}

.opening-hours-emergency p {
    margin: 0;
}

/* Responsive Design */
@media (max-width: 768px) {
    .opening-hours-compact .hours-row {
        flex-direction: column;
        gap: 0.25rem;
    }
    
    .opening-hours-compact .days {
        min-width: auto;
    }
    
    .opening-hours-default strong {
        display: block;
        margin-bottom: 0.25rem;
    }
    
    .opening-hours-today {
        padding: 0.75rem;
    }
}

/* Optional: Integration with BlankSlate theme colors */
.opening-hours-block h4 {
    color: var(--primary-color, #2e7a8a);
}

.opening-hours-today {
    border-left-color: var(--accent-color, #3a9db5);
}

/* Optional: Card-style layout for default view */
.opening-hours-card {
    background: #ffffff;
    padding: 1.5rem;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    margin: 1rem 0;
}

.opening-hours-card h4 {
    margin-top: 0;
    color: #2e7a8a;
    border-bottom: 2px solid #3a9db5;
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
}
/* START   Icons with tool tips ******/
#icon-list {
	background: var(--color-bg-primary);
}
.icon-displays {
	padding: .3em;
	float: left;
}
.tooltip {
    position: relative;
    display: inline-block;
	padding: 0 1em;
}
.tooltip img {
	width: 100%;
	max-width: 100px;
	height: auto;
}

.tooltip .tooltiptext {
    visibility: hidden;
    width: 180px;
    background-color: var(--color-secondary);
    color: var(--color-text-white);
    text-align: center;
    border-radius: 2px;
    padding: 5px 0;
    position: absolute;
    z-index: 1;
    bottom: 110%;
    left: 50%;
    margin-left: -90px;
    opacity: 0;
    transition: opacity 0.3s;
}

.tooltip .tooltiptext::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: var(--color-secondary) transparent transparent transparent;
}

.tooltip:hover .tooltiptext {
    visibility: visible;
    opacity: 1;
}
.list-icons {
	list-style: none;
	line-height: 3.5;
	vertical-align: top;
}
.list-icons li {
	width: 50%;
	float: left;
	padding: 0 .2em;
	box-sizing: border-box;
}
.list-icons img {
	width: 100%;
	max-width: 45px;
	height: auto;
	vertical-align: middle;
	margin-right: .5em;
}
/* END   Icons with tool tips ******/
.tagline {
  letter-spacing: 0.05em;
}
.tagline .dot {
  padding: 0.5em;
}
/**** Contact Form Styling  *****/
.red-required  {
	color: var(--color-form-error);
	font-size: .8em;
	font-weight: bold;
}
#enquiry-form {
	padding: 2em;
	box-sizing: border-box;
	border-radius: 2px;
	background: #fff;
}
#form-your-details , #form-camping-details {
	padding: 1em;
	box-sizing: border-box;
	border: solid 1px #fff;
	margin: .5em 0;
}
.form-50 {
	width: 48%;
	float: left;
	padding: .2em 0;
	box-sizing: border-box;
	margin: 0 1%;
}
.small-text {
	font-size: 80%;
	color: var(--color-text-primary);
	margin-left: 100px;
}
input {
    padding: 12px 20px;
    margin: 8px 0;
    box-sizing: border-box;
}
input[type=text] , input[type=email] , input[type=url]  {
	width:100%;
}
select {
	padding: 12px 20px !important;
    margin: 8px 0 !important;
    box-sizing: border-box;
}
textarea {
    width: 100%;
    padding: 12px 20px;
	margin: 8px 0;
    box-sizing: border-box;   
    border-radius: 4px;
}

span.wpcf7-list-item { 
     display: block !important; 
	 padding: .3em 0;
}
input[type=submit] {
	width: 100%;
    max-width: 450px;
	padding: 1em 2em;
	background: var(--color-button-primary);
	color: var(--color-button-text);
	font-size: 1.2em;
	overflow: hidden;
	border: solid 1px var(--color-button-border);
	border-radius: 3px;
	cursor: pointer;
	-webkit-transition: background .5s;
    transition: background .5s;
	box-sizing: border-box;
    margin-top: 1em;

}
input[type=submit]:hover , .more-button:hover  {
	background: var(--color-button-primary-hover);
	color: var(--color-button-text);
}
#enquiry-form h3 {
	background: var(--color-bg-secondary);
	padding: .5em;
	box-sizing: border-box;
	margin: .5em 0;
	border-radius: 2px;
}


/****New Form Styling****/
.booking-form-container {
    max-width: 800px;
    margin: 0 auto;
    background: #ffffff;
    padding: 2rem;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(58,157,181,0.1);
}

.form-section {
    border: 2px solid #e8f4f8;
    border-radius: 8px;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    background: #fafaf9;
}

.form-section legend h4 {
    color: #2e7a8a;
    background: #ffffff;
    padding: 0 15px;
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
}

.form-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.form-field-half {
    flex: 1;
    min-width: 250px;
}

.form-field-full {
    flex: 1 1 100%;
}

.form-section label {
    display: block;
    font-weight: 600;
    color: #2e7a8a;
    margin-bottom: 5px;
    font-size: 0.95rem;
}

.form-section input[type="text"],
.form-section input[type="email"],
.form-section input[type="tel"],
.form-section input[type="number"],
.form-section select,
.form-section textarea {
    width: 100%;
    padding: 10px 12px;
    border: 2px solid #e8e8e8;
    border-radius: 6px;
    font-size: 0.95rem;
    transition: border-color 0.3s ease;
    background: #ffffff;
}

.form-section input:focus,
.form-section select:focus,
.form-section textarea:focus {
    outline: none;
    border-color: #3a9db5;
    box-shadow: 0 0 0 3px rgba(58,157,181,0.1);
}

.form-section input.required:invalid {
    border-color: #dc3545;
}

/* Checkbox styling */
.form-section input[type="checkbox"] {
    margin-right: 8px;
    margin-bottom: 8px;
    transform: scale(1.1);
}

.form-section .wpcf7-checkbox,
.form-section .wpcf7-list-item {
    margin-bottom: 8px;
}

.form-section .wpcf7-list-item label {
    font-weight: normal;
    display: inline;
    margin-left: 5px;
}

/* Consent section styling */
.consent-section {
    background: #e8f4f8;
    padding: 1rem;
    border-radius: 6px;
    border: 1px solid #3a9db5;
}

.consent-section .wpcf7-list-item {
    margin-bottom: 15px;
    padding: 10px;
    background: #ffffff;
    border-radius: 4px;
}

/* Submit section */
.form-submit-section {
    background: #f2e9d8;
    padding: 1.5rem;
    border-radius: 8px;
    text-align: center;
    margin-top: 1rem;
}

.form-info {
    margin-bottom: 1.5rem;
}

.form-info p {
    margin: 5px 0;
    font-size: 0.9rem;
    color: #4a4a4a;
}

.cbt-submit-button {
    background: linear-gradient(135deg, #7db843 0%, #9ac93c 100%);
    color: white;
    padding: 15px 40px;
    font-size: 1.1rem;
    font-weight: 600;
    border: none;
    border-radius: 25px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 12px rgba(125,184,67,0.3);
}

.cbt-submit-button:hover {
    background: linear-gradient(135deg, #9ac93c 0%, #7db843 100%);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(125,184,67,0.4);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .booking-form-container {
        padding: 1rem;
    }
    
    .form-row {
        flex-direction: column;
    }
    
    .form-field-half {
        min-width: auto;
    }
}

/* Error and success messages */
.wpcf7-validation-errors {
    background: #f8d7da;
    color: #721c24;
    padding: 15px;
    border-radius: 6px;
    margin: 15px 0;
    border: 1px solid #f5c6cb;
}

.wpcf7-mail-sent-ok {
    background: #d4edda;
    color: #155724;
    padding: 15px;
    border-radius: 6px;
    margin: 15px 0;
    border: 1px solid #c3e6cb;
}

.wpcf7-not-valid {
    border-color: #dc3545 !important;
}

.wpcf7-form-control-wrap .wpcf7-not-valid-tip {
    color: #dc3545;
    font-size: 0.8rem;
    margin-top: 5px;
}



hr.soft {
	border: solid 5px var(--color-bg-secondary);
	margin: 1em 0;
	clear: both;
}

hr.soft-small {
	border: solid 5px var(--color-bg-primary);
	margin: 1em 0;
	clear: both;
}
/************ Custom Code ***********/
/*  Anchor Links Offset 
p .anchor-point {
	padding-top: 200px !important;
	position: relative;
} */

a[name] {
	padding-top: 200px;
        margin-top: -200px;
	display: inline-block;
}

.top-space {
	margin-top: 2em;
}

.wp-block-latest-posts__list li {
  border: solid 1px var(--color-button-blue);
  padding: .5em;
  box-sizing: border-box;
  margin-bottom: .5em !important;
  font-size: 85%;
  font-weight: 400;
  line-height: 1.2;
}
/****  PRICING BLOCKS ***/
/* ========================================
   CBT PRICING GRID STYLES
   ======================================== */

.cbt-pricing-display {
  padding: 2rem 0;
}

.pricing-grid {
  display: grid;
  gap: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* Dynamic grid columns based on data attribute */
.pricing-grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.pricing-grid[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.pricing-grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }

/* Pricing Items */
.pricing-item {
  background: #ffffff;
  border-radius: var(--border-radius-medium, 8px);
  padding: 1.5rem;
  text-align: center;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
}

.pricing-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

/* Width Spanning */
.pricing-item--width-1 { grid-column: span 1; }
.pricing-item--width-2 { grid-column: span 2; }
.pricing-item--width-3 { grid-column: span 3; }
.pricing-item--width-4 { grid-column: span 4; }

/* Item Content */
.pricing-item__content {
  position: relative;
  z-index: 2;
}

.pricing-item__title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--color-text-primary, #2d2d2d);
}

.pricing-item__price {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 0.75rem;
  color: var(--color-primary, #3a9db5);
}

.pricing-item__description {
  color: var(--color-text-secondary, #4a4a4a);
  line-height: 1.5;
  margin: 0;
}

/* Badge Styling */
.pricing-item__badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  padding: 0.25rem 0.75rem;
  border-radius: 15px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 3;
}

/* Highlight Variations */
.pricing-item--free {
  border: 2px solid var(--color-secondary, #7db843);
}

.pricing-item--free .pricing-item__price {
  color: var(--color-secondary, #7db843);
}

.pricing-item--free .pricing-item__badge {
  background: var(--color-secondary, #7db843);
  color: white;
}

.pricing-item--popular {
  border: 2px solid var(--color-primary, #3a9db5);
  transform: scale(1.05);
}

.pricing-item--popular .pricing-item__badge {
  background: var(--color-primary, #3a9db5);
  color: white;
}

.pricing-item--premium {
  border: 2px solid var(--color-accent, #7bb3b0);
  background: linear-gradient(135deg, #ffffff 0%, var(--color-bg-accent, #e8f4f8) 100%);
}

.pricing-item--premium .pricing-item__badge {
  background: var(--color-accent, #7bb3b0);
  color: white;
}

/* Pricing Notice */
.pricing-notice {
  margin-top: 2rem;
  text-align: center;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.pricing-notice p {
  margin-bottom: 0.75rem;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .pricing-grid[data-columns="4"] { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid[data-columns="3"] { grid-template-columns: repeat(2, 1fr); }
  
  .pricing-item--width-3,
  .pricing-item--width-4 { grid-column: span 2; }
}

@media (max-width: 768px) {
  .pricing-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem;
    padding: 0 0.75rem;
  }
  
  .pricing-item {
    padding: 1.25rem;
  }
  
  .pricing-item--width-1,
  .pricing-item--width-2,
  .pricing-item--width-3,
  .pricing-item--width-4 {
    grid-column: span 1 !important;
  }
  
  .pricing-item--popular {
    transform: none;
  }
  
  .pricing-item__badge {
    top: 0.75rem;
    right: 0.75rem;
  }
}

@media (max-width: 480px) {
  .cbt-pricing-display {
    padding: 1.5rem 0;
  }
  
  .pricing-item {
    padding: 1rem;
  }
  
  .pricing-item__title {
    font-size: 1.1rem;
  }
  
  .pricing-item__price {
    font-size: 1.25rem;
  }
}

/* Animation on scroll (if WOW.js is available) */
.pricing-item {
  opacity: 0;
}

.pricing-item.wow {
  opacity: 1;
}

/* Fallback animation if no WOW.js */
@media (prefers-reduced-motion: no-preference) {
  .pricing-item {
    animation: fadeInUp 0.6s ease forwards;
  }
  
  .pricing-item:nth-child(1) { animation-delay: 0.1s; }
  .pricing-item:nth-child(2) { animation-delay: 0.2s; }
  .pricing-item:nth-child(3) { animation-delay: 0.3s; }
  .pricing-item:nth-child(4) { animation-delay: 0.4s; }
  .pricing-item:nth-child(5) { animation-delay: 0.5s; }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ********** START FOOTER *********/
#footer {
	background: var(--color-bg-footer);
	padding: 2em 0;
	font-size: 90%;
	font-family: var(--font-body);
}
#footer h3 {
	color: var(--color-button-blue);
  font-family: var(--font-heading);
  font-size: 1.1em;
  font-weight: 600;
  margin-bottom: 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
#footer a:link , #footer a:visited {
	color: var(--color-link-footer);
  font-weight: 400;

	transition: all ease-in-out .3s;
}
#footer a:hover {
	color: var(--color-link-footer-hover);
}
#footer-left, #footer-left-middle, #footer-middle, #footer-right {
	width: 25%;
	float: left;
	padding: 1em;
	box-sizing: border-box;
	overflow: hidden;
	list-style: none;
}
#footer-left {
  width: 20%;
}
#footer-middle {
  width: 30%;
}
.footer-widget ul {
	list-style: none;
	color: var(--color-link-footer);
  margin: 0;
}
.footer-widget {
  margin-bottom: 25px;
}
.footer-widget ul li {
	line-height: 2;
  margin: 0;
}
#business-details {
	text-align: center;
	background: var(--color-bg-secondary);
}
#business-details a:link , #business-details a:visited {
	color: var(--color-text-primary);
}
#copyright {
	font-family: var(--font-body);
	padding: 1em 0;
	font-size: .9em;
	text-align: center;
	color: var(--color-text-primary);
	background: var(--color-bg-copy);
	}
#copyright a:link , #copyright a:visited {
    color: var(--color-link);
}
#copyright a:hover {
	color: var(--color-text-primary);
	font-weight: bold;
}

/* ========================================
   FOOTER BIO SECTION
   ======================================== */
.footer-company-bio {
	padding-top: 1.5em;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.footer-company-bio .bio-title {
	color: var(--color-button-blue);
	font-family: var(--font-heading);
	font-size: 1.1em;
	font-weight: 600;
	margin-bottom: 0.8em;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.footer-company-bio .bio-text {
	color: var(--color-text-pale);
	line-height: 1.6;
	font-size: 1em;
}

.footer-company-bio .bio-text p {
	margin-bottom: 1em;
}

.footer-company-bio .bio-text p:last-child {
	margin-bottom: 0;
}

.footer-company-bio .bio-text a {
	color: var(--color-link-footer-hover);
	text-decoration: underline;
	transition: all ease-in-out .3s;
}

.footer-company-bio .bio-text a:hover {
	color: var(--color-text-white);
	text-decoration: none;
}

/* ********** END FOOTER*********/
/* =====================================================
   FLOATING BOOKING BUTTON STYLES
   Add this to your theme's main CSS file
   ===================================================== */

#gmcbt-floating-booking {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 9999;
}

.gmcbt-booking-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px;
    background: var(--color-button-green, #7db843);
    color: var(--color-text-white, #ffffff);
    text-decoration: none;
    border-radius: 50px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    font-family: var(--font-headings, 'Lato', sans-serif);
    font-size: 15px;
    font-weight: 600;
    transition: all 0.3s ease;
}

.gmcbt-booking-btn:hover {
    background: var(--color-secondary-dark, #5a9030);
    transform: translateY(-2px);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.2);
    color: var(--color-text-white, #ffffff);
}

.gmcbt-booking-btn svg {
    flex-shrink: 0;
}

/* Tablet Responsive */
@media (max-width: 768px) {
    #gmcbt-floating-booking {
        bottom: 20px;
        right: 20px;
    }
    
    .gmcbt-booking-btn {
        padding: 12px 20px;
        font-size: 14px;
    }
}

/* Small Mobile (420px and below) */
@media (max-width: 420px) {
    #gmcbt-floating-booking {
        bottom: 15px;
        right: 50%;
        left: auto;
        transform: translateX(50%);
    }
    
    .gmcbt-booking-btn {
        width: auto;
        max-width: 200px;
        justify-content: center;
        padding: 10px 16px;
        font-size: 13px;
        gap: 8px;
        margin: 0 auto;
    }
    
    .gmcbt-booking-btn span {
        white-space: nowrap;
    }
}

/* Hide on print */
@media print {
    #gmcbt-floating-booking {
        display: none;
    }
}
/****** Media Queries moved to style-responsive.css *******/