/* ============================================================
   KiteDR  -  Homepage styles
   Loaded only on the front page. All rules scoped to body.home
   to prevent conflicts with main.css.
============================================================ */

/* ---- Header overrides ---- */
/* Homepage uses the same dark header as inner pages  -  logo is white SVG and needs a dark background */

/* Variable remapping to theme tokens */
body.home {
	--ocean:    var(--kdr-blue);
	--ocean-2:  #0A4A8A;
	--coral:    var(--kdr-orange);
	--sand:     var(--kdr-light);
	--foam:     var(--kdr-white);
	--ink:      var(--kdr-text);
	--muted:    var(--kdr-muted);
	--edge:     var(--kdr-border);
	--shadow:   0 24px 60px rgba(6,59,92,.18);
	--radius:   24px;
	--h1:       clamp(38px,5.5vw,72px);
	--h2:       clamp(26px,3vw,42px);
	--h3:       clamp(21px,2vw,28px);
}

/* Typography overrides */
body.home h2 { font-size: var(--h2); line-height: 1.04; letter-spacing: -.04em; color: var(--ocean); margin: 12px 0 14px; }
body.home h3 { font-size: var(--h3); line-height: 1.18; color: var(--ocean); margin: 0 0 10px; }

body.home .eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--ocean-2);
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
	font-size: 13px;
	margin-bottom: 0;
}

body.home .lead { font-size: 20px; color: var(--muted); margin: 0; }

/* ---- Buttons ---- */
body.home .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	border-radius: 999px;
	padding: 15px 22px;
	font-weight: 700;
	line-height: 1;
	border: 1px solid transparent;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
	font-size: 16px;
}
body.home .btn:hover { transform: translateY(-2px); color: inherit; }
body.home .btn-primary { background: var(--coral); color: #fff; box-shadow: 0 14px 30px rgba(207,20,43,.3); }
body.home .btn-primary:hover { background: var(--kdr-orange-dark); color: #fff; }
body.home .btn-secondary { background: #fff; color: var(--ocean); border-color: rgba(255,255,255,.55); }
body.home .btn-secondary:hover { color: var(--ocean); }
body.home .btn-outline { background: transparent; color: var(--ocean); border-color: var(--edge); }
body.home .btn-outline:hover { background: var(--kdr-blue-light); color: var(--ocean); }
body.home .btn-dark { background: var(--ocean); color: #fff; }
body.home .btn-dark:hover { background: var(--kdr-blue-dark); color: #fff; }

/* ---- Hero ---- */
body.home .hero {
	position: relative;
	isolation: isolate;
	min-height: min(820px, 90vh);
	display: grid;
	align-items: center;
	overflow: hidden;
	color: #fff;
	background: var(--ocean);
	padding: 0;
}
body.home .hero-bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	display: block;
}
body.home .hero-bg img,
body.home .hero-bg source + img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	max-width: none;
}
body.home .hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(90deg, rgba(3,26,43,.86) 0%, rgba(6,59,92,.72) 45%, rgba(6,59,92,.22) 100%),
		linear-gradient(0deg, rgba(3,26,43,.55), rgba(3,26,43,.08));
}
body.home .hero-grid {
	display: grid;
	grid-template-columns: minmax(0,1.04fr) minmax(320px,.62fr);
	gap: 42px;
	align-items: center;
	padding-block: 74px;
}
body.home .hero h1 {
	font-size: var(--h1);
	line-height: .96;
	letter-spacing: -.06em;
	margin: 16px 0 18px;
	max-width: 850px;
	color: #fff;
}
body.home .hero .sub {
	font-size: clamp(19px,2vw,24px);
	line-height: 1.45;
	color: rgba(255,255,255,.9);
	max-width: 700px;
	margin: 0 0 28px;
}
body.home .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-bottom: 24px; }
body.home .hero-micro { font-size: 14px; color: rgba(255,255,255,.82); margin: 0; }
body.home .trust-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
body.home .trust-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 9px 12px;
	border-radius: 999px;
	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.22);
	font-size: 14px;
	font-weight: 700;
	color: #fff;
}

