/* =========================================================================
   PMJ · "The Broadsheet"
   Editorial fintech home page + global header/footer restyle.
   Laravel 12 + Bootstrap 5 + jQuery. Loaded globally — home-specific blocks
   are scoped under .page-home so other pages are not affected.
   ========================================================================= */

/* ---------- 1. Tokens (global) ---------- */
:root {
	--pmj-ink:       #0e0b2e;
	--pmj-ink-90:    rgba(14, 11, 46, 0.90);
	--pmj-ink-70:    rgba(14, 11, 46, 0.70);
	--pmj-ink-55:    rgba(14, 11, 46, 0.55);
	--pmj-ink-35:    rgba(14, 11, 46, 0.35);
	--pmj-ink-15:    rgba(14, 11, 46, 0.15);
	--pmj-indigo:    #2d2566;
	--pmj-indigo-dk: #1a1442;
	--pmj-coral:     #f43b47;
	--pmj-coral-ink: #b8202a;
	--pmj-mist:      #a5dbf3;
	--pmj-verdant:   #0f6c44;
	--pmj-amber:     #b86e00;
	--pmj-cream:     #fbf9f4;
	--pmj-porcelain: #f5f2ea;
	--pmj-paper:     #ffffff;
	--pmj-hairline:  rgba(14, 11, 46, 0.14);
	--pmj-hairline-s:rgba(14, 11, 46, 0.07);
	--pmj-night:     #0a0820;
	--pmj-night-ln:  rgba(251, 249, 244, 0.14);

	--pmj-ff-display: "Fraunces", Georgia, "Times New Roman", serif;
	--pmj-ff-body:    "Albert Sans", "Helvetica Neue", Arial, sans-serif;
	--pmj-ff-mono:    "JetBrains Mono", ui-monospace, Menlo, monospace;

	--pmj-ease:      cubic-bezier(0.22, 0.61, 0.36, 1);
	--pmj-ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
}

/* =========================================================================
   2. GLOBAL NAVIGATION OVERRIDE (.vh-nav)
   Applies site-wide. Replaces the violet-chrome look.
   ========================================================================= */
.vh-nav {
	position: sticky;
	top: 0;
	z-index: 1040;
	padding: 1rem 0 !important;
	background: transparent !important;
	border-bottom: 1px solid transparent;
	transition:
		background 0.55s var(--pmj-ease),
		backdrop-filter 0.55s var(--pmj-ease),
		-webkit-backdrop-filter 0.55s var(--pmj-ease),
		border-color 0.55s var(--pmj-ease),
		padding 0.55s var(--pmj-ease),
		box-shadow 0.55s var(--pmj-ease);
}

.vh-nav.vh-nav-scrolled {
	background: rgba(251, 249, 244, 0.82) !important;
	-webkit-backdrop-filter: saturate(160%) blur(16px);
	backdrop-filter: saturate(160%) blur(16px);
	border-bottom-color: var(--pmj-hairline);
	padding-top: 0.65rem !important;
	padding-bottom: 0.65rem !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	box-shadow: 0 24px 60px -48px rgba(14, 11, 46, 0.35);
}

/* Coral hairline that slides in as you scroll */
.vh-nav::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 1px;
	background: var(--pmj-coral);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.9s var(--pmj-ease-out);
	pointer-events: none;
}
.vh-nav.vh-nav-scrolled::after { transform: scaleX(1); }

/* Logo */
.vh-nav .header-image,
.vh-nav a > img {
	height: 46px;
	width: auto;
	transition: height 0.55s var(--pmj-ease), filter 0.4s var(--pmj-ease);
}
.vh-nav.vh-nav-scrolled .header-image,
.vh-nav.vh-nav-scrolled a > img { height: 34px; }

/* Mobile toggler */
.vh-nav .navbar-toggler {
	border: 1px solid var(--pmj-ink) !important;
	border-radius: 2px !important;
	padding: 0.55rem 0.8rem !important;
	background: var(--pmj-cream) !important;
	box-shadow: none !important;
	transition: background 0.3s var(--pmj-ease), color 0.3s var(--pmj-ease);
}
.vh-nav .navbar-toggler:focus { box-shadow: none !important; outline: none !important; }
.vh-nav .navbar-toggler:hover { background: var(--pmj-ink) !important; }
.vh-nav .navbar-toggler:hover .navbar-toggler-icon {
	filter: invert(1);
}
.vh-nav .navbar-toggler-icon {
	width: 1.25em;
	height: 1.25em;
	background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath stroke='%230e0b2e' stroke-width='2' stroke-linecap='square' d='M3 7h18M3 12h18M3 17h18'/%3E%3C/svg%3E") !important;
}

/* Menu list */
.vh-nav .navbar-nav {
	align-items: center;
	gap: 0.15rem;
}

.vh-nav .navbar-nav .nav-item {
	margin: 0;
	padding: 0;
}

