/*
Theme Name: ChillTogether Travel
Theme URI: https://chilltogether.travel
Description: Child theme for Grand Tour Pro — ChillTogether Travel brand identity. Modern, visual-heavy, small-group photography tour brand.
Version: 1.0.0
Author: Chill / ChillTogether Travel
Author URI: https://chilltogether.travel
Template: grandtour
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: grandtour
*/

/* ════════════════════════════════════════════════════════════════════
   CHILLTOGETHER TRAVEL — DESIGN SYSTEM
   ════════════════════════════════════════════════════════════════════

   Brand Palette
   ─────────────
   --ct-green-deep    : #1D6B4A  (primary CTA, headings accent)
   --ct-green-mid     : #2E8B62  (hover states)
   --ct-green-light   : #E8F5EE  (backgrounds, badges)
   --ct-amber         : #F59E0B  (warm accent, badges)
   --ct-amber-light   : #FEF3C7  (amber bg tints)
   --ct-dark          : #111827  (body text)
   --ct-mid           : #374151  (secondary text)
   --ct-muted         : #6B7280  (muted/placeholder)
   --ct-border        : #E5E7EB  (borders)
   --ct-bg            : #F9F7F4  (warm off-white bg)
   --ct-white         : #FFFFFF

   Typography
   ─────────────
   Headings : Playfair Display (serif, Google Fonts)
   Body      : Inter (sans-serif, Google Fonts)

   ════════════════════════════════════════════════════════════════════ */

/* ── CSS Custom Properties ──────────────────────────────────────── */
:root {
	--ct-green-deep   : #1D6B4A;
	--ct-green-mid    : #2E8B62;
	--ct-green-light  : #E8F5EE;
	--ct-amber        : #F59E0B;
	--ct-amber-light  : #FEF3C7;
	--ct-dark         : #111827;
	--ct-mid          : #374151;
	--ct-muted        : #6B7280;
	--ct-border       : #E5E7EB;
	--ct-bg           : #F9F7F4;
	--ct-white        : #FFFFFF;
	--ct-radius       : 10px;
	--ct-radius-sm    : 6px;
	--ct-shadow       : 0 4px 24px rgba(0,0,0,.08);
	--ct-shadow-hover : 0 8px 32px rgba(0,0,0,.14);
	--ct-transition   : 0.22s ease;
	--ct-font-body    : 'Inter', system-ui, -apple-system, sans-serif;
	--ct-font-heading : 'Playfair Display', Georgia, serif;
}

/* ════════════════════════════════════════════════════════════════════
   1. GLOBAL TYPOGRAPHY & BASE
   ════════════════════════════════════════════════════════════════════ */

body {
	font-family: var(--ct-font-body);
	color: var(--ct-dark);
	background-color: var(--ct-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ct-font-heading);
	color: var(--ct-dark);
	line-height: 1.25;
}

#page_content_wrapper h1,
.sidebar_content h1 {
	font-family: var(--ct-font-heading);
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	color: var(--ct-dark);
	letter-spacing: -0.02em;
}

/* ════════════════════════════════════════════════════════════════════
   2. COLOUR OVERRIDES — brand green replaces default blue/grey
   ════════════════════════════════════════════════════════════════════ */

.button,
input[type="submit"],
button[type="submit"] {
	background-color: var(--ct-green-deep) !important;
	border-color:     var(--ct-green-deep) !important;
	color: var(--ct-white) !important;
	font-family: var(--ct-font-body);
	font-weight: 600;
	letter-spacing: 0.02em;
	border-radius: var(--ct-radius-sm) !important;
	transition: background-color var(--ct-transition), box-shadow var(--ct-transition), transform var(--ct-transition);
}

.button:hover,
input[type="submit"]:hover,
button[type="submit"]:hover {
	background-color: var(--ct-green-mid) !important;
	border-color:     var(--ct-green-mid) !important;
	box-shadow: 0 4px 16px rgba(29,107,74,.30) !important;
	transform: translateY(-1px);
}

a { color: var(--ct-green-deep); transition: color var(--ct-transition); }
a:hover { color: var(--ct-green-mid); }

/* ════════════════════════════════════════════════════════════════════
   3. TOUR ATTRIBUTE STRIP (Days / Age / Months / Availability)
   ════════════════════════════════════════════════════════════════════ */

