/*!
 * MRAB Promo — by BinaryPH
 * Promotional, interactive app mock-up. Dark, neon (cyan + magenta), animated.
 * Everything is scoped under .mrab-promo so it never collides with the theme.
 */

.mrab-promo {
	/* Brand palette — lifted from the real Android app (colors.xml). */
	--mrab-ink:        #0A0A12;
	--mrab-ink-2:      #15151F;
	--mrab-ink-3:      #22232E;
	--mrab-cyan:       #4DD4FF;
	--mrab-cyan-dim:   #1FA9D9;
	--mrab-magenta:    #FF3D8B;
	--mrab-magenta-dim:#D11F6A;
	--mrab-on:         #F4F6FA;
	--mrab-muted:      #9C9EAE;
	--mrab-ok:         #36D399;
	--mrab-line:       rgba(255, 255, 255, .08);
	--mrab-card:       rgba(255, 255, 255, .04);
	--mrab-grad:       linear-gradient(120deg, var(--mrab-cyan), var(--mrab-magenta));
	--mrab-radius:     18px;
	--mrab-font:       "Inter", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;

	position: relative;
	isolation: isolate;
	overflow: hidden;
	box-sizing: border-box;
	padding: clamp(28px, 5vw, 72px) clamp(16px, 4vw, 56px);
	background:
		radial-gradient(1200px 600px at 85% -10%, rgba(255, 61, 139, .14), transparent 60%),
		radial-gradient(1000px 600px at -10% 20%, rgba(77, 212, 255, .14), transparent 55%),
		var(--mrab-ink);
	color: var(--mrab-on);
	font-family: var(--mrab-font);
	line-height: 1.5;
	border-radius: clamp(16px, 2vw, 28px);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

.mrab-promo *,
.mrab-promo *::before,
.mrab-promo *::after { box-sizing: border-box; }

.mrab-promo button { font-family: inherit; }

/* Visible keyboard focus on the dark surface. */
.mrab-promo a:focus-visible,
.mrab-promo button:focus-visible {
	outline: 2px solid var(--mrab-cyan);
	outline-offset: 2px;
	border-radius: 8px;
}

/* ---------------------------------------------------------------- background */
.mrab-bg { position: absolute; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }

.mrab-orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(70px);
	opacity: .55;
	will-change: transform;
}
.mrab-orb-1 {
	width: 42vw; height: 42vw; max-width: 520px; max-height: 520px;
	top: -8%; right: -6%;
	background: radial-gradient(circle, var(--mrab-magenta), transparent 65%);
	animation: mrab-float-a 16s ease-in-out infinite;
}
.mrab-orb-2 {
	width: 38vw; height: 38vw; max-width: 460px; max-height: 460px;
	bottom: -10%; left: -8%;
	background: radial-gradient(circle, var(--mrab-cyan), transparent 65%);
	animation: mrab-float-b 19s ease-in-out infinite;
}
.mrab-grid {
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px);
	background-size: 46px 46px;
	-webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, #000 30%, transparent 80%);
	        mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, #000 30%, transparent 80%);
}

@keyframes mrab-float-a { 50% { transform: translate3d(-30px, 26px, 0) scale(1.08); } }
@keyframes mrab-float-b { 50% { transform: translate3d(28px, -22px, 0) scale(1.06); } }

/* --------------------------------------------------------------------- shell */
.mrab-shell {
	position: relative;
	max-width: 1140px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.05fr .95fr;
	gap: clamp(24px, 4vw, 64px);
	align-items: center;
}

/* ---------------------------------------------------------------------- hero */
.mrab-hero { min-width: 0; }

.mrab-brandrow { display: flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.mrab-brand-logo { width: 48px; height: 48px; display: inline-flex; flex: 0 0 auto; }
.mrab-brand-logo .mrab-logo-svg,
.mrab-brand-logo .mrab-logo-img { width: 100%; height: 100%; }
/* The bundled circular brand mark: clip the square corners so it reads as a
   round badge on the dark surface (and the home glow becomes a circular halo). */
.mrab-logo-img { display: block; object-fit: contain; }
.mrab-logo-round { border-radius: 50%; }
.mrab-brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.mrab-brand-name { font-weight: 800; font-size: 22px; letter-spacing: .12em; }
.mrab-brand-by {
	font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--mrab-magenta); font-weight: 700;
}