.vh-nav .navbar-nav .nav-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	font-family: var(--pmj-ff-mono) !important;
	font-size: 0.7rem !important;
	font-weight: 500 !important;
	letter-spacing: 0.2em !important;
	text-transform: uppercase !important;
	color: var(--pmj-ink) !important;
	padding: 0.75rem 1rem !important;
	transition: color 0.35s var(--pmj-ease);
}

.vh-nav .navbar-nav .nav-link::after {
	content: "";
	position: absolute;
	left: 1rem;
	right: 1rem;
	bottom: 0.55rem;
	height: 1px;
	background: var(--pmj-coral);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.5s var(--pmj-ease-out);
}

.vh-nav .navbar-nav .nav-link:hover,
.vh-nav .navbar-nav .nav-link:focus {
	color: var(--pmj-indigo) !important;
	background: transparent !important;
}

.vh-nav .navbar-nav .nav-link:hover::after {
	transform: scaleX(1);
}

.vh-nav .navbar-nav .nav-link.active {
	color: var(--pmj-coral) !important;
}
.vh-nav .navbar-nav .nav-link.active::before {
	content: "";
	position: absolute;
	left: 0.35rem;
	top: 50%;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--pmj-coral);
	transform: translateY(-50%);
	box-shadow: 0 0 0 3px rgba(244, 59, 71, 0.15);
}
.vh-nav .navbar-nav .nav-link.active {
	padding-left: 1.25rem !important;
}
.vh-nav .navbar-nav .nav-link.active::after {
	transform: scaleX(1);
	background: var(--pmj-coral);
}

/* Welcome greeting (auth) */
.vh-nav #head-username {
	font-family: var(--pmj-ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 0.98rem;
	color: var(--pmj-ink-70);
	padding: 0.5rem 1rem;
	letter-spacing: -0.005em;
	font-variation-settings: "SOFT" 100, "opsz" 144;
}

/* Special CTA treatment for Register link (guest) */
.vh-nav .navbar-nav .nav-link[href*="register"] {
	background: var(--pmj-ink) !important;
	color: var(--pmj-cream) !important;
	border-radius: 2px;
	margin-left: 0.35rem;
	padding: 0.7rem 1.1rem !important;
	transition: background 0.35s var(--pmj-ease), color 0.35s var(--pmj-ease), transform 0.35s var(--pmj-ease);
}
.vh-nav .navbar-nav .nav-link[href*="register"]::after { display: none; }
.vh-nav .navbar-nav .nav-link[href*="register"]:hover {
	background: var(--pmj-coral) !important;
	color: #fff !important;
	transform: translateY(-1px);
}

/* Mobile collapsed drawer */
@media (max-width: 991.98px) {
	.vh-nav .navbar-collapse {
		margin-top: 1rem;
		padding: 1.25rem 0.25rem;
		background: var(--pmj-cream);
		border: 1px solid var(--pmj-hairline);
		border-radius: 2px;
	}
	.vh-nav .navbar-nav {
		align-items: stretch;
		gap: 0;
	}
	.vh-nav .navbar-nav .nav-link {
		padding: 0.9rem 1.25rem !important;
		border-bottom: 1px solid var(--pmj-hairline-s);
	}
	.vh-nav .navbar-nav .nav-link::after { display: none; }
	.vh-nav .navbar-nav .nav-item:last-child .nav-link { border-bottom: 0; }
	.vh-nav .navbar-nav .nav-link[href*="register"] {
		margin: 0.75rem 1rem;
		text-align: center;
		justify-content: center;
	}
}

/* =========================================================================
   3. GLOBAL FOOTER OVERRIDE (.vh-footer)
   ========================================================================= */
.vh-footer {
	position: relative;
	background: var(--pmj-night) !important;
	color: #cfcabd;
	font-family: var(--pmj-ff-body);
	padding: 0 !important;
	overflow: hidden;
	border-top: 1px solid var(--pmj-ink-15);
}

.vh-footer::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
	background-size: 80px 80px;
	mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 100%);
	-webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 100%);
	pointer-events: none;
}

.vh-footer > .footer-wrapper {
	position: relative;
	padding: clamp(3.5rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem) !important;
	background: transparent !important;
}

.vh-footer .container { position: relative; }

.vh-footer a { transition: color 0.3s var(--pmj-ease); }

.vh-footer .row { align-items: flex-start; }

.vh-footer img[alt] {
	width: 150px !important;
	filter: brightness(0) invert(1) opacity(0.95);
}

.vh-footer .vh-footer-heading {
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--pmj-coral);
	margin: 0 0 1.25rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--pmj-night-ln);
}

.vh-footer p,
.vh-footer .col-lg-4 > p {
	color: rgba(255,255,255,0.65) !important;
	font-size: 0.94rem !important;
	line-height: 1.7 !important;
	font-family: var(--pmj-ff-body) !important;
	margin: 1.25rem 0 0 !important;
	max-width: 32ch !important;
}

