/*!
Theme Name: carfortrips.com
Theme URI: http://underscores.me/
Author: Daniel Voloshyn
Author URI: https://danielvoloshyn.com
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: carfortrips-com
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

carfortrips.com is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
	background: #fff;
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 10px 20px;
	padding-left: 10px;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

img {
	height: auto;
	max-width: 100%;
}

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Links
--------------------------------------------- */
a {
	color: #4169e1;
}

a:visited {
	color: #800080;
}

a:hover,
a:focus,
a:active {
	color: #191970;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
	border-color: #ccc #ccc #bbb;
	border-radius: 3px;
	background: #e6e6e6;
	color: rgba(0, 0, 0, 0.8);
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	border-radius: 3px;
	padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
	display: block;
	width: 100%;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	display: block;
	left: auto;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

@media screen and (min-width: 37.5em) {

	.menu-toggle {
		display: none;
	}

	.main-navigation ul {
		display: flex;
	}
}

.site-main .comment-navigation,
.site-main
.posts-navigation,
.site-main
.post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
}

.widget select {
	max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.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-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.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;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

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

/*--------------------------------------------------------------
# Apple-like Theme — Carfortrips
--------------------------------------------------------------*/

/* CSS Custom Properties
--------------------------------------------- */
:root {
	--color-black: #000000;
	--color-white: #ffffff;
	--color-gray-50: #fafafa;
	--color-gray-100: #f5f5f7;
	--color-gray-200: #e8e8ed;
	--color-gray-300: #d2d2d7;
	--color-gray-400: #86868b;
	--color-gray-500: #6e6e73;
	--color-gray-600: #424245;
	--color-gray-800: #1d1d1f;
	--color-gray-900: #111111;

	--color-primary: #0071e3;
	--color-primary-hover: #0077ed;

	--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;

	--header-height: 90px;
	--container-max: 1200px;
	--container-padding: 24px;
	--border-radius: 16px;
	--border-radius-sm: 12px;

	--transition-fast: 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
	--transition-medium: 0.4s cubic-bezier(0.25, 0.1, 0.25, 1);
	--transition-slow: 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);

	/* Price section */
	--price-economy: #3b82f6;
	--price-standard: #8b5cf6;
	--price-suv: #f59e0b;
	--price-luxury: #ef4444;
	--chart-bar-start: #0464c5;
	--chart-bar-end: #0077ed;
	--chart-track-bg: #f1f5f9;
	--chart-value-color: #475569;
	--disclaimer-bg: #f8fafc;
	--disclaimer-border: #e2e8f0;

	--gradient-amber: linear-gradient(90deg, #0077ed 0%, #0071e3 100%);
}

/* Global Reset & Base
--------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	font-family: var(--font-family);
	font-size: 16px;
	line-height: 1.6;
	color: var(--color-gray-800);
	background-color: var(--color-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

/* Header — Apple-like
--------------------------------------------- */
.site-header {
	position: static;
	background: var(--color-white);
	border-bottom: 1px solid var(--color-gray-200);
}

/* Hero variant: transparent, overlaps hero image */
.site-header--hero {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 10;
	background: transparent;
	border-bottom: none;
}

.header-inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
	display: flex;
	align-items: center;
	height: var(--header-height);
}

.site-branding {
	flex: 0 0 auto;
}

.menu-toggle {
	margin-left: auto;
}

/* Logo */

.site-branding .custom-logo-link {
	display: flex;
	align-items: center;
	text-decoration: none;
}

.site-branding .custom-logo {
	height: 80px;
	width: auto;
}

.site-branding .site-title-text {
	font-size: 18px;
	font-weight: 600;
	color: var(--color-gray-800);
	letter-spacing: -0.01em;
}

.site-header--hero .site-branding .site-title-text {
	color: var(--color-white);
}

/* Desktop Navigation */
.main-navigation {
	display: none;
	width: auto;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 32px;
}

.main-navigation ul li a {
	font-size: 15px;
	font-weight: 500;
	color: var(--color-gray-600);
	text-decoration: none;
	letter-spacing: -0.01em;
	transition: color var(--transition-fast);
	padding: 4px 0;
}

.main-navigation ul li a:hover,
.main-navigation ul li a:focus {
	color: var(--color-gray-800);
}

.main-navigation ul li.current-menu-item > a,
.main-navigation ul li.current_page_item > a {
	color: var(--color-gray-800);
	font-weight: 600;
}

/* Hero header: white nav links */
.site-header--hero .main-navigation ul li a {
	color: rgba(255, 255, 255, 0.8);
}

.site-header--hero .main-navigation ul li a:hover,
.site-header--hero .main-navigation ul li a:focus {
	color: var(--color-white);
}

.site-header--hero .main-navigation ul li.current-menu-item > a,
.site-header--hero .main-navigation ul li.current_page_item > a {
	color: var(--color-white);
}

/* Sub-menu */
.main-navigation ul ul {
	position: absolute;
	top: 100%;
	left: -16px;
	flex-direction: column;
	gap: 0;
	min-width: 200px;
	background: rgba(255, 255, 255, 0.95);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	border-radius: var(--border-radius-sm);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
	padding: 8px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity var(--transition-fast), transform var(--transition-fast), visibility var(--transition-fast);
}

.main-navigation ul li {
	position: relative;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.main-navigation ul ul li a {
	padding: 8px 20px;
	display: block;
	font-size: 14px;
	color: var(--color-gray-600);
	white-space: nowrap;
}

.main-navigation ul li.menu-item-has-children .sub-menu li a {
	color: #000000 !important;
} 

.main-navigation ul ul li a:hover {
	background: var(--color-gray-100);
	color: var(--color-gray-800);
}

/* Hamburger toggle */
.menu-toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 10px;
	border-radius: 8px;
	transition: background var(--transition-fast);
	position: relative;
	z-index: 1001;
}

.menu-toggle:hover {
	background: rgba(0, 0, 0, 0.06);
}

.site-header--hero .menu-toggle:hover {
	background: rgba(255, 255, 255, 0.12);
}

.hamburger-line {
	display: block;
	width: 20px;
	height: 2px;
	background: var(--color-gray-800);
	border-radius: 1px;
	transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.site-header--hero .hamburger-line {
	background: var(--color-white);
}

/* Hamburger → X animation */
.mobile-menu-open .hamburger-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.mobile-menu-open .hamburger-line:nth-child(2) {
	opacity: 0;
}

.mobile-menu-open .hamburger-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Menu Overlay */
.mobile-menu-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 60vh;
	background: rgba(255, 255, 255, 0.98);
	-webkit-backdrop-filter: saturate(180%) blur(24px);
	backdrop-filter: saturate(180%) blur(24px);
	z-index: 1000;
	transform: translateY(-100%);
	visibility: hidden;
	transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0.35s;
	display: flex;
	flex-direction: column;
	border-radius: 0 0 24px 24px;
	box-shadow: 0 8px 48px rgba(0, 0, 0, 0.12);
	overflow: hidden;
}

.mobile-menu-open .mobile-menu-overlay {
	transform: translateY(0);
	visibility: visible;
	transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0s;
}

/* Push hamburger below the overlay while menu is open */
.mobile-menu-open .menu-toggle {
	z-index: 990;
}

/* Close button bar at the top of the overlay */
.mobile-menu-bar {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 0 20px;
	height: var(--header-height);
	flex-shrink: 0;
}

.mobile-menu-close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: none;
	border: none;
	cursor: pointer;
	border-radius: 50%;
	color: var(--color-primary);
	transition: background var(--transition-fast);
	padding: 0;
}

