/* ===================================================================
   HotelNet — Landing Page v2
   Self-contained stylesheet for the rebuilt marketing landing page.
   Loaded IN ADDITION to base.css + hotelnet.css (see main_v2.html), so
   it reuses the brand tokens (--red/--peach/etc.), the global .btn-*
   classes, .reveal scroll-reveal and the .stat-number counters, and
   only adds the v2-specific layout. Every class is prefixed `lp2-`
   so nothing here can leak into / collide with the v1 page.
   =================================================================== */

:root {
	--lp2-cream:      #FBF3F0;   /* soft peach-tint section bg            */
	--lp2-ink:        #1A1011;   /* near-black headings on light bg       */
	--lp2-muted:      #6A5E5E;   /* body copy on light bg                 */
	--lp2-line:       rgba(17, 10, 10, 0.08);
	--lp2-maxw:       1180px;    /* shared content max width              */
	--lp2-radius:     22px;
	--lp2-radius-sm:  14px;
	--lp2-shadow:     0 28px 70px -28px rgba(103, 6, 13, 0.38);
	--lp2-shadow-sm:  0 14px 34px -16px rgba(17, 10, 10, 0.30);
}

/* In-page anchor targets clear the (sticky) navbar when scrolled to. */
[id^="lp2-"] { scroll-margin-top: 92px; }

/* Shared centred container */
.lp2-wrap {
	max-width: var(--lp2-maxw);
	margin-inline: auto;
	width: 100%;
}

/* Section vertical rhythm (side padding comes from the global `section`
   rule in hotelnet.css). */
.lp2-pad   { padding-top: var(--hn-section-py);       padding-bottom: var(--hn-section-py); }
.lp2-pad-t { padding-top: var(--hn-section-py); }

/* Shared eyebrow pill (light surfaces) */
.lp2-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background-color: var(--peach);
	color: var(--red);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	padding: 6px 16px;
	border-radius: 3rem;
	margin-bottom: 22px;
}
.lp2-eyebrow .live-dot {
	width: 7px; height: 7px; border-radius: 50%;
	background-color: var(--red); display: inline-block;
	animation: pulse-dot 2s ease-in-out infinite;
}

/* Shared section heading block */
.lp2-h2 {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: clamp(2rem, 1.3rem + 2.4vw, 3rem);
	line-height: 1.12;
	color: var(--lp2-ink);
	margin-bottom: 18px;
}
/* Editorial accent: the coloured word(s) in a heading render in italic serif.
   `padding-right` keeps the slanted final glyph from clipping at the edge. */
.lp2-h2 .red {
	font-style: italic;
	padding-right: 0.06em;
}
.lp2-lead {
	font-size: 15.5px;
	line-height: 1.8;
	color: var(--lp2-muted);
	max-width: 540px;
}

/* ===================================================================
   1. HERO  — full-bleed hotel-lobby photo + gradient overlay
   =================================================================== */
.lp2-hero {
	position: relative;
	min-height: min(92vh, 820px);
	display: flex;
	/* Top-align the copy so it sits just under the nav (instead of being
	   pinned to the bottom of a tall hero, which left a big gap up top and
	   pushed the subtitle/CTAs past the fold). The sticky nav occupies its
	   own space, so only a small top padding is needed here. */
	align-items: flex-start;
	padding: 56px 54px 64px;
	overflow: hidden;
	color: #fff;
	isolation: isolate;
	/* Fallback gradient (brand red) shows if the photo is missing. */
	background:
		linear-gradient(120deg, #910911 0%, #67060D 55%, #BD665B 100%);
}
.lp2-hero-bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	background-image: url('../img/v2/hero-lobby.jpg');
	background-size: cover;
	background-position: center;
	transform: scale(1.02);
}
/* Readability scrim — rosewood (#67060D), darker toward the bottom-left
   where the copy sits, so the white + peach foreground text keeps strong
   contrast. (#67060D = rgb(103,6,13)) */
.lp2-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(180deg, rgba(103,6,13,0.48) 0%, rgba(103,6,13,0.22) 40%, rgba(103,6,13,0.92) 100%),
		linear-gradient(95deg, rgba(103,6,13,0.80) 0%, rgba(103,6,13,0.32) 55%, rgba(103,6,13,0) 100%);
}