.vh-footer .col-lg-3 div[style],
.vh-footer .col-lg-3 .col-lg-3 > div {
	color: rgba(255,255,255,0.75) !important;
	font-size: 0.95rem !important;
	line-height: 1.8 !important;
	font-family: var(--pmj-ff-body) !important;
}

.vh-footer .footer-items {
	color: rgba(255,255,255,0.75) !important;
	text-decoration: none !important;
	font-family: var(--pmj-ff-body) !important;
	font-size: 0.95rem !important;
	position: relative;
	padding-left: 0;
	transition: color 0.35s var(--pmj-ease), padding-left 0.35s var(--pmj-ease);
}

.vh-footer .footer-items::before {
	content: "→";
	display: inline-block;
	opacity: 0;
	margin-right: 0.35rem;
	color: var(--pmj-coral);
	transform: translateX(-4px);
	transition: opacity 0.35s var(--pmj-ease), transform 0.35s var(--pmj-ease);
	font-family: var(--pmj-ff-mono);
}

.vh-footer .footer-items:hover {
	color: #fff !important;
}

.vh-footer .footer-items:hover::before {
	opacity: 1;
	transform: translateX(0);
}

.vh-footer .footer-link {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	padding: 0.85rem 1.35rem;
	background: transparent;
	color: #fff !important;
	text-decoration: none !important;
	border: 1px solid rgba(255,255,255,0.35);
	border-radius: 2px;
	font-family: var(--pmj-ff-mono);
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	transition: all 0.4s var(--pmj-ease);
	margin-top: 0.25rem;
}

.vh-footer .footer-link::after {
	content: "→";
	transition: transform 0.45s var(--pmj-ease-out);
}

.vh-footer .footer-link:hover {
	background: var(--pmj-coral);
	border-color: var(--pmj-coral);
	color: #fff !important;
	transform: translateY(-2px);
	box-shadow: 0 18px 40px -22px rgba(244, 59, 71, 0.6);
}
.vh-footer .footer-link:hover::after { transform: translateX(4px); }

/* License disclosure block */
.vh-footer .vh-footer-license {
	display: block;
	margin-top: 3rem;
	padding: 1.5rem 0 0;
	border-top: 1px solid var(--pmj-night-ln);
	font-family: var(--pmj-ff-mono);
	font-size: 0.7rem;
	line-height: 1.85;
	letter-spacing: 0.02em;
	color: rgba(255,255,255,0.5) !important;
	text-decoration: none !important;
	max-width: 82ch;
	transition: color 0.35s var(--pmj-ease);
}
.vh-footer .vh-footer-license:hover {
	color: rgba(255,255,255,0.85) !important;
}

/* Bottom bar */
.vh-footer .bottom-footer {
	position: relative;
	padding: 1.5rem clamp(1rem, 4vw, 3rem) !important;
	background: transparent !important;
	border-top: 1px solid var(--pmj-night-ln);
}
.vh-footer .bottom-footer p {
	margin: 0 !important;
	font-family: var(--pmj-ff-mono) !important;
	font-size: 0.68rem !important;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.4) !important;
	max-width: none !important;
}
.vh-footer .bottom-footer p a {
	color: rgba(255,255,255,0.75) !important;
	text-decoration: none !important;
}
.vh-footer .bottom-footer p a:hover {
	color: var(--pmj-coral) !important;
}

/* =========================================================================
   4. PAGE: HOME (.page-home)
   ========================================================================= */
.page-home {
	background:
		radial-gradient(900px 500px at 90% -10%, rgba(101, 40, 247, 0.09), transparent 60%),
		radial-gradient(800px 500px at -10% 20%, rgba(165, 219, 243, 0.22), transparent 55%),
		linear-gradient(180deg, #F6F4FF 0%, #ECE6FF 100%);
	color: var(--pmj-ink);
	font-family: var(--pmj-ff-body);
	font-feature-settings: "ss01", "ss02";
	-webkit-font-smoothing: antialiased;
	position: relative;
	overflow: hidden;
}

/* Reset the legacy .main-linear wrapper from the layout */
body .main-linear:has(.page-home) {
	background: transparent !important;
}

.page-home::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(var(--pmj-hairline-s) 1px, transparent 1px),
		linear-gradient(90deg, var(--pmj-hairline-s) 1px, transparent 1px);
	background-size: 90px 90px;
	mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, #000 40%, transparent 100%);
	-webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, #000 40%, transparent 100%);
	opacity: 0.55;
	z-index: 0;
}

.page-home::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.3;
	mix-blend-mode: multiply;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.055  0 0 0 0 0.043  0 0 0 0 0.18  0 0 0 0.09 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	z-index: 0;
}

.page-home > section { position: relative; z-index: 1; }

.home-container {
	width: min(1220px, 92vw);
	margin: 0 auto;
}