.mobile-menu-close:hover {
	background: rgba(0, 113, 227, 0.08);
}

.mobile-menu-close .material-icons-outlined {
	font-size: 24px;
	line-height: 1;
}

.mobile-navigation {
	flex: 1;
	overflow-y: auto;
	padding: 0 24px 24px;
}

.mobile-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-navigation ul li {
	margin: 0;
	border-bottom: 1px solid var(--color-gray-100);
}

.mobile-navigation ul li:last-child {
	border-bottom: none;
}

.mobile-navigation ul li a {
	display: block;
	font-size: 16px;
	font-weight: 600;
	color: var(--color-gray-800);
	text-decoration: none;
	padding: 14px 0;
	letter-spacing: -0.01em;
	transition: color var(--transition-fast);
}

.mobile-navigation ul li a:hover {
	color: var(--color-primary);
}

.mobile-navigation ul li.current-menu-item > a,
.mobile-navigation ul li.current_page_item > a {
	color: var(--color-primary);
}

.mobile-navigation ul ul {
	margin: 0;
	padding: 0 0 8px 16px;
}

.mobile-navigation ul ul li {
	border-bottom: none;
}

.mobile-navigation ul ul li a {
	font-size: 14px;
	font-weight: 400;
	color: var(--color-gray-500);
	padding: 6px 0;
}

/* Lock body scroll when menu is open */
.mobile-menu-open {
	overflow: hidden;
}

/* Scrolled hamburger always dark */
.site-header.header-scrolled .hamburger-line {
	background: var(--color-gray-800);
}

.site-header--hero.header-scrolled .hamburger-line {
	background: var(--color-white);
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
.hero-section {
	position: relative;
	height: 600px;
	max-height: 600px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-color: var(--color-gray-900);
	overflow: hidden;
}

.hero-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.65);
	z-index: 1;
}

.hero-content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 1200px;
	padding: 80px var(--container-padding) 40px;
	margin: 0 auto;
}

.hero-title {
	font-size: clamp(36px, 6vw, 44px);
	font-weight: 700;
	color: var(--color-white);
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin: 0 0 20px;
}

.hero-description {
	font-size: clamp(16px, 2.5vw, 18px);
	font-weight: 300;
	color: #FFFFFF;
	line-height: 1.5;
	margin: 0 auto 36px;
	max-width: 640px;
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
}

/* Advantages — Badge row */
.hero-advantages {
	display: grid;
	grid-template-columns: repeat(4, auto);
	gap: 12px;
	justify-content: center;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.hero-advantage-badge {
	display: flex;
	align-items: center;
	gap: 10px;
	background: rgba(255, 255, 255, 0.1);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid var(--color-primary);
	border-radius: 50px;
	padding: 7px 20px 7px 14px;
	transition: background var(--transition-fast), border-color var(--transition-fast);
	white-space: nowrap;
}

.hero-advantage-badge:hover {
	background: rgba(255, 255, 255, 0.18);
	border-color: rgba(255, 255, 255, 0.26);
}

.hero-advantage-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
}

.hero-advantage-icon svg {
	width: 27px;
	height: 27px;
}

.hero-advantage-title {
	font-size: 14px;
	font-weight: 500;
	color: var(--color-white);
	letter-spacing: -0.01em;
	line-height: 1.3;
}

/* Hero section responsive */
@media screen and (max-width: 768px) {
	.hero-section {
		height: 500px;
		max-height: 500px;
	}

	.hero-advantages {
		grid-template-columns: repeat(2, auto);
		gap: 8px;
	}

	.hero-content {
		padding: 140px var(--container-padding) 30px;
	}

	.entry-content h2 {
		line-height: 1.3;
	}
}

@media screen and (max-width: 480px) {
	.hero-section {
		height: auto;
		min-height: 420px;
		max-height: none;
	}

	.hero-advantages {
		grid-template-columns: 1fr 1fr;
		gap: 8px;
	}

	.hero-advantage-badge {
		white-space: normal;
		padding: 8px 14px 8px 10px;
	}

	.hero-advantage-title {
		font-size: 12px;
		text-align: left;
	}
}

/*--------------------------------------------------------------
# Page Layout — Clean
--------------------------------------------------------------*/
.site-main {
	padding-top: 60px;
	padding-bottom: 80px;
}

/* Hero template pages: hero starts right after header */
.page-template-page-hero .site-main {
	padding-top: 0;
	padding-bottom: 0px;
}

/* Featured image — float right
--------------------------------------------- */
.page-featured-image {
	float: right;
	margin: 0 0 28px 40px;
	width: 400px;
	max-width: 46%;
}

.page-featured-image img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: var(--border-radius);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.page-featured-caption {
	margin: 10px 0 0;
	font-size: 13px;
	color: var(--color-gray-400);
	line-height: 1.5;
	text-align: center;
}

/* Gutenberg block library може додавати display:flow-root до .is-layout-flow —
   скасовуємо тільки в межах entry-content, щоб float працював */
.entry-content .is-layout-flow,
.entry-content .wp-block-post-content {
	display: block;
}

.entry-content::after {
	content: '';
	display: table;
	clear: both;
}

/* Underscores base задає clear:both для всіх h1-h6 — це ламає float картинки.
   Скасовуємо тільки всередині entry-content на hero-сторінках. */
.page-template-page-hero .entry-content h1,
.page-template-page-hero .entry-content h2,
.page-template-page-hero .entry-content h3,
.page-template-page-hero .entry-content h4,
.page-template-page-hero .entry-content h5,
.page-template-page-hero .entry-content h6 {
	clear: none;
}

@media screen and (max-width: 768px) {
	.page-featured-image {
		float: none;
		max-width: 100%;
		margin: 0 0 28px;
	}
}

.entry-content {
	margin: 0;
	font-size: 17px;
	line-height: 1.7;
	color: var(--color-gray-600);
}

.entry-content h2 {
	font-size: 32px;
	font-weight: 700;
	color: var(--color-gray-800);
	letter-spacing: -0.02em;
	margin: 2em 0 0.6em;
}

.entry-content h3 {
	font-size: 24px;
	font-weight: 600;
	color: var(--color-gray-800);
	letter-spacing: -0.01em;
	margin: 1.8em 0 0.5em;
}

.entry-content p {
	margin: 0 0 10px;
}

.entry-content a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.entry-content a:hover {
	color: var(--color-primary-hover);
	text-decoration: underline;
}

/*--------------------------------------------------------------
# Footer — Apple style
--------------------------------------------------------------*/
.site-footer {
	background: #f5f5f7;
	padding: 64px 0 40px;
}

.footer-inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

/* Logo */
.footer-logo {
	margin-bottom: 20px;
}

.footer-logo a {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

.footer-logo__img {
	height: 100px;
	width: auto;
	display: block;
}

.footer-logo__text {
	font-size: 18px;
	font-weight: 700;
	color: #1d1d1f;
	letter-spacing: -0.02em;
}

/* SEO text */
.footer-seo-text {
	max-width: 1000px;
	font-size: 15px;
	line-height: 1.7;
	color: #606060;
	margin: 0 0 36px;
}

.footer-seo-text p {
	margin: 0 0 10px;
}

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

.footer-seo-text a {
	color: #515154;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.footer-seo-text a:hover {
	color: #1d1d1f;
}


.footer-instagram {
	margin: -16px 0 36px;
	text-align: center;
}

.footer-instagram__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 24px;
	background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
	color: #fff;
	text-decoration: none;
	border-radius: 50px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 2px 12px rgba(188, 24, 136, 0.25);
}

.footer-instagram__btn:hover {
	opacity: 0.88;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(188, 24, 136, 0.35);
	color: #fff;
}