.mrab-headline {
	margin: 0 0 16px;
	font-size: clamp(30px, 4.6vw, 54px);
	font-weight: 800;
	line-height: 1.04;
	letter-spacing: -.015em;
}
.mrab-grad {
	background: var(--mrab-grad);
	-webkit-background-clip: text;
	        background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

.mrab-sub {
	margin: 0 0 20px;
	max-width: 46ch;
	color: var(--mrab-muted);
	font-size: clamp(15px, 1.5vw, 17px);
}
.mrab-sub strong { color: var(--mrab-on); font-weight: 700; }
.mrab-sub em { color: var(--mrab-cyan); font-style: normal; font-weight: 600; }
.mrab-nowrap { white-space: nowrap; color: var(--mrab-magenta); font-weight: 600; }

/* rotating taglish line */
.mrab-rotator {
	position: relative;
	height: 28px;
	margin-bottom: 26px;
	font-weight: 600;
	font-size: clamp(14px, 1.5vw, 16px);
}
.mrab-rotator-line {
	position: absolute; inset: 0;
	display: flex; align-items: center; gap: 8px;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity .5s ease, transform .5s ease;
	color: var(--mrab-cyan);
}
.mrab-rotator-line::before { content: "›"; color: var(--mrab-magenta); font-weight: 800; }
.mrab-rotator-line.is-active { opacity: 1; transform: none; }

/* CTAs */
.mrab-ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 26px; }
.mrab-btn {
	display: inline-flex; align-items: center; gap: 9px;
	padding: 13px 22px;
	border-radius: 14px;
	font-weight: 700; font-size: 15px;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform .18s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.mrab-btn-ico { width: 18px; height: 18px; fill: currentColor; }
.mrab-btn-primary {
	color: var(--mrab-ink);
	background: var(--mrab-grad);
	box-shadow: 0 10px 30px -10px rgba(255, 61, 139, .6), 0 6px 18px -8px rgba(77, 212, 255, .5);
}
.mrab-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -12px rgba(255, 61, 139, .7); }
.mrab-btn-ghost {
	color: var(--mrab-on);
	background: var(--mrab-card);
	border-color: var(--mrab-line);
	-webkit-backdrop-filter: blur(6px);
	        backdrop-filter: blur(6px);
}
.mrab-btn-ghost:hover { transform: translateY(-2px); border-color: var(--mrab-cyan); color: var(--mrab-cyan); }

/* A CTA with no destination yet — looks like a button but is not clickable. */
.mrab-btn-static { cursor: default; }
.mrab-btn-static:hover { transform: none; box-shadow: none; }
.mrab-btn-ghost.mrab-btn-static:hover { border-color: var(--mrab-line); color: var(--mrab-on); }

/* trust chips */
.mrab-trust {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; gap: 10px 18px;
	font-size: 13px; color: var(--mrab-muted);
}
.mrab-trust li { display: inline-flex; align-items: center; gap: 7px; }
.mrab-trust-ico { font-size: 15px; }

/* preview / coming-soon messaging */
.mrab-badge {
	display: inline-flex; align-items: center; gap: 8px;
	margin-bottom: 18px; padding: 6px 14px;
	border-radius: 999px;
	font-size: 12.5px; font-weight: 700; letter-spacing: .01em;
	color: var(--mrab-cyan);
	background: rgba(77, 212, 255, .1);
	border: 1px solid rgba(77, 212, 255, .28);
}
.mrab-badge-dot {
	width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto;
	background: var(--mrab-magenta);
	box-shadow: 0 0 0 0 rgba(255, 61, 139, .6);
	animation: mrab-ring 1.8s ease-out infinite;
}
.mrab-soon-ribbon {
	position: absolute; z-index: 6; top: -6px; right: 6px;
	padding: 6px 14px; border-radius: 999px;
	font-size: 11px; font-weight: 800; letter-spacing: .16em;
	color: var(--mrab-ink); background: var(--mrab-grad);
	box-shadow: 0 10px 24px -10px rgba(255, 61, 139, .8);
	animation: mrab-bob 2.6s ease-in-out infinite;
}
@keyframes mrab-bob { 50% { transform: translateY(-5px); } }
.mrab-disclaimer {
	margin: 14px auto 0; max-width: 300px;
	font-size: 12px; line-height: 1.5; text-align: center; color: var(--mrab-muted);
}
.mrab-disclaimer strong { color: var(--mrab-magenta); }