/* ---------- 5. Eyebrow / section markers ---------- */
.home-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
}
.home-eyebrow::before {
	content: "";
	display: block;
	width: 28px;
	height: 1px;
	background: var(--pmj-ink-35);
}
.home-eyebrow--light {
	color: rgba(255,255,255,0.65);
}
.home-eyebrow--light::before {
	background: rgba(255,255,255,0.5);
}

.home-section-head {
	padding-bottom: 2rem;
	margin-bottom: 3rem;
	border-bottom: 1px solid var(--pmj-hairline);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
}

.home-section-head h2 {
	font-family: var(--pmj-ff-display);
	font-weight: 300;
	font-size: clamp(2rem, 5vw, 3.75rem);
	line-height: 0.98;
	letter-spacing: -0.03em;
	color: var(--pmj-ink);
	margin: 0;
	font-variation-settings: "SOFT" 40, "opsz" 144;
	max-width: 18ch;
}
.home-section-head h2 em {
	font-style: italic;
	font-weight: 300;
	color: var(--pmj-indigo);
	font-variation-settings: "SOFT" 100, "opsz" 144;
}

.home-section-lead {
	font-size: 1.05rem;
	color: var(--pmj-ink-70);
	max-width: 52ch;
	line-height: 1.6;
	margin: 0;
}

/* ---------- 6. HERO ---------- */
.home-hero {
	padding: clamp(5rem, 10vw, 9rem) 0 clamp(4rem, 7vw, 7rem);
}

.home-hero__kicker {
	font-family: var(--pmj-ff-mono);
	font-size: 0.72rem;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
	padding-bottom: 1.25rem;
	margin-bottom: 2.5rem;
	border-bottom: 1px solid var(--pmj-hairline);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.5rem;
}
.home-hero__kicker strong {
	color: var(--pmj-coral);
	font-weight: 500;
}

.home-hero__title {
	font-family: var(--pmj-ff-display);
	font-weight: 300;
	font-size: clamp(3rem, 10vw, 8rem);
	line-height: 0.92;
	letter-spacing: -0.038em;
	color: var(--pmj-ink);
	margin: 0 0 2rem;
	max-width: 14ch;
	font-variation-settings: "SOFT" 30, "opsz" 144;
}

.home-hero__title em {
	font-style: italic;
	font-weight: 300;
	color: var(--pmj-indigo);
	font-variation-settings: "SOFT" 100, "opsz" 144;
	position: relative;
	white-space: nowrap;
}

.home-hero__title .dot {
	color: var(--pmj-coral);
	font-style: normal;
}

.home-hero__sub {
	font-size: clamp(1rem, 1.6vw, 1.2rem);
	line-height: 1.6;
	color: var(--pmj-ink-70);
	max-width: 48ch;
	margin: 0 0 2.75rem;
}

.home-hero__sub strong {
	color: var(--pmj-ink);
	font-weight: 600;
}

.home-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 4rem;
}

.home-hero__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--pmj-hairline);
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
}
.home-hero__meta-item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}
.home-hero__meta-item .dot {
	width: 5px; height: 5px;
	border-radius: 50%;
	background: var(--pmj-coral);
}

/* ---------- 7. Buttons ---------- */
.btn-paper {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.85rem;
	padding: 1.05rem 1.85rem;
	background: var(--pmj-ink);
	color: var(--pmj-cream);
	border: 1px solid var(--pmj-ink);
	border-radius: 2px;
	font-family: var(--pmj-ff-mono);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition:
		transform 0.45s var(--pmj-ease),
		background 0.45s var(--pmj-ease),
		color 0.45s var(--pmj-ease),
		border-color 0.45s var(--pmj-ease),
		box-shadow 0.45s var(--pmj-ease);
	overflow: hidden;
}

.btn-paper svg {
	width: 16px;
	height: 16px;
	transition: transform 0.5s var(--pmj-ease-out);
}

.btn-paper:hover {
	transform: translateY(-2px);
	background: var(--pmj-indigo);
	color: var(--pmj-cream);
	border-color: var(--pmj-indigo);
	box-shadow: 0 22px 50px -28px rgba(69, 58, 148, 0.6);
}
.btn-paper:hover svg { transform: translateX(5px); }

.btn-paper--ghost {
	background: transparent;
	color: var(--pmj-ink);
}
.btn-paper--ghost:hover {
	background: var(--pmj-ink);
	color: var(--pmj-cream);
	border-color: var(--pmj-ink);
}

.btn-paper--coral {
	background: var(--pmj-coral);
	border-color: var(--pmj-coral);
	color: #fff;
}
.btn-paper--coral:hover {
	background: var(--pmj-coral-ink);
	border-color: var(--pmj-coral-ink);
	box-shadow: 0 22px 50px -28px rgba(244, 59, 71, 0.65);
}