.footer-instagram__btn svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
}

.footer-instagram__btn:visited {
	color: #fff;
}

/* Footer nav */
.footer-nav {
	margin-bottom: 32px;
}

.footer-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 4px 0;
}

.footer-nav ul li {
	display: flex;
	align-items: center;
}

.footer-nav ul li + li::before {
	content: '';
	display: inline-block;
	width: 1px;
	height: 12px;
	background: #c7c7cc;
	margin: 0 14px;
	flex-shrink: 0;
}

.footer-nav ul li a {
	font-size: 14px;
	color: #515154;
	text-decoration: none;
	transition: color var(--transition-fast);
	white-space: nowrap;
}

.footer-nav ul li a:hover {
	color: #1d1d1f;
}

/* Divider */
.footer-divider {
	width: 100%;
	height: 1px;
	background: #d2d2d7;
	margin-bottom: 20px;
}

/* Copyright */
.footer-copyright {
	font-size: 15px;
	color: #585858;
	margin: 0;
	line-height: 1.5;
}

.footer-copyright a {
	color: #86868b;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.footer-copyright a:hover {
	color: #1d1d1f;
}

@media screen and (max-width: 640px) {
	.site-footer {
		padding: 48px 0 32px;
	}

	.footer-nav ul {
		gap: 8px 0;
	}

	.footer-nav ul li + li::before {
		margin: 0 10px;
	}
}

/*--------------------------------------------------------------
# Desktop breakpoint
--------------------------------------------------------------*/
@media screen and (min-width: 769px) {
	.main-navigation {
		display: flex;
		align-items: center;
		width: auto;
		margin-left: auto;
	}

	.menu-toggle {
		display: none;
	}

	.mobile-menu-overlay {
		display: none;
	}
}

@media screen and (max-width: 768px) {
	:root {
		--header-height: 100px;
	}

	.site-branding .custom-logo {
		height: 70px;
	}
}

/*--------------------------------------------------------------
# Widget Section
--------------------------------------------------------------*/
.widget-section {
	background: #ffffff;
	padding: 40px 0 0px;
}

.widget-section .container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.carfortrips-widget-wrap {
	width: 100%;
}

/* Advantages row
--------------------------------------------- */
.page-advantages {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 8px 24px;
	margin-bottom: 32px;
}

.page-advantage-item {
	display: flex;
	align-items: center;
	gap: 7px;
	white-space: nowrap;
}

.page-advantage-icon {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	line-height: 1;
}

.page-advantage-text {
	font-size: 14px;
	font-weight: 500;
	color: var(--color-gray-600);
	letter-spacing: -0.01em;
}

@media screen and (max-width: 768px) {
	.widget-section {
		padding: 32px 0 40px;
	}

	.page-advantages {
		gap: 8px 16px;
		margin-bottom: 24px;
	}

	.page-advantage-text {
		font-size: 13px;
	}
}

.search-cigarette__wrap, .vehicle-card-footer__view, .search__button-more {
    background: var(--gradient-amber) !important;
}

/*--------------------------------------------------------------
# Price Section — Car Hire Price module
--------------------------------------------------------------*/
.price-section {
	padding: 60px 0 80px;
	background: var(--color-white);
}

.price-section .container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.price-section__title {
	font-size: 32px;
	font-weight: 700;
	color: var(--color-gray-800);
	letter-spacing: -0.025em;
	margin: 0 0 20px;
	line-height: 1.2;
}

.price-section__title--chart {
	margin-top: 56px;
}

.price-section__text {
	font-size: 17px;
	line-height: 1.75;
	color: var(--color-gray-600);
	margin-bottom: 32px;
}

.price-section__text p {
	margin: 0 0 14px;
}

.price-section__text ul,
.price-section__text ol {
	padding-left: 1.4em;
	margin: 0 0 20px;
}

.price-section__text li {
	margin-bottom: 6px;
}

.price-section__text a {
	color: var(--color-primary);
	text-decoration: none;
}

.price-section__text a:hover {
	text-decoration: underline;
}

.price-section__text h3 {
	font-size: 22px;
	font-weight: 600;
	color: var(--color-gray-800);
	margin: 1.6em 0 0.5em;
}

/* Price cards
--------------------------------------------- */
.price-cards {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin: 32px 0 40px;
}

.price-card {
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--border-radius);
	padding: 20px;
	overflow: hidden;
	transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.price-card:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

/* Header row: icon + name */
.price-card__header {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 18px;
}

.price-card__icon-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 48px;
	height: 48px;
	border-radius: 14px;
	flex-shrink: 0;
}

