/* Reel Edge Media — Okanagan Business Spotlight landing page
   Brand: primary #1a52d5 · navy #0d1b4b · green #38a169 */

.rems-l {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: #1e293b;
	line-height: 1.6;
	background: #ffffff;
}

.rems-l * { box-sizing: border-box; }

/* The plugin serves this page through a full-width template, so each section is
   simply 100% wide and carries its OWN background (the theme page background is
   dark, so every section must set its own to keep text readable). */
.rems-l-hero,
.rems-l-section,
.rems-l-band,
.rems-l-steps-wrap,
.rems-l-form-wrap {
	width: 100%;
}

.rems-l-section { background: #ffffff; }

.rems-l-inner {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 22px;
}

.rems-l-section { padding: 70px 22px; }
.rems-l-center { text-align: center; }

/* Headings */
.rems-l-h2 {
	font-size: 2rem;
	line-height: 1.15;
	color: #0d1b4b;
	margin: 0 0 14px;
	font-weight: 800;
}
.rems-l-h2--light { color: #fff; }
.rems-l-sub {
	font-size: 1.1rem;
	color: #475569;
	max-width: 720px;
	margin: 0 0 34px;
}
.rems-l-center.rems-l-sub { margin-left: auto; margin-right: auto; }

/* HERO */
.rems-l-hero {
	background:
		radial-gradient(1200px 500px at 80% -10%, rgba(96,165,250,.35), transparent 60%),
		linear-gradient(135deg, #0d1b4b 0%, #1a52d5 100%);
	color: #fff;
	padding: 92px 22px 100px;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.rems-l-badge {
	display: inline-block;
	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.35);
	color: #fff;
	font-weight: 700;
	font-size: .85rem;
	letter-spacing: .04em;
	padding: 7px 16px;
	border-radius: 30px;
	margin-bottom: 18px;
	backdrop-filter: blur(4px);
}
.rems-l-eyebrow {
	display: block;
	text-transform: uppercase;
	letter-spacing: .18em;
	font-size: .8rem;
	font-weight: 700;
	color: #bcd0ff;
	margin-bottom: 14px;
}
.rems-l-h1 {
	font-size: clamp(2.4rem, 6vw, 4rem);
	line-height: 1.05;
	font-weight: 900;
	margin: 0 0 14px;
	color: #fff;
}
.rems-l-tag {
	font-size: clamp(1.1rem, 2.4vw, 1.5rem);
	font-weight: 600;
	color: #e8efff;
	margin: 0 0 26px;
}
.rems-l-lede {
	max-width: 720px;
	margin: 0 auto 34px;
	font-size: 1.12rem;
	color: #d7e2ff;
}
.rems-l-hero-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
}
.rems-l-free { color: #cfe0ff; font-size: 1.05rem; }
.rems-l-free strong { color: #fff; }

/* Buttons */
.rems-l-btn {
	display: inline-block;
	background: #fff;
	/* !important so the theme's global a:hover (which turns links white)
	   can't make the dark text disappear on the white button. */
	color: #0d1b4b !important;
	padding: 14px 30px;
	border-radius: 10px;
	font-weight: 800;
	text-decoration: none !important;
	transition: transform .12s, box-shadow .12s;
	box-shadow: 0 10px 26px rgba(0,0,0,.18);
}
.rems-l-btn:hover,
.rems-l-btn:focus {
	color: #0d1b4b !important;
	background: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 32px rgba(0,0,0,.26);
}
.rems-l-btn--lg { font-size: 1.15rem; padding: 17px 40px; }
.rems-l-btn--ghost {
	background: transparent;
	color: #1a52d5 !important;
	border: 2px solid #1a52d5;
	box-shadow: none;
}
.rems-l-btn--ghost:hover,
.rems-l-btn--ghost:focus { background: #1a52d5; color: #fff !important; }

/* BENEFITS */
.rems-l-benefits {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px 28px;
	margin-bottom: 40px;
}
.rems-l-benefit {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	font-size: 1.05rem;
	color: #334155;
}
.rems-l-check {
	flex: 0 0 auto;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: #f0fff4;
	color: #38a169;
	border: 1px solid #38a169;
	display: inline-flex;
	align-items: center; justify-content: center;
	font-weight: 800; font-size: .9rem;
	margin-top: 2px;
}
.rems-l-value {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 40px;
	background: #f8faff;
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 28px 34px;
}
.rems-l-value > div { display: flex; flex-direction: column; align-items: center; }
.rems-l-value-label { text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; color: #64748b; font-weight: 700; }
.rems-l-value-num { font-size: 2.2rem; font-weight: 900; color: #0d1b4b; }
.rems-l-value-free { color: #38a169; }
.rems-l-value-divider { width: 1px; height: 54px; background: #d9e2f0; }

/* BANDS */
.rems-l-band {
	background: linear-gradient(135deg, #0d1b4b, #14307a);
	color: #d7e2ff;
	padding: 66px 22px;
}
.rems-l-band--alt {
	background: linear-gradient(135deg, #1a52d5, #0d1b4b);
}
.rems-l-band-text { font-size: 1.12rem; max-width: 760px; margin: 0 0 16px; }
/* Centered bands (e.g. "Why Stories Matter") re-center the text block. */
.rems-l-center .rems-l-band-text { margin-left: auto; margin-right: auto; }
.rems-l-band-text--big { font-size: 1.4rem; font-weight: 600; color: #fff; }

/* WHO — pills */
.rems-l-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 14px;
}
.rems-l-pill {
	display: flex;
	align-items: center;
	gap: 12px;
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	padding: 16px 18px;
	font-weight: 600;
	color: #1e293b;
	transition: border-color .12s, transform .12s;
}
.rems-l-pill:hover { border-color: #1a52d5; transform: translateY(-2px); }
.rems-l-pill-ico { font-size: 1.4rem; }

/* STEPS */
.rems-l-steps-wrap { background: #f4f6fb; padding: 70px 22px; }
.rems-l-steps {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 22px;
	margin-top: 10px;
}
.rems-l-step {
	display: flex;
	gap: 16px;
	background: #fff;
	border: 1px solid #e8edf6;
	border-radius: 14px;
	padding: 22px 24px;
}
.rems-l-step-num {
	flex: 0 0 auto;
	width: 42px; height: 42px;
	border-radius: 50%;
	background: linear-gradient(135deg, #1a52d5, #0d1b4b);
	color: #fff;
	display: inline-flex;
	align-items: center; justify-content: center;
	font-weight: 800; font-size: 1.15rem;
}
.rems-l-step h3 { margin: 2px 0 4px; color: #0d1b4b; font-size: 1.12rem; }
.rems-l-step p { margin: 0; color: #334155; }

/* PORTFOLIO */
.rems-l-portfolio { padding: 72px 22px; }
.rems-l-pf-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
	margin-top: 34px;
}
.rems-l-pf-card {
	display: block;
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	border: 1px solid #e8edf6;
	text-decoration: none;
	color: inherit;
	transition: transform .15s, box-shadow .15s;
}
.rems-l-pf-card:hover { transform: translateY(-4px); box-shadow: 0 16px 34px rgba(13,27,75,.14); }
.rems-l-pf-img { aspect-ratio: 3 / 2; overflow: hidden; background: #eef2fb; }
.rems-l-pf-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rems-l-pf-fallback {
	display: flex;
	width: 100%; height: 100%;
	align-items: center; justify-content: center;
	text-align: center;
	padding: 18px;
	background: linear-gradient(135deg, #1a52d5, #0d1b4b);
	color: #fff;
	font-weight: 800;
	font-size: 1.1rem;
}
.rems-l-pf-body { padding: 16px 18px 20px; }
.rems-l-pf-cat {
	display: inline-block;
	font-size: .72rem;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
	color: #1a52d5;
	background: #eef3ff;
	padding: 3px 10px;
	border-radius: 20px;
	margin-bottom: 8px;
}
.rems-l-pf-body h3 { margin: 0; font-size: 1.08rem; color: #0d1b4b; }

/* FAQ */
.rems-l-faq { max-width: 760px; }
.rems-l-faq-item {
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	padding: 4px 20px;
	margin-bottom: 12px;
	background: #fff;
}
.rems-l-faq-item summary {
	cursor: pointer;
	font-weight: 700;
	color: #0d1b4b;
	padding: 14px 0;
	list-style: none;
	position: relative;
	padding-right: 28px;
}
.rems-l-faq-item summary::-webkit-details-marker { display: none; }
.rems-l-faq-item summary::after {
	content: '+';
	position: absolute;
	right: 2px; top: 12px;
	font-size: 1.4rem;
	color: #1a52d5;
	font-weight: 400;
}
.rems-l-faq-item[open] summary::after { content: '–'; }
.rems-l-faq-item p { margin: 0 0 16px; color: #475569; }

/* FORM SECTION */
.rems-l-form-wrap {
	background: #f4f6fb;
	padding: 72px 22px 90px;
}
.rems-l-form-head { text-align: center; margin-bottom: 36px; }
.rems-l-form-head .rems-l-sub { margin-left: auto; margin-right: auto; }
/* the form keeps its own card styling from form.css */

/* RESPONSIVE */
@media (max-width: 820px) {
	.rems-l-benefits { grid-template-columns: 1fr; }
	.rems-l-steps { grid-template-columns: 1fr; }
	.rems-l-pf-grid { grid-template-columns: repeat(2, 1fr); }
	.rems-l-section { padding: 52px 22px; }
}
@media (max-width: 540px) {
	.rems-l-pf-grid { grid-template-columns: 1fr; }
	.rems-l-value { flex-direction: column; gap: 18px; }
	.rems-l-value-divider { width: 54px; height: 1px; }
}