.btn-paper--cream {
	background: var(--pmj-cream);
	border-color: var(--pmj-cream);
	color: var(--pmj-ink);
}
.btn-paper--cream:hover {
	background: var(--pmj-coral);
	border-color: var(--pmj-coral);
	color: #fff;
	box-shadow: 0 22px 50px -28px rgba(244, 59, 71, 0.5);
}

/* ---------- 8. FEATURES ---------- */
.home-features {
	padding: clamp(4rem, 7vw, 7rem) 0;
}

.home-features__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--pmj-hairline);
	border-bottom: 1px solid var(--pmj-hairline);
}

.home-feature {
	position: relative;
	padding: 3rem 2.25rem;
	border-right: 1px solid var(--pmj-hairline);
	background: transparent;
	transition: background 0.5s var(--pmj-ease);
}
.home-feature:last-child { border-right: 0; }

.home-feature:hover {
	background: var(--pmj-paper);
}

.home-feature__num {
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--pmj-coral);
	margin-bottom: 2.5rem;
}

.home-feature__icon {
	width: 44px;
	height: 44px;
	margin-bottom: 1.5rem;
	color: var(--pmj-ink);
	transition: transform 0.6s var(--pmj-ease-out), color 0.4s var(--pmj-ease);
}
.home-feature:hover .home-feature__icon {
	transform: translateX(4px) rotate(-2deg);
	color: var(--pmj-indigo);
}

.home-feature h3 {
	font-family: var(--pmj-ff-display);
	font-weight: 400;
	font-size: 1.85rem;
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--pmj-ink);
	margin: 0 0 0.85rem;
	font-variation-settings: "SOFT" 50, "opsz" 144;
}

.home-feature p {
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--pmj-ink-70);
	margin: 0;
	max-width: 32ch;
}

@media (max-width: 900px) {
	.home-features__grid { grid-template-columns: 1fr; }
	.home-feature {
		border-right: 0;
		border-bottom: 1px solid var(--pmj-hairline);
	}
	.home-feature:last-child { border-bottom: 0; }
}

/* ---------- 9. STATS STRIP ---------- */
.home-stats {
	padding: clamp(3rem, 5vw, 5rem) 0;
}

.home-stats__head {
	margin-bottom: 2.5rem;
}

.home-stats__strip {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border-top: 1px solid var(--pmj-ink);
	border-bottom: 1px solid var(--pmj-hairline);
}

.home-stat {
	padding: 2.25rem 1.5rem;
	border-right: 1px solid var(--pmj-hairline);
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.home-stat:last-child { border-right: 0; }

.home-stat__value {
	font-family: var(--pmj-ff-display);
	font-weight: 300;
	font-size: clamp(2rem, 4vw, 3.25rem);
	line-height: 1;
	letter-spacing: -0.025em;
	color: var(--pmj-ink);
	font-variation-settings: "SOFT" 30, "opsz" 144;
}

.home-stat__label {
	font-family: var(--pmj-ff-mono);
	font-size: 0.65rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
	margin-top: 0.5rem;
}

@media (max-width: 768px) {
	.home-stats__strip {
		grid-template-columns: repeat(2, 1fr);
	}
	.home-stat {
		padding: 1.5rem 1rem;
	}
	.home-stat:nth-child(2) { border-right: 0; }
	.home-stat:nth-child(1), .home-stat:nth-child(2) {
		border-bottom: 1px solid var(--pmj-hairline);
	}
}

/* ---------- 10. HOW IT WORKS ---------- */
.home-how {
	padding: clamp(4rem, 7vw, 7rem) 0;
}

.home-how__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	counter-reset: step;
}

.home-how__item {
	position: relative;
	padding: 2.75rem 2.25rem 2.75rem 0;
	border-left: 1px solid var(--pmj-hairline);
	padding-left: 2.25rem;
}
.home-how__item:first-child { border-left: 1px solid var(--pmj-ink); }