.price-card--economy  .price-card__icon-wrap { background: linear-gradient(135deg, #2563eb, #60a5fa); }
.price-card--standard .price-card__icon-wrap { background: linear-gradient(135deg, #7c3aed, #a78bfa); }
.price-card--suv      .price-card__icon-wrap { background: linear-gradient(135deg, #d97706, #fbbf24); }
.price-card--luxury   .price-card__icon-wrap { background: linear-gradient(135deg, #dc2626, #f87171); }

.price-card__icon-wrap svg {
	width: 24px;
	height: 24px;
}

.price-card__cat {
	font-size: 15px;
	font-weight: 700;
	color: var(--color-gray-800);
	letter-spacing: -0.01em;
	line-height: 1.2;
}

.price-card__sub {
	font-size: 12px;
	color: var(--color-gray-400);
	font-weight: 500;
	margin-top: 2px;
}

/* Price block */
.price-card__price-block {
	display: flex;
	align-items: baseline;
	gap: 3px;
	flex-wrap: wrap;
	border-top: 1px solid var(--color-gray-100);
	padding-top: 14px;
}

.price-card__from {
	font-size: 12px;
	font-weight: 500;
	color: var(--color-gray-400);
	margin-right: 2px;
	align-self: center;
}

.price-card__amount {
	font-size: 17px;
	font-weight: 800;
	color: var(--color-gray-800);
	letter-spacing: -0.04em;
	line-height: 1;
}

.price-card__sep {
	font-size: 18px;
	font-weight: 400;
	color: var(--color-gray-300);
}

.price-card__unit {
	font-size: 12px;
	font-weight: 500;
	color: var(--color-gray-400);
	align-self: flex-end;
	margin-left: 2px;
	margin-bottom: 2px;
}

@media screen and (max-width: 768px) {
	.price-cards {
		grid-template-columns: repeat(1, 1fr);
		gap: 12px;
	}

	.price-card__icon-wrap {
		width: 40px;
		height: 40px;
		border-radius: 11px;
	}

	.price-card__amount {
		font-size: 19px;
	}

	.price-section__title {
		font-size: 26px;
	}
}

/* Disclaimer
--------------------------------------------- */
.price-disclaimer {
	background: var(--disclaimer-bg);
	border: 1px solid var(--disclaimer-border);
	border-radius: var(--border-radius-sm);
	padding: 20px 24px;
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin: 32px 0;
}

.price-disclaimer__icon {
	flex-shrink: 0;
	font-size: 18px;
	line-height: 1.6;
}

.price-disclaimer__text {
	margin: 0;
	font-size: 14px;
	line-height: 1.65;
	color: var(--color-gray-500);
}

/* Chart
--------------------------------------------- */
.price-chart {
	display: flex;
	gap: 8px;
	align-items: flex-end;
	margin: 32px 0 40px;
}

.price-chart__col {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.price-chart__track {
	width: 100%;
	height: 300px;
	background: var(--chart-track-bg);
	border-radius: 10px;
	position: relative;
}

.price-chart__bar {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: var(--h, 0%);
	background: linear-gradient(to top, var(--chart-bar-start), var(--chart-bar-end));
	border-radius: 8px 8px 0 0;
	transform: scaleY(0);
	transform-origin: bottom;
	animation: cftBarGrow 0.8s cubic-bezier(0.34, 1.2, 0.64, 1) forwards;
}

@keyframes cftBarGrow {
	to {
		transform: scaleY(1);
	}
}

.price-chart__value {
	position: absolute;
	bottom: var(--h, 0%);
	left: 0;
	right: 0;
	text-align: center;
	font-size: 12px;
	font-weight: 700;
	color: var(--chart-value-color);
	padding-bottom: 6px;
	opacity: 0;
	animation: cftValFade 0.4s ease forwards;
}

@keyframes cftValFade {
	to {
		opacity: 1;
	}
}

.price-chart__label {
	font-size: 13px;
	font-weight: 600;
	color: var(--color-gray-400);
	letter-spacing: 0.01em;
}

@media screen and (max-width: 768px) {
	.price-chart {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 8px;
	}

	.price-chart__col {
		min-width: 48px;
	}

	.price-chart__track {
		height: 220px;
	}

	.price-chart__label {
		font-size: 11px;
	}

	.price-chart__value {
		font-size: 10px;
	}

	.price-section__text tbody td {
		white-space: nowrap;
	}

	.price-section__text {
		font-size: 16px;
	}

	.entry-content {
		font-size: 16px;
	}
}

/* Tables inside price section
--------------------------------------------- */
.price-section__text table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 28px 0;
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--border-radius-sm);
	overflow: hidden;
	font-size: 14px;
}

.price-section__text thead th {
	background: var(--color-gray-50);
	text-align: left;
	padding: 12px 16px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-gray-500);
	border-bottom: 2px solid var(--color-gray-200);
}

.price-section__text tbody td {
	padding: 11px 16px;
	color: var(--color-gray-600);
	border-bottom: 1px solid var(--color-gray-100);
}

.price-section__text tbody tr:last-child td {
	border-bottom: none;
}

.price-section__text tbody tr:hover td {
	background: var(--color-gray-50);
}

/* Responsive table scroll — horizontal scroll on mobile */
@media screen and (max-width: 768px) {
	.entry-content table,
	.price-section__text table,
	.ct-location-card table {
		display: block;
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}

/*--------------------------------------------------------------
# Requirements Section
--------------------------------------------------------------*/
.req-section {
	padding: 64px 0;
	background: var(--color-gray-50);
	border-top: 1px solid var(--color-gray-200);
}

.req-section__inner {
	max-width: 100%;
}

/* Two-column layout */
.req-layout {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: 56px;
	align-items: start;
}

.req-section__title {
	font-size: 32px;
	font-weight: 700;
	color: var(--color-gray-800);
	letter-spacing: -0.025em;
	margin: 0 0 24px;
	line-height: 1.2;
}

/* Age badge — compact */
.req-age-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--color-primary);
	border-radius: 50px;
	padding: 6px 14px 6px 8px;
	margin-bottom: 20px;
}

.req-age-badge__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: rgba(255,255,255,0.2);
	border-radius: 50%;
	font-size: 16px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.02em;
	line-height: 1;
}

.req-age-badge__label {
	font-size: 13px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
	letter-spacing: 0.01em;
	line-height: 1;
}

/* Intro text */
.req-section__text {
	font-size: 17px;
	line-height: 1.75;
	color: var(--color-gray-600);
	margin-bottom: 32px;
}

.req-section__text p {
	margin: 0 0 12px;
}

.req-section__text p:last-child {
	margin-bottom: 0;
}

/* Documents list */
.req-docs {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 32px;
}

.req-doc-item {
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--border-radius-sm);
	padding: 16px 20px;
	transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.req-doc-item:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
	transform: translateX(4px);
}

.req-doc-item__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--color-primary), #60a5fa);
	flex-shrink: 0;
}

.req-doc-item__icon svg {
	width: 22px;
	height: 22px;
	fill: #ffffff;
}

.req-doc-item__title {
	font-size: 16px;
	font-weight: 600;
	color: var(--color-gray-800);
	letter-spacing: -0.01em;
}

/* Closing note */
.req-section__note {
	background: var(--color-white);
	border-radius: var(--border-radius-sm);
	padding: 15px 24px;
	font-size: 15px;
	line-height: 1.65;
	color: var(--color-gray-500);
}

.req-section__note p {
	margin: 0 0 8px;
}

.req-section__note p:last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 900px) {
	.req-layout {
		grid-template-columns: 1fr;
		gap: 32px;
	}
}

@media screen and (max-width: 768px) {
	.req-section {
		padding: 48px 0;
	}

	.req-section__title {
		font-size: 26px;
	}

	.req-doc-item {
		padding: 14px 16px;
	}

	.req-doc-item__icon {
		width: 38px;
		height: 38px;
		border-radius: 10px;
	}

	.req-doc-item__title {
		font-size: 15px;
	}
	.req-section__text {
		font-size: 16px;
	}
}

/* ==========================================================================
   Booking / How-to-Book section  –  Progress step style
   ========================================================================== */

.booking-section {
	padding: 80px 0;
	background: var(--color-white);
	border-top: 1px solid var(--color-gray-200);
}

/* ---- Header block: title + intro centred above the steps ---- */

.booking-section__header {
	text-align: center;
	max-width: 800px;
	margin: 0 auto 36px;
}

.booking-section__title {
	font-size: 34px;
	font-weight: 700;
	color: var(--color-gray-800);
	margin: 0 0 16px;
	letter-spacing: -0.025em;
	line-height: 1.2;
}

.booking-section__intro {
	color: var(--color-gray-500);
	font-size: 17px;
	line-height: 1.7;
	margin: 0;
}

.booking-section__intro p {
	margin: 0 0 10px;
}

.booking-section__intro p:last-child {
	margin-bottom: 0;
}

/* ---- Progress steps wrapper ---- */

.booking-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	margin-bottom: 10px;
	position: relative;
	background: #f5f5f5;
	border-radius: 25px;
}



/* ---- Individual step card ---- */

.booking-step-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 35px 30px 25px 30px;
	position: relative;
	z-index: 1;
}

/* Number pill above icon */
.booking-step__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: linear-gradient(135deg, #45ace7 0%, var(--color-primary-hover) 100%);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-bottom: 12px;
	box-shadow: 0 3px 10px rgba(99, 102, 241, 0.4);
	flex-shrink: 0;
}

/* Icon circle */
.booking-step__icon {
	width: 72px;
	height: 72px;
	border-radius: 20px;
	background: linear-gradient(135deg, #45ace7 0%, var(--color-primary-hover) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	box-shadow: 0 6px 20px rgba(99, 102, 241, 0.28);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.booking-step-card:hover .booking-step__icon {
	transform: translateY(-4px);
	box-shadow: 0 14px 30px rgba(99, 102, 241, 0.35);
}

.booking-step__icon svg {
	width: 32px;
	height: 32px;
	fill: #fff;
	display: block;
}

.booking-step__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-gray-800);
	margin: 0 0 10px;
	letter-spacing: -0.01em;
	line-height: 1.3;
}

.booking-step__text {
	font-size: 15px;
	color: var(--color-gray-500);
	line-height: 1.7;
	margin: 0;
	max-width: 320px;
}

/* ---- Closing note ---- */

.booking-section__note {
	margin: 0 auto;
	text-align: center;
	border-radius: var(--border-radius);
	padding: 10px 32px;
	color: var(--color-gray-500);
	font-size: 15px;
	line-height: 1.7;
}

