/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */
@font-face {
  font-family: "InterVariable";
  src: url("/fonts/InterVariable.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "InterVariable";
  src: url("/fonts/InterVariable-Italic.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@layer properties {
	@supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or
		((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
		*,
		:before,
		:after,
		::backdrop {
			--tw-space-y-reverse: 0;
			--tw-border-style: solid;
			--tw-gradient-position: initial;
			--tw-gradient-from: #0000;
			--tw-gradient-via: #0000;
			--tw-gradient-to: #0000;
			--tw-gradient-stops: initial;
			--tw-gradient-via-stops: initial;
			--tw-gradient-from-position: 0%;
			--tw-gradient-via-position: 50%;
			--tw-gradient-to-position: 100%;
			--tw-leading: initial;
			--tw-font-weight: initial;
			--tw-tracking: initial;
			--tw-shadow: 0 0 #0000;
			--tw-shadow-color: initial;
			--tw-shadow-alpha: 100%;
			--tw-inset-shadow: 0 0 #0000;
			--tw-inset-shadow-color: initial;
			--tw-inset-shadow-alpha: 100%;
			--tw-ring-color: initial;
			--tw-ring-shadow: 0 0 #0000;
			--tw-inset-ring-color: initial;
			--tw-inset-ring-shadow: 0 0 #0000;
			--tw-ring-inset: initial;
			--tw-ring-offset-width: 0px;
			--tw-ring-offset-color: #fff;
			--tw-ring-offset-shadow: 0 0 #0000;
			--tw-backdrop-blur: initial;
			--tw-backdrop-brightness: initial;
			--tw-backdrop-contrast: initial;
			--tw-backdrop-grayscale: initial;
			--tw-backdrop-hue-rotate: initial;
			--tw-backdrop-invert: initial;
			--tw-backdrop-opacity: initial;
			--tw-backdrop-saturate: initial;
			--tw-backdrop-sepia: initial;
		}
	}
}
@layer theme {
	:root,
	:host {
		--font-sans: "InterVariable", ui-sans-serif, system-ui, sans-serif,
  "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
		--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
			"Liberation Mono", "Courier New", monospace;
		--color-red-50: oklch(97.1% 0.013 17.38);
		--color-red-400: oklch(70.4% 0.191 22.216);
		--color-red-600: oklch(57.7% 0.245 27.325);
		--color-red-700: oklch(50.5% 0.213 27.518);
		--color-green-500: oklch(72.3% 0.219 149.579);
		--color-slate-50: oklch(98.4% 0.003 247.858);
		--color-slate-100: oklch(96.8% 0.007 247.896);
		--color-slate-200: oklch(92.9% 0.013 255.508);
		--color-slate-300: oklch(86.9% 0.022 252.894);
		--color-slate-500: oklch(55.4% 0.046 257.417);
		--color-slate-600: oklch(44.6% 0.043 257.281);
		--color-slate-700: oklch(37.2% 0.044 257.287);
		--color-slate-800: oklch(27.9% 0.041 260.031);
		--color-slate-900: oklch(20.8% 0.042 265.755);
		--color-white: #fff;
		--spacing: 0.25rem;
		--container-2xl: 42rem;
		--container-7xl: 80rem;
		--text-xs: 0.75rem;
		--text-xs--line-height: calc(1 / 0.75);
		--text-sm: 0.875rem;
		--text-sm--line-height: calc(1.25 / 0.875);
		--text-base: 1rem;
		--text-base--line-height: calc(1.5 / 1);
		--text-lg: 1.125rem;
		--text-lg--line-height: calc(1.75 / 1.125);
		--text-2xl: 1.5rem;
		--text-2xl--line-height: calc(2 / 1.5);
		--text-3xl: 1.875rem;
		--text-3xl--line-height: calc(2.25 / 1.875);
		--text-5xl: 3rem;
		--text-5xl--line-height: 1;
		--font-weight-medium: 500;
		--font-weight-semibold: 600;
		--font-weight-bold: 700;
		--font-weight-extrabold: 800;
		--tracking-tight: -0.025em;
		--tracking-wide: 0.025em;
		--leading-tight: 1.25;
		--radius-lg: 0.5rem;
		--radius-xl: 0.75rem;
		--radius-2xl: 1rem;
		--radius-3xl: 2rem;
		--default-font-family: var(--font-sans);
		--default-mono-font-family: var(--font-mono);
	}
}
@layer base {
	*,
	:after,
	:before,
	::backdrop {
		box-sizing: border-box;
		margin: 0;
		padding: 0;
	}
	::file-selector-button {
		box-sizing: border-box;
		border: 0 solid;
		margin: 0;
		padding: 0;
	}
	html,
	:host {
		-webkit-text-size-adjust: 100%;
		tab-size: 4;
		line-height: 1.5;
		font-family: var(
			--default-font-family,
			ui-sans-serif,
			system-ui,
			sans-serif,
			"Apple Color Emoji",
			"Segoe UI Emoji",
			"Segoe UI Symbol",
			"Noto Color Emoji"
		);
		font-feature-settings: var(--default-font-feature-settings, normal);
		font-variation-settings: var(--default-font-variation-settings, normal);
		-webkit-tap-highlight-color: transparent;
	}
	hr {
		height: 0;
		color: inherit;
		border-top-width: 1px;
	}
	abbr:where([title]) {
		-webkit-text-decoration: underline dotted;
		text-decoration: underline dotted;
	}
	h1,
	h2,
	h3,
	h4,
	h5,
	h6 {
		font-size: inherit;
		font-weight: inherit;
	}
	a {
		color: inherit;
		-webkit-text-decoration: inherit;
		-webkit-text-decoration: inherit;
		-webkit-text-decoration: inherit;
		text-decoration: inherit;
	}
	b,
	strong {
		font-weight: bolder;
	}
	code,
	kbd,
	samp,
	pre {
		font-family: var(
			--default-mono-font-family,
			ui-monospace,
			SFMono-Regular,
			Menlo,
			Monaco,
			Consolas,
			"Liberation Mono",
			"Courier New",
			monospace
		);
		font-feature-settings: var(--default-mono-font-feature-settings, normal);
		font-variation-settings: var(
			--default-mono-font-variation-settings,
			normal
		);
		font-size: 1em;
	}
	small {
		font-size: 80%;
	}
	sub,
	sup {
		vertical-align: baseline;
		font-size: 75%;
		line-height: 0;
		position: relative;
	}
	sub {
		bottom: -0.25em;
	}
	sup {
		top: -0.5em;
	}
	table {
		text-indent: 0;
		border-color: inherit;
		border-collapse: collapse;
	}
	:-moz-focusring {
		outline: auto;
	}
	progress {
		vertical-align: baseline;
	}
	summary {
		display: list-item;
	}
	ol,
	ul,
	menu {
		list-style: none;
	}
	img,
	svg,
	video,
	canvas,
	audio,
	iframe,
	embed,
	object {
		vertical-align: middle;
		display: block;
	}
	img,
	video {
		max-width: 100%;
		height: auto;
	}
	button,
	input,
	select,
	optgroup,
	textarea {
		font: inherit;
		font-feature-settings: inherit;
		font-variation-settings: inherit;
		letter-spacing: inherit;
		color: inherit;
		opacity: 1;
		background-color: #0000;
		border-radius: 0;
	}
	::file-selector-button {
		font: inherit;
		font-feature-settings: inherit;
		font-variation-settings: inherit;
		letter-spacing: inherit;
		color: inherit;
		opacity: 1;
		background-color: #0000;
		border-radius: 0;
	}
	:where(select:is([multiple], [size])) optgroup {
		font-weight: bolder;
	}
	:where(select:is([multiple], [size])) optgroup option {
		padding-inline-start: 20px;
	}
	::file-selector-button {
		margin-inline-end: 4px;
	}
	::placeholder {
		opacity: 1;
	}
	@supports (not ((-webkit-appearance: -apple-pay-button))) or
		(contain-intrinsic-size: 1px) {
		::placeholder {
			color: currentColor;
		}
		@supports (color: color-mix(in lab, red, red)) {
			::placeholder {
				color: color-mix(in oklab, currentcolor 50%, transparent);
			}
		}
	}
	textarea {
		resize: vertical;
	}
	::-webkit-search-decoration {
		-webkit-appearance: none;
	}
	::-webkit-date-and-time-value {
		min-height: 1lh;
		text-align: inherit;
	}
	::-webkit-datetime-edit {
		display: inline-flex;
	}
	::-webkit-datetime-edit-fields-wrapper {
		padding: 0;
	}
	::-webkit-datetime-edit {
		padding-block: 0;
	}
	::-webkit-datetime-edit-year-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-month-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-day-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-hour-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-minute-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-second-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-millisecond-field {
		padding-block: 0;
	}
	::-webkit-datetime-edit-meridiem-field {
		padding-block: 0;
	}
	::-webkit-calendar-picker-indicator {
		line-height: 1;
	}
	:-moz-ui-invalid {
		box-shadow: none;
	}
	button,
	input:where([type="button"], [type="reset"], [type="submit"]) {
		appearance: button;
	}
	::file-selector-button {
		appearance: button;
	}
	::-webkit-inner-spin-button {
		height: auto;
	}
	::-webkit-outer-spin-button {
		height: auto;
	}
	[hidden]:where(:not([hidden="until-found"])) {
		display: none !important;
	}
}
@layer components;
@layer utilities {
	.sr-only {
		clip-path: inset(50%);
		white-space: nowrap;
		border-width: 0;
		width: 1px;
		height: 1px;
		margin: -1px;
		padding: 0;
		position: absolute;
		overflow: hidden;
	}
	.fixed {
		position: fixed;
	}
	.relative {
		position: relative;
	}
	.sticky {
		position: sticky;
	}
	.inset-x-0 {
		inset-inline: calc(var(--spacing) * 0);
	}
	.top-0 {
		top: calc(var(--spacing) * 0);
	}
	.top-\[var\(--bar-h\)\] {
		top: var(--bar-h);
	}
	.z-40 {
		z-index: 40;
	}
	.z-50 {
		z-index: 50;
	}
	.mx-auto {
		margin-inline: auto;
	}
	.mt-1 {
		margin-top: calc(var(--spacing) * 1);
	}
	.mt-2 {
		margin-top: calc(var(--spacing) * 2);
	}
	.mt-3 {
		margin-top: calc(var(--spacing) * 3);
	}
	.mt-4 {
		margin-top: calc(var(--spacing) * 4);
	}
	.mt-6 {
		margin-top: calc(var(--spacing) * 6);
	}
	.mt-8 {
		margin-top: calc(var(--spacing) * 8);
	}
	.mb-10 {
		margin-bottom: calc(var(--spacing) * 10);
	}
	.block {
		display: block;
	}
	.flex {
		display: flex;
	}
	.grid {
		display: grid;
	}
	.hidden {
		display: none;
	}
	.inline-flex {
		display: inline-flex;
	}
	.inline-grid {
		display: inline-grid;
	}
	.aspect-\[4\/3\] {
		aspect-ratio: 4/3;
	}
	.h-2 {
		height: calc(var(--spacing) * 2);
	}
	.h-4 {
		height: calc(var(--spacing) * 4);
	}
	.h-5 {
		height: calc(var(--spacing) * 5);
	}
	.h-9 {
		height: calc(var(--spacing) * 9);
	}
	.h-10 {
		height: calc(var(--spacing) * 10);
	}
	.h-16 {
		height: calc(var(--spacing) * 16);
	}
	.h-full {
		height: 100%;
	}
	.w-2 {
		width: calc(var(--spacing) * 2);
	}
	.w-4 {
		width: calc(var(--spacing) * 4);
	}
	.w-5 {
		width: calc(var(--spacing) * 5);
	}
	.w-9 {
		width: calc(var(--spacing) * 9);
	}
	.w-10 {
		width: calc(var(--spacing) * 10);
	}
	.w-full {
		width: 100%;
	}
	.max-w-2xl {
		max-width: var(--container-2xl);
	}
	.max-w-7xl {
		max-width: var(--container-7xl);
	}
	.cursor-pointer {
		cursor: pointer;
	}
	.list-inside {
		list-style-position: inside;
	}
	.list-disc {
		list-style-type: disc;
	}
	.grid-cols-1 {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}
	.flex-wrap {
		flex-wrap: wrap;
	}
	.place-items-center {
		place-items: center;
	}
	.items-center {
		align-items: center;
	}
	.items-end {
		align-items: flex-end;
	}
	.items-start {
		align-items: flex-start;
	}
	.justify-between {
		justify-content: space-between;
	}
	.gap-2 {
		gap: calc(var(--spacing) * 2);
	}
	.gap-3 {
		gap: calc(var(--spacing) * 3);
	}
	.gap-4 {
		gap: calc(var(--spacing) * 4);
	}
	.gap-6 {
		gap: calc(var(--spacing) * 6);
	}
	.gap-8 {
		gap: calc(var(--spacing) * 8);
	}
	.gap-10 {
		gap: calc(var(--spacing) * 10);
	}
	:where(.space-y-1 > :not(:last-child)) {
		--tw-space-y-reverse: 0;
		margin-block-start: calc(
			calc(var(--spacing) * 1) * var(--tw-space-y-reverse)
		);
		margin-block-end: calc(
			calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse))
		);
	}
	:where(.space-y-2 > :not(:last-child)) {
		--tw-space-y-reverse: 0;
		margin-block-start: calc(
			calc(var(--spacing) * 2) * var(--tw-space-y-reverse)
		);
		margin-block-end: calc(
			calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse))
		);
	}
	.overflow-hidden {
		overflow: hidden;
	}
	.scroll-smooth {
		scroll-behavior: smooth;
	}
	.rounded {
		border-radius: 0.25rem;
	}
	.rounded-2xl {
		border-radius: var(--radius-2xl);
	}
	.rounded-3xl {
		border-radius: var(--radius-3xl);
	}
	.rounded-full {
		border-radius: 3.40282e38px;
	}
	.rounded-lg {
		border-radius: var(--radius-lg);
	}
	.rounded-xl {
		border-radius: var(--radius-xl);
	}
	.border {
		border-style: var(--tw-border-style);
		border-width: 1px;
	}
	.border-t {
		border-top-style: var(--tw-border-style);
		border-top-width: 1px;
	}
	.border-b {
		border-bottom-style: var(--tw-border-style);
		border-bottom-width: 1px;
	}
	.border-slate-100 {
		border-color: var(--color-slate-100);
	}
	.border-slate-200 {
		border-color: var(--color-slate-200);
	}
	.border-slate-300 {
		border-color: var(--color-slate-300);
	}
	.bg-green-500 {
		background-color: var(--color-green-500);
	}
	.bg-red-50 {
		background-color: var(--color-red-50);
	}
	.bg-red-600 {
		background-color: var(--color-red-600);
	}
	.bg-slate-50 {
		background-color: var(--color-slate-50);
	}
	.bg-white {
		background-color: var(--color-white);
	}
	.bg-white\/10 {
		background-color: #ffffff1a;
	}
	.bottom-5 {
	    bottom: 5px;
	}
	.right-5 {
	    right:5px;
	}
	@supports (color: color-mix(in lab, red, red)) {
		.bg-white\/10 {
			background-color: color-mix(
				in oklab,
				var(--color-white) 10%,
				transparent
			);
		}
	}
	.bg-white\/80 {
		background-color: #fffc;
	}
	@supports (color: color-mix(in lab, red, red)) {
		.bg-white\/80 {
			background-color: color-mix(
				in oklab,
				var(--color-white) 80%,
				transparent
			);
		}
	}
	@supports (color: color-mix(in lab, red, red)) {
		.bg-emergency-600\/90 {
			background-color: color-mix(
				in oklab,
				var(--emergency-600) 90%,
				transparent
			);
		}
	}
	.bg-gradient-to-b {
		--tw-gradient-position: to bottom in oklab;
		background-image: linear-gradient(var(--tw-gradient-stops));
	}
	.from-slate-50 {
		--tw-gradient-from: var(--color-slate-50);
		--tw-gradient-stops: var(
			--tw-gradient-via-stops,
			var(--tw-gradient-position),
			var(--tw-gradient-from) var(--tw-gradient-from-position),
			var(--tw-gradient-to) var(--tw-gradient-to-position)
		);
	}
	.to-white {
		--tw-gradient-to: var(--color-white);
		--tw-gradient-stops: var(
			--tw-gradient-via-stops,
			var(--tw-gradient-position),
			var(--tw-gradient-from) var(--tw-gradient-from-position),
			var(--tw-gradient-to) var(--tw-gradient-to-position)
		);
	}
	.object-cover {
		object-fit: cover;
	}
	.p-5 {
		padding: calc(var(--spacing) * 5);
	}
	.p-6 {
		padding: calc(var(--spacing) * 6);
	}
	.px-3 {
		padding-inline: calc(var(--spacing) * 3);
	}
	.px-4 {
		padding-inline: calc(var(--spacing) * 4);
	}
	.px-5 {
		padding-inline: calc(var(--spacing) * 5);
	}
	.py-1\.5 {
		padding-block: calc(var(--spacing) * 1.5);
	}
	.py-2 {
		padding-block: calc(var(--spacing) * 2);
	}
	.py-3 {
		padding-block: calc(var(--spacing) * 3);
	}
	.py-4 {
		padding-block: calc(var(--spacing) * 4);
	}
	.py-5 {
		padding-block: calc(var(--spacing) * 5);
	}
	.py-10 {
		padding-block: calc(var(--spacing) * 10);
	}
	.py-16 {
		padding-block: calc(var(--spacing) * 16);
	}
	.pt-28 {
		padding-top: calc(var(--spacing) * 28);
	}
	.pb-16 {
		padding-bottom: calc(var(--spacing) * 16);
	}
	.text-2xl {
		font-size: var(--text-2xl);
		line-height: var(--tw-leading, var(--text-2xl--line-height));
	}
	.text-3xl {
		font-size: var(--text-3xl);
		line-height: var(--tw-leading, var(--text-3xl--line-height));
	}
	.text-base {
		font-size: var(--text-base);
		line-height: var(--tw-leading, var(--text-base--line-height));
	}
	.text-lg {
		font-size: var(--text-lg);
		line-height: var(--tw-leading, var(--text-lg--line-height));
	}
	.text-sm {
		font-size: var(--text-sm);
		line-height: var(--tw-leading, var(--text-sm--line-height));
	}
	.text-xs {
		font-size: var(--text-xs);
		line-height: var(--tw-leading, var(--text-xs--line-height));
	}
	.leading-tight {
		--tw-leading: var(--leading-tight);
		line-height: var(--leading-tight);
	}
	.font-bold {
		--tw-font-weight: var(--font-weight-bold);
		font-weight: var(--font-weight-bold);
	}
	.font-extrabold {
		--tw-font-weight: var(--font-weight-extrabold);
		font-weight: var(--font-weight-extrabold);
	}
	.font-medium {
		--tw-font-weight: var(--font-weight-medium);
		font-weight: var(--font-weight-medium);
	}
	.font-semibold {
		--tw-font-weight: var(--font-weight-semibold);
		font-weight: var(--font-weight-semibold);
	}
	.tracking-tight {
		--tw-tracking: var(--tracking-tight);
		letter-spacing: var(--tracking-tight);
	}
	.tracking-wide {
		--tw-tracking: var(--tracking-wide);
		letter-spacing: var(--tracking-wide);
	}
	.text-red-600 {
		color: var(--color-red-600);
	}
	.text-slate-500 {
		color: var(--color-slate-500);
	}
	.text-slate-600 {
		color: var(--color-slate-600);
	}
	.text-slate-700 {
		color: var(--color-slate-700);
	}
	.text-slate-800 {
		color: var(--color-slate-800);
	}
	.text-slate-900 {
		color: var(--color-slate-900);
	}
	.text-white {
		color: var(--color-white);
	}
	.antialiased {
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
	.ring-1 {
		--tw-ring-shadow: var(--tw-ring-inset) 0 0 0
			calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
		box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow),
			var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
	}
	.ring-white\/20 {
		--tw-ring-color: #fff3;
	}
	@supports (color: color-mix(in lab, red, red)) {
		.ring-white\/20 {
			--tw-ring-color: color-mix(in oklab, var(--color-white) 20%, transparent);
		}
	}
	.backdrop-blur {
		--tw-backdrop-blur: blur(8px);
		-webkit-backdrop-filter: var(--tw-backdrop-blur)
			var(--tw-backdrop-brightness) var(--tw-backdrop-contrast)
			var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate)
			var(--tw-backdrop-invert) var(--tw-backdrop-opacity)
			var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
		backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness)
			var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale)
			var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert)
			var(--tw-backdrop-opacity) var(--tw-backdrop-saturate)
			var(--tw-backdrop-sepia);
	}
	@media (hover: hover) {
		.hover\:border-red-400:hover {
			border-color: var(--color-red-400);
		}
		.hover\:bg-red-700:hover {
			background-color: var(--color-red-700);
		}
		.hover\:bg-slate-100:hover {
			background-color: var(--color-slate-100);
		}
		.hover\:bg-white\/20:hover {
			background-color: #fff3;
		}
		@supports (color: color-mix(in lab, red, red)) {
			.hover\:bg-white\/20:hover {
				background-color: color-mix(
					in oklab,
					var(--color-white) 20%,
					transparent
				);
			}
		}
		.hover\:text-red-700:hover {
			color: var(--color-red-700);
		}
		.hover\:underline:hover {
			text-decoration-line: underline;
		}
		.hover\:text-primary-700:hover {
			color: var(--brand-accent-600);
		}
		.hover\:border-primary-400:hover {
			border-color: color-mix(in srgb, var(--brand-primary-600) 50%, white);
		}
		.hover\:text-emergency-700:hover {
			color: var(--brand-accent-600);
		}
		.hover\:border-emergency-600:hover {
			border-color: var(--emergency-700);
		}
		.hover\:bg-emergency-700:hover {
			background-color: var(--emergency-700);
		}
		.hover\:bg-primary-700:hover {
			background-color: var(--brand-primary-700);
		}
	}
	.focus\:outline-none:focus {
		--tw-outline-style: none;
		outline-style: none;
	}
	.focus-visible\:ring-2:focus-visible {
		--tw-ring-shadow: var(--tw-ring-inset) 0 0 0
			calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
		box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow),
			var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
	}
	.focus-visible\:ring-white:focus-visible {
		--tw-ring-color: var(--color-white);
	}
	.focus-visible\:ring-offset-2:focus-visible {
		--tw-ring-offset-width: 2px;
		--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0
			var(--tw-ring-offset-width) var(--tw-ring-offset-color);
	}
	.focus\:border-primary-500:focus {
		border-color: var(--brand-primary-600);
	}
	.ring-primary-500,
	.focus\:ring-primary-500:focus {
		--tw-ring-color: var(--brand-primary-600);
	}
	@supports (
		(-webkit-backdrop-filter: var(--tw)) or (backdrop-filter: var(--tw))
	) {
		.supports-\[backdrop-filter\]\:bg-white\/60 {
			background-color: #fff9;
		}
		@supports (color: color-mix(in lab, red, red)) {
			.supports-\[backdrop-filter\]\:bg-white\/60 {
				background-color: color-mix(
					in oklab,
					var(--color-white) 60%,
					transparent
				);
			}
		}
	}
	@media (min-width: 48rem) {
		.md\:col-span-2 {
			grid-column: span 2 / span 2;
		}
		.md\:flex {
			display: flex;
		}
		.md\:grid-cols-2 {
			grid-template-columns: repeat(2, minmax(0, 1fr));
		}
		.md\:grid-cols-3 {
			grid-template-columns: repeat(3, minmax(0, 1fr));
		}
		.md\:text-3xl {
			font-size: var(--text-3xl);
			line-height: var(--tw-leading, var(--text-3xl--line-height));
		}
		.md\:text-5xl {
			font-size: var(--text-5xl);
			line-height: var(--tw-leading, var(--text-5xl--line-height));
		}
	}
}
:root {
	--bar-h: 44px;
	/* Primary brand: NAVY */
	--brand-primary-600: #0b2b4b;
	--brand-primary-700: #08223b;

	/* Accent: NAVY GREEN */
	--brand-accent-600: #0b5d4a;
	--brand-accent-50: #0b5d4a10;

	/* Emergency: RED */
	--emergency-600: #dc2626;
	--emergency-700: #b91c1c;
	--emergency-50: rgba(220, 38, 38, 0.08);
}
.emergency-bar {
	height: var(--bar-h);
}
/* Utility mappings */
.shadow-soft {
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06), 0 1px 1px rgba(0, 0, 0, 0.04);
}
.shadow-md {
	box-shadow: 0 1px 4px rgba(0 0 0 / 0.84), 0 1px 1px rgba(0, 0, 0, 0.04);
}
.justify-end {
	justify-content: end;
}
.justify-center {
	justify-content: center;
}
.justify-between {
	justify-content: space-between;
}
.items-center {
	align-items: center;
}
.items-end {
	align-items: end;
}
.self-center {
	align-self: center;
}
.inline-flex {
	display: inline-flex;
}
.flex-col {
	flex-direction: column;
}
.flex-row {
	flex-direction: row;
}
.sm\:flex-col {
	@media (width <= 40rem) {
		flex-direction: column;
	}
}
.sm\:justify-between {
	@media (width <= 40rem) {
		justify-content: space-between;
	}
}
.sm\:items-center {
	@media (width <= 40rem) {
		align-items: center;
	}
}
.sm\:gap-2 {
	@media (width <= 40rem) {
		gap: calc(var(--spacing) * 2);
	}
}
.sm\:gap-3 {
	@media (width <= 40rem) {
		gap: calc(var(--spacing) * 3);
	}
}
.sm\:flex {
	@media (width <= 40rem) {
		display: flex;
	}
}

