/*
 * Homepage-specific styles.
 *
 * Sections that appear only on the front page. Loaded alongside main.css.
 */

/* ============ HERO ============ */
.hj-home-hero { padding-top: 140px; padding-bottom: 100px; }
.hj-home-hero-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: end;
	margin-bottom: var(--space-7);
}
.hj-home-hero-left { max-width: 720px; }
.hj-home-hero-left .hj-display-hero { max-width: 12ch; margin-bottom: 40px; }
.hj-home-hero-left .hj-standfirst { font-size: 22px; line-height: 1.55; margin-bottom: 56px; }

.hj-home-hero-aside {
	padding: 48px;
	border: 1px solid rgba(243, 234, 213, 0.22);
	background: rgba(8, 23, 43, 0.45);
	max-width: 480px;
	margin-left: auto;
}
.hj-aside-text {
	font-family: var(--serif);
	font-size: 19px;
	line-height: 1.6;
	color: var(--cream);
	margin: 0 0 32px 0;
	font-weight: 400;
}
.hj-aside-sign {
	font-family: var(--serif);
	font-size: 16px;
	color: var(--cream-mute);
	padding-top: 16px;
	border-top: 1px solid rgba(243, 234, 213, 0.12);
	font-style: italic;
}
.hj-aside-sign strong {
	font-weight: 600;
	font-style: normal;
	display: block;
	color: var(--cream);
	font-family: var(--sans);
	font-size: 13px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin-bottom: 4px;
}

/* ============ POSITIONING (II) ============ */
.hj-positioning {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border: 1px solid var(--rule);
}
.hj-pos-col {
	padding: 64px 56px;
	border-right: 1px solid var(--rule);
	background: var(--cream-soft);
}
.hj-pos-col:last-child { border-right: none; }
.hj-pos-num {
	font-family: var(--sans);
	font-size: 12px;
	letter-spacing: 0.28em;
	color: var(--oxblood);
	font-weight: 700;
	margin-bottom: 24px;
	display: block;
}
.hj-pos-col h3 {
	font-family: var(--display);
	font-variation-settings: "opsz" 72;
	font-weight: 400;
	font-size: 32px;
	line-height: 1.05;
	letter-spacing: -0.01em;
	margin: 0 0 20px 0;
	color: var(--ink);
}
.hj-pos-col h3 em {
	font-style: italic;
	color: var(--oxblood);
	font-weight: 300;
}
.hj-pos-col p {
	font-family: var(--serif);
	font-size: 19px;
	line-height: 1.6;
	color: var(--charcoal);
	margin: 0;
}
.hj-halo {
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--rule-soft);
	font-family: var(--sans);
	font-size: 14px;
	color: var(--ink-mute);
	line-height: 1.55;
}

/* ============ ROSTER (III) ============ */
.hj-aircraft-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border: 1px solid var(--rule-dark);
}
.hj-aircraft-card {
	padding: 40px 32px;
	border-right: 1px solid var(--rule-dark);
	border-bottom: 1px solid var(--rule-dark);
	background: transparent;
	display: flex;
	flex-direction: column;
	transition: background var(--dur-slow);
	color: var(--cream);
	cursor: pointer;
}
.hj-aircraft-card:hover { background: rgba(168, 139, 92, 0.08); color: var(--cream); }
.hj-aircraft-card:nth-child(4n) { border-right: none; }
.hj-aircraft-card:nth-last-child(-n+4) { border-bottom: none; }

.hj-aircraft-card .ac-label {
	font-family: var(--sans);
	font-size: 11px;
	letter-spacing: 0.26em;
	color: var(--gold);
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 16px;
}
.hj-aircraft-card .ac-label .roman { color: var(--cream-mute); margin-right: 12px; }

.hj-aircraft-card .ac-silhouette {
	height: 80px;
	margin: 16px 0 32px;
	color: var(--gold);
	opacity: 0.85;
}
.hj-aircraft-card .ac-silhouette svg { width: 100%; height: 100%; }
.hj-aircraft-card .ac-silhouette .line { stroke: currentColor; stroke-width: 1.2; fill: none; }