.lp2-hero-inner { max-width: var(--lp2-maxw); margin-inline: auto; width: 100%; }

.lp2-hero .lp2-eyebrow {
	background: rgba(255, 255, 255, 0.16);
	color: #fff;
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	border: 1px solid rgba(255, 255, 255, 0.28);
}
.lp2-hero .lp2-eyebrow .live-dot { background: #fff; }

.lp2-hero h1 {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: clamp(2rem, 1.1rem + 2.7vw, 3.35rem);
	line-height: 1.1;
	color: #fff;
	margin: 0 0 22px;
	/* Shared measure with the subtitle so both columns are the same width.
	   ~49rem sits just past the headline's longest line ("Suppliers Under
	   One Platform"), so the h1 stays 2 lines and fills the box, and the
	   subtitle below wraps to the same visual width. */
	max-width: min(100%, 49rem);
	text-shadow: 0 2px 30px rgba(0, 0, 0, 0.35);
}
.lp2-hero h1 .accent { color: var(--peach); font-style: italic; padding-right: 0.06em; }

.lp2-hero-sub {
	font-size: clamp(14.5px, 13px + 0.4vw, 17px);
	line-height: 1.8;
	color: rgba(255, 255, 255, 0.92);
	/* Same measure as the h1 above so the two blocks share one width. */
	max-width: min(100%, 49rem);
	margin-bottom: 34px;
}

.lp2-hero-cta {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}
/* A light "ghost" button that reads well on the photo. */
.lp2-btn-ghost {
	color: #fff;
	background: rgba(255, 255, 255, 0.10);
	border: 1px solid rgba(255, 255, 255, 0.55) !important;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}
.lp2-btn-ghost:hover { color: var(--rosewood); background: #fff; border-color: #fff !important; }

/* ===================================================================
   1b. NAVBAR — brown while the hero is behind it, white once scrolled
       past it. Toggled by the `hn-nav--on-hero` class, which is added
       ONLY by the v2 homepage JS (main_v2.html). Every other page keeps
       the default white navbar. Selectors carry the same specificity as
       `#mainNav.hn-nav.nav-scrolled` and win on source order (this file
       loads after hotelnet.css), so the brown theme survives scrolling.
   =================================================================== */
#mainNav.hn-nav.hn-nav--on-hero {
	background: #67060D;
	box-shadow: none;
	border-bottom-color: transparent;
}
#mainNav.hn-nav--on-hero .hn-nav-item > a,
#mainNav.hn-nav--on-hero .hn-signin {
	color: #fff;
}
#mainNav.hn-nav--on-hero .hn-nav-item:hover > a,
#mainNav.hn-nav--on-hero .hn-nav-item.is-active > a,
#mainNav.hn-nav--on-hero .hn-signin:hover {
	color: var(--peach);
}
#mainNav.hn-nav--on-hero .hn-nav-item > a > span::after {
	background: var(--peach);
}
#mainNav.hn-nav--on-hero .hn-mobile-toggle {
	color: #fff;
}
/* "Get Started" / account button — peach on brown so it still pops. */
#mainNav.hn-nav--on-hero .hn-nav-actions .hn-cta {
	background: var(--peach);
	color: var(--rosewood);
	border-color: var(--peach) !important;
}
#mainNav.hn-nav--on-hero .hn-nav-actions .hn-cta:hover {
	background: #fff;
	color: var(--rosewood);
	border-color: #fff !important;
}

/* ===================================================================
   2. PATHWAYS  — three audience entry tiles, raised card overlapping hero
   =================================================================== */
/* White breathing room above the card separates it from the red hero.
   Small trailing pad only — the metrics belong to the pathways block, so the
   gap to the next section is owned by that section's own top padding (avoids a
   doubled-up void between the metrics and "For Hotels"). */
