/**
 * Midwest Armor - Rewards page ("Mist" light mode).
 * Native replacement for the Elementor /rewards-program/ page.
 * Reference: ref-design/rewards_page.html. Scoped under .mw-rewards; internal
 * classes use the mwr- prefix so nothing leaks to / from global theme CSS.
 *
 * Responsive via a container query on .mw-rewards (container-type: inline-size),
 * so the layout flips at the frame width, not the viewport - same as the ref.
 *
 * Fonts (Inter + JetBrains Mono) are already loaded by the chrome; the @import
 * is a safety net for when chrome is off.
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

.mw-rewards {
	--mwr-ink: #141416;
	--mwr-muted: rgba(20, 20, 22, 0.55);
	--mwr-border: rgba(20, 20, 22, 0.10);
	--mwr-hairline: rgba(20, 20, 22, 0.08);
	--mwr-util: #eeeff1;
	--mwr-accent: #3a3d42;
	--mwr-sans: 'Inter', system-ui, -apple-system, sans-serif;
	--mwr-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

	container-type: inline-size;
	max-width: 1080px;
	margin: 0 auto;
	background: #fff;
	color: var(--mwr-ink);
	font-family: var(--mwr-sans);
	-webkit-font-smoothing: antialiased;
}
.mw-rewards-page { padding: 24px 16px 64px; }
.mw-rewards * { box-sizing: border-box; }

/* HERO */
.mw-rewards .mwr-hero { padding: 48px 28px 40px; border-bottom: 1px solid var(--mwr-border); }
.mw-rewards .mwr-eyebrow { font-family: var(--mwr-mono); font-size: 10px; letter-spacing: 2.2px; color: var(--mwr-muted); font-weight: 600; text-transform: uppercase; }
.mw-rewards .mwr-hero h1 { font-size: 46px; font-weight: 600; letter-spacing: -2px; line-height: 0.95; margin: 14px 0 0; font-family: var(--mwr-sans); color: var(--mwr-ink); }
.mw-rewards .mwr-hero p { font-size: 15px; line-height: 1.62; color: #33353a; margin: 20px 0 0; max-width: 600px; }

/* SPEC STRIP */
.mw-rewards .mwr-specs { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--mwr-border); }
.mw-rewards .mwr-cell { padding: 24px 20px; min-width: 0; }
.mw-rewards .mwr-cell:first-child { border-right: 1px solid var(--mwr-border); }
.mw-rewards .mwr-k { font-family: var(--mwr-mono); font-size: 9px; letter-spacing: 1.6px; color: var(--mwr-muted); text-transform: uppercase; }
.mw-rewards .mwr-v { font-size: 24px; font-weight: 600; letter-spacing: -0.8px; margin-top: 8px; line-height: 1; white-space: nowrap; }
.mw-rewards .mwr-v span { color: var(--mwr-muted); }
/* The " PTS" / " OFF" units overflow the half-width spec cell on phones; the ref
   drops them on mobile (shows "250 = $25") and restores them on desktop. */
.mw-rewards .mwr-u { display: none; }