.home-how__num {
	display: block;
	font-family: var(--pmj-ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 2.5rem;
	line-height: 1;
	color: var(--pmj-coral);
	margin-bottom: 1.75rem;
	font-variation-settings: "SOFT" 100, "opsz" 144;
}

.home-how__item h3 {
	font-family: var(--pmj-ff-display);
	font-weight: 400;
	font-size: 1.65rem;
	line-height: 1.1;
	letter-spacing: -0.015em;
	color: var(--pmj-ink);
	margin: 0 0 0.75rem;
	font-variation-settings: "SOFT" 50, "opsz" 144;
}

.home-how__item p {
	font-size: 0.97rem;
	line-height: 1.65;
	color: var(--pmj-ink-70);
	margin: 0;
	max-width: 30ch;
}

@media (max-width: 900px) {
	.home-how__list { grid-template-columns: 1fr; }
	.home-how__item {
		border-left: 1px solid var(--pmj-hairline);
	}
	.home-how__item:first-child { border-left: 1px solid var(--pmj-ink); }
}

/* ---------- 11. FAQ ---------- */
.home-faq {
	padding: clamp(4rem, 7vw, 7rem) 0;
	background:
		linear-gradient(180deg, transparent 0, rgba(255,255,255,0.82) 15%, rgba(255,255,255,0.82) 85%, transparent 100%);
}

.home-faq__list {
	max-width: 860px;
	margin: 0 auto;
	border-top: 1px solid var(--pmj-ink);
}

.home-faq__item {
	border-bottom: 1px solid var(--pmj-hairline);
}

.home-faq__header {
	margin: 0;
}

.home-faq__trigger {
	all: unset;
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 1.5rem;
	width: 100%;
	padding: 1.85rem 0.5rem;
	cursor: pointer;
	transition: padding 0.45s var(--pmj-ease);
}

.home-faq__trigger:focus-visible {
	outline: 1px solid var(--pmj-coral);
	outline-offset: 4px;
}

.home-faq__num {
	font-family: var(--pmj-ff-mono);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	color: var(--pmj-coral);
	align-self: start;
	padding-top: 0.35rem;
}

.home-faq__q {
	font-family: var(--pmj-ff-display);
	font-weight: 400;
	font-size: clamp(1.2rem, 2vw, 1.6rem);
	line-height: 1.25;
	letter-spacing: -0.015em;
	color: var(--pmj-ink);
	text-align: left;
	font-variation-settings: "SOFT" 40, "opsz" 144;
	transition: color 0.4s var(--pmj-ease);
}

.home-faq__chev {
	position: relative;
	width: 28px;
	height: 28px;
	border: 1px solid var(--pmj-ink);
	border-radius: 50%;
	flex-shrink: 0;
	transition: all 0.45s var(--pmj-ease);
}
.home-faq__chev::before,
.home-faq__chev::after {
	content: "";
	position: absolute;
	background: var(--pmj-ink);
	left: 50%;
	top: 50%;
	transition: all 0.45s var(--pmj-ease);
}
.home-faq__chev::before {
	width: 12px;
	height: 1.5px;
	transform: translate(-50%, -50%);
}
.home-faq__chev::after {
	width: 1.5px;
	height: 12px;
	transform: translate(-50%, -50%);
}

.home-faq__trigger[aria-expanded="true"] .home-faq__q {
	color: var(--pmj-indigo);
}
.home-faq__trigger[aria-expanded="true"] .home-faq__chev {
	background: var(--pmj-ink);
	border-color: var(--pmj-ink);
	transform: rotate(180deg);
}
.home-faq__trigger[aria-expanded="true"] .home-faq__chev::before,
.home-faq__trigger[aria-expanded="true"] .home-faq__chev::after {
	background: var(--pmj-cream);
}
.home-faq__trigger[aria-expanded="true"] .home-faq__chev::after {
	height: 0;
}

.home-faq__panel {
	/* Bootstrap collapse handles open/close */
}

.home-faq__body {
	padding: 0 0.5rem 2rem 3.25rem;
	font-size: 1rem;
	line-height: 1.75;
	color: var(--pmj-ink-70);
	max-width: 62ch;
}

.home-faq__body p { margin: 0 0 0.75rem; }
.home-faq__body p:last-child { margin-bottom: 0; }

@media (max-width: 640px) {
	.home-faq__trigger {
		grid-template-columns: auto 1fr;
		gap: 1rem;
	}
	.home-faq__chev {
		grid-column: 2;
		justify-self: end;
		margin-top: 0.35rem;
	}
	.home-faq__q {
		grid-column: 2;
		grid-row: 1;
	}
	.home-faq__body {
		padding-left: 2.25rem;
	}
}

/* ---------- 12. CTA STRIP ---------- */
.home-cta {
	padding: clamp(4rem, 7vw, 7rem) 0;
}

.home-cta__inner {
	position: relative;
	background: var(--pmj-ink);
	color: var(--pmj-cream);
	padding: clamp(3rem, 6vw, 5.5rem) clamp(2rem, 5vw, 4.5rem);
	border-radius: 2px;
	overflow: hidden;
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	gap: 2.5rem 3rem;
	align-items: end;
}

.home-cta__inner::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(600px 300px at 80% 10%, rgba(244, 59, 71, 0.18), transparent 60%),
		repeating-linear-gradient(-45deg, transparent 0 16px, rgba(255,255,255,0.025) 16px 17px);
	pointer-events: none;
}

.home-cta__inner > * { position: relative; }

.home-cta__inner h2 {
	font-family: var(--pmj-ff-display);
	font-weight: 300;
	font-size: clamp(2.2rem, 5vw, 4rem);
	line-height: 0.98;
	letter-spacing: -0.03em;
	color: var(--pmj-cream);
	margin: 1.25rem 0 0;
	font-variation-settings: "SOFT" 30, "opsz" 144;
	max-width: 14ch;
}
.home-cta__inner h2 em {
	font-style: italic;
	color: var(--pmj-coral);
	font-variation-settings: "SOFT" 100, "opsz" 144;
}