.lp2-pathways { background: #fff; position: relative; z-index: 3; padding-top: 72px; padding-bottom: 72px; }
.lp2-pathways-card {
	max-width: var(--lp2-maxw);
	margin: 0 auto;
	background: #fff;
	border-radius: var(--lp2-radius);
	box-shadow: var(--lp2-shadow);
	border: 1px solid var(--lp2-line);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	overflow: hidden;
}
.lp2-path {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 34px 30px;
	border-right: 1px solid var(--lp2-line);
	transition: background 0.25s ease, transform 0.25s ease;
}
.lp2-path:last-child { border-right: none; }
.lp2-path:hover { background: var(--lp2-cream); }
.lp2-path-ico {
	width: 52px; height: 52px;
	border-radius: 14px;
	display: flex; align-items: center; justify-content: center;
	background: var(--peach);
	color: var(--red);
	font-size: 21px;
}
.lp2-path-kicker {
	font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--red);
}
.lp2-path h3 {
	font-family: 'Playfair Display', serif;
	font-weight: 800; font-size: 1.4rem; color: var(--lp2-ink); margin: 0;
}
.lp2-path p { font-size: 13.5px; line-height: 1.65; color: var(--lp2-muted); margin: 0; flex: 1; }
.lp2-path-link {
	font-size: 13px; font-weight: 600; color: var(--red);
	display: inline-flex; align-items: center; gap: 7px;
	margin-top: 4px;
}
.lp2-path-link i { transition: transform 0.25s ease; }
.lp2-path:hover .lp2-path-link i { transform: translateX(4px); }

/* ===================================================================
   3. AUDIENCE sections  (For Hotels / Job Seekers / Suppliers)
   (The "by the numbers" metrics now use the reused v1 stats_bar.html,
    styled by hotelnet.css — no v2 metrics styles needed here.)
   =================================================================== */