.booking-section__note p {
	margin: 0 0 10px;
}

.booking-section__note p:last-child {
	margin-bottom: 0;
}

/* ---- Responsive ---- */

@media screen and (max-width: 900px) {
	.booking-steps {
		grid-template-columns: 1fr;
	}

	.booking-steps::before {
		display: none;
	}

	.booking-step-card {
		flex-direction: row;
		align-items: flex-start;
		text-align: left;
		gap: 20px;
		padding: 20px 20px;
		border-bottom: 1px solid var(--color-gray-200);
	}

	.booking-step-card:last-child {
		border-bottom: none;
	}

	.booking-step__icon {
		flex-shrink: 0;
		margin-bottom: 0;
	}

	.booking-step__body {
		flex: 1;
	}

	.booking-step__num {
		margin-bottom: 8px;
	}

	.booking-step__text {
		max-width: none;
	}
}

@media screen and (max-width: 640px) {
	.booking-section {
		padding: 56px 0;
	}

	.booking-section__title {
		font-size: 26px;
	}

	.booking-section__intro {
		font-size: 16px;
	}

	.booking-section__header {
		margin-bottom: 40px;
	}

	.booking-step__icon {
		width: 56px;
		height: 56px;
		border-radius: 15px;
	}

	.booking-step__icon svg {
		width: 26px;
		height: 26px;
	}

	.booking-step__num {
		display: none;
	}
}

/* ==========================================================================
   Popular Tourist Locations — Bento grid
   ========================================================================== */

.locations-section {
	padding: 80px 0;
	background: var(--color-gray-100);
	border-top: 1px solid var(--color-gray-200);
}

.locations-section__header {
	text-align: center;
	max-width: 1000px;
	margin: 0 auto 26px;
}

.locations-section__title {
	font-size: 34px;
	font-weight: 700;
	color: var(--color-gray-800);
	margin: 0 0 16px;
	letter-spacing: -0.025em;
	line-height: 1.2;
}

.locations-section__intro {
	color: var(--color-gray-500);
	font-size: 17px;
	line-height: 1.7;
	margin: 0;
}

.locations-section__intro p {
	margin: 0 0 10px;
}

.locations-section__intro p:last-child {
	margin-bottom: 0;
}

/* ---- Bento grid ---- */

.locations-grid {
	display: grid;
	gap: 20px;
}

/* 4 items: asymmetric zig-zag bento */
.locations-grid--4 {
	grid-template-columns: 7fr 5fr;
	grid-template-rows: auto auto;
}

.locations-grid--4 .loc-card--1 { grid-column: 1; }
.locations-grid--4 .loc-card--2 { grid-column: 2; }
.locations-grid--4 .loc-card--3 { grid-column: 1; }
.locations-grid--4 .loc-card--4 { grid-column: 2; }

/* 3 items */
.locations-grid--3 {
	grid-template-columns: 7fr 5fr;
}

.locations-grid--3 .loc-card--1 { grid-column: 1; grid-row: 1 / 3; }
.locations-grid--3 .loc-card--1 .loc-card__image { height: 100%; min-height: 360px; }
.locations-grid--3 .loc-card--1 .loc-card__image img { height: 100%; }
.locations-grid--3 .loc-card--2 { grid-column: 2; }
.locations-grid--3 .loc-card--3 { grid-column: 2; }

/* 2 items */
.locations-grid--2 {
	grid-template-columns: 1fr 1fr;
}

/* 1 item */
.locations-grid--1 {
	grid-template-columns: 1fr;
	max-width: 720px;
}

/* ---- Location card ---- */

.loc-card {
	background: var(--color-white);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
	display: flex;
	flex-direction: column;
}

.loc-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 48px rgba(0, 0, 0, 0.12);
}

/* Image area */
.loc-card__image {
	position: relative;
	height: 260px;
	overflow: hidden;
	flex-shrink: 0;
}

.loc-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.loc-card:hover .loc-card__image img {
	transform: scale(1.05);
}

.loc-card__image--empty {
	background: linear-gradient(135deg, #6366f1 0%, #818cf8 50%, #a78bfa 100%);
}

/* Gradient overlay at bottom of image for title readability */
.loc-card__overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 50%;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0) 100%);
	pointer-events: none;
	z-index: 1;
}

/* Title overlaid on image */
.loc-card__title--over {
	position: absolute;
	bottom: 20px;
	left: 24px;
	right: 24px;
	margin: 0;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	z-index: 2;
	letter-spacing: -0.015em;
	line-height: 1.25;
	text-shadow: 0 1px 6px rgba(0, 0, 0, 0.3);
}

/* Text body below image */
.loc-card__body {
	padding: 24px;
	flex: 1;
	color: var(--color-gray-500);
	font-size: 15px;
	line-height: 1.7;
}

.loc-card__body p {
	margin: 0 0 12px;
}

.loc-card__body p:last-child {
	margin-bottom: 0;
}

.loc-card__body ul,
.loc-card__body ol {
	margin: 0 0 14px;
	padding-left: 20px;
}

.loc-card__body li {
	margin-bottom: 4px;
}

.loc-card__body strong {
	color: var(--color-gray-800);
	font-weight: 600;
}

/* ---- Responsive ---- */

@media screen and (max-width: 900px) {
	.locations-grid--4 {
		grid-template-columns: 1fr 1fr;
	}

	.locations-grid--3 {
		grid-template-columns: 1fr;
	}

	.locations-grid--3 .loc-card--1 {
		grid-row: auto;
	}

	.locations-grid--3 .loc-card--1 .loc-card__image {
		height: 260px;
		min-height: 0;
	}
}

@media screen and (max-width: 640px) {
	.locations-section {
		padding: 56px 0;
	}

	.locations-section__title {
		font-size: 26px;
	}

	.locations-section__intro {
		font-size: 16px;
	}

	.locations-section__header {
		margin-bottom: 40px;
	}

	.locations-grid--4,
	.locations-grid--3,
	.locations-grid--2 {
		grid-template-columns: 1fr;
	}

	.locations-grid--4 .loc-card--1,
	.locations-grid--4 .loc-card--2,
	.locations-grid--4 .loc-card--3,
	.locations-grid--4 .loc-card--4 {
		grid-column: 1;
	}

	.loc-card__image {
		height: 220px;
	}

	.loc-card__title--over {
		font-size: 19px;
		bottom: 16px;
		left: 18px;
		right: 18px;
	}

	.loc-card__body {
		padding: 18px;
	}

	.loc-card {
		border-radius: 16px;
	}
}

/* ==========================================================================
   Customer Reviews section
   ========================================================================== */

.reviews-section {
	padding: 80px 0;
	background: var(--color-white);
	border-top: 1px solid var(--color-gray-200);
}

/* ---- Header ---- */

.reviews-section__header {
	text-align: center;
	max-width: 1000px;
	margin: 0 auto 30px;
}

.reviews-section__title {
	font-size: 34px;
	font-weight: 700;
	color: var(--color-gray-800);
	margin: 0 0 16px;
	letter-spacing: -0.025em;
	line-height: 1.2;
}

.reviews-section__intro {
	color: var(--color-gray-500);
	font-size: 17px;
	line-height: 1.7;
	margin: 0;
}

.reviews-section__intro p {
	margin: 0 0 8px;
}

.reviews-section__intro p:last-child {
	margin-bottom: 0;
}

/* ---- Aggregate rating block — Apple App Store style ---- */

.reviews-aggregate {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 0;
	margin: 0 auto 52px;
	background: #ffffff;
	border-radius: 22px;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(0, 0, 0, 0.05);
	overflow: hidden;
	width: fit-content;
}