.home-cta__aside {
	display: flex;
	flex-direction: column;
	gap: 1.75rem;
	align-items: flex-start;
}
.home-cta__aside p {
	font-size: 1rem;
	line-height: 1.65;
	color: rgba(255,255,255,0.72);
	margin: 0;
	max-width: 34ch;
}

@media (max-width: 820px) {
	.home-cta__inner {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

/* =========================================================================
   13. Reveal choreography
   ========================================================================= */
[data-reveal] {
	opacity: 0;
	transform: translateY(24px);
	filter: blur(6px);
	transition:
		opacity 0.9s var(--pmj-ease-out),
		transform 0.9s var(--pmj-ease-out),
		filter 0.9s var(--pmj-ease-out);
	will-change: opacity, transform, filter;
}
[data-reveal].is-visible {
	opacity: 1;
	transform: none;
	filter: blur(0);
}

/* Legacy .vh-reveal class from the old home markup — keep supported in case
   anything external still references it. */
.vh-reveal {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.9s var(--pmj-ease-out), transform 0.9s var(--pmj-ease-out);
}
.vh-reveal.is-visible {
	opacity: 1;
	transform: none;
}

/* =========================================================================
   15. AUTHED WELCOME STRIP (above hero, @auth only)
   ========================================================================= */
.home-authed {
	position: relative;
	z-index: 1;
	border-bottom: 1px solid var(--pmj-hairline);
	background: rgba(255, 255, 255, 0.55);
	-webkit-backdrop-filter: saturate(140%) blur(6px);
	backdrop-filter: saturate(140%) blur(6px);
}

.home-authed__inner {
	width: min(1220px, 92vw);
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1.75rem;
	padding: 0.9rem 0;
}

.home-authed__eyebrow {
	font-family: var(--pmj-ff-mono);
	font-size: 0.64rem;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--pmj-coral);
	position: relative;
	padding-left: 1.6rem;
}
.home-authed__eyebrow::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 20px;
	height: 1px;
	background: var(--pmj-ink-35);
	transform: translateY(-50%);
}

.home-authed__name {
	font-family: var(--pmj-ff-display);
	font-weight: 400;
	font-size: 1rem;
	color: var(--pmj-ink);
	flex: 1 1 auto;
	font-variation-settings: "SOFT" 40, "opsz" 144;
}
.home-authed__name em {
	font-style: italic;
	font-weight: 400;
	color: var(--pmj-indigo);
	font-variation-settings: "SOFT" 100, "opsz" 144;
}

.home-authed__link {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--pmj-ink) !important;
	text-decoration: none !important;
	padding: 0.4rem 0;
	border-bottom: 1px solid var(--pmj-ink);
	transition: color 0.35s var(--pmj-ease), border-color 0.35s var(--pmj-ease);
}
.home-authed__link svg { transition: transform 0.45s var(--pmj-ease-out); }
.home-authed__link:hover {
	color: var(--pmj-coral) !important;
	border-color: var(--pmj-coral);
}
.home-authed__link:hover svg { transform: translateX(4px); }

@media (max-width: 640px) {
	.home-authed__inner { padding: 0.85rem 0; }
	.home-authed__name { flex: 1 1 100%; order: 2; }
	.home-authed__eyebrow { order: 1; }
	.home-authed__link { order: 3; }
}

/* =========================================================================
   16. MARKET WATCH (№ 02)
   ========================================================================= */
.home-market {
	padding: clamp(3rem, 6vw, 5.5rem) 0 clamp(2rem, 4vw, 4rem);
}

.home-market__head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.75rem 2rem;
	padding-bottom: 1.5rem;
	margin-bottom: 0;
	border-bottom: 1px solid var(--pmj-ink);
}

.home-market__stamp {
	font-family: var(--pmj-ff-mono);
	font-size: 0.66rem;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
}
.home-market__stamp time { color: var(--pmj-ink); }

.home-market__strip {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border-bottom: 1px solid var(--pmj-hairline);
}

.home-market__row {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 1.25rem;
	padding: 1.5rem 1.35rem;
	border-right: 1px solid var(--pmj-hairline);
	background: transparent;
	transition: background 0.45s var(--pmj-ease);
}
.home-market__row:last-child { border-right: 0; }
.home-market__row:hover { background: var(--pmj-paper); }