/* ============================================================= PHONE MOCK-UP */
.mrab-phone-wrap {
	position: relative;
	display: flex; flex-direction: column; align-items: center;
	justify-self: center;
}
.mrab-glow {
	position: absolute; inset: -6% -10% 6%;
	background: radial-gradient(closest-side, rgba(77, 212, 255, .22), transparent 75%);
	filter: blur(30px); z-index: 0;
	animation: mrab-breathe 6s ease-in-out infinite;
}
@keyframes mrab-breathe { 50% { opacity: .55; transform: scale(1.05); } }

.mrab-phone {
	position: relative; z-index: 1;
	width: min(340px, 78vw);
	/* Fallback height for engines that ignore aspect-ratio (old iOS WebViews):
	   keeps the frame proportional instead of collapsing to the chrome height. */
	min-height: min(725px, calc(78vw * 19.2 / 9));
	aspect-ratio: 9 / 19.2;
	background: #05050a;
	border-radius: 42px;
	padding: 12px;
	border: 1px solid rgba(255, 255, 255, .12);
	box-shadow:
		0 40px 80px -30px rgba(0, 0, 0, .9),
		0 0 0 2px rgba(255, 255, 255, .04) inset,
		0 0 60px -20px rgba(77, 212, 255, .35);
	display: flex; flex-direction: column;
}
/* phone screen interior */
.mrab-phone::before {
	content: ""; position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
	width: 120px; height: 22px; background: #05050a; border-radius: 0 0 16px 16px; z-index: 6;
}

.mrab-phone-statusbar {
	position: relative; z-index: 7;
	display: flex; align-items: center; justify-content: space-between;
	height: 24px; padding: 0 18px;
	font-size: 12px; font-weight: 700; color: var(--mrab-on);
	background: var(--mrab-ink); border-radius: 32px 32px 0 0;
}
.mrab-sb-icons { display: inline-flex; align-items: center; gap: 5px; }
.mrab-sb-icons svg { height: 11px; width: auto; fill: var(--mrab-on); color: var(--mrab-on); }

.mrab-viewport {
	position: relative;
	flex: 1 1 auto;
	overflow: hidden;
	background: var(--mrab-ink);
}

/* phone bottom nav (Android) */
.mrab-phone-nav {
	display: flex; align-items: center; justify-content: space-around;
	height: 34px; background: var(--mrab-ink); border-radius: 0 0 32px 32px;
}
.mrab-phone-nav button,
.mrab-phone-nav span {
	background: none; border: 0; padding: 0; cursor: pointer;
	width: 30px; height: 24px; display: inline-flex; align-items: center; justify-content: center;
}
.mrab-phone-nav svg { width: 16px; height: 16px; fill: var(--mrab-muted); color: var(--mrab-muted); }
.mrab-nav-home svg { width: 14px; height: 14px; }
.mrab-phone-nav button:hover svg { fill: var(--mrab-cyan); color: var(--mrab-cyan); }

/* ------------------------------------------------------------------- screens */
.mrab-screen {
	position: absolute; inset: 0;
	display: flex; flex-direction: column;
	opacity: 0; visibility: hidden;
	transform: translateX(14%) scale(.99);
	transition: opacity .34s ease, transform .34s cubic-bezier(.22, 1, .36, 1), visibility .34s;
	overflow: hidden;
}
.mrab-screen.is-active { opacity: 1; visibility: visible; transform: none; z-index: 2; }
.mrab-screen.is-leaving { transform: translateX(-12%) scale(.99); opacity: 0; }