.single_tour_attribute_wrapper {
	background: var(--ct-white);
	border-radius: var(--ct-radius);
	box-shadow: var(--ct-shadow);
	padding: 18px 20px !important;
	border: 1px solid var(--ct-border) !important;
	margin-bottom: 24px !important;
}

.tour_attribute_icon {
	color: var(--ct-green-deep) !important;
	font-size: 1.4rem !important;
	margin-bottom: 6px !important;
}

.tour_attribute_content {
	font-size: 0.82rem;
	color: var(--ct-mid);
	font-weight: 500;
	line-height: 1.4;
}

/* ════════════════════════════════════════════════════════════════════
   4. TOUR ITINERARY ACCORDION — mobile-optimised
   ════════════════════════════════════════════════════════════════════ */

.ui-accordion .ui-accordion-header {
	background: var(--ct-white) !important;
	border: 1px solid var(--ct-border) !important;
	border-radius: var(--ct-radius-sm) !important;
	font-family: var(--ct-font-body) !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	color: var(--ct-dark) !important;
	padding: 14px 18px !important;
	margin-bottom: 6px !important;
	cursor: pointer;
	transition: background-color var(--ct-transition), border-color var(--ct-transition);
}

.ui-accordion .ui-accordion-header:hover,
.ui-accordion .ui-accordion-header.ui-state-active {
	background: var(--ct-green-light) !important;
	border-color: var(--ct-green-deep) !important;
	color: var(--ct-green-deep) !important;
}

.ui-accordion .ui-accordion-header .ui-icon {
	background-color: transparent !important;
	color: var(--ct-green-deep) !important;
}

.ui-accordion .ui-accordion-content {
	background: var(--ct-white) !important;
	border: 1px solid var(--ct-border) !important;
	border-top: none !important;
	border-radius: 0 0 var(--ct-radius-sm) var(--ct-radius-sm) !important;
	padding: 18px 20px !important;
	font-size: 0.92rem !important;
	line-height: 1.7 !important;
	color: var(--ct-mid) !important;
	margin-bottom: 6px !important;
}

/* ════════════════════════════════════════════════════════════════════
   5. PRICING TABLE
   ════════════════════════════════════════════════════════════════════ */

.single_tour_price {
	font-family: var(--ct-font-heading) !important;
	font-size: 1.8rem !important;
	color: var(--ct-green-deep) !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
}

.single_tour_price.fullwidth { font-size: 2rem !important; }

.single_tour_price .normal_price {
	font-size: 1rem !important;
	color: var(--ct-muted) !important;
	text-decoration: line-through !important;
	font-family: var(--ct-font-body) !important;
	font-weight: 400 !important;
}

.single_tour_per_person {
	font-size: 0.78rem;
	color: var(--ct-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-weight: 600;
	margin-top: 2px;
}

.ct-price-block,
.single_tour_header_price {
	background: linear-gradient(135deg, var(--ct-green-light) 0%, var(--ct-white) 100%);
	border-radius: var(--ct-radius);
	padding: 16px 20px !important;
	border: 1px solid rgba(29,107,74,.15);
	margin-bottom: 16px !important;
}

.ct-price-display .ct-price-label {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--ct-muted);
	font-weight: 600;
	margin-bottom: 4px;
}

.ct-price-display .ct-price-suffix {
	font-size: 0.8rem;
	color: var(--ct-muted);
	font-family: var(--ct-font-body);
	font-weight: 400;
	margin-left: 4px;
}

/* ════════════════════════════════════════════════════════════════════
   6. DEPARTURE / DETAILS LIST
   ════════════════════════════════════════════════════════════════════ */

#page_content_wrapper .inner .sidebar_content ul.single_tour_departure_wrapper,
.single_tour_departure_wrapper {
	background: var(--ct-white) !important;
	border-radius: var(--ct-radius) !important;
	box-shadow: var(--ct-shadow) !important;
	border: 1px solid var(--ct-border) !important;
	padding: 0 !important;
	overflow: hidden;
}

.single_tour_departure_wrapper li {
	padding: 16px 22px !important;
	border-bottom: 1px solid var(--ct-border) !important;
}
.single_tour_departure_wrapper li:last-child { border-bottom: none !important; }