/* SECTION (how to earn) */
.mw-rewards .mwr-section { padding: 44px 28px; }
.mw-rewards .mwr-secthead { display: flex; align-items: baseline; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid var(--mwr-ink); margin-bottom: 8px; }
.mw-rewards .mwr-secthead h2 { font-size: 13px; font-family: var(--mwr-mono); letter-spacing: 2px; font-weight: 700; margin: 0; text-transform: uppercase; white-space: nowrap; color: var(--mwr-ink); }
.mw-rewards .mwr-n { font-family: var(--mwr-mono); font-size: 10px; letter-spacing: 1.5px; color: var(--mwr-muted); white-space: nowrap; }
.mw-rewards .mwr-steps { display: grid; grid-template-columns: 1fr; }
.mw-rewards .mwr-step { padding: 28px 0; border-bottom: 1px solid var(--mwr-hairline); }
.mw-rewards .mwr-step:last-child { border-bottom: none; }
.mw-rewards .mwr-icon { width: 46px; height: 46px; border: 1px solid var(--mwr-ink); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.mw-rewards .mwr-icon svg { stroke: var(--mwr-ink); }
.mw-rewards .mwr-num { font-family: var(--mwr-mono); font-size: 10px; letter-spacing: 1.8px; color: var(--mwr-muted); font-weight: 600; }
.mw-rewards .mwr-step h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.4px; margin: 8px 0; font-family: var(--mwr-sans); color: var(--mwr-ink); }
.mw-rewards .mwr-step p { font-size: 14px; line-height: 1.6; color: #44464a; margin: 0; max-width: 340px; }

/* FINE PRINT */
.mw-rewards .mwr-fine { background: var(--mwr-util); padding: 28px; border-top: 1px solid var(--mwr-border); border-bottom: 1px solid var(--mwr-border); display: grid; grid-template-columns: 1fr; }
.mw-rewards .mwr-finerow { display: flex; gap: 12px; align-items: flex-start; font-size: 12.5px; line-height: 1.5; color: #33353a; padding: 11px 0; }
.mw-rewards .mwr-finerow + .mwr-finerow { border-top: 1px solid var(--mwr-hairline); }
.mw-rewards .mwr-mk { font-family: var(--mwr-mono); font-size: 9px; letter-spacing: 1px; color: var(--mwr-accent); font-weight: 600; padding-top: 3px; white-space: nowrap; }

/* TERMS */
.mw-rewards .mwr-terms { padding: 40px 28px 48px; }
.mw-rewards .mwr-terms h4 { font-family: var(--mwr-mono); font-size: 11px; letter-spacing: 2px; font-weight: 700; margin: 0 0 18px; text-transform: uppercase; color: var(--mwr-ink); }
.mw-rewards .mwr-termsbody { display: grid; grid-template-columns: 1fr; gap: 0 48px; }
.mw-rewards .mwr-terms p { font-size: 12px; line-height: 1.7; color: var(--mwr-muted); margin: 0 0 16px; }
.mw-rewards .mwr-terms p:last-child { margin-bottom: 0; }

/* CTA */
.mw-rewards .mwr-cta { padding: 0 28px 48px; }
.mw-rewards .mwr-cta a { display: block; text-align: center; background: var(--mwr-ink); color: #fff; text-decoration: none; font-family: var(--mwr-mono); font-size: 12px; letter-spacing: 2px; font-weight: 700; padding: 18px; text-transform: uppercase; }
.mw-rewards .mwr-cta a:hover { background: #000; color: #fff; }
.mw-rewards .mwr-sub { text-align: center; font-family: var(--mwr-mono); font-size: 9px; letter-spacing: 1.4px; color: var(--mwr-muted); margin-top: 14px; text-transform: uppercase; }

/* Desktop layout - triggers on the .mw-rewards container width (not viewport). */
@container (min-width: 760px) {
	.mw-rewards .mwr-hero { padding: 80px 72px 64px; display: grid; grid-template-columns: 1.1fr 0.9fr; column-gap: 64px; align-items: end; }
	.mw-rewards .mwr-lead { grid-column: 1; }
	.mw-rewards .mwr-hero h1 { font-size: 84px; letter-spacing: -3px; }
	.mw-rewards .mwr-hero p { margin-top: 0; font-size: 17px; line-height: 1.65; align-self: end; padding-bottom: 6px; }
	.mw-rewards .mwr-cell { padding: 32px 72px; }
	.mw-rewards .mwr-v { font-size: 40px; }
	.mw-rewards .mwr-u { display: inline; }
	.mw-rewards .mwr-section { padding: 80px 72px; }
	.mw-rewards .mwr-steps { grid-template-columns: repeat(3, 1fr); }
	.mw-rewards .mwr-step { padding: 40px 36px 0; border-bottom: none; border-right: 1px solid var(--mwr-hairline); }
	.mw-rewards .mwr-step:first-child { padding-left: 0; }
	.mw-rewards .mwr-step:last-child { border-right: none; padding-right: 0; }
	.mw-rewards .mwr-step h3 { font-size: 22px; }
	.mw-rewards .mwr-step p { font-size: 15px; max-width: none; }
	.mw-rewards .mwr-fine { padding: 36px 72px; grid-template-columns: repeat(3, 1fr); gap: 0 48px; }
	.mw-rewards .mwr-finerow { padding: 0; flex-direction: column; gap: 10px; border-top: none !important; }
	.mw-rewards .mwr-mk { padding-top: 0; }
	.mw-rewards .mwr-terms { padding: 72px 72px 88px; }
	.mw-rewards .mwr-termsbody { grid-template-columns: 1fr 1fr; }
	.mw-rewards .mwr-cta { padding: 0 72px 88px; display: flex; align-items: center; gap: 28px; }
	.mw-rewards .mwr-cta a { display: inline-block; padding: 20px 44px; }
	.mw-rewards .mwr-sub { margin-top: 0; text-align: left; }
}