/* ----- HOME screen ----- */
.mrab-screen-home {
	background:
		radial-gradient(120% 60% at 50% -5%, rgba(77, 212, 255, .12), transparent 60%),
		var(--mrab-ink);
	overflow-y: auto;
}
.mrab-home-inner {
	display: flex; flex-direction: column; align-items: center;
	padding: 22px 22px 16px; text-align: center; min-height: 100%;
}
.mrab-home-logo { width: 76px; height: 76px; margin-top: 8px; filter: drop-shadow(0 0 14px rgba(77, 212, 255, .4)); }
.mrab-home-logo .mrab-logo-svg, .mrab-home-logo .mrab-logo-img { width: 100%; height: 100%; }
.mrab-home-title { font-size: 34px; font-weight: 800; letter-spacing: .08em; margin-top: 8px; }
.mrab-home-by { font-size: 10px; letter-spacing: .24em; color: var(--mrab-magenta); font-weight: 700; }
.mrab-home-tagline { font-size: 12px; color: var(--mrab-muted); margin-top: 10px; max-width: 24ch; }
.mrab-home-cta { font-size: 13px; font-weight: 700; color: var(--mrab-magenta); margin: 10px 0 18px; }

.mrab-appbtn {
	width: 100%; margin-top: 10px;
	display: inline-flex; align-items: center; justify-content: center; gap: 9px;
	padding: 13px 16px; border-radius: 14px;
	font-size: 14px; font-weight: 700; cursor: pointer;
	border: 1px solid transparent; color: var(--mrab-on);
	transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.mrab-appbtn-ico { font-size: 16px; }
.mrab-appbtn-primary {
	color: var(--mrab-ink); background: var(--mrab-grad);
	box-shadow: 0 8px 20px -8px rgba(77, 212, 255, .6);
}
.mrab-appbtn-tonal { background: rgba(77, 212, 255, .12); color: var(--mrab-cyan); border-color: rgba(77, 212, 255, .25); }
.mrab-appbtn-outline { background: transparent; border-color: var(--mrab-line); color: var(--mrab-muted); margin-top: 18px; }
.mrab-appbtn:hover { transform: translateY(-1px); }
.mrab-appbtn-tonal:hover { background: rgba(77, 212, 255, .2); }
.mrab-appbtn-outline:hover { border-color: var(--mrab-cyan); color: var(--mrab-cyan); }
.mrab-home-foot { margin-top: auto; padding-top: 16px; font-size: 10px; letter-spacing: .1em; color: var(--mrab-muted); }

/* ----- FORM screen (driver sign-up) ----- */
.mrab-screen-form {
	background:
		radial-gradient(120% 60% at 50% -5%, rgba(255, 61, 139, .1), transparent 60%),
		var(--mrab-ink);
}
.mrab-form-inner { flex: 1 1 auto; overflow-y: auto; padding: 14px 14px 18px; }
.mrab-form-intro { margin: 2px 0 14px; font-size: 12.5px; line-height: 1.55; color: var(--mrab-muted); }

/* Real form controls, matched to the faux .mrab-input look used elsewhere. */
.mrab-input-real {
	display: block; width: 100%;
	font-family: inherit; line-height: 1.4;
	-webkit-appearance: none; appearance: none; outline: none;
}
.mrab-input-real::placeholder { color: var(--mrab-muted); opacity: .8; }
.mrab-input-real:focus {
	border-color: var(--mrab-cyan);
	box-shadow: 0 0 0 3px rgba(77, 212, 255, .18);
}
.mrab-select {
	cursor: pointer; padding-right: 32px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239C9EAE'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 9px center; background-size: 18px;
}
.mrab-select option { background: var(--mrab-ink-2); color: var(--mrab-on); }

/* ----- MAP screens shared ----- */
.mrab-screen-map { background: var(--mrab-ink); }
.mrab-appbar {
	position: relative; z-index: 5;
	display: flex; align-items: center; gap: 6px;
	height: 46px; padding: 0 8px;
	background: rgba(10, 10, 18, .82);
	-webkit-backdrop-filter: blur(8px);
	        backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--mrab-line);
}
.mrab-back { background: none; border: 0; cursor: pointer; padding: 6px; display: inline-flex; }
.mrab-back svg { width: 20px; height: 20px; fill: var(--mrab-on); }
.mrab-appbar-title { font-size: 15px; font-weight: 700; }