.single_tour_departure_title {
	font-size: 0.72rem !important;
	text-transform: uppercase !important;
	letter-spacing: 0.08em !important;
	color: var(--ct-muted) !important;
	font-weight: 700 !important;
	margin-bottom: 6px !important;
}

.single_tour_departure_content {
	font-size: 0.92rem !important;
	color: var(--ct-dark) !important;
	line-height: 1.6 !important;
}

.single_tour_departure_content .ti-check { color: var(--ct-green-deep) !important; margin-right: 6px; }
.single_tour_departure_content .ti-close  { color: #EF4444 !important; margin-right: 6px; }

/* ════════════════════════════════════════════════════════════════════
   7. JOIN / PRIVATE TOUR TOGGLE
   ════════════════════════════════════════════════════════════════════ */

.ct-tour-type-toggle {
	display: flex;
	gap: 6px;
	background: var(--ct-border);
	border-radius: var(--ct-radius);
	padding: 4px;
	margin-bottom: 18px;
}

.ct-tour-type-tab {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 14px;
	border: none;
	border-radius: calc(var(--ct-radius) - 2px);
	background: transparent;
	font-family: var(--ct-font-body);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--ct-muted);
	cursor: pointer;
	transition: all var(--ct-transition);
	white-space: nowrap;
	line-height: 1.2;
}

.ct-tour-type-tab .ct-tab-icon { font-size: 0.9rem; flex-shrink: 0; }

.ct-tour-type-tab.ct-tab--active {
	background: var(--ct-white);
	color: var(--ct-green-deep);
	box-shadow: 0 2px 8px rgba(0,0,0,.10);
}

.ct-tour-type-tab:hover:not(.ct-tab--active) {
	color: var(--ct-dark);
	background: rgba(255,255,255,.5);
}

.ct-toggle--card { margin-top: 16px; }

/* ════════════════════════════════════════════════════════════════════
   8. PANEL TRANSITIONS
   ════════════════════════════════════════════════════════════════════ */

.ct-tour-panel { display: none; animation: ctFadeIn 0.25s ease forwards; }
.ct-tour-panel.ct-panel--visible { display: block; }

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

/* ════════════════════════════════════════════════════════════════════
   9. PRIVATE TOUR FORM
   ════════════════════════════════════════════════════════════════════ */

.ct-private-form-wrap {
	background: var(--ct-white);
	border-radius: var(--ct-radius);
	border: 1px solid var(--ct-border);
	overflow: hidden;
}

.ct-private-form-header {
	background: linear-gradient(135deg, var(--ct-green-deep) 0%, #155a3a 100%);
	padding: 20px 22px 18px;
}

.ct-private-badge {
	display: inline-block;
	background: var(--ct-amber);
	color: var(--ct-dark);
	font-size: 0.68rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 3px 10px;
	border-radius: 100px;
	margin-bottom: 10px;
}

.ct-private-form-header h3 {
	font-family: var(--ct-font-heading);
	font-size: 1.25rem;
	color: var(--ct-white) !important;
	margin: 0 0 6px;
	line-height: 1.25;
}

.ct-private-form-header p {
	font-size: 0.82rem;
	color: rgba(255,255,255,.8);
	margin: 0;
	line-height: 1.5;
}

.ct-private-form { padding: 20px 22px; }

.ct-form-row { margin-bottom: 14px; }

.ct-form-row--2col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.ct-form-group { display: flex; flex-direction: column; gap: 5px; }

.ct-form-group label {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--ct-mid);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ct-required { color: var(--ct-green-deep); }

.ct-form-group input[type="text"],
.ct-form-group input[type="email"],
.ct-form-group input[type="tel"],
.ct-form-group input[type="number"],
.ct-form-group select,
.ct-form-group textarea {
	width: 100%;
	padding: 10px 13px;
	border: 1.5px solid var(--ct-border);
	border-radius: var(--ct-radius-sm);
	font-family: var(--ct-font-body);
	font-size: 0.88rem;
	color: var(--ct-dark);
	background: var(--ct-bg);
	transition: border-color var(--ct-transition), box-shadow var(--ct-transition);
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}

.ct-form-group input:focus,
.ct-form-group select:focus,
.ct-form-group textarea:focus {
	outline: none;
	border-color: var(--ct-green-deep);
	box-shadow: 0 0 0 3px rgba(29,107,74,.15);
	background: var(--ct-white);
}

.ct-form-group textarea { resize: vertical; min-height: 90px; line-height: 1.6; }

.ct-field--error input,
.ct-field--error select,
.ct-field--error textarea {
	border-color: #EF4444 !important;
	box-shadow: 0 0 0 3px rgba(239,68,68,.12) !important;
}

.ct-form-submit-row { margin-top: 18px; }

.ct-submit-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 20px !important;
	background: var(--ct-green-deep) !important;
	color: var(--ct-white) !important;
	border: none !important;
	border-radius: var(--ct-radius) !important;
	font-family: var(--ct-font-body) !important;
	font-size: 0.95rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: background-color var(--ct-transition), box-shadow var(--ct-transition), transform var(--ct-transition);
}