.hj-aircraft-card .ac-name {
	font-family: var(--display);
	font-variation-settings: "opsz" 48;
	font-size: 26px;
	font-weight: 400;
	line-height: 1.15;
	color: var(--cream);
	margin: 0 0 4px 0;
}
.hj-aircraft-card .ac-name em { font-style: italic; font-weight: 300; color: var(--gold); }
.hj-aircraft-card .ac-class {
	font-family: var(--serif);
	font-size: 15px;
	color: var(--cream-mute);
	margin-bottom: 20px;
}
.hj-aircraft-card .ac-specs {
	display: flex;
	gap: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--rule-dark);
	margin-top: auto;
}
.hj-aircraft-card .ac-specs > div { flex: 1; }
.hj-aircraft-card .ac-specs .k {
	font-family: var(--sans);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--gold);
	font-weight: 700;
	margin-bottom: 4px;
}
.hj-aircraft-card .ac-specs .v {
	font-family: var(--display);
	font-size: 20px;
	font-weight: 400;
	color: var(--cream);
	line-height: 1;
}

/* ============ ROUTES (IV) ============ */
.hj-routes-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	margin-top: var(--space-5);
}

/* ============ THE STANDARD (V) ============ */
.hj-standard-grid {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 80px;
	align-items: start;
}
.hj-standard-intro {
	position: sticky;
	top: 120px;
}
.hj-standard-intro .hj-section-title { font-size: clamp(28px, 3vw, 44px); margin-top: var(--space-3); }
.hj-standard-intro .hj-standfirst { margin-top: var(--space-4); }
.hj-standard-list {
	display: flex;
	flex-direction: column;
	gap: 40px;
}
.hj-standard-item {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 32px;
	padding-bottom: 40px;
	border-bottom: 1px solid var(--rule-dark);
}
.hj-standard-item:last-child { border-bottom: none; }
.hj-standard-item .num {
	font-family: var(--display);
	font-size: 44px;
	font-weight: 300;
	color: var(--gold);
	line-height: 1;
	padding-top: 4px;
	font-style: italic;
}
.hj-standard-item h4 {
	font-family: var(--display);
	font-size: 26px;
	font-weight: 500;
	margin: 0 0 12px 0;
	color: var(--cream);
}
.hj-standard-item p {
	font-family: var(--serif);
	font-size: 18px;
	line-height: 1.6;
	color: var(--cream);
	margin: 0;
}

/* ============ HOUSE ACCOUNT (VI) ============ */
.hj-account-grid {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 64px;
	align-items: start;
}
.hj-account-pitch .hj-ornament {
	color: var(--oxblood);
	margin-bottom: 24px;
	text-align: left;
	letter-spacing: 0.5em;
}
.hj-account-pitch h3 {
	font-family: var(--display);
	font-variation-settings: "opsz" 96;
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 300;
	line-height: 1.05;
	margin: 0 0 24px 0;
	color: var(--ink);
}
.hj-account-pitch h3 em { font-style: italic; color: var(--oxblood); }
.hj-account-pitch p {
	font-family: var(--serif);
	font-size: 19px;
	line-height: 1.65;
	color: var(--charcoal);
	margin: 0 0 20px 0;
}

.hj-account-card {
	background: var(--ink);
	color: var(--cream);
	padding: 48px 40px;
	border: 1px solid var(--gold);
	position: relative;
}
.hj-account-card .card-corner {
	position: absolute;
	top: 20px;
	right: 20px;
	font-family: var(--sans);
	font-size: 11px;
	letter-spacing: 0.3em;
	color: var(--gold);
	font-weight: 700;
}
.hj-account-card .card-label {
	font-family: var(--sans);
	font-size: 11px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--gold);
	font-weight: 700;
	margin-bottom: 20px;
}
.hj-account-card h4 {
	font-family: var(--display);
	font-variation-settings: "opsz" 72;
	font-size: 26px;
	font-weight: 400;
	line-height: 1.15;
	color: var(--cream);
	margin: 0 0 28px 0;
	letter-spacing: -0.005em;
}
.hj-account-card h4 em { font-style: italic; color: var(--gold); }
.hj-account-card ul { list-style: none; padding: 0; margin: 0; }
.hj-account-card li {
	padding: 14px 0;
	border-bottom: 1px solid var(--rule-dark);
	font-family: var(--serif);
	font-size: 16px;
	line-height: 1.5;
	color: var(--cream);
	display: grid;
	grid-template-columns: 28px 1fr;
	gap: 12px;
}
.hj-account-card li::before {
	content: "·";
	color: var(--gold);
	font-family: var(--display);
	font-size: 28px;
	line-height: 0.6;
	font-weight: 700;
}