.home-market__left {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}
.home-market__pair {
	font-family: var(--pmj-ff-mono);
	font-size: 0.66rem;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pmj-ink);
}
.home-market__name {
	font-family: var(--pmj-ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 0.88rem;
	color: var(--pmj-ink-55);
	font-variation-settings: "SOFT" 100, "opsz" 9;
}

.home-market__spark {
	display: block;
	width: 100%;
	height: 40px;
	min-width: 0;
	color: var(--pmj-ink-35);
}
.home-market__spark svg {
	width: 100%;
	height: 100%;
	overflow: visible;
	display: block;
}
.home-market__spark-line {
	stroke-dasharray: 400;
	stroke-dashoffset: 400;
	transition: stroke-dashoffset 1.4s var(--pmj-ease-out);
}
.home-market__row.is-visible .home-market__spark-line {
	stroke-dashoffset: 0;
}
.home-market__row--up .home-market__spark { color: var(--pmj-verdant); }
.home-market__row--down .home-market__spark { color: var(--pmj-coral); }

.home-market__right {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	text-align: right;
	white-space: nowrap;
}
.home-market__price {
	font-family: var(--pmj-ff-mono);
	font-size: 0.95rem;
	font-weight: 500;
	color: var(--pmj-ink);
	font-variant-numeric: tabular-nums;
}
.home-market__change {
	font-family: var(--pmj-ff-mono);
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	font-variant-numeric: tabular-nums;
}
.home-market__row--up .home-market__change  { color: var(--pmj-verdant); }
.home-market__row--down .home-market__change { color: var(--pmj-coral); }

.home-market__disclaimer {
	margin: 1.25rem 0 0;
	font-family: var(--pmj-ff-mono);
	font-size: 0.66rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--pmj-ink-35);
	line-height: 1.6;
}
.home-market__disclaimer a {
	color: var(--pmj-ink) !important;
	text-decoration: none;
	border-bottom: 1px solid var(--pmj-coral);
	transition: color 0.3s var(--pmj-ease);
}
.home-market__disclaimer a:hover { color: var(--pmj-coral) !important; }

@media (max-width: 1024px) {
	.home-market__strip { grid-template-columns: repeat(2, 1fr); }
	.home-market__row:nth-child(2) { border-right: 0; }
	.home-market__row:nth-child(1),
	.home-market__row:nth-child(2) { border-bottom: 1px solid var(--pmj-hairline); }
}
@media (max-width: 560px) {
	.home-market__strip { grid-template-columns: 1fr; }
	.home-market__row {
		border-right: 0;
		border-bottom: 1px solid var(--pmj-hairline);
	}
	.home-market__row:last-child { border-bottom: 0; }
	.home-market__head {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* =========================================================================
   17. CREDENTIALS (№ 06)
   ========================================================================= */
.home-credentials {
	padding: clamp(4rem, 7vw, 7rem) 0;
}

.home-credentials__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--pmj-ink);
	border-bottom: 1px solid var(--pmj-hairline);
}

.home-credential {
	position: relative;
	padding: 2.75rem 2.25rem 2.5rem;
	border-right: 1px solid var(--pmj-hairline);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	background: transparent;
	transition: background 0.5s var(--pmj-ease);
}
.home-credential:last-child { border-right: 0; }
.home-credential:hover { background: var(--pmj-paper); }

.home-credential__mark {
	font-family: var(--pmj-ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 2rem;
	line-height: 1;
	color: var(--pmj-coral);
	font-variation-settings: "SOFT" 100, "opsz" 144;
	margin-bottom: 1rem;
}

.home-credential__label {
	font-family: var(--pmj-ff-mono);
	font-size: 0.66rem;
	font-weight: 500;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--pmj-ink-55);
}

.home-credential__value {
	font-family: var(--pmj-ff-display);
	font-weight: 400;
	font-size: 1.75rem;
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--pmj-ink);
	font-variation-settings: "SOFT" 50, "opsz" 144;
	margin: 0.25rem 0 0.75rem;
}

.home-credential__body {
	font-size: 0.94rem;
	line-height: 1.65;
	color: var(--pmj-ink-70);
	margin: 0;
	max-width: 32ch;
}

.home-credential__meta {
	margin-top: auto;
	padding-top: 1.25rem;
	border-top: 1px solid var(--pmj-hairline-s);
	font-family: var(--pmj-ff-mono);
	font-size: 0.64rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--pmj-ink-35);
}

.home-credential__link {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin-top: auto;
	padding: 1.25rem 0 0;
	border-top: 1px solid var(--pmj-hairline-s);
	font-family: var(--pmj-ff-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--pmj-ink) !important;
	text-decoration: none !important;
	transition: color 0.35s var(--pmj-ease);
}
.home-credential__link svg { transition: transform 0.45s var(--pmj-ease-out); }
.home-credential__link:hover { color: var(--pmj-coral) !important; }
.home-credential__link:hover svg { transform: translateX(4px); }

@media (max-width: 900px) {
	.home-credentials__grid { grid-template-columns: 1fr; }
	.home-credential {
		border-right: 0;
		border-bottom: 1px solid var(--pmj-hairline);
	}
	.home-credential:last-child { border-bottom: 0; }
}

/* =========================================================================
   14. Reduced motion
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
	[data-reveal],
	.vh-reveal {
		opacity: 1;
		transform: none;
		filter: none;
		transition: none;
	}
	.vh-nav,
	.vh-nav::after,
	.btn-paper,
	.home-faq__trigger,
	.home-feature__icon { transition: none; }
}