.ct-submit-btn:hover:not(:disabled) {
	background: var(--ct-green-mid) !important;
	box-shadow: 0 6px 20px rgba(29,107,74,.35) !important;
	transform: translateY(-2px);
}

.ct-submit-btn:disabled { opacity: .7; cursor: not-allowed; transform: none !important; }
.ct-btn-icon { font-size: 1rem; }

.ct-form-response {
	margin-top: 14px;
	padding: 12px 16px;
	border-radius: var(--ct-radius-sm);
	font-size: 0.88rem;
	font-weight: 500;
	line-height: 1.5;
}
.ct-form-response.ct-response--success {
	background: var(--ct-green-light);
	color: var(--ct-green-deep);
	border: 1px solid rgba(29,107,74,.25);
}
.ct-form-response.ct-response--error {
	background: #FEF2F2;
	color: #991B1B;
	border: 1px solid rgba(239,68,68,.25);
}

.ct-form-privacy {
	font-size: 0.74rem;
	color: var(--ct-muted);
	text-align: center;
	margin-top: 12px;
	line-height: 1.5;
}

/* ════════════════════════════════════════════════════════════════════
   10. STANDARD BOOKING FORM (CF7 / WooCommerce)
   ════════════════════════════════════════════════════════════════════ */

.single_tour_booking_wrapper {
	background: var(--ct-white) !important;
	border-radius: var(--ct-radius) !important;
	border: 1px solid var(--ct-border) !important;
	padding: 20px !important;
}

.single_tour_booking_wrapper label {
	font-size: 0.78rem !important;
	font-weight: 600 !important;
	color: var(--ct-mid) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
}

.single_tour_booking_wrapper input[type="text"],
.single_tour_booking_wrapper input[type="email"],
.single_tour_booking_wrapper input[type="tel"],
.single_tour_booking_wrapper input[type="date"],
.single_tour_booking_wrapper select,
.single_tour_booking_wrapper textarea {
	border: 1.5px solid var(--ct-border) !important;
	border-radius: var(--ct-radius-sm) !important;
	padding: 10px 13px !important;
	font-family: var(--ct-font-body) !important;
	font-size: 0.88rem !important;
	background: var(--ct-bg) !important;
	transition: border-color var(--ct-transition) !important;
}

.single_tour_booking_wrapper input:focus,
.single_tour_booking_wrapper select:focus,
.single_tour_booking_wrapper textarea:focus {
	border-color: var(--ct-green-deep) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(29,107,74,.12) !important;
	background: var(--ct-white) !important;
}

.single_tour_booking_wrapper .wpcf7-not-valid-tip {
	color: #EF4444 !important;
	font-size: 0.75rem !important;
}
.single_tour_booking_wrapper div.wpcf7-response-output {
	border-radius: var(--ct-radius-sm) !important;
	font-size: 0.85rem !important;
	padding: 10px 14px !important;
}

/* ════════════════════════════════════════════════════════════════════
   11. TOUR LABEL / BADGE
   ════════════════════════════════════════════════════════════════════ */

.tour_label {
	display: inline-block !important;
	background: var(--ct-amber) !important;
	color: var(--ct-dark) !important;
	font-size: 0.7rem !important;
	font-weight: 800 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	padding: 3px 10px !important;
	border-radius: 100px !important;
}

/* ════════════════════════════════════════════════════════════════════
   12. SHARE BUTTON
   ════════════════════════════════════════════════════════════════════ */

