.page-shell {
	width: min(1100px, calc(100% - 32px));
	margin: 0 auto;
	padding: 22px 0 44px;
}

.hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 16px;
	align-items: center;
	margin-bottom: 16px;
}

.hero h1 {
	margin: 0;
	font-size: 1.42rem;
	font-weight: 750;
	letter-spacing: 0;
}

.hero p {
	margin: 4px 0 0;
	color: var(--muted);
	font-size: 0.92rem;
	line-height: 1.5;
}

.layout {
	display: grid;
	grid-template-columns: minmax(310px, 360px) minmax(0, 1fr);
	grid-template-areas:
		"upload map"
		"table table";
	gap: 16px;
}

.upload-panel {
	grid-area: upload;
	padding: 18px;
}

.table-panel {
	grid-area: table;
	padding: 18px;
}

.map-panel {
	grid-area: map;
	padding: 18px;
}

.map-frame {
	margin-top: 14px;
}

.map-container {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid var(--line);
	background: #f9fafb;
}

.map-container img {
	width: 100%;
	display: block;
}

.map-overlay {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.flight-label {
	position: absolute;
	display: grid;
	gap: 3px;
	min-width: 118px;
	max-width: 168px;
	padding: 8px 10px;
	border-radius: 10px;
	border: 1px solid rgba(37, 99, 235, 0.2);
	background: rgba(255, 255, 255, 0.96);
	box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.flight-label strong {
	font-size: 0.78rem;
	color: var(--brand);
	letter-spacing: 0;
}

.flight-label span {
	font-size: 0.82rem;
	line-height: 1.35;
}

@media (max-width: 980px) {
	.hero {
		grid-template-columns: 1fr;
	}

	.layout {
		grid-template-columns: 1fr;
		grid-template-areas:
			"upload"
			"table"
			"map";
	}

	.page-shell {
		width: min(100% - 20px, 1100px);
		padding-top: 16px;
	}

	.status-chip {
		max-width: none;
		text-align: left;
	}
}