@media (max-width: 1080px) {

	.hero-stage,
	.summary-layout {
		grid-template-columns: 1fr;
	}

	.hero-gallery {
		grid-template-columns: 1fr 1fr;
	}

	.hero-visual {
		justify-content: flex-start;
	}

	.summary-layout>.section-heading {
		position: static;
		padding-right: 0;
	}

	.restaurant-card {
		grid-template-columns: 1fr;
	}

	.restaurant-visual {
		height: 220px;
	}

	.hero-stats,
	.feature-grid,
	.summary-grid,
	.cost-layout,
	.map-layout,
	.timeline-day {
		grid-template-columns: 1fr 1fr;
	}

	.restaurant-card {
		grid-template-columns: 240px minmax(0, 1fr);
	}

	.gallery-item.wide,
	.gallery-item.tall,
	.gallery-item.medium,
	.gallery-item.small {
		grid-column: span 6;
	}
}

@media (max-width: 780px) {
	:root {
		--container: min(100vw - 18px, 1000px);
	}

	.hero {
		padding-top: 14px;
		gap: 16px;
	}

	.hero-stage {
		gap: 16px;
	}

	.topbar {
		border-radius: 24px;
		align-items: flex-start;
		flex-wrap: wrap;
	}

	.menu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 42px;
		padding: 0 14px;
		border: 1px solid var(--line);
		border-radius: 999px;
		background: #fff;
		color: var(--text);
		font-weight: 700;
	}

	.menu {
		display: none;
		width: 100%;
		flex-direction: column;
		align-items: flex-start;
		padding-top: 10px;
	}

	.menu.is-open {
		display: flex;
	}

	.menu a {
		width: 100%;
	}

	.hero-content,
	.hero-visual {
		padding: 22px;
	}

	.hero-kicker-row {
		align-items: flex-start;
	}

	.hero h1 {
		max-width: 100%;
		font-size: clamp(2.5rem, 11vw, 3.9rem);
	}

	.section-heading h2,
	.love-card h2,
	.timeline-content h3 {
		max-width: 100%;
	}

	.hero-gallery {
		grid-template-columns: 1fr;
	}

	.hero-photo-large,
	.hero-photo-small {
		min-height: 220px;
		grid-row: span 1;
	}

	.hero-stats,
	.summary-grid,
	.feature-grid,
	.cost-layout,
	.map-layout,
	.timeline-day,
	.countdown-grid {
		grid-template-columns: 1fr;
	}

	.timeline-day,
	.timeline-day.is-alt {
		grid-template-columns: 1fr;
	}

	.timeline-day.is-alt .timeline-media,
	.timeline-day.is-alt .timeline-content {
		order: initial;
	}

	.timeline-chapter {
		flex-direction: row;
		align-items: center;
		justify-content: flex-start;
		padding-top: 0;
	}

	.timeline-word {
		writing-mode: horizontal-tb;
		transform: none;
	}

	.section {
		padding: 24px 18px 32px;
		border-radius: 26px;
	}

	.summary-strip,
	.restaurant-meta {
		grid-template-columns: 1fr;
	}

	.summary-quote {
		font-size: 1.12rem;
		padding-left: 14px;
	}

	.summary-quote::before {
		font-size: 2.5rem;
		top: -16px;
	}

	.love-cover-top,
	.love-signoff {
		justify-content: center;
	}

	.route-leg-top {
		grid-template-columns: 40px minmax(0, 1fr);
		gap: 12px;
	}

	.cost-item {
		flex-direction: column;
		align-items: flex-start;
	}

	.cost-figure {
		padding-top: 0;
		text-align: left;
	}

	.glass-card,
	.feature-card,
	.cost-panel,
	.hint-box,
	.restaurant-card,
	.love-card,
	.timeline-day,
	.hero-content,
	.hero-visual {
		border-radius: 24px;
	}

	.timeline-content {
		padding: 4px 2px 2px;
	}

	.summary-grid .glass-card:first-child,
	.summary-grid .glass-card:nth-child(2),
	.summary-grid .glass-card:nth-child(3) {
		transform: none;
	}

	.timeline-content h3 {
		font-size: 1.65rem;
	}

	.hero-copy::first-letter,
	.love-card p::first-letter {
		font-size: 1.2em;
	}

	#trip-map {
		height: 400px;
	}

	.carousel-arrow {
		width: 38px;
		height: 38px;
	}

	.carousel-dots {
		right: 12px;
		bottom: 12px;
	}

	.gallery-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: 120px;
	}

	.gallery-item.wide,
	.gallery-item.tall,
	.gallery-item.medium,
	.gallery-item.small {
		grid-column: span 1;
		grid-row: span 2;
	}
}
