/* CHO Itinerary — single template
 * Palette nero/argento, Cinzel + Cormorant Garamond
 * Aligned with cho-archive-grid / cho-magazine-hub conventions
 */

.cho-itinerary {
	max-width: 1100px;
	margin: 0 auto;
	padding: 2.5rem 1.25rem 4rem;
	font-family: 'Cormorant Garamond', Georgia, serif;
	color: #0a0a0a;
}

/* Hero */
.cho-itinerary__hero { margin-bottom: 2.5rem; }
.cho-itinerary__hero-img { margin-bottom: 1.5rem; overflow: hidden; border-radius: 4px; }
.cho-itinerary__hero-img img { width: 100%; height: auto; display: block; }
.cho-itinerary__hero-inner { text-align: center; max-width: 820px; margin: 0 auto; }
.cho-itinerary__eyebrow {
	font-family: 'Cinzel', serif;
	font-size: .78rem;
	letter-spacing: .3em;
	color: #8a7544;
	text-transform: uppercase;
	margin: 0 0 .8rem;
}
.cho-itinerary__title {
	font-family: 'Cinzel', serif;
	font-size: clamp(1.9rem, 4vw, 2.9rem);
	color: #0a0a0a;
	margin: 0 0 .6rem;
	letter-spacing: .04em;
	line-height: 1.15;
}
.cho-itinerary__byline {
	font-size: .95rem;
	color: #666;
	font-style: italic;
	margin: 0 0 1rem;
}
.cho-itinerary__lede {
	font-size: 1.1rem;
	color: #2a2a2a;
	line-height: 1.55;
	max-width: 700px;
	margin: 0 auto;
}

/* Stats strip */
.cho-itinerary__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: .5rem;
	background: #f6f4ee;
	border: 1px solid #e3dfd4;
	border-radius: 4px;
	padding: 1.25rem;
	margin-bottom: 2.5rem;
}
.cho-stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: .25rem .5rem;
}
.cho-stat__num {
	font-family: 'Cinzel', serif;
	font-size: 1.15rem;
	color: #0a0a0a;
	letter-spacing: .04em;
	line-height: 1.2;
}
.cho-stat__lbl {
	font-family: 'Cinzel', serif;
	font-size: .68rem;
	letter-spacing: .25em;
	color: #8a7544;
	text-transform: uppercase;
	margin-top: .35rem;
}

/* Map SVG */
.cho-itinerary__map {
	margin-bottom: 2.5rem;
	background: #f6f4ee;
	border: 1px solid #e3dfd4;
	border-radius: 4px;
	padding: 1.25rem;
}
.cho-itinerary__svg {
	display: block;
	width: 100%;
	height: auto;
	max-height: 420px;
}
.cho-itinerary__map-empty {
	margin: 0;
	padding: 2rem;
	text-align: center;
	color: #666;
	font-style: italic;
}

/* Body content */
.cho-itinerary__content {
	font-size: 1.05rem;
	line-height: 1.65;
	color: #2a2a2a;
	max-width: 740px;
	margin: 0 auto 2.5rem;
}
.cho-itinerary__content p { margin: 0 0 1rem; }

/* Section titles */
.cho-itinerary__section-title {
	font-family: 'Cinzel', serif;
	font-size: 1.5rem;
	color: #0a0a0a;
	letter-spacing: .06em;
	text-align: center;
	margin: 0 0 1.75rem;
	padding-bottom: .75rem;
	border-bottom: 1px solid #e3dfd4;
}

/* Steps */
.cho-itinerary__steps { margin-bottom: 3rem; }
.cho-itinerary__step {
	display: grid;
	grid-template-columns: 60px 220px 1fr;
	gap: 1.25rem;
	align-items: flex-start;
	padding: 1.25rem 0;
	border-bottom: 1px solid #e3dfd4;
}
.cho-itinerary__step:last-child { border-bottom: 0; }
.cho-itinerary__step-num {
	font-family: 'Cinzel', serif;
	font-size: 2rem;
	color: #c9a96e;
	line-height: 1;
	text-align: center;
	padding-top: .25rem;
}
.cho-itinerary__step-thumb img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 3px;
	border: 1px solid #e3dfd4;
}
.cho-itinerary__step-body h3 {
	font-family: 'Cinzel', serif;
	font-size: 1.15rem;
	letter-spacing: .03em;
	margin: 0 0 .4rem;
}
.cho-itinerary__step-body h3 a,
.cho-itinerary__step-body h3 a:visited { color: #0a0a0a; text-decoration: none; }
.cho-itinerary__step-body h3 a:hover { color: #8a7544; }
.cho-itinerary__step-body p {
	margin: 0 0 .5rem;
	font-size: 1rem;
	line-height: 1.55;
	color: #2a2a2a;
}
.cho-itinerary__step-meta {
	font-family: 'Cinzel', serif;
	font-size: .72rem;
	letter-spacing: .15em;
	color: #8a7544;
	text-transform: uppercase;
}

/* Downloads */
.cho-itinerary__downloads {
	text-align: center;
	background: #0a0a0a;
	color: #f6f4ee;
	padding: 2.5rem 1.5rem;
	border-radius: 4px;
	margin-top: 2rem;
}
.cho-itinerary__downloads .cho-itinerary__section-title {
	color: #f6f4ee;
	border-bottom-color: rgba(201, 169, 110, .3);
}
.cho-itinerary__download-row {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}
.cho-btn {
	display: inline-block;
	font-family: 'Cinzel', serif;
	font-size: .85rem;
	letter-spacing: .15em;
	text-transform: uppercase;
	padding: .85rem 1.75rem;
	background: #c9a96e;
	color: #0a0a0a;
	text-decoration: none;
	border: 1px solid #c9a96e;
	border-radius: 3px;
	transition: background .2s, color .2s;
}
.cho-btn:hover { background: #f6f4ee; color: #0a0a0a; }
.cho-btn--ghost {
	background: transparent;
	color: #c9a96e;
}
.cho-btn--ghost:hover { background: #c9a96e; color: #0a0a0a; }
.cho-itinerary__download-help {
	font-size: .9rem;
	font-style: italic;
	color: rgba(246, 244, 238, .7);
	margin: 0;
}

/* Mobile */
@media (max-width: 720px) {
	.cho-itinerary { padding: 1.5rem 1rem 3rem; }
	.cho-itinerary__step {
		grid-template-columns: 50px 1fr;
		grid-template-areas: "num body" "thumb body";
	}
	.cho-itinerary__step-num { grid-area: num; font-size: 1.6rem; }
	.cho-itinerary__step-thumb { grid-area: thumb; }
	.cho-itinerary__step-body { grid-area: body; }
}