.lp2-aud { overflow: hidden; }
.lp2-aud--cream { background: var(--lp2-cream); }
.lp2-aud-grid {
	max-width: var(--lp2-maxw);
	margin-inline: auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.lp2-aud--flip .lp2-aud-media { order: -1; }   /* image on the left */

.lp2-aud-copy { min-width: 0; }
.lp2-aud-copy .lp2-h2 .red { color: var(--red); }

.lp2-checklist { list-style: none; margin: 32px 0 0; padding: 0; }
.lp2-checklist li {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	margin-bottom: 20px;
	font-size: 15px;
	line-height: 1.55;
	color: var(--dark-grey);
}
.lp2-checklist li:last-child { margin-bottom: 0; }
/* A light peach "chip" check — cleaner and calmer than repeated solid red dots.
   FontAwesome's JS replaces the <i> with an <svg>, so style both element types. */
.lp2-checklist li > i,
.lp2-checklist li > svg {
	box-sizing: content-box;
	width: 12px;
	height: 12px;
	padding: 7px;
	border-radius: 8px;
	background: var(--peach);
	color: var(--red);
	font-size: 12px;
	line-height: 1;
	flex-shrink: 0;
	margin-top: 1px;
	overflow: visible;
}

.lp2-aud-cta { margin-top: 30px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.lp2-link {
	font-weight: 600; font-size: 14px; color: var(--red);
	display: inline-flex; align-items: center; gap: 8px;
}
.lp2-link i { transition: transform 0.25s ease; }
.lp2-link:hover i { transform: translateX(4px); }

/* Audience media — one clean framed photo (no busy offset panel). */
.lp2-aud-media { position: relative; }
.lp2-aud-figure {
	position: relative;
	margin: 0;                 /* drop the UA/Bootstrap <figure> bottom margin */
	border-radius: 24px;
	overflow: hidden;
	box-shadow: 0 36px 70px -34px rgba(103, 6, 13, 0.34);
	aspect-ratio: 4 / 3.4;
	background: linear-gradient(135deg, var(--rosewood), var(--clay));
}
.lp2-aud-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Small floating stat badge on the media */
.lp2-aud-badge {
	position: absolute;
	left: 20px; bottom: 20px;
	background: var(--peach);
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	border-radius: 14px;
	padding: 12px 18px;
	box-shadow: 0 14px 30px -14px rgba(103, 6, 13, 0.40);
	display: flex;
	align-items: center;
	gap: 13px;
}
/* FA swaps <i> for <svg>; colour both. */
.lp2-aud-badge i,
.lp2-aud-badge svg { color: var(--red); font-size: 18px; flex-shrink: 0; }
.lp2-aud-badge b { display: block; font-size: 15px; color: var(--rosewood); line-height: 1.15; }
.lp2-aud-badge span { font-size: 11.5px; color: var(--lp2-muted); line-height: 1.3; }

/* ===================================================================
   5. INFORMATION CENTRE  — dark rosewood band
   =================================================================== */
.lp2-info {
	position: relative;
	overflow: hidden;
	color: #fff;
	background: linear-gradient(150deg, #5C050B 0%, #910911 60%, #7A0710 100%);
}
.lp2-info .lp2-eyebrow {
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.28);
}
.lp2-info .lp2-eyebrow .live-dot { background: #fff; }
.lp2-info-head { max-width: 720px; margin-inline: auto; text-align: center; }
.lp2-info-head .lp2-h2 { color: #fff; }
.lp2-info-head .lp2-lead { color: rgba(255, 255, 255, 0.86); margin-inline: auto; }

.lp2-info-grid {
	max-width: var(--lp2-maxw);
	margin: 48px auto 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}
.lp2-info-card {
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--lp2-radius);
	padding: 30px 26px;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	position: relative;
}
.lp2-info-ico {
	width: 50px; height: 50px;
	border-radius: 14px;
	display: flex; align-items: center; justify-content: center;
	background: var(--peach);
	color: var(--red);
	font-size: 20px;
	margin-bottom: 18px;
}
.lp2-info-card h3 {
	font-family: 'Playfair Display', serif;
	font-weight: 800;
	font-size: 1.3rem;
	color: #fff;
	margin: 0 0 10px;
}
.lp2-info-card p { font-size: 13.5px; line-height: 1.65; color: rgba(255, 255, 255, 0.82); margin: 0; }
.lp2-tag {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
	padding: 4px 11px; border-radius: 3rem; margin-bottom: 14px;
}
.lp2-tag--live    { background: rgba(255,255,255,0.18); color: #fff; }
.lp2-tag--live .dot { width: 6px; height: 6px; border-radius: 50%; background: #7CF2B0; display: inline-block; }
.lp2-tag--soon    { background: var(--peach); color: var(--rosewood); }
.lp2-info-cta { text-align: center; margin-top: 44px; }

/* ===================================================================
   6. CLOSING CTA  — solid red band
   =================================================================== */
.lp2-close {
	background: var(--red);
	color: var(--peach);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.lp2-close-inner { max-width: 900px; margin-inline: auto; position: relative; z-index: 2; }
.lp2-close h2 {
	font-family: 'Playfair Display', serif;
	font-weight: 900;
	font-size: clamp(1.9rem, 1.3rem + 2vw, 2.9rem);
	color: #fff;
	margin: 0 0 16px;
}
.lp2-close p { color: rgba(255, 255, 255, 0.88); font-size: 15px; margin: 0 0 30px; }
.lp2-close-cta { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
/* Three path buttons — trimmer than the global btn-large so all three sit on one row. */
.lp2-close-cta .btn { padding: 16px 32px; }
.lp2-close-blob {
	position: absolute;
	width: 460px; height: 460px; border-radius: 50%;
	background: radial-gradient(circle, rgba(254,215,201,0.18), transparent 70%);
	z-index: 1;
}
.lp2-close-blob-1 { top: -180px; left: -120px; }
.lp2-close-blob-2 { bottom: -220px; right: -120px; }

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width: 992px) {
	.lp2-aud-grid { grid-template-columns: 1fr; gap: 44px; }
	.lp2-aud--flip .lp2-aud-media { order: 0; }      /* image back below copy */
	.lp2-info-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
	.lp2-hero { padding: 64px 24px 48px; min-height: unset; }
	.lp2-pathways { padding-top: 48px; padding-bottom: 48px; }
	.lp2-pathways-card { grid-template-columns: 1fr; margin-top: 0; }
	.lp2-path { border-right: none; border-bottom: 1px solid var(--lp2-line); }
	.lp2-path:last-child { border-bottom: none; }

	.lp2-aud-cta { gap: 14px; }
	.lp2-hero-cta .btn-large,
	.lp2-close-cta .btn-large { padding: 16px 40px; }
}

/* Respect reduced-motion: the .reveal class already animates; soften here. */
@media (prefers-reduced-motion: reduce) {
	.lp2-hero-bg { transform: none; }
	.lp2-path, .lp2-path-link i, .lp2-link i { transition: none; }
}