.reviews-aggregate__left {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 36px 44px;
	gap: 4px;
}

.reviews-aggregate__sep {
	width: 1px;
	align-self: stretch;
	background: rgba(0, 0, 0, 0.07);
	flex-shrink: 0;
}

.reviews-aggregate__right {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 36px 44px;
	gap: 10px;
}

.reviews-aggregate__score {
	font-size: 76px;
	font-weight: 700;
	color: #1d1d1f;
	line-height: 1;
	letter-spacing: -0.05em;
	font-variant-numeric: tabular-nums;
}

.reviews-aggregate__out-of {
	font-size: 13px;
	color: #86868b;
	font-weight: 400;
	letter-spacing: 0.01em;
}

.reviews-aggregate__label {
	font-size: 13px;
	color: #86868b;
	font-weight: 400;
}

/* ---- Stars ---- */

.rev-stars {
	display: inline-flex;
	gap: 2px;
}

.rev-star {
	font-size: 20px;
	line-height: 1;
	color: #d1d5db;
	display: inline-block;
}

.reviews-aggregate .rev-star {
	font-size: 24px;
}

.reviews-aggregate .rev-star--full {
	color: #ff9f0a;
}

.reviews-aggregate .rev-star--half::before {
	color: #ff9f0a;
}

.rev-star--full {
	color: #f59e0b;
}

.rev-star--empty {
	color: #d1d5db;
}

.rev-star--half {
	position: relative;
	color: #d1d5db;
}

.rev-star--half::before {
	content: '★';
	position: absolute;
	left: 0;
	top: 0;
	color: #f59e0b;
	clip-path: inset(0 50% 0 0);
}

/* ---- Reviews grid ---- */

.reviews-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

/* ---- Review card ---- */

.rev-card {
	background: var(--color-white);
	border: 1px solid var(--color-gray-200);
	border-radius: 20px;
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.rev-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.09);
}

/* Stars + decorative quote mark */
.rev-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.rev-card__quote-mark {
	font-size: 48px;
	line-height: 1;
	color: #e0e7ff;
	font-family: Georgia, serif;
	font-weight: 700;
	margin-top: -8px;
	user-select: none;
}

/* Review text */
.rev-card__text {
	color: var(--color-gray-500);
	font-size: 15px;
	line-height: 1.7;
	flex: 1;
}

.rev-card__text p {
	margin: 0 0 10px;
}

.rev-card__text p:last-child {
	margin-bottom: 0;
}

/* Author row */
.rev-card__author {
	display: flex;
	align-items: center;
	gap: 12px;
	padding-top: 16px;
	border-top: 1px solid var(--color-gray-200);
}

/* Gradient avatar circle */
.rev-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.02em;
}

.rev-card__author-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.rev-card__author-name {
	font-size: 14px;
	font-weight: 700;
	color: var(--color-gray-800);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.rev-card__author-location {
	font-size: 12px;
	color: var(--color-gray-400);
}

.rev-card__date {
	font-size: 11px;
	color: var(--color-gray-400);
	white-space: nowrap;
	flex-shrink: 0;
}

/* ---- Responsive ---- */

@media screen and (max-width: 900px) {
	.reviews-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width: 640px) {
	.reviews-section {
		padding: 56px 0;
	}

	.reviews-section__title {
		font-size: 26px;
	}

	.reviews-grid {
		grid-template-columns: 1fr;
	}

	.reviews-aggregate {
		flex-direction: column;
		padding: 0;
		width: auto;
	}

	.reviews-aggregate__left,
	.reviews-aggregate__right {
		padding: 24px 32px;
		width: 100%;
	}

	.reviews-aggregate__sep {
		width: 56px;
		height: 1px;
		align-self: auto;
	}

	.reviews-aggregate__score {
		font-size: 56px;
	}

	.rev-card {
		padding: 22px;
		border-radius: 16px;
	}
}

/* ==============================================
   FAQ Section — Apple-style accordion
   ============================================== */

.faq-section {
	padding: 96px 0;
	background: var(--color-gray-50, #f5f5f7);
}

.faq-section__header {
	text-align: center;
	max-width: 1000px;
	margin: 0 auto 36px;
}

.faq-section__title {
	font-size: clamp(28px, 4vw, 38px);
	font-weight: 700;
	color: #1d1d1f;
	letter-spacing: -0.03em;
	margin: 0 0 16px;
	line-height: 1.15;
}

.faq-section__intro {
	font-size: 17px;
	color: #6e6e73;
	line-height: 1.65;
}

.faq-section__intro p {
	margin: 0 0 8px;
}

.faq-section__intro p:last-child {
	margin-bottom: 0;
}

/* ---- FAQ grid ---- */

.faq-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	align-items: start;
}

/* ---- FAQ item card ---- */

.faq-item {
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06), 0 0 0 1px rgba(0, 0, 0, 0.06);
	overflow: hidden;
	transition: box-shadow var(--transition-fast, 0.15s ease);
}

.faq-item:hover {
	box-shadow: 0 6px 28px rgba(0, 0, 0, 0.10), 0 0 0 1px rgba(0, 0, 0, 0.08);
}

/* ---- Question button ---- */

.faq-item__q {
	display: flex;
	align-items: center;
	gap: 14px;
	width: 100%;
	padding: 17px 22px;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
	transition: background var(--transition-fast, 0.15s ease);
}

.faq-item__q:hover {
	background: rgba(0, 0, 0, 0.02);
}

.faq-item__q:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: -2px;
	border-radius: 14px;
}

/* ---- Icon badge ---- */

.faq-item__icon {
	width: 38px;
	height: 38px;
	border-radius: 11px;
	background: linear-gradient(145deg, var(--color-primary), #60a5fa);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: #ffffff;
}

.faq-item__icon svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
	display: block;
}

/* ---- Question text ---- */

.faq-item__q-text {
	flex: 1;
	font-size: 16px;
	font-weight: 600;
	color: #1d1d1f;
	line-height: 1.4;
}

/* ---- Chevron ---- */

.faq-item__chevron {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.05);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: #86868b;
	transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1), background 0.2s ease, color 0.2s ease;
}

.faq-item__chevron svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
	display: block;
}

.faq-item[data-open] .faq-item__chevron {
	transform: rotate(180deg);
	background: rgba(0, 113, 227, 0.10);
	color: var(--color-primary);
}

/* ---- Answer panel ---- */

.faq-item__a {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-item__a-inner {
	padding: 16px 22px 22px 74px; /* 22px left + 38px icon + 14px gap = 74px aligns with text */
	font-size: 15px;
	color: #6e6e73;
	line-height: 1.7;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
}

/* ---- Responsive ---- */

@media screen and (max-width: 768px) {
	.faq-grid {
		grid-template-columns: 1fr;
	}
	.faq-item__q {
		padding: 15px 15px;
	}
	.faq-item__q-text {
		font-size: 15px;
    line-height: 1.3;
	}
}

@media screen and (max-width: 640px) {
	.faq-section {
		padding: 56px 0;
	}

	.faq-section__title {
		font-size: 26px;
	}

	.faq-item__a-inner {
		padding-left: 22px;
	}
}

/* ==============================================
   Material Icons — nav menu icons
   ============================================== */

/* Icon inside nav link (<a>) */
.nav-icon.material-icons-outlined {
	font-size: 20px;
	line-height: 1;
	vertical-align: middle;
	margin-right: 5px;
	margin-top: -2px; /* optical vertical alignment */
	display: inline-block;
	flex-shrink: 0;
}

/* Keep nav links that have icons flex-aligned */
#primary-menu .menu-item a,
#footer-menu-list .menu-item a {
	display: inline-flex;
	align-items: center;
}

/* ==============================================
   About Us Page — Tailwind-inspired
   ============================================== */

/* ---- Page shell ---- */
.ab-page {
	background: #f8fafc;
	min-height: 100vh;
}

.ab-mx {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

/* ---- Section rhythm ---- */
.ab-section {
	padding: 56px 0;
}

.ab-section--flush {
	padding: 0;
}

/* ---- Section headings ---- */
.ab-section__h2 {
	font-size: 28px;
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 0 0 32px;
}

.ab-section__h2--center {
	text-align: center;
}

.ab-section__intro {
	font-size: 16px;
	color: #64748b;
	line-height: 1.6;
	margin: -20px 0 36px;
	text-align: center;
}

.ab-section__intro--left {
	text-align: left;
	margin-top: -20px;
}

/* ---- Hero ---- */
.ab-hero {
	padding: 72px 0 0px;
	text-align: center;
}

.ab-hero__badge {
	width: 64px;
	height: 64px;
	margin: 0 auto 20px;
	border-radius: 18px;
	background: linear-gradient(145deg, #0ea5e9, var(--color-primary));
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 14px rgba(0, 113, 227, 0.3);
}

.ab-hero__badge .material-icons-outlined {
	font-size: 32px;
	color: #ffffff;
}

.ab-hero__title {
	font-size: clamp(30px, 5vw, 44px);
	font-weight: 800;
	color: #0f172a;
	letter-spacing: -0.03em;
	line-height: 1.15;
	margin: 0 0 12px;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.ab-hero__sub {
	font-size: 18px;
	color: #64748b;
	max-width: 800px;
	margin: 0 auto;
	line-height: 1.6;
}

/* ---- White card ---- */
.ab-card {
	background: #ffffff;
	border-radius: 16px;
	padding: 40px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.ab-card__h2 {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 24px;
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
	margin: 20px 0 40px;
	line-height: 1.3;
}

.ab-card__h2-icon {
	font-size: 28px !important;
	color: var(--color-primary);
	flex-shrink: 0;
}

.ab-prose {
	font-size: 16px;
	line-height: 1.75;
	color: #475569;
}

.ab-prose p {
	margin: 0 0 16px;
}

.ab-prose p:last-child {
	margin-bottom: 0;
}

/* ---- Stats bar ---- */
.ab-stats {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin: 40px 0;
}

.ab-stat {
	background: #ffffff;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 14px;
	padding: 20px 28px;
	border-radius: 14px;
	flex: 1 1 auto;
	min-width: 180px;
}

.ab-stat__icon {
	font-size: 42px !important;
	color: var(--color-primary);
	flex-shrink: 0;
}

.ab-stat__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ab-stat__val {
	font-size: 20px;
	font-weight: 800;
	color: #0f172a;
	line-height: 1;
}

.ab-stat__label {
	font-size: 15px;
	color: #94a3b8;
	font-weight: 600;
}

/* ---- Partners trust bar ---- */
.ab-partners {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 24px 32px;
}

.ab-partner {
	flex: 0 0 auto;
	max-width: calc(10% - 32px);
	display: flex;
	align-items: center;
	justify-content: center;
}

.ab-partner img {
	display: block;
	width: 130px;
	height: auto;
	object-fit: contain;
	filter: grayscale(100%) opacity(0.55);
	transition: filter 0.3s ease;
}

.ab-partner:hover img {
	filter: grayscale(0%) opacity(1);
}

.ab-partner a {
	display: flex;
	align-items: center;
	line-height: 0;
}

/* ---- Feature cards grid ---- */
.ab-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.ab-fcard {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 28px;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.ab-fcard:hover {
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.ab-fcard__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: rgba(0, 113, 227, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}

.ab-fcard__icon .material-icons-outlined {
	font-size: 24px;
	color: var(--color-primary);
}

.ab-fcard__title {
	font-size: 16px;
	font-weight: 600;
	color: #0f172a;
	margin: 0 0 8px;
	line-height: 1.35;
}

.ab-fcard__text {
	font-size: 14px;
	color: #64748b;
	line-height: 1.65;
	margin: 0;
}

/* ---- Steps ---- */
.ab-steps-track {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.ab-step {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 28px 24px;
	text-align: center;
	position: relative;
}

.ab-step__num {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, #0ea5e9, var(--color-primary));
	color: #ffffff;
	font-size: 14px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 26px;
	box-shadow: 0 2px 8px rgba(0, 113, 227, 0.35);
}

.ab-step__icon {
	margin-bottom: 12px;
	display: none;
}

.ab-step__icon .material-icons-outlined {
	font-size: 28px;
	color: var(--color-primary);
}

.ab-step__title {
	font-size: 16px;
	font-weight: 600;
	color: #0f172a;
	margin: 0 0 8px;
	line-height: 1.35;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.ab-step__title .material-icons-outlined {
	font-size: 20px;
	color: #0f172a;
	flex-shrink: 0;
}

.ab-step__text {
	font-size: 14px;
	color: #64748b;
	line-height: 1.65;
	margin: 0;
}

/* ---- Destinations ---- */
.ab-dest-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}

.ab-dest {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 24px;
	display: flex;
	align-items: flex-start;
	gap: 16px;
	transition: box-shadow 0.2s ease;
}

.ab-dest:hover {
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
}

.ab-dest__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: rgba(0, 113, 227, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ab-dest__icon .material-icons-outlined {
	font-size: 24px;
	color: var(--color-primary);
}

.ab-dest__city {
	font-size: 16px;
	font-weight: 600;
	color: #0f172a;
	margin: 0 0 4px;
	line-height: 1.3;
}

.ab-dest__text {
	font-size: 14px;
	color: #64748b;
	line-height: 1.6;
	margin: 0;
}

/* ---- CTA block ---- */
.ab-cta {
	background: #ffffff;
	border-radius: 20px;
	padding: 56px 40px;
	text-align: center;
}

.ab-cta__title {
	font-size: 28px;
	font-weight: 700;
	color: #0f172a;
	margin: 0 0 12px;
	letter-spacing: -0.02em;
}

.ab-cta__intro {
	font-size: 16px;
	color: #475569;
	margin: 0 0 28px;
	line-height: 1.6;
	max-width: 700px;
	margin: 0 auto 28px auto;
}

.ab-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	background: var(--color-primary);
	color: #ffffff !important;
	font-size: 16px;
	font-weight: 600;
	border-radius: 12px;
	text-decoration: none;
	transition: background 0.2s ease, transform 0.15s ease;
	box-shadow: 0 4px 14px rgba(0, 113, 227, 0.35);
}

.ab-cta__btn:hover {
	background: var(--color-primary-hover);
	transform: translateY(-1px);
	color: #ffffff;
}

.ab-cta__btn .material-icons-outlined {
	font-size: 20px;
}

.ab-cta__sub {
	font-size: 13px;
	color: #64748b;
	margin: 16px 0 0;
}

.ab-section.features h2 {
	text-align: center;
}

.ab-cta__mail {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 24px;
	font-size: 14px;
	color: #94a3b8;
}

.ab-cta__mail .material-icons-outlined {
	font-size: 20px;
	color: #64748b;
}

.ab-cta__mail a {
	color: var(--color-primary);
	text-decoration: none;
}

.ab-cta__mail a:hover {
	text-decoration: underline;
}

.ab-section.destinations h2 {
	text-align: center;
}

/* ---- About responsive ---- */
@media screen and (max-width: 900px) {
	.ab-features-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.ab-steps-track {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width: 640px) {
	.ab-hero {
		padding: 48px 0 40px;
	}

	.ab-hero__badge {
		width: 52px;
		height: 52px;
		border-radius: 14px;
	}

	.ab-hero__badge .material-icons-outlined {
		font-size: 26px;
	}

	.ab-section {
		padding: 36px 0;
	}

	.ab-card {
		padding: 24px;
		border-radius: 12px;
	}

	.ab-stats {
		margin: 24px 0;
	}

	.ab-features-grid,
	.ab-steps-track,
	.ab-dest-grid {
		grid-template-columns: 1fr;
	}

	.ab-partner {
		max-width: calc(20% - 32px);
	}

	.ab-partner img {
		max-width: 80px;
		height: 28px;
	}

	.ab-cta {
		padding: 36px 24px;
		margin: 36px 0;
		border-radius: 16px;
	}

	.ab-section__h2 {
		font-size: 24px;
	}
}

/* ==========================================================================
   Legal Page (Privacy Policy, Terms, etc.)
   ========================================================================== */

.legal-page {
	background: var(--color-gray-100);
	min-height: calc(100vh - var(--header-height));
	padding: 56px 24px 80px;
}

.legal-mx {
	max-width: 1200px;
	margin: 0 auto;
}

.legal-title {
	font-size: 32px;
	font-weight: 700;
	color: #0f172a;
	letter-spacing: -0.02em;
	margin: 0 0 28px;
	line-height: 1.25;
	text-align: center;
}

.legal-card {
	background: #ffffff;
	border-radius: 16px;
	padding: 48px 56px;
}

.legal-prose {
	font-size: 15px;
	line-height: 1.8;
	color: #334155;
}

.legal-prose h2 {
	font-size: 20px;
	font-weight: 700;
	color: #0f172a;
	margin: 36px 0 12px;
	letter-spacing: -0.01em;
}

.legal-prose h3 {
	font-size: 17px;
	font-weight: 600;
	color: #1e293b;
	margin: 28px 0 10px;
}

.legal-prose p {
	margin: 0 0 16px;
}

.legal-prose ul,
.legal-prose ol {
	margin: 0 0 16px;
	padding-left: 24px;
}

.legal-prose li {
	margin-bottom: 6px;
}

.legal-prose a {
	color: var(--color-primary);
	text-decoration: none;
}

.legal-prose a:hover {
	text-decoration: underline;
}

.legal-prose strong {
	font-weight: 600;
	color: #0f172a;
}

@media screen and (max-width: 900px) {
	.legal-page {
		padding: 32px 16px 56px;
	}

	.legal-card {
		padding: 28px 24px;
		border-radius: 12px;
	}

	.legal-title {
		font-size: 26px;
	}
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

.ct-page {
	background: #f8fafc;
	min-height: 100vh;
}

/* ---- Contact info cards ---- */
.ct-info-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.ct-info-card {
	background: #ffffff;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 18px 20px;
	display: flex;
	align-items: flex-start;
	gap: 16px;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.ct-info-card:hover {
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.ct-info-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: rgba(0, 113, 227, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.ct-info-card__icon .material-icons-outlined {
	font-size: 22px;
	color: var(--color-primary);
}

.ct-info-card__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.ct-info-card__label {
	font-size: 11px;
	font-weight: 700;
	color: #000000;
	text-transform: uppercase;
	letter-spacing: 0.07em;
}

.ct-info-card__value {
	font-size: 15px;
	font-weight: 500;
	color: #545454;
	line-height: 1.5;
	word-break: break-word;
}

a.ct-info-card__value {
	color: var(--color-primary);
	text-decoration: none;
}

a.ct-info-card__value:hover {
	text-decoration: underline;
}

.ct-info-card__btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-top: 0px;
	padding: 5px 12px;
	background: rgba(0, 113, 227, 0.08);
	color: var(--color-primary);
	font-size: 12px;
	font-weight: 600;
	border-radius: 20px;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
	align-self: flex-start;
}

.ct-info-card__btn:hover {
	background: var(--color-primary);
	color: #ffffff;
}

.ct-info-card__btn .material-icons-outlined {
	font-size: 14px !important;
}

.ct-info-card--wide {
	grid-column: span 2;
}

/* ---- Location intro card ---- */
.ct-location-card {
	background: #ffffff;
	border-radius: 16px;
	padding: 36px 40px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
	margin-bottom: 24px;
}

.ct-location-prose {
	font-size: 16px;
	line-height: 1.75;
	color: #475569;
}

/* ---- Bullet list ---- */
.ct-bullets {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid #f1f5f9;
}

.ct-bullets__title {
	font-size: 15px;
	font-weight: 600;
	color: #1e293b;
	margin: 0 0 12px;
	line-height: 1.4;
}

.ct-bullets__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ct-bullets__list li {
	font-size: 15px;
	color: #475569;
	line-height: 1.6;
	display: flex;
	align-items: baseline;
	gap: 10px;
}

.ct-bullets__list li::before {
	content: '—';
	color: var(--color-primary);
	flex-shrink: 0;
	font-weight: 700;
}

/* ---- Map widget card ---- */
.ct-map {
	background: #ffffff;
	border-radius: 16px;
	padding: 36px 40px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.ct-map__title {
	font-size: 22px;
	font-weight: 700;
	color: #0f172a;
	margin: 0 0 20px;
	letter-spacing: -0.02em;
	line-height: 1.3;
	display: flex;
	align-items: center;
	gap: 10px;
}

.ct-map__title::before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 22px;
	background: linear-gradient(180deg, #0ea5e9, var(--color-primary));
	border-radius: 2px;
	flex-shrink: 0;
}

.ct-map__meta {
	margin-bottom: 24px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	padding: 16px 20px;
}

.ct-map__meta-row {
	font-size: 14px;
	color: #475569;
	margin: 0;
	display: flex;
	align-items: center;
	gap: 8px;
	line-height: 1.5;
}

.ct-map__meta-icon {
	font-size: 16px !important;
	color: var(--color-primary);
	flex-shrink: 0;
}

.ct-map__meta-row strong {
	color: #1e293b;
	font-weight: 600;
}

.ct-map__meta-row a {
	color: var(--color-primary);
	text-decoration: none;
	word-break: break-all;
}

.ct-map__meta-row a:hover {
	text-decoration: underline;
}

.ct-map__frame {
	border-radius: 12px;
	overflow: hidden;
	line-height: 0;
}

.ct-map__frame iframe {
	display: block;
	width: 100%;
	height: 450px;
	border: 0;
}

/* ---- Contact responsive ---- */
@media screen and (max-width: 900px) {
	.ct-info-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width: 640px) {
	.ct-info-grid {
		grid-template-columns: 1fr;
	}

	.ct-info-card--wide {
		grid-column: span 1;
	}

	.ct-location-card,
	.ct-map {
		padding: 24px;
		border-radius: 12px;
	}

	.ct-map__frame iframe {
		height: 320px;
	}

	.ct-map__title {
		font-size: 18px;
	}
}

/*--------------------------------------------------------------
# WordPress Admin Bar — compatibility
# When logged in, WP adds html { margin-top: 32px } and
# body.admin-bar. Fixed/absolute headers need to shift down.
--------------------------------------------------------------*/
.admin-bar .site-header--hero {
	top: 32px;
}

.admin-bar .mobile-menu-overlay {
	top: 32px;
}

/* On ≤782px WP admin bar is 46px tall */
@media screen and (max-width: 782px) {
	.admin-bar .site-header--hero {
		top: 46px;
	}

	.admin-bar .mobile-menu-overlay {
		top: 46px;
	}
}