/* ============ JOURNAL (VII) ============ */
.hj-journal-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: 48px;
}
.hj-article-card {
	display: block;
	border-top: 2px solid var(--ink);
	padding-top: 20px;
	color: inherit;
}
.hj-article-card:first-child { border-top-color: var(--oxblood); }
.hj-article-card .art-label {
	font-family: var(--sans);
	font-size: 11px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--oxblood);
	margin-bottom: 16px;
	display: flex;
	justify-content: space-between;
}
.hj-article-card .art-label .issue { color: var(--ink-mute); font-weight: 500; }
.hj-article-card .art-title {
	font-family: var(--display);
	font-variation-settings: "opsz" 96;
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--ink);
	margin: 0 0 16px 0;
	transition: color var(--dur-fast);
}
.hj-article-card:first-child .art-title { font-size: 42px; }
.hj-article-card:nth-child(2) .art-title, .hj-article-card:nth-child(3) .art-title { font-size: 30px; }
.hj-article-card .art-title em { font-style: italic; font-weight: 300; color: var(--oxblood); }
.hj-article-card:hover .art-title { color: var(--oxblood); }
.hj-article-card .art-excerpt {
	font-family: var(--serif);
	font-size: 17px;
	line-height: 1.55;
	color: var(--charcoal);
	margin: 0 0 20px 0;
}
.hj-article-card .art-meta {
	font-family: var(--sans);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-mute);
	padding-top: 16px;
	border-top: 1px solid var(--rule-soft);
	font-weight: 500;
}
.hj-article-card .art-meta .author { color: var(--ink); font-weight: 700; }
.hj-article-card .art-meta .sep { margin: 0 8px; color: var(--oxblood); }

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px) {
	.hj-home-hero { padding-top: 80px; padding-bottom: 64px; }
	.hj-home-hero-grid { grid-template-columns: 1fr; gap: 56px; }
	.hj-home-hero-aside { max-width: 100%; margin: 0; }
	.hj-positioning { grid-template-columns: 1fr; }
	.hj-pos-col { border-right: none; border-bottom: 1px solid var(--rule); padding: 48px 32px; }
	.hj-pos-col:last-child { border-bottom: none; }
	.hj-aircraft-grid { grid-template-columns: repeat(2, 1fr); }
	.hj-aircraft-card { border-right: 1px solid var(--rule-dark); border-bottom: 1px solid var(--rule-dark); }
	.hj-aircraft-card:nth-child(4n) { border-right: 1px solid var(--rule-dark); }
	.hj-aircraft-card:nth-child(2n) { border-right: none; }
	.hj-aircraft-card:nth-last-child(-n+4) { border-bottom: 1px solid var(--rule-dark); }
	.hj-aircraft-card:nth-last-child(-n+2) { border-bottom: none; }
	.hj-routes-grid { grid-template-columns: 1fr; }
	.hj-standard-grid { grid-template-columns: 1fr; gap: 48px; }
	.hj-standard-intro { position: static; }
	.hj-account-grid { grid-template-columns: 1fr; gap: 48px; }
	.hj-journal-grid { grid-template-columns: 1fr; gap: 56px; }
	.hj-article-card:first-child .art-title { font-size: 36px; }
}

@media (max-width: 640px) {
	.hj-aircraft-grid { grid-template-columns: 1fr; }
	.hj-aircraft-card { border-right: none !important; }
	.hj-aircraft-card:not(:last-child) { border-bottom: 1px solid var(--rule-dark) !important; }
	.hj-account-card { padding: 32px 24px; }
	.hj-pos-col { padding: 40px 24px; }
}