/* map (Leaflet / OpenStreetMap) */
.mrab-map { position: relative; flex: 1 1 auto; overflow: hidden; background: #0c1018; }
/* z-index:0 contains Leaflet's internal panes so they don't paint over the
   appbar / search card / sheet (which sit at z-index 4–5). */
.mrab-leaflet { position: absolute; inset: 0; z-index: 0; background: #0c1018; }
/* Leaflet positions tiles with offsets that break under border-box; reset its subtree. */
.mrab-promo .leaflet-container,
.mrab-promo .leaflet-container * { box-sizing: content-box; }

.mrab-promo .leaflet-container { background: #0c1018; font-family: var(--mrab-font); }
.mrab-promo .leaflet-control-attribution {
	background: rgba(10, 10, 18, .72); color: var(--mrab-muted); font-size: 9px;
}
.mrab-promo .leaflet-control-attribution a { color: var(--mrab-cyan); }
.mrab-promo .leaflet-bar a {
	background: var(--mrab-ink-2); color: var(--mrab-on);
	border-bottom-color: var(--mrab-line);
}
.mrab-promo .leaflet-bar a:hover { background: var(--mrab-ink-3); color: var(--mrab-cyan); }
/* strip the default white box from our divIcon markers */
.mrab-promo .leaflet-div-icon.mrab-divicon { background: none; border: none; }

/* neon map markers */
.mrab-mk {
	position: relative; display: block; width: 16px; height: 16px;
	border-radius: 50%; border: 2px solid #fff;
	box-shadow: 0 0 8px currentColor, 0 2px 6px rgba(0, 0, 0, .6);
}
.mrab-mk-cyan { background: var(--mrab-cyan); color: var(--mrab-cyan); }
.mrab-mk-magenta { background: var(--mrab-magenta); color: var(--mrab-magenta); }
.mrab-mk::after {
	content: ""; position: absolute; inset: -6px; border-radius: 50%;
	background: currentColor; opacity: .35; z-index: -1;
	animation: mrab-pulse 2.2s ease-out infinite;
}
@keyframes mrab-pulse {
	0%   { transform: scale(.5); opacity: .7; }
	100% { transform: scale(1.9); opacity: 0; }
}

/* driver marker that glides along the route */
.mrab-driver-ic {
	display: flex; align-items: center; justify-content: center;
	width: 28px; height: 28px; font-size: 15px; border-radius: 50%;
	background: rgba(255, 61, 139, .92); border: 2px solid #fff;
	box-shadow: 0 0 12px var(--mrab-magenta), 0 2px 6px rgba(0, 0, 0, .6);
}

/* search card */
.mrab-searchcard {
	position: absolute; z-index: 4; top: 56px; left: 10px; right: 10px;
	display: flex; align-items: center; gap: 8px;
	padding: 10px 12px; border-radius: 12px;
	background: rgba(21, 21, 31, .92);
	-webkit-backdrop-filter: blur(8px);
	        backdrop-filter: blur(8px);
	border: 1px solid var(--mrab-line);
	box-shadow: 0 8px 22px -12px rgba(0, 0, 0, .8);
	font-size: 12px; color: var(--mrab-muted);
}
.mrab-search-ico { opacity: .7; }

/* bottom sheet */
.mrab-sheet {
	position: relative; z-index: 4;
	margin-top: auto;
	background: var(--mrab-ink-2);
	border-top: 1px solid var(--mrab-line);
	border-radius: 18px 18px 0 0;
	padding: 14px 14px 16px;
	box-shadow: 0 -10px 30px -16px rgba(0, 0, 0, .9);
	max-height: 72%; overflow-y: auto;
	transition: max-height .34s cubic-bezier(.22, 1, .36, 1);
}
/* The Padala sheet carries the most content — give it more room. */
.mrab-sheet-tall { max-height: 84%; }

/* Real, tappable grab handle: tap it to minimize the sheet and reveal the map.
   It draws the same little pill as the old ::before, but as an actual button. */
.mrab-grab {
	display: block; width: 100%; height: 18px;
	margin: -4px 0 10px; padding: 0;
	background: none; border: 0; cursor: pointer;
	position: relative;
	touch-action: manipulation;
}
.mrab-grab::before {
	content: ""; position: absolute; top: 4px; left: 50%; transform: translateX(-50%);
	width: 38px; height: 4px; border-radius: 4px;
	background: rgba(255, 255, 255, .18);
	transition: background .2s ease, width .2s ease;
}
.mrab-grab:hover::before,
.mrab-grab:focus-visible::before { background: var(--mrab-cyan); width: 52px; }

/* Collapsed: clip the sheet down to just the handle so the map is fully visible.
   Higher specificity than .mrab-sheet-tall, so it wins without !important. */
.mrab-sheet.is-collapsed {
	max-height: 30px; overflow: hidden;
	padding-top: 10px; padding-bottom: 6px;
}
.mrab-sheet.is-collapsed .mrab-grab { margin-bottom: 0; }

.mrab-line { font-size: 12.5px; display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.mrab-line b { color: var(--mrab-on); font-weight: 600; }
.mrab-muted, .mrab-muted b { color: var(--mrab-muted); }
.mrab-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; box-shadow: 0 0 8px currentColor; }
.mrab-dot-cyan { background: var(--mrab-cyan); color: var(--mrab-cyan); }
.mrab-dot-magenta { background: var(--mrab-magenta); color: var(--mrab-magenta); }

/* segmented toggle */
.mrab-toggle {
	display: flex; gap: 6px; margin: 10px 0; padding: 4px;
	background: var(--mrab-ink-3); border-radius: 12px;
}
.mrab-toggle button {
	flex: 1; padding: 8px 6px; border: 0; border-radius: 9px;
	background: transparent; color: var(--mrab-muted);
	font-size: 12px; font-weight: 700; cursor: pointer;
	transition: background .2s ease, color .2s ease;
}
.mrab-toggle button.is-active { background: var(--mrab-grad); color: var(--mrab-ink); }

/* fields */
.mrab-field { margin-top: 10px; }
.mrab-field label { display: block; font-size: 10.5px; letter-spacing: .03em; color: var(--mrab-muted); margin-bottom: 4px; }
.mrab-input, .mrab-textarea {
	font-size: 12.5px; color: var(--mrab-on);
	background: var(--mrab-ink-3); border: 1px solid var(--mrab-line);
	border-radius: 10px; padding: 9px 11px;
}
.mrab-textarea { line-height: 1.7; }
.mrab-field-row .mrab-input { display: inline-block; min-width: 80px; }

.mrab-cap-note { font-size: 10.5px; color: var(--mrab-muted); margin: 10px 0 4px; }

.mrab-quote {
	margin: 12px 0 4px; padding: 9px 11px;
	font-size: 13px; font-weight: 700; color: var(--mrab-cyan);
	background: rgba(77, 212, 255, .08); border: 1px solid rgba(77, 212, 255, .2);
	border-radius: 10px;
}

.mrab-book { margin-top: 12px; }
.mrab-book[disabled],
.mrab-book[aria-disabled="true"] { opacity: .5; cursor: default; }
.mrab-attn { animation: mrab-attn 1.6s ease; }
@keyframes mrab-attn {
	0%, 100% { box-shadow: 0 8px 20px -8px rgba(77, 212, 255, .6); }
	30%, 70% { box-shadow: 0 0 0 4px rgba(255, 61, 139, .55), 0 10px 24px -8px rgba(255, 61, 139, .7); transform: translateY(-1px); }
}

.mrab-status {
	margin-top: 11px; padding: 9px 11px; border-radius: 10px;
	font-size: 12px; font-weight: 600;
	background: rgba(255, 255, 255, .05); border: 1px solid var(--mrab-line);
	color: var(--mrab-on);
	display: flex; align-items: center; gap: 8px;
}
/* The status is a persistent live region; it stays in the DOM and is hidden
   only while empty, so each new message is announced by assistive tech. */
.mrab-status:empty { display: none; }
.mrab-status.is-ok { color: var(--mrab-ok); border-color: rgba(54, 211, 153, .3); background: rgba(54, 211, 153, .08); }
.mrab-status.is-done { color: var(--mrab-cyan); border-color: rgba(77, 212, 255, .3); background: rgba(77, 212, 255, .08); }
.mrab-status .mrab-spin {
	width: 13px; height: 13px; border-radius: 50%; flex: 0 0 auto;
	border: 2px solid rgba(255, 255, 255, .25); border-top-color: var(--mrab-cyan);
	animation: mrab-spin .8s linear infinite;
}
@keyframes mrab-spin { to { transform: rotate(360deg); } }

/* hint under the phone */
.mrab-hint {
	position: relative; z-index: 1;
	margin-top: 18px;
	display: inline-flex; align-items: center; gap: 9px;
	font-size: 13px; color: var(--mrab-muted);
}
.mrab-hint-pulse {
	width: 9px; height: 9px; border-radius: 50%; background: var(--mrab-magenta);
	box-shadow: 0 0 0 0 rgba(255, 61, 139, .6); animation: mrab-ring 1.8s ease-out infinite;
}
@keyframes mrab-ring {
	0%   { box-shadow: 0 0 0 0 rgba(255, 61, 139, .55); }
	100% { box-shadow: 0 0 0 12px rgba(255, 61, 139, 0); }
}

/* service switcher under the phone — makes all three demos obviously testable */
.mrab-srvtabs {
	position: relative; z-index: 1;
	display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
	margin-top: 14px;
}
.mrab-srvtab {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 15px; border-radius: 999px; cursor: pointer;
	font-size: 13px; font-weight: 700;
	color: var(--mrab-muted); background: var(--mrab-card);
	border: 1px solid var(--mrab-line);
	transition: color .2s ease, border-color .2s ease, background .2s ease, transform .15s ease;
}
.mrab-srvtab:hover { transform: translateY(-1px); color: var(--mrab-on); border-color: var(--mrab-cyan); }
.mrab-srvtab.is-active { color: var(--mrab-ink); background: var(--mrab-grad); border-color: transparent; }

/* =============================================================== feature grid */
.mrab-features {
	max-width: 1140px; margin: clamp(40px, 7vw, 84px) auto 0;
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.mrab-feature {
	padding: 22px 20px; border-radius: var(--mrab-radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .015));
	border: 1px solid var(--mrab-line);
	transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.mrab-feature:hover {
	transform: translateY(-4px);
	border-color: rgba(77, 212, 255, .35);
	box-shadow: 0 22px 44px -26px rgba(77, 212, 255, .55);
}
.mrab-feature-ico {
	width: 46px; height: 46px; border-radius: 13px; margin-bottom: 14px;
	display: inline-flex; align-items: center; justify-content: center; font-size: 22px;
	background: rgba(77, 212, 255, .1); border: 1px solid rgba(77, 212, 255, .22);
}
.mrab-feature h3 { margin: 0 0 7px; font-size: 16px; font-weight: 700; }
.mrab-feature p { margin: 0; font-size: 13.5px; color: var(--mrab-muted); line-height: 1.6; }

/* ================================================================ bottom CTA */
.mrab-bottomcta {
	max-width: 1140px; margin: clamp(28px, 4vw, 48px) auto 0;
	display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 20px;
	padding: clamp(22px, 3vw, 34px);
	border-radius: var(--mrab-radius);
	background:
		radial-gradient(140% 140% at 0% 0%, rgba(77, 212, 255, .14), transparent 55%),
		radial-gradient(140% 140% at 100% 100%, rgba(255, 61, 139, .14), transparent 55%),
		var(--mrab-ink-2);
	border: 1px solid var(--mrab-line);
}
.mrab-bottomcta-text .mrab-brand-name { font-size: clamp(20px, 3vw, 28px); display: block; margin-bottom: 4px; letter-spacing: 0; }
.mrab-bottomcta-text p { margin: 0; color: var(--mrab-muted); font-size: 14px; max-width: 48ch; }

/* social / contact bar */
.mrab-social {
	max-width: 1140px; margin: 30px auto 0;
	display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 10px;
}
.mrab-social-ico {
	width: 38px; height: 38px; border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--mrab-muted); background: var(--mrab-card); border: 1px solid var(--mrab-line);
	transition: color .2s ease, border-color .2s ease, background .2s ease, transform .15s ease;
}
.mrab-social-ico svg { width: 17px; height: 17px; fill: currentColor; }
.mrab-social-ico:hover { color: var(--mrab-cyan); border-color: var(--mrab-cyan); transform: translateY(-2px); }
.mrab-social-link {
	margin-left: 4px; padding: 8px 10px;
	font-size: 13px; font-weight: 600; color: var(--mrab-muted); text-decoration: none;
	transition: color .2s ease;
}
.mrab-social-link:hover { color: var(--mrab-cyan); }

.mrab-foot {
	max-width: 1140px; margin: 16px auto 0;
	text-align: center; font-size: 11px; letter-spacing: .12em; color: var(--mrab-muted);
}

/* ===================================================================== toast */
.mrab-toast {
	position: absolute; left: 50%; bottom: 22px; transform: translate(-50%, 20px);
	z-index: 30;
	max-width: 84%;
	padding: 11px 18px; border-radius: 12px;
	background: rgba(21, 21, 31, .96); border: 1px solid var(--mrab-line);
	box-shadow: 0 16px 40px -16px rgba(0, 0, 0, .9);
	color: var(--mrab-on); font-size: 13px; font-weight: 600;
	opacity: 0; visibility: hidden; pointer-events: none;
	transition: opacity .3s ease, transform .3s ease, visibility .3s;
}
.mrab-toast.is-show { opacity: 1; visibility: visible; transform: translate(-50%, 0); }

/* ============================================================== reveal on scroll */
.mrab-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s cubic-bezier(.22, 1, .36, 1); }
.mrab-reveal.is-in { opacity: 1; transform: none; }

/* ============================================================== responsiveness */
@media (max-width: 880px) {
	.mrab-shell { grid-template-columns: 1fr; gap: 36px; }
	.mrab-hero { text-align: center; order: 1; }
	.mrab-brandrow, .mrab-ctas, .mrab-trust { justify-content: center; }
	.mrab-sub { margin-left: auto; margin-right: auto; }
	.mrab-phone-wrap { order: 2; }
	.mrab-features { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.mrab-features { grid-template-columns: 1fr; }
	.mrab-bottomcta { flex-direction: column; text-align: center; }
	.mrab-bottomcta .mrab-ctas { justify-content: center; }
	.mrab-trust { gap: 8px 14px; }
	/* Tighten the in-phone home stack so it fits without an internal scrollbar
	   on the smallest devices (phone shrinks via width: min(340px, 78vw)). */
	.mrab-home-logo { width: 58px; height: 58px; }
	.mrab-home-title { font-size: 30px; }
	.mrab-home-cta { margin: 8px 0 14px; }
	.mrab-appbtn { padding: 11px 14px; margin-top: 8px; }
	.mrab-appbtn-outline { margin-top: 14px; }
}

/* ============================================================ reduced motion */
@media (prefers-reduced-motion: reduce) {
	.mrab-promo *,
	.mrab-promo *::before,
	.mrab-promo *::after {
		animation-duration: .001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .001ms !important;
	}
	.mrab-reveal { opacity: 1; transform: none; }
}