/* ---- Booking card ---- */
body.home .booking-card {
	background: rgba(255,255,255,.96);
	color: var(--ink);
	border-radius: var(--radius);
	padding: 28px;
	box-shadow: var(--shadow);
	border: 1px solid rgba(255,255,255,.4);
}
body.home .booking-card h2 {
	font-size: 24px;
	line-height: 1.15;
	margin: 0 0 8px;
	color: var(--ocean);
	letter-spacing: -.02em;
}
body.home .booking-card > p {
	margin: 0 0 18px;
	color: var(--muted);
	font-size: 15px;
}

/* ---- Proof strip ---- */
body.home .proof-strip { background: #fff; border-bottom: 1px solid var(--edge); padding: 0; }
body.home .proof-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 1px;
	background: var(--edge);
	border-inline: 1px solid var(--edge);
}
body.home .proof-stat { background: #fff; padding: 24px; text-align: center; }
body.home .proof-stat strong { display: block; font-size: 28px; line-height: 1; color: var(--ocean); font-family: var(--font-head); }
body.home .proof-stat span { display: block; margin-top: 8px; color: var(--muted); font-size: 14px; font-weight: 700; }

/* ---- Section system ---- */
body.home .section { padding-block: clamp(50px,6vw,80px); }
body.home .section-alt { background: #fff; }
body.home .section-sand { background: var(--sand); }
body.home .section-head { max-width: 760px; margin-bottom: 36px; }
body.home .section-head.center { text-align: center; margin-inline: auto; }

/* ---- Cards ---- */
body.home .cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
body.home .card {
	background: #fff;
	border: 1px solid var(--edge);
	border-radius: var(--radius);
	padding: 26px;
	box-shadow: 0 12px 30px rgba(16,32,51,.06);
}
body.home .card { display: flex; flex-direction: column; border-top: 3px solid var(--kdr-blue-light); }
body.home .card:hover { border-top-color: var(--coral); }
body.home .card p { color: var(--muted); margin: 0; flex: 1; }
body.home .card h3 { margin-bottom: 10px; }
body.home .card ul { flex: 1; }
body.home .card > div[style*="margin-top:18px"] { margin-top: auto !important; padding-top: 18px; }

/* ---- Journey / Steps ---- */
body.home .journey { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; align-items: center; }
body.home .steps { counter-reset: step; display: grid; gap: 14px; }
body.home .step {
	counter-increment: step;
	background: #fff;
	border: 1px solid var(--edge);
	border-radius: 20px;
	padding: 20px 20px 20px 72px;
	position: relative;
}
body.home .step::before {
	content: counter(step);
	position: absolute;
	left: 20px;
	top: 20px;
	width: 36px;
	height: 36px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: var(--coral);
	color: #fff;
	font-weight: 900;
	font-family: var(--font-head);
}
body.home .step h3 { font-size: 20px; margin: 0 0 4px; }
body.home .step p { margin: 0; color: var(--muted); }

/* ---- Photo card ---- */
body.home .photo-card {
	min-height: 520px;
	border-radius: 32px;
	overflow: hidden;
	position: relative;
	background: var(--ocean);
	box-shadow: var(--shadow);
}
body.home .photo-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	inset: 0;
	max-width: none;
}
body.home .photo-note {
	position: absolute;
	left: 24px;
	right: 24px;
	bottom: 24px;
	background: rgba(255,255,255,.92);
	border-radius: 20px;
	padding: 18px;
	color: var(--ink);
	box-shadow: 0 15px 40px rgba(0,0,0,.18);
	font-size: 15px;
}

/* ---- Packages ---- */
body.home .packages { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; align-items: stretch; }
body.home .package {
	position: relative;
	background: #fff;
	border: 1px solid var(--edge);
	border-radius: 28px;
	padding: 28px;
	box-shadow: 0 12px 30px rgba(16,32,51,.06);
}
body.home .package.featured {
	border: 2px solid var(--coral);
	transform: translateY(-8px);
	box-shadow: 0 24px 50px rgba(207,20,43,.18);
	padding-top: 52px;
}
body.home .badge {
	position: absolute;
	top: 18px;
	right: 18px;
	background: var(--coral);
	color: #fff;
	border-radius: 999px;
	padding: 6px 10px;
	font-size: 12px;
	font-weight: 900;
}
body.home .price {
	font-size: 36px;
	line-height: 1;
	font-weight: 900;
	color: var(--ocean);
	letter-spacing: -.04em;
	margin: 16px 0 8px;
	font-family: var(--font-head);
}
body.home .price small { font-size: 16px; color: var(--muted); font-weight: 700; }
body.home .package ul { padding: 0; margin: 18px 0 22px; list-style: none; display: grid; gap: 10px; }
body.home .package li { display: flex; gap: 10px; color: var(--ink); }
body.home .package li::before { content: "✓"; color: var(--coral); font-weight: 900; flex-shrink: 0; }

/* ---- Compare table ---- */
body.home .compare { overflow: auto; border: 1px solid var(--edge); border-radius: 24px; background: #fff; }
body.home .compare table { width: 100%; border-collapse: collapse; min-width: 720px; }
body.home .compare th,
body.home .compare td { padding: 18px; border-bottom: 1px solid var(--edge); text-align: left; vertical-align: top; font-size: 15px; }
body.home .compare th { background: var(--ocean); color: #fff; font-family: var(--font-head); }
body.home .compare tr:last-child td { border-bottom: 0; }

/* ---- Reviews ---- */
body.home .reviews { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
body.home .review {
	background: #fff;
	border: 1px solid var(--edge);
	border-radius: var(--radius);
	padding: 28px;
	box-shadow: 0 12px 30px rgba(16,32,51,.06);
	display: flex;
	flex-direction: column;
}
body.home .review .stars { color: var(--coral); font-size: 15px; letter-spacing: 3px; margin-bottom: 14px; }
body.home .review blockquote {
	margin: 0 0 auto;
	font-size: 17px;
	line-height: 1.6;
	font-weight: 400;
	letter-spacing: 0;
	color: var(--ink);
	font-style: italic;
	border: none;
	padding: 0;
}
body.home .review cite { display: block; margin-top: 18px; font-size: 13px; font-weight: 800; color: var(--muted); font-style: normal; }

/* ---- Final CTA ---- */
body.home .final-cta {
	background: linear-gradient(135deg, var(--ocean), #041E31);
	color: #fff;
	border-radius: 36px;
	padding: clamp(34px,6vw,70px);
	display: grid;
	grid-template-columns: 1.1fr .7fr;
	gap: 26px;
	align-items: center;
	overflow: hidden;
}
body.home .final-cta h2 { color: #fff; margin-top: 0; }
body.home .final-cta p { color: rgba(255,255,255,.82); margin-bottom: 0; }

/* ---- Responsive ---- */
@media (max-width: 920px) {
	body.home .hero-grid,
	body.home .journey,
	body.home .final-cta { grid-template-columns: 1fr; }
	body.home .booking-card { max-width: 560px; }
	body.home .proof-grid,
	body.home .cards,
	body.home .packages,
	body.home .reviews { grid-template-columns: 1fr 1fr; }
	body.home .package.featured { transform: none; }
	body.home .photo-card { min-height: 420px; }
}

@media (max-width: 640px) {
	body.home .proof-grid,
	body.home .cards,
	body.home .packages,
	body.home .reviews { grid-template-columns: 1fr; }
	body.home .hero-grid { padding-block: 54px; }
	body.home .hero h1 { font-size: 46px; }
	body.home .hero-actions { flex-direction: column; }
	body.home .hero-actions .btn { width: 100%; }
	body.home .trust-row { display: grid; grid-template-columns: 1fr 1fr; }
	body.home .booking-card { padding: 20px; }
	body.home .final-cta { grid-template-columns: 1fr; }
}