.text-center {
	text-align: center;
}

/* Primary = brand navy */
.bg-primary-50 {
	background-color: color-mix(in srgb, var(--brand-primary-600) 6%, white);
}
.bg-primary-600 {
	background-color: var(--brand-primary-600);
}
.bg-primary-700 {
	background-color: var(--brand-primary-700);
}
.text-primary-700 {
	color: var(--brand-primary-700);
}

.top-safe {
	top: calc(var(--bar-h) + 15px + env(safe-area-inset-top));
}
.sm\:top-safe {
	@media (width <= 40rem) {
		top: calc(var(--bar-h) + 30px + env(safe-area-inset-top));
	}
}
.md\:hidden{ @media (width >= 48rem) {display: none;}}
.md\:flex{ @media (width >= 48rem) {display: flex;}}

/* Accent (optional helpers) */
.bg-accent-50 {
	background-color: var(--brand-accent-50);
}
.text-accent-600 {
	color: var(--brand-accent-600);
}
.border-accent-600 {
	border-color: var(--brand-accent-600);
}

/* Emergency-only helpers */
.bg-emergency-50 {
	background-color: var(--emergency-50);
}
.bg-emergency-600 {
	background-color: var(--emergency-600);
}
.bg-emergency-700 {
	background-color: var(--emergency-700);
}
.text-emergency-700 {
	color: var(--emergency-700);
}
@property --tw-space-y-reverse {
	syntax: "*";
	inherits: false;
	initial-value: 0;
}
@property --tw-border-style {
	syntax: "*";
	inherits: false;
	initial-value: solid;
}
@property --tw-gradient-position {
	syntax: "*";
	inherits: false;
}
@property --tw-gradient-from {
	syntax: "<color>";
	inherits: false;
	initial-value: #0000;
}
@property --tw-gradient-via {
	syntax: "<color>";
	inherits: false;
	initial-value: #0000;
}
@property --tw-gradient-to {
	syntax: "<color>";
	inherits: false;
	initial-value: #0000;
}
@property --tw-gradient-stops {
	syntax: "*";
	inherits: false;
}
@property --tw-gradient-via-stops {
	syntax: "*";
	inherits: false;
}
@property --tw-gradient-from-position {
	syntax: "<length-percentage>";
	inherits: false;
	initial-value: 0%;
}
@property --tw-gradient-via-position {
	syntax: "<length-percentage>";
	inherits: false;
	initial-value: 50%;
}
@property --tw-gradient-to-position {
	syntax: "<length-percentage>";
	inherits: false;
	initial-value: 100%;
}
@property --tw-leading {
	syntax: "*";
	inherits: false;
}
@property --tw-font-weight {
	syntax: "*";
	inherits: false;
}
@property --tw-tracking {
	syntax: "*";
	inherits: false;
}
@property --tw-shadow {
	syntax: "*";
	inherits: false;
	initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
	syntax: "*";
	inherits: false;
}
@property --tw-shadow-alpha {
	syntax: "<percentage>";
	inherits: false;
	initial-value: 100%;
}
@property --tw-inset-shadow {
	syntax: "*";
	inherits: false;
	initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
	syntax: "*";
	inherits: false;
}
@property --tw-inset-shadow-alpha {
	syntax: "<percentage>";
	inherits: false;
	initial-value: 100%;
}
@property --tw-ring-color {
	syntax: "*";
	inherits: false;
}
@property --tw-ring-shadow {
	syntax: "*";
	inherits: false;
	initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
	syntax: "*";
	inherits: false;
}
@property --tw-inset-ring-shadow {
	syntax: "*";
	inherits: false;
	initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
	syntax: "*";
	inherits: false;
}
@property --tw-ring-offset-width {
	syntax: "<length>";
	inherits: false;
	initial-value: 0;
}
@property --tw-ring-offset-color {
	syntax: "*";
	inherits: false;
	initial-value: #fff;
}
@property --tw-ring-offset-shadow {
	syntax: "*";
	inherits: false;
	initial-value: 0 0 #0000;
}
@property --tw-backdrop-blur {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-brightness {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-contrast {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-grayscale {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-hue-rotate {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-invert {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-opacity {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-saturate {
	syntax: "*";
	inherits: false;
}
@property --tw-backdrop-sepia {
	syntax: "*";
	inherits: false;
}