.ct-share-btn,
#single_tour_share_button {
	border-color: var(--ct-border) !important;
	color: var(--ct-mid) !important;
	background: transparent !important;
	margin-top: 10px !important;
}
.ct-share-btn:hover,
#single_tour_share_button:hover {
	border-color: var(--ct-green-deep) !important;
	color: var(--ct-green-deep) !important;
}

/* ════════════════════════════════════════════════════════════════════
   13. TOUR CARD GRID/CLASSIC (archive listing)
   ════════════════════════════════════════════════════════════════════ */

.tour_grid_wrapper,
.tour_classic_wrapper {
	border-radius: var(--ct-radius) !important;
	overflow: hidden !important;
	box-shadow: var(--ct-shadow) !important;
	transition: box-shadow var(--ct-transition), transform var(--ct-transition) !important;
	border: 1px solid var(--ct-border) !important;
}

.tour_grid_wrapper:hover,
.tour_classic_wrapper:hover {
	box-shadow: var(--ct-shadow-hover) !important;
	transform: translateY(-3px);
}

.tour_grid_content_wrapper h2,
.tour_grid_content_wrapper h3,
.tour_classic_title {
	font-family: var(--ct-font-heading) !important;
	font-size: 1.1rem !important;
	color: var(--ct-dark) !important;
}

.tour_grid_price,
.tour_classic_price {
	color: var(--ct-green-deep) !important;
	font-weight: 700 !important;
}

/* ════════════════════════════════════════════════════════════════════
   14. NAVIGATION
   ════════════════════════════════════════════════════════════════════ */

.site-title,
#site_title a {
	font-family: var(--ct-font-heading) !important;
	font-weight: 700;
	letter-spacing: -0.02em;
}

#top_bar .main_menu > li.current-menu-item > a,
#top_bar .main_menu > li:hover > a {
	color: var(--ct-green-deep) !important;
}

/* ════════════════════════════════════════════════════════════════════
   15. MOBILE RESPONSIVE — max-width: 768px
   ════════════════════════════════════════════════════════════════════ */

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

	.single_tour_attribute_wrapper .one_fourth,
	.single_tour_attribute_wrapper .one_fifth {
		width: 48% !important;
		float: left !important;
		margin-bottom: 14px !important;
	}

	.ct-tour-type-toggle { flex-direction: row; gap: 4px; }
	.ct-tour-type-tab    { font-size: 0.8rem; padding: 9px 10px; }
	.ct-tab-icon         { font-size: 0.85rem; }

	.ct-form-row--2col { grid-template-columns: 1fr; gap: 12px; }

	.ct-private-form-header { padding: 16px 16px 14px; }
	.ct-private-form        { padding: 16px; }
	.ct-private-form-header h3 { font-size: 1.1rem; }

	.ct-price-block,
	.single_tour_header_price { padding: 12px 14px !important; }
	.single_tour_price { font-size: 1.5rem !important; }

	.ui-accordion .ui-accordion-header  { padding: 12px 14px !important; font-size: 0.88rem !important; }
	.ui-accordion .ui-accordion-content { padding: 14px 16px !important; font-size: 0.88rem !important; }

	.single_tour_departure_wrapper li { padding: 12px 16px !important; }
	.single_tour_departure_content .one_half {
		width: 100% !important;
		float: none !important;
		margin-bottom: 4px !important;
	}

	.ct-submit-btn { padding: 13px 16px !important; font-size: 0.9rem !important; }

	.single_tour_book_card_content {
		border-radius: var(--ct-radius) !important;
		padding: 18px !important;
	}
}

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

	.ct-tour-type-tab { font-size: 0.75rem; padding: 8px 6px; }
	.ct-tab-icon { display: none; }

	#page_content_wrapper h1,
	.sidebar_content h1 { font-size: 1.4rem !important; }

	.single_tour_price { font-size: 1.35rem !important; }
	.ct-private-form-header h3 { font-size: 1rem; }

	/* Disable hover lift on touch devices */
	.tour_grid_wrapper:hover,
	.tour_classic_wrapper:hover { transform: none; }
}

/* ════════════════════════════════════════════════════════════════════
   16. PRINT
   ════════════════════════════════════════════════════════════════════ */

@media print {
	.ct-tour-type-toggle { display: none !important; }
	.ct-tour-panel       { display: block !important; }
	.ct-private-form     { display: none !important; }
}