/* ---------------------------------------------------------------------------
   Idea Travel — styling for the Travel Content Plugin's front-end pages.
   Enqueued (by functions.php) only on travel_item archives, single travel_item,
   and the travel taxonomies. Targets the theme's override templates in
   idea-travel/travel-content-plugin/ (the .it-travel-* classes).
   Uses the theme.json presets (--wp--preset--*).
--------------------------------------------------------------------------- */

:root {
	--it-travel-gutter: clamp(1.25rem, 4vw, 2.5rem);
	--it-travel-max: 1360px;
}

.it-travel-archive,
.it-travel-single {
	box-sizing: border-box;
}
.it-travel-archive *,
.it-travel-single * { box-sizing: border-box; }

/* shared container */
.it-travel-archive__intro,
.it-travel-archive__filter,
.it-travel-grid,
.it-travel-pagination,
.it-travel-empty,
.it-travel-single__intro,
.it-travel-single__main {
	max-width: var(--it-travel-max);
	margin-inline: auto;
	padding-inline: var(--it-travel-gutter);
}
.it-travel-single__hero { margin: 0; }

/* ---- Archive / taxonomy ------------------------------------------------- */
.it-travel-archive { padding-block: clamp(2.5rem, 6vw, 7.5rem) clamp(3rem, 8vw, 7.5rem); }
.it-travel-archive__intro-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--wp--preset--spacing--70);
	align-items: end;
}
@media (max-width: 781px) { .it-travel-archive__intro-grid { grid-template-columns: 1fr; gap: var(--wp--preset--spacing--50); } }
.it-travel-archive__kicker {
	margin: 0 0 var(--wp--preset--spacing--30);
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
	color: var(--wp--preset--color--accent);
}
.it-travel-archive__title {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 400; line-height: 1; letter-spacing: -0.04em;
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--heading);
}
.it-travel-archive__title em { font-style: italic; color: var(--wp--preset--color--accent); }
.it-travel-archive__lead {
	margin: 0;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--large);
	line-height: 1.55; color: var(--wp--preset--color--body);
}
.it-travel-archive__filter { margin-top: var(--wp--preset--spacing--70); }

/* ---- Card grid ---------------------------------------------------------- */
.it-travel-grid {
	margin-top: var(--wp--preset--spacing--80);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
@media (max-width: 1100px) { .it-travel-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px)  { .it-travel-grid { grid-template-columns: 1fr; } }

/* ---- travel-content/featured-trips block (homepage) --------------------------------------------
   The plugin block wraps its cards in .travel-archive > .travel-archive__grid and loads its own
   travel-public.css; these rules (higher-specificity than travel-public.css's .travel-archive__grid)
   give it a 4-up grid matching the theme. The cards inside are our it-travel-card override, styled above. */
.wp-block-travel-content-featured-trips .travel-archive__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
@media (max-width: 1100px) { .wp-block-travel-content-featured-trips .travel-archive__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px)  { .wp-block-travel-content-featured-trips .travel-archive__grid { grid-template-columns: 1fr; } }
/* heading is left empty in front-page.html (the section-heading pattern supplies one); hide it if ever set */
.it-featured-trips .wp-block-travel-content-featured-trips .travel-archive__title {
	margin: 0 0 var(--wp--preset--spacing--50);
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 400; font-size: var(--wp--preset--font-size--xx-large); line-height: 1; letter-spacing: -0.04em;
	color: var(--wp--preset--color--heading);
}

.it-travel-card {
	display: flex; flex-direction: column;
	border: 1px solid rgba(0,0,0,0.12);
	background: var(--wp--preset--color--base);
}
.it-travel-card__media { display: block; line-height: 0; }
.it-travel-card__media img { width: 100%; height: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; }
.it-travel-card__body {
	display: flex; flex-direction: column; gap: var(--wp--preset--spacing--40);
	padding: var(--wp--preset--spacing--40);
	flex: 1 0 auto;
}
.it-travel-card__eyebrow {
	margin: 0;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
	color: var(--wp--preset--color--accent);
}
.it-travel-card__title {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 400; line-height: 1; letter-spacing: -0.03em;
	font-size: var(--wp--preset--font-size--x-large);
	color: var(--wp--preset--color--heading);
}
.it-travel-card__title a { color: inherit; text-decoration: none; }
.it-travel-card__title a:hover { color: var(--wp--preset--color--accent); }
.it-travel-card__summary {
	margin: 0;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--large);
	line-height: 1.55; color: var(--wp--preset--color--body);
	/* Belt-and-suspenders: PHP already trims to ~25 words; this caps it to a fixed line count too,
	   so a card with a long teaser can't blow out the row height in the grid. */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	line-clamp: 4;
	overflow: hidden;
}
.it-travel-card__price {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-style: italic; font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--accent);
}
.it-travel-card__cta {
	margin-top: auto;               /* pushes the button to the bottom of the (equal-height) card */
	display: inline-flex; align-items: center; justify-content: center;
	padding: 0.7rem 1rem;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--medium); letter-spacing: 0.0375em;
	background: var(--wp--preset--color--contrast); color: var(--wp--preset--color--base);
	text-decoration: none; border: 0; border-radius: 0;
	transition: background-color 150ms ease;
}
.it-travel-card__cta:hover, .it-travel-card__cta:focus-visible {
	background: var(--wp--preset--color--accent); color: var(--wp--preset--color--base); text-decoration: none;
}

/* ---- Pagination / empty ------------------------------------------------- */
/* "More journeys from our partners" — the live-API hybrid-search results below the local ones */
.it-travel-partners {
	max-width: var(--it-travel-max);
	margin: var(--wp--preset--spacing--90) auto 0;
	padding-inline: var(--it-travel-gutter);
	padding-top: var(--wp--preset--spacing--70);
	border-top: 1px solid rgba(0, 0, 0, 0.12);
}
.it-travel-partners > .it-travel-block__title { margin-bottom: var(--wp--preset--spacing--50); }
.it-travel-partners > .it-travel-grid { margin-top: 0; max-width: none; margin-inline: 0; padding-inline: 0; }
.it-travel-partners__more {
	margin: var(--wp--preset--spacing--70) 0 0;
	text-align: center;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
}
.it-travel-partners__more a { color: var(--wp--preset--color--accent); text-decoration: none; }
.it-travel-partners__more a:hover { color: var(--wp--preset--color--heading); }

.it-travel-pagination { margin-top: var(--wp--preset--spacing--80); }
.it-travel-pagination .nav-links { display: flex; gap: var(--wp--preset--spacing--30); justify-content: center; flex-wrap: wrap; }
.it-travel-pagination a, .it-travel-pagination span.current {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small); letter-spacing: 2px; text-transform: uppercase;
	padding: 0.6rem 0.9rem; text-decoration: none;
	border: 1px solid rgba(0,0,0,0.12); color: var(--wp--preset--color--body);
}
.it-travel-pagination span.current { background: var(--wp--preset--color--contrast); color: var(--wp--preset--color--base); border-color: var(--wp--preset--color--contrast); }
.it-travel-pagination a:hover { border-color: var(--wp--preset--color--accent); color: var(--wp--preset--color--accent); }
.it-travel-empty {
	margin-top: var(--wp--preset--spacing--80);
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--large); color: var(--wp--preset--color--body);
}

/* ---- Filter form (theme override partial) ------------------------------- */
.it-travel-filter { font-family: var(--wp--preset--font-family--sans); }
.it-travel-filter__primary {
	display: flex; flex-wrap: wrap; align-items: flex-end; gap: var(--wp--preset--spacing--40);
	padding-bottom: var(--wp--preset--spacing--40);
	border-bottom: 1px solid rgba(0,0,0,0.12);
}
.it-travel-filter__field { display: flex; flex-direction: column; gap: 0.35rem; flex: 1 1 12rem; min-width: 0; }
.it-travel-filter__field > span,
.it-travel-filter__field > legend > span {
	font-size: var(--wp--preset--font-size--x-small); font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
	color: var(--wp--preset--color--body);
}
.it-travel-filter__field--wide { flex: 1 1 100%; }
.it-travel-filter select,
.it-travel-filter input[type="text"],
.it-travel-filter input[type="number"] {
	font-family: inherit; font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--heading);
	background: var(--wp--preset--color--base);
	border: 1px solid rgba(0,0,0,0.2); border-radius: 0;
	padding: 0.55rem 0.7rem; width: 100%;
}
.it-travel-filter select:focus,
.it-travel-filter input:focus { outline: 2px solid var(--wp--preset--color--accent); outline-offset: 1px; }
.it-travel-filter__price { display: flex; align-items: center; gap: 0.5rem; }
.it-travel-filter__price input { width: 6rem; flex: 0 1 6rem; }
.it-travel-filter__actions { display: flex; gap: var(--wp--preset--spacing--30); align-items: center; }
.it-travel-filter__submit {
	font-family: inherit; font-size: var(--wp--preset--font-size--medium); letter-spacing: 0.0375em;
	background: var(--wp--preset--color--contrast); color: var(--wp--preset--color--base);
	border: 0; border-radius: 0; padding: 0.7rem 1.4rem; cursor: pointer;
	transition: background-color 150ms ease;
}
.it-travel-filter__submit:hover { background: var(--wp--preset--color--accent); }
.it-travel-filter__clear { font-size: var(--wp--preset--font-size--x-small); letter-spacing: 2px; text-transform: uppercase; color: var(--wp--preset--color--body); text-decoration: none; }
.it-travel-filter__clear:hover { color: var(--wp--preset--color--accent); }
.it-travel-filter__more { margin-top: var(--wp--preset--spacing--40); }
.it-travel-filter__more > summary {
	cursor: pointer; list-style: none;
	font-size: var(--wp--preset--font-size--x-small); font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
	color: var(--wp--preset--color--accent);
}
.it-travel-filter__more > summary::-webkit-details-marker { display: none; }
.it-travel-filter__more > summary::before { content: "+ "; }
.it-travel-filter__more[open] > summary::before { content: "– "; }
.it-travel-filter__more-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--wp--preset--spacing--40);
	margin-top: var(--wp--preset--spacing--40);
}
@media (max-width: 781px) { .it-travel-filter__more-grid { grid-template-columns: 1fr; } }
.it-travel-filter__attrs { border: 0; padding: 0; margin: 0; }
.it-travel-filter__attrs legend { padding: 0; margin-bottom: 0.35rem; }
.it-travel-filter__attrs-wrap { display: flex; flex-wrap: wrap; gap: 0.4rem 1rem; }
.it-travel-filter__check { display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--wp--preset--font-size--small); color: var(--wp--preset--color--body); text-transform: none; letter-spacing: 0.5px; }

/* ---- Single travel_item ------------------------------------------------- */
.it-travel-single { padding-top: clamp(2.5rem, 6vw, 7.5rem); padding-bottom: clamp(3rem, 8vw, 7.5rem); }
.it-travel-single__intro { margin-bottom: var(--wp--preset--spacing--80); }
.it-travel-single__intro-grid {
	display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--wp--preset--spacing--70); align-items: end;
}
@media (max-width: 781px) { .it-travel-single__intro-grid { grid-template-columns: 1fr; gap: var(--wp--preset--spacing--50); } }
.it-travel-single__kicker {
	margin: 0 0 var(--wp--preset--spacing--30);
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small); font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
	color: var(--wp--preset--color--accent);
}
.it-travel-single__title {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 400; line-height: 1; letter-spacing: -0.05em;
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--heading);
}
.it-travel-single__subtitle {
	margin: var(--wp--preset--spacing--20) 0 0;
	font-family: var(--wp--preset--font-family--serif);
	font-style: italic; font-size: var(--wp--preset--font-size--x-large); line-height: 1.1;
	color: var(--wp--preset--color--accent);
}
.it-travel-single__summary {
	margin: var(--wp--preset--spacing--40) 0 0;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--large); line-height: 1.55; color: var(--wp--preset--color--body);
}
.it-travel-single__aside { display: flex; flex-direction: column; align-items: flex-start; gap: var(--wp--preset--spacing--40); }
@media (min-width: 782px) { .it-travel-single__aside { align-items: flex-end; text-align: right; } }
.it-travel-single__price {
	margin: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-style: italic; font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--accent);
}
.it-travel-single__cta {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 0.75rem 1.25rem;
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--medium); letter-spacing: 0.0375em;
	background: var(--wp--preset--color--contrast); color: var(--wp--preset--color--base);
	text-decoration: none; border-radius: 0; transition: background-color 150ms ease;
}
.it-travel-single__cta:hover, .it-travel-single__cta:focus-visible { background: var(--wp--preset--color--accent); color: var(--wp--preset--color--base); }
.it-travel-single__hero { width: 100%; }
.it-travel-single__hero img { width: 100%; height: auto; max-height: 70vh; object-fit: cover; display: block; aspect-ratio: 1360 / 826; }
.it-travel-single__main {
	max-width: 820px;
	display: flex; flex-direction: column; gap: var(--wp--preset--spacing--80);
	padding-top: var(--wp--preset--spacing--80);
}
.it-travel-single__content { font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--large); line-height: 1.6; color: var(--wp--preset--color--body); }
.it-travel-single__content h2 { font-family: var(--wp--preset--font-family--serif); font-weight: 400; color: var(--wp--preset--color--heading); font-size: var(--wp--preset--font-size--x-large); line-height: 1.1; }
.it-travel-single__content a { color: var(--wp--preset--color--accent); }
.it-travel-single__terms { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.it-travel-single__terms li {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--x-small); letter-spacing: 1.5px; text-transform: uppercase;
	color: var(--wp--preset--color--body);
	border: 1px solid rgba(0,0,0,0.15); padding: 0.35rem 0.7rem;
}

.it-travel-block__title {
	margin: 0 0 var(--wp--preset--spacing--40);
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 400; font-size: var(--wp--preset--font-size--x-large); line-height: 1; letter-spacing: -0.03em;
	color: var(--wp--preset--color--heading);
}

/* Collapsible sections (<details>) — Pricing & Day by day default closed (hidden). */
.it-travel-disclosure { display: block; }
.it-travel-disclosure > .it-travel-disclosure__summary {
	margin: 0;                       /* override .it-travel-block__title's bottom margin while collapsed */
	display: flex;
	align-items: center;
	gap: 0.6rem;
	cursor: pointer;
	list-style: none;                /* hide the default disclosure triangle */
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.it-travel-disclosure > .it-travel-disclosure__summary::-webkit-details-marker { display: none; }
.it-travel-disclosure > .it-travel-disclosure__summary::after {
	content: "";
	flex: 0 0 auto;
	width: 0.6em; height: 0.6em;
	margin-left: auto;
	border-right: 2px solid var(--wp--preset--color--accent);
	border-bottom: 2px solid var(--wp--preset--color--accent);
	transform: rotate(45deg);        /* chevron pointing down (collapsed) */
	transition: transform 150ms ease;
}
.it-travel-disclosure[open] > .it-travel-disclosure__summary::after { transform: rotate(-135deg); }   /* points up when open */
.it-travel-disclosure[open] > .it-travel-disclosure__summary { margin-bottom: var(--wp--preset--spacing--40); }
.it-travel-disclosure > .it-travel-disclosure__summary:hover,
.it-travel-disclosure > .it-travel-disclosure__summary:focus-visible { color: var(--wp--preset--color--accent); }
.it-travel-disclosure__body { padding-top: var(--wp--preset--spacing--20); }

.it-travel-details__list { display: grid; grid-template-columns: max-content 1fr; gap: 0.5rem 1.5rem; margin: 0; font-family: var(--wp--preset--font-family--sans); }
.it-travel-details__list dt { font-size: var(--wp--preset--font-size--x-small); letter-spacing: 1.5px; text-transform: uppercase; color: var(--wp--preset--color--accent); align-self: center; }
.it-travel-details__list dd { margin: 0; font-size: var(--wp--preset--font-size--large); color: var(--wp--preset--color--heading); }

.it-travel-list ul { margin: 0; padding-left: 1.1em; font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--large); color: var(--wp--preset--color--body); }
.it-travel-list li { margin-bottom: 0.4rem; }

.it-travel-pricing__table { width: 100%; border-collapse: collapse; font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--medium); }
.it-travel-pricing__table th { text-align: left; font-size: var(--wp--preset--font-size--x-small); letter-spacing: 1.5px; text-transform: uppercase; color: var(--wp--preset--color--accent); padding: 0.6rem 0.75rem; border-bottom: 1.5px solid rgba(0,0,0,0.6); }
.it-travel-pricing__table td { padding: 0.7rem 0.75rem; border-bottom: 1px solid rgba(0,0,0,0.1); color: var(--wp--preset--color--heading); }

.it-travel-itinerary__list { list-style: none; counter-reset: itin; margin: 0; padding: 0; }
.it-travel-itinerary__day { display: grid; grid-template-columns: 6rem 1fr; gap: var(--wp--preset--spacing--40); padding: var(--wp--preset--spacing--40) 0; border-top: 1px solid rgba(0,0,0,0.12); }
.it-travel-itinerary__day:first-child { border-top: 0; }
@media (max-width: 600px) { .it-travel-itinerary__day { grid-template-columns: 1fr; gap: 0.5rem; } }
.it-travel-itinerary__daynum { margin: 0; font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--x-small); letter-spacing: 2px; text-transform: uppercase; color: var(--wp--preset--color--body); }
.it-travel-itinerary__heading { margin: 0 0 0.4rem; font-family: var(--wp--preset--font-family--serif); font-weight: 400; font-size: var(--wp--preset--font-size--x-large); line-height: 1; letter-spacing: -0.03em; color: var(--wp--preset--color--heading); }
.it-travel-itinerary__detail p { margin: 0; font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--large); line-height: 1.55; color: var(--wp--preset--color--body); }

/* The plugin's inquiry form inside .it-travel-inquiry — light cleanup so it sits in the theme */
.it-travel-inquiry { background: var(--wp--preset--color--complimentary); padding: var(--wp--preset--spacing--70); }
.it-travel-inquiry h2, .it-travel-inquiry h3 { font-family: var(--wp--preset--font-family--serif); font-weight: 400; color: var(--wp--preset--color--heading); }
.it-travel-inquiry label { font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--x-small); letter-spacing: 1px; text-transform: uppercase; color: var(--wp--preset--color--body); }
.it-travel-inquiry input[type="text"], .it-travel-inquiry input[type="email"], .it-travel-inquiry input[type="tel"], .it-travel-inquiry textarea {
	font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--medium);
	border: 1px solid rgba(0,0,0,0.2); border-radius: 0; padding: 0.55rem 0.7rem; width: 100%; background: var(--wp--preset--color--base);
}
.it-travel-inquiry button[type="submit"], .it-travel-inquiry input[type="submit"] {
	font-family: var(--wp--preset--font-family--sans); font-size: var(--wp--preset--font-size--medium); letter-spacing: 0.0375em;
	background: var(--wp--preset--color--contrast); color: var(--wp--preset--color--base); border: 0; border-radius: 0; padding: 0.75rem 1.4rem; cursor: pointer;
	transition: background-color 150ms ease;
}
.it-travel-inquiry button[type="submit"]:hover, .it-travel-inquiry input[type="submit"]:hover { background: var(--wp--preset--color--accent); }

/* Style the plugin's own travel-filter block wrapper if it's used (e.g. on the Destinations page),
   in case the plugin's render.php outputs the un-overridden partial there too. */
.wp-block-travel-content-travel-filter { font-family: var(--wp--preset--font-family--sans); }
