:root {
	--u-color-primary: #1f63b5;
	--u-color-primary-hover: #174f91;
	--u-color-primary-strong: #0f3f7a;
	--u-color-primary-soft: #eaf2fb;
	--u-color-success: #26734d;
	--u-color-success-soft: #e8f5ee;
	--u-color-warning: #8a5700;
	--u-color-danger: #b42318;
	--u-color-danger-soft: #fff0ee;
	--u-color-text: #243142;
	--u-color-text-muted: #5f6f82;
	--u-color-border: #cbd5e1;
	--u-color-surface: #ffffff;
	--u-color-canvas: #f3f6f9;
	--u-progress-primary-start: #1f63b5;
	--u-progress-primary-end: #38a3a5;
	--u-progress-danger-start: #b42318;
	--u-progress-danger-end: #d95d4f;
	--u-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--u-font-size-sm: 0.875rem;
	--u-font-size-base: 1rem;
	--u-font-size-lg: 1.25rem;
	--u-font-size-xl: 1.75rem;
	--u-line-height: 1.5;
	--u-space-1: 0.25rem;
	--u-space-2: 0.5rem;
	--u-space-3: 0.75rem;
	--u-space-4: 1rem;
	--u-space-5: 1.5rem;
	--u-space-6: 2rem;
	--u-space-8: 3rem;
	--u-radius-sm: 0.375rem;
	--u-radius-md: 0.625rem;
	--u-radius-lg: 0.875rem;
	--u-shadow-card: 0 1rem 2.5rem rgba(36, 49, 66, 0.12);
	--u-content-auth: 30rem;
	--u-focus-ring: 0 0 0 3px rgba(31, 99, 181, 0.28);
	--u-transition-fast: 150ms ease;
}

.u-visually-hidden {
	border: 0 !important;
	clip: rect(0 0 0 0) !important;
	height: 1px !important;
	margin: -1px !important;
	overflow: hidden !important;
	padding: 0 !important;
	position: absolute !important;
	white-space: nowrap !important;
	width: 1px !important;
}

.u-auth-page,
.u-session-page {
	background: var(--u-color-canvas);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	min-height: 100%;
	text-align: left;
}

.u-auth-page *,
.u-auth-page *::before,
.u-auth-page *::after,
.u-session-page *,
.u-session-page *::before,
.u-session-page *::after {
	box-sizing: border-box;
}

.u-auth-page a,
.u-session-page a {
	color: var(--u-color-primary);
	text-decoration: underline;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.15em;
}

.u-auth-page a:hover,
.u-session-page a:hover {
	color: var(--u-color-primary-hover);
}

.u-auth-page a:focus-visible,
.u-auth-page button:focus-visible,
.u-auth-page input:focus-visible,
.u-session-page a:focus-visible {
	border-radius: var(--u-radius-sm);
	box-shadow: var(--u-focus-ring);
	outline: 2px solid transparent;
}

.u-auth-page #container,
.u-session-page #container {
	margin: 0 auto;
	max-width: 100%;
	min-height: 100vh;
	padding: var(--u-space-6) var(--u-space-4);
	width: 100%;
}

.u-auth-page #login_logo {
	margin: 0 auto var(--u-space-5);
	text-align: center;
}

.u-auth-page #login_logo img {
	height: auto;
	max-width: 10.3125rem;
	width: 100%;
}

.u-auth-page #login_container.u-auth-card,
.u-session-card {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	box-shadow: var(--u-shadow-card);
	margin: 0 auto;
	max-width: var(--u-content-auth);
	padding: var(--u-space-6);
	width: 100%;
}

.u-auth-page #login_container.u-auth-card h1,
.u-session-card h1 {
	border: 0;
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: 0 0 var(--u-space-2);
	padding: 0;
}

.u-auth-intro {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-base);
	margin: 0 0 var(--u-space-5);
}

.u-auth-actions {
	display: grid;
	gap: var(--u-space-3);
	margin-top: var(--u-space-5);
}

.u-auth-page .u-button,
.u-auth-page input.u-button {
	align-items: center;
	appearance: none;
	background: var(--u-color-primary);
	background-image: none;
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	font-weight: 700;
	justify-content: center;
	line-height: 1.25;
	min-height: 2.75rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-align: center;
	text-decoration: none;
	text-shadow: none;
	transition: background-color var(--u-transition-fast), border-color var(--u-transition-fast);
	width: 100%;
}

.u-auth-page .u-button:hover,
.u-auth-page input.u-button:hover {
	background: var(--u-color-primary-hover);
	background-image: none;
	border-color: var(--u-color-primary-hover);
	color: #ffffff;
	text-decoration: none;
}

.u-auth-form {
	display: block;
	margin-top: var(--u-space-5);
}

.u-auth-page .login_row {
	margin: 0 0 var(--u-space-4);
	text-align: left;
	width: 100%;
}

.u-auth-page .login_row label {
	display: block;
	font-size: var(--u-font-size-sm);
	font-weight: 700;
	margin-bottom: var(--u-space-2);
}

.u-auth-page .login_row input {
	background: var(--u-color-surface);
	background-image: none;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-3);
	width: 100%;
}

.u-auth-page .login_row input:focus {
	border-color: var(--u-color-primary);
	box-shadow: var(--u-focus-ring);
	outline: 2px solid transparent;
}

.u-auth-help {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: calc(var(--u-space-2) * -1) 0 var(--u-space-3);
}

.u-auth-secondary {
	font-size: var(--u-font-size-sm);
	margin: var(--u-space-4) 0 0;
	text-align: center;
}

.u-auth-page #student_instructions {
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm);
	margin: 0 0 var(--u-space-5);
	padding: var(--u-space-4);
	text-align: left;
}

.u-auth-page #student_instructions p {
	margin: var(--u-space-3) 0 0;
}

.u-auth-page .login_error_box,
.u-auth-page .error_box,
.u-auth-page .success_box {
	background-image: none;
	border-radius: var(--u-radius-md);
	font-size: var(--u-font-size-sm) !important;
	margin: 0 0 var(--u-space-4);
	padding: var(--u-space-3) var(--u-space-4);
	text-align: left !important;
	width: 100%;
}

.u-auth-page .login_error_box,
.u-auth-page .error_box {
	background-color: var(--u-color-danger-soft);
	border: 1px solid #f2b8b2;
	color: var(--u-color-danger);
}

.u-auth-page .success_box {
	background-color: var(--u-color-success-soft);
	border: 1px solid #acd4bd;
	color: var(--u-color-success);
}

.u-auth-page #login_footer {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	line-height: 1.65;
	margin: var(--u-space-5) auto 0;
	max-width: var(--u-content-auth);
	padding: 0 var(--u-space-2);
	text-align: center;
}

.u-security-note {
	align-items: center;
	display: flex;
	gap: var(--u-space-2);
	justify-content: center;
	margin-bottom: var(--u-space-2);
}

.u-security-note img {
	height: 1rem;
	width: 1rem;
}

.u-session-page #container {
	align-items: center;
	display: flex;
}

.u-session-card p {
	font-size: var(--u-font-size-base);
	margin: 0;
}

@media (max-width: 36rem) {
	.u-auth-page #container,
	.u-session-page #container {
		padding: var(--u-space-5) var(--u-space-3);
	}

	.u-auth-page #login_container.u-auth-card,
	.u-session-card {
		border-radius: var(--u-radius-md);
		padding: var(--u-space-5);
	}
}

@media (prefers-reduced-motion: reduce) {
	.u-auth-page *,
	.u-auth-page *::before,
	.u-auth-page *::after,
	.u-session-page *,
	.u-session-page *::before,
	.u-session-page *::after {
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
}

.u-app-page {
	background: var(--u-color-canvas);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-sm);
	line-height: var(--u-line-height);
	text-align: left;
}

.u-app-page *,
.u-app-page *::before,
.u-app-page *::after {
	box-sizing: border-box;
}

.u-app-page #top_wrapper {
	background: var(--u-color-surface);
	border-bottom: 1px solid var(--u-color-border);
	box-shadow: 0 1px 3px rgba(36, 49, 66, 0.08);
	height: 4.5rem;
}

.u-app-page #container.u-app-container {
	margin: 0 auto;
	max-width: 90rem;
	padding: 0 var(--u-space-5) 7rem;
	width: 100%;
}

.u-app-page #logo {
	padding-top: var(--u-space-3);
}

.u-app-page #logo img {
	height: auto;
	max-width: 10.3125rem;
}

.u-app-page #account_name {
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	margin: var(--u-space-5) 0 0;
	max-width: min(42vw, 32rem);
	overflow: hidden;
	text-overflow: ellipsis;
	text-shadow: none;
	white-space: nowrap;
}

.u-app-page #top_links.u-app-utilities {
	display: flex;
	float: right;
	gap: var(--u-space-2);
	margin: var(--u-space-3) 0 0 var(--u-space-4);
}

.u-app-page #top_links.u-app-utilities a {
	align-items: center;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--u-radius-md);
	color: var(--u-color-text-muted);
	display: inline-flex;
	float: none;
	gap: var(--u-space-2);
	height: auto;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	text-decoration: none;
	width: auto;
}

.u-app-page #top_links.u-app-utilities a:hover {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
	color: var(--u-color-primary-hover);
}

.u-app-page #top_links.u-app-utilities img {
	height: 1rem;
	width: 1rem;
}

.u-app-page #top_links.u-app-utilities .clearboth {
	display: none;
}

.u-app-page a:focus-visible,
.u-app-page button:focus-visible,
.u-app-page input:focus-visible,
.u-app-page select:focus-visible,
.u-app-page textarea:focus-visible,
.u-app-page [tabindex]:focus-visible {
	box-shadow: var(--u-focus-ring);
	outline: 2px solid transparent;
}

.u-app-page #fancybox-wrap,
.u-app-page #fancybox-outer,
.u-app-page #fancybox-content {
	box-sizing: border-box;
	max-width: calc(100vw - 1rem) !important;
}

.u-app-page #fancybox-content {
	overflow: auto !important;
}

.u-app-page #fancybox-content > div {
	max-width: 100%;
}

.u-app-page #fancybox-content #ajax_content {
	max-width: 100% !important;
	width: 100% !important;
}

.u-app-page .login_error_box,
.u-app-page .error_box,
.u-app-page .success_box {
	background-image: none;
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	font-size: var(--u-font-size-sm) !important;
	line-height: var(--u-line-height);
	margin: var(--u-space-3) 0;
	max-width: 100%;
	padding: var(--u-space-3) var(--u-space-4);
	text-align: left !important;
	width: auto;
}

.u-app-page .login_error_box,
.u-app-page .error_box {
	background: var(--u-color-danger-soft);
	border: 1px solid #f5b5ae;
	color: var(--u-color-danger);
}

.u-app-page .success_box {
	background: var(--u-color-success-soft);
	border: 1px solid #acd4bd;
	color: var(--u-color-success);
}

.u-app-page .large_submit {
	align-items: center;
	background: var(--u-color-primary);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-sm);
	font-weight: 700;
	justify-content: center;
	line-height: 1.2;
	margin: var(--u-space-2) 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page .large_submit:hover {
	background: var(--u-color-primary-hover);
	border-color: var(--u-color-primary-hover);
}

.u-app-page .app_button,
.u-app-page .app_function,
.u-app-page .red_button,
.u-app-page #toolbar .tb-1,
.u-app-page #monther {
	border-radius: var(--u-radius-md);
	box-shadow: none;
	font-family: var(--u-font-sans);
	text-shadow: none !important;
}

.u-app-page .app_button,
.u-app-page .app_function {
	align-items: center;
	background: #f8fafc;
	background-image: none !important;
	border: 1px solid var(--u-color-border);
	color: var(--u-color-text) !important;
	display: inline-flex;
	justify-content: center;
	min-height: 2.75rem;
	white-space: normal;
}

.u-app-page .green_buttons .tb-1,
.u-app-page .green_buttons .app_button {
	background: var(--u-color-primary) !important;
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%) !important;
	border-color: var(--u-color-primary) !important;
	color: #fff !important;
	text-shadow: none !important;
}

.u-app-page .green_buttons .tb-1:hover,
.u-app-page .green_buttons .app_button:hover,
.u-app-page .green_buttons .tb-1:focus-visible,
.u-app-page .green_buttons .app_button:focus-visible {
	background: var(--u-color-primary-hover) !important;
	border-color: var(--u-color-primary-hover) !important;
	color: #fff !important;
}

.u-app-page .red_button {
	align-items: center;
	background: var(--u-color-danger) !important;
	background-image: none !important;
	border: 1px solid var(--u-color-danger);
	color: #fff;
	display: inline-flex;
	justify-content: center;
	min-height: 2.75rem;
}

.u-app-page .red_button:hover,
.u-app-page .red_button:focus-visible {
	background: #8f1d14 !important;
	border-color: #8f1d14;
	color: #fff;
}

.u-app-page #fancybox-content .app_function,
.u-app-page #ajax_content .top_save .app_function,
.u-app-page #ajax_content .form_button_group .app_function {
	background: var(--u-color-primary) !important;
	background-image: none !important;
	border: 1px solid var(--u-color-primary) !important;
	color: #fff !important;
}

.u-app-page #fancybox-content .app_function:hover,
.u-app-page #fancybox-content .app_function:focus-visible,
.u-app-page #ajax_content .top_save .app_function:hover,
.u-app-page #ajax_content .top_save .app_function:focus-visible,
.u-app-page #ajax_content .form_button_group .app_function:hover,
.u-app-page #ajax_content .form_button_group .app_function:focus-visible {
	background: var(--u-color-primary-hover) !important;
	border-color: var(--u-color-primary-hover) !important;
}

.u-app-page .positive,
.u-student-page .positive,
.u-app-page span.positive {
	color: #1b6b52 !important;
}

.u-app-page .negative,
.u-student-page .negative,
.u-app-page span.negative {
	color: var(--u-color-danger) !important;
}

.u-app-page .greenbar,
.u-app-page .redbar,
.u-student-page .greenbar,
.u-student-page .redbar {
	background: #edf2f7;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	min-height: 0.75rem;
	overflow: hidden;
}

.u-app-page .bar_container,
.u-student-page .bar_container,
.u-app-page .usage_wrapper,
.u-student-page .usage_wrapper {
	background: #edf2f7;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	overflow: hidden;
}

.u-app-page .bar_container div,
.u-student-page .bar_container div,
.u-app-page .usage_wrapper div,
.u-student-page .usage_wrapper div {
	min-height: 0.75rem;
	padding: 0;
}

.u-app-page .greenbar div,
.u-student-page .greenbar div {
	background: var(--u-progress-primary-start) !important;
	background-image: linear-gradient(90deg, var(--u-progress-primary-start), var(--u-progress-primary-end)) !important;
}

.u-app-page .redbar div,
.u-student-page .redbar div {
	background: var(--u-progress-danger-start) !important;
	background-image: linear-gradient(90deg, var(--u-progress-danger-start), var(--u-progress-danger-end)) !important;
}

.u-app-layout {
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: 13rem minmax(0, 1fr);
	margin-top: var(--u-space-5);
}

.u-app-page #app_nav_container {
	align-self: start;
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	box-shadow: 0 0.5rem 1.5rem rgba(36, 49, 66, 0.08);
	float: none;
	margin: 0;
	padding: var(--u-space-2);
	width: auto;
}

.u-app-page #app_nav_container a.mn {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--u-radius-md);
	clear: none;
	color: var(--u-color-text);
	display: flex;
	font-size: var(--u-font-size-sm);
	gap: var(--u-space-3);
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	text-decoration: none;
	text-shadow: none;
	width: auto;
}

.u-app-page #app_nav_container a.mn + a.mn,
.u-app-page #app_nav_container #sub_nav + a.mn {
	margin-top: var(--u-space-1);
}

.u-app-page #app_nav_container a.mn:hover {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
	box-shadow: none;
	color: var(--u-color-primary-hover) !important;
}

.u-app-page #app_nav_container #app_nav_selected.mn {
	background: var(--u-color-primary);
	background-image: none;
	border-color: var(--u-color-primary);
	box-shadow: none;
	color: #ffffff !important;
	text-shadow: none;
}

.u-app-page #app_nav_container #app_nav_selected.mn:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page #app_nav_container a img {
	margin: 0;
}

.u-app-page #sub_nav {
	display: grid;
	gap: var(--u-space-1);
	margin: var(--u-space-1) 0 var(--u-space-2) var(--u-space-6);
}

.u-app-page #sub_nav a.sn {
	background: transparent;
	background-image: none;
	border: 0;
	border-left: 2px solid var(--u-color-border);
	border-radius: 0;
	color: var(--u-color-text-muted);
	float: none;
	font-size: var(--u-font-size-sm);
	margin: 0;
	padding: var(--u-space-2) var(--u-space-3);
	text-shadow: none;
	width: auto;
}

.u-app-page #sub_nav a.sn:hover,
.u-app-page #sub_nav a.sub_select {
	background: var(--u-color-primary-soft);
	background-image: none;
	border-color: var(--u-color-primary);
	color: var(--u-color-primary-hover);
	text-shadow: none;
}

.u-app-page #app_right_container {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	box-shadow: 0 0.5rem 1.5rem rgba(36, 49, 66, 0.06);
	float: none;
	margin: 0;
	min-width: 0;
	overflow: hidden;
	width: auto;
}

.u-app-page .app_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-page-heading {
	align-items: center;
	display: flex;
	gap: var(--u-space-4);
	justify-content: space-between;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-page-heading .app_category_header {
	flex: 1 1 auto;
	margin: 0;
	min-width: 0;
}

.u-app-page .u-page-heading .button_group,
.u-app-page .u-section-heading .button_group {
	float: none;
	margin: 0 !important;
	padding: 0 !important;
}

.u-app-page .u-section-heading {
	align-items: flex-start;
	display: flex;
	gap: var(--u-space-4);
	justify-content: space-between;
	margin-bottom: var(--u-space-3);
}

.u-app-page .u-section-heading > div:first-child {
	min-width: 0;
}

.u-app-page #toolbar {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	height: auto;
	margin: var(--u-space-5);
	min-height: 2.75rem;
}

.u-app-page #toolbar .tb-1,
.u-app-page #monther {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	line-height: 1.25;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page #toolbar input#query {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	flex: 1 1 12rem;
	font-size: var(--u-font-size-base);
	height: 2.75rem;
	margin: 0;
	min-width: 8rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page #toolbar .search {
	background: var(--u-color-primary);
	background-image: none;
	border: 1px solid var(--u-color-primary);
	color: #ffffff !important;
	text-decoration: none;
	text-shadow: none !important;
}

.u-app-page #toolbar .right_container {
	bottom: auto;
	display: flex;
	gap: var(--u-space-1);
	margin-left: auto;
	position: static;
	right: auto;
}

.u-app-page #toolbar .green_buttons .tb-1 {
	border-radius: var(--u-radius-md);
}

.u-app-page #toolbar .single,
.u-app-page #toolbar .left,
.u-app-page #toolbar .right {
	border-color: var(--u-color-border);
}

.u-app-page #toolbar .left,
.u-app-page .student_transaction .left {
	border-right-color: var(--u-color-border) !important;
}

.u-app-page #toolbar .right,
.u-app-page .student_transaction .right {
	border-left-color: var(--u-color-border) !important;
}

.u-app-page #toolbar .sort,
.u-app-page #toolbar .month {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	top: calc(100% + var(--u-space-1));
	z-index: 20;
}

.u-app-page #toolbar [role="option"]:focus {
	background: var(--u-color-primary-soft);
	outline: 0;
}

.u-app-page .u-list-loading {
	align-items: center;
	color: var(--u-color-text-muted);
	display: flex;
	justify-content: center;
	min-height: 12rem;
	padding: var(--u-space-6);
}

.u-app-page .u-list-pagination {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0 var(--u-space-5);
}

.u-app-page #student_list {
	margin: var(--u-space-3) var(--u-space-5) var(--u-space-5);
}

.u-app-page #student_list a {
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-1) var(--u-space-5);
	grid-template-areas:
		"name login student grade"
		"groups groups last last";
	grid-template-columns: minmax(12rem, 1fr) auto auto auto;
	margin-bottom: var(--u-space-1);
	min-height: 4.5rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-decoration: none;
}

.u-app-page #student_list a.odd {
	background: #f8fafc;
}

.u-app-page #student_list a:hover,
.u-app-page #student_list a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page #student_list .u-student-name {
	color: var(--u-color-primary);
	font-size: var(--u-font-size-base);
	grid-area: name;
	overflow-wrap: anywhere;
}

.u-app-page #student_list .u-student-login {
	grid-area: login;
}

.u-app-page #student_list .u-student-id {
	grid-area: student;
}

.u-app-page #student_list .u-student-grade {
	grid-area: grade;
}

.u-app-page #student_list .u-student-groups {
	grid-area: groups;
	overflow-wrap: anywhere;
}

.u-app-page #student_list .u-student-last-login {
	grid-area: last;
}

.u-app-page #student_list .right,
.u-app-page #student_list .bottom_right {
	clear: none;
	float: none;
	margin: 0;
	min-width: 0;
	overflow: visible;
	text-align: right;
	white-space: nowrap;
}

.u-app-page .ajax_nothing_there {
	background: #f8fafc;
	border: 1px dashed var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text-muted);
	margin: var(--u-space-6) var(--u-space-5);
	padding: var(--u-space-6);
}

.u-app-page #group_list {
	margin: var(--u-space-3) var(--u-space-5) var(--u-space-5);
}

.u-app-page #group_list a {
	align-items: center;
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: var(--u-space-1);
	min-height: 4.5rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-decoration: none;
}

.u-app-page #group_list a.odd {
	background: #f8fafc;
}

.u-app-page #group_list a:hover,
.u-app-page #group_list a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page #group_list .u-group-name {
	color: var(--u-color-primary);
	font-size: var(--u-font-size-base);
	grid-column: 1;
	grid-row: 1;
	overflow-wrap: anywhere;
}

.u-app-page #group_list .u-group-members {
	float: none;
	grid-column: 2;
	grid-row: 1;
	margin: 0;
	min-width: 0;
	text-align: right;
	white-space: nowrap;
}

.u-app-page #footer {
	background: var(--u-color-surface);
	border-top: 1px solid var(--u-color-border);
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
}

@media (max-width: 64rem) {
	.u-app-page #container.u-app-container {
		padding-left: var(--u-space-4);
		padding-right: var(--u-space-4);
	}

	.u-app-layout {
		grid-template-columns: 10rem minmax(0, 1fr);
	}

	.u-app-page #top_links.u-app-utilities a span {
		position: absolute;
		height: 1px;
		width: 1px;
		overflow: hidden;
		clip: rect(1px, 1px, 1px, 1px);
		white-space: nowrap;
	}
}

@media (max-width: 48rem) {
	.u-app-page #top_wrapper {
		height: 7.5rem;
	}

	.u-app-page #container.u-app-container {
		padding-left: var(--u-space-3);
		padding-right: var(--u-space-3);
	}

	.u-app-page #logo {
		float: none;
		padding-top: var(--u-space-3);
	}

	.u-app-page #account_name {
		float: none;
		margin: var(--u-space-2) 0 0;
		max-width: 100%;
	}

	.u-app-page #top_links.u-app-utilities {
		margin-top: var(--u-space-2);
	}

	.u-app-layout {
		display: block;
		margin-top: var(--u-space-4);
	}

	.u-app-page #app_nav_container {
		display: flex;
		gap: var(--u-space-1);
		margin-bottom: var(--u-space-4);
		overflow-x: auto;
		padding: var(--u-space-2);
		scrollbar-width: thin;
	}

	.u-app-page #app_nav_container a.mn {
		flex: 0 0 auto;
	}

	.u-app-page #sub_nav {
		display: flex;
		flex: 0 0 auto;
		margin: 0;
	}

	.u-app-page #sub_nav a.sn {
		border: 0;
		border-radius: var(--u-radius-sm);
		white-space: nowrap;
	}

	.u-app-page .app_category_header {
		font-size: 1.5rem;
		margin: var(--u-space-4);
	}

	.u-app-page .u-page-heading,
	.u-app-page .u-section-heading {
		align-items: stretch;
		flex-direction: column;
		gap: var(--u-space-3);
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-page-heading .app_category_header {
		margin: 0;
	}

	.u-app-page .u-page-heading .button_group,
	.u-app-page .u-section-heading .button_group {
		justify-content: stretch;
		width: 100%;
	}

	.u-app-page .u-page-heading .app_button,
	.u-app-page .u-section-heading .app_button {
		flex: 1 1 auto;
		width: 100%;
	}

	.u-app-page #toolbar {
		margin: var(--u-space-4);
	}

	.u-app-page #toolbar .right_container {
		flex: 1 0 100%;
		margin-left: 0;
		order: 2;
	}

	.u-app-page #toolbar .right_container .tb-1 {
		flex: 1 1 auto;
	}

	.u-app-page .u-list-pagination,
	.u-app-page #student_list,
	.u-app-page #group_list {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #student_list a {
		gap: var(--u-space-2);
		grid-template-areas:
			"name name"
			"groups groups"
			"login grade"
			"student last";
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		padding: var(--u-space-4);
	}

	.u-app-page #student_list .right,
	.u-app-page #student_list .bottom_right {
		text-align: left;
		white-space: normal;
	}

	.u-app-page #group_list a {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-app-page #group_list .u-group-members {
		grid-column: 1;
		grid-row: 2;
		text-align: left;
	}
}

.u-app-page .u-dashboard-grid {
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: minmax(0, 2fr) minmax(16rem, 1fr);
	padding: 0 var(--u-space-5) var(--u-space-5);
}

.u-app-page .u-dashboard-grid .dashboard_container {
	float: none;
	margin: 0;
	min-width: 0;
	width: auto;
}

.u-app-page .u-dashboard-grid .db_left,
.u-app-page .u-dashboard-grid .db_right {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-4);
}

.u-app-page #dashboard_nav {
	background: transparent;
	border: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	height: auto;
	margin: 0 0 var(--u-space-4);
	padding: 0;
}

.u-app-page #dashboard_nav .app_button {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page #dashboard_nav .selected {
	background: var(--u-color-primary);
	background-image: none;
	border-color: var(--u-color-primary) !important;
	color: #ffffff !important;
}

.u-app-page .u-dashboard-grid #content {
	min-height: 20rem;
}

.u-app-page .u-dashboard-grid .dashboard_container h2,
.u-app-page .u-dashboard-grid .dashboard_container h3,
.u-app-page .u-dashboard-grid .dashboard_container h4 {
	color: var(--u-color-text);
	text-shadow: none;
}

.u-app-page .u-dashboard-grid .dashboard_container h3 {
	border-bottom: 1px solid var(--u-color-border);
	font-size: var(--u-font-size-lg);
	margin-top: var(--u-space-4);
}

.u-app-page .u-dashboard-grid .d_event,
.u-app-page .u-dashboard-grid .d_date,
.u-app-page .u-dashboard-grid .d_type,
.u-app-page .u-dashboard-grid .none {
	overflow-wrap: anywhere;
}

.u-app-page .u-dashboard-grid .chart_container {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-3) 0 var(--u-space-5);
	max-width: 100%;
	overflow: hidden;
	padding: var(--u-space-3);
}

.u-app-page .u-dashboard-chart {
	min-height: 16.25rem;
	width: 100%;
}

.u-app-page .u-dashboard-meter {
	align-items: center;
	display: grid;
	gap: var(--u-space-2);
	grid-template-columns: minmax(0, 1fr) auto;
	margin: var(--u-space-2) 0 var(--u-space-5) !important;
	text-align: right;
}

.u-app-page .u-dashboard-meter .usage_wrapper {
	float: none !important;
	margin: 0;
	width: 100% !important;
}

@media (max-width: 64rem) {
	.u-app-page .u-dashboard-grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 48rem) {
	.u-app-page .u-dashboard-grid {
		gap: var(--u-space-4);
		padding: 0 var(--u-space-4) var(--u-space-4);
	}

	.u-app-page #dashboard_nav .app_button {
		flex: 1 1 auto;
	}
}

.u-app-page .u-inventory-actions {
	display: flex;
	float: none;
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-inventory-actions #add_category {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page #plaques.u-inventory-grid {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
	margin: var(--u-space-5);
}

.u-app-page #plaques.u-inventory-grid .inv_plaque {
	align-items: center;
	background: #f8fafc;
	background-image: none;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	display: grid;
	float: none;
	gap: var(--u-space-2) var(--u-space-4);
	grid-template-areas:
		"icon count"
		"name name";
	grid-template-columns: auto minmax(0, 1fr);
	height: auto;
	margin: 0;
	min-height: 8rem;
	padding: var(--u-space-4);
	text-decoration: none;
	width: auto;
}

.u-app-page #plaques.u-inventory-grid .inv_plaque:hover {
	background: var(--u-color-primary-soft);
	background-image: none;
	border-color: #9ebfe3;
	color: var(--u-color-primary-hover);
}

.u-app-page #plaques.u-inventory-grid .inv_plaque:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page #plaques.u-inventory-grid .inv_plaque img {
	border-radius: var(--u-radius-sm);
	box-shadow: none;
	float: none;
	grid-area: icon;
	height: 3.5rem;
	margin: 0;
	width: 3.5rem;
}

.u-app-page #plaques.u-inventory-grid .u-inventory-count {
	color: var(--u-color-text);
	font-size: 2rem;
	font-weight: 700;
	grid-area: count;
	letter-spacing: -0.03em;
	line-height: 1;
	margin: 0;
	min-width: 0;
	overflow-wrap: anywhere;
}

.u-app-page #plaques.u-inventory-grid .u-inventory-count-label {
	color: var(--u-color-text-muted);
	cursor: inherit;
	display: inline;
	font-size: var(--u-font-size-sm);
	font-weight: 600;
	letter-spacing: 0;
	margin: 0;
	overflow: visible;
	text-align: inherit;
	white-space: normal;
}

.u-app-page #plaques.u-inventory-grid .u-inventory-name {
	color: inherit;
	cursor: move;
	font-size: var(--u-font-size-base);
	font-weight: 700;
	grid-area: name;
	line-height: 1.3;
	margin: 0;
	overflow: visible;
	overflow-wrap: anywhere;
	text-align: left;
	white-space: normal;
}

.u-app-page #plaques.u-inventory-grid .clearboth {
	display: none;
}

.u-app-page #plaques.u-inventory-grid .u-inventory-empty {
	background: #f8fafc;
	border: 1px dashed var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text-muted);
	grid-column: 1 / -1;
	margin: 0;
	padding: var(--u-space-6);
	text-align: center;
}

@media (max-width: 48rem) {
	.u-app-page .u-inventory-actions,
	.u-app-page #plaques.u-inventory-grid {
		margin: var(--u-space-4);
	}

	.u-app-page .u-inventory-actions #add_category {
		width: 100%;
	}
}

.u-app-page #inventory_list {
	margin: var(--u-space-3) var(--u-space-5) var(--u-space-5);
}

.u-app-page #inventory_list > a {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-shadow: 0 1px 2px rgba(36, 49, 66, 0.04);
	display: grid;
	gap: var(--u-space-2) var(--u-space-4);
	grid-template-columns: minmax(0, 1fr) minmax(9rem, auto);
	margin-bottom: var(--u-space-2);
	min-height: 4.5rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-decoration: none;
}

.u-app-page #inventory_list > a.odd {
	background: #f8fafc;
}

.u-app-page #inventory_list > a:hover,
.u-app-page #inventory_list > a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page #inventory_list .u-inventory-item-name {
	color: var(--u-color-primary);
	font-size: var(--u-font-size-base);
	grid-column: 1;
	grid-row: 1;
	overflow-wrap: anywhere;
}

.u-app-page #inventory_list .u-inventory-assignment {
	float: none;
	grid-column: 2;
	grid-row: 1;
	margin: 0;
	min-width: 0;
	overflow: visible;
	overflow-wrap: anywhere;
	text-align: right;
	white-space: normal;
}

.u-app-page #inventory_list .u-inventory-assignment img {
	margin-left: var(--u-space-1);
}

.u-app-page #inventory_list .u-inventory-field {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-sm);
	float: none;
	margin: 0;
	max-width: 22rem;
	min-width: 0;
	overflow-wrap: anywhere;
	padding: var(--u-space-2);
}

.u-app-page #inventory_list .clearboth {
	display: none;
}

.u-app-page #inventory_list .ajax_nothing_there {
	margin-left: 0;
	margin-right: 0;
}

@media (max-width: 48rem) {
	.u-app-page #inventory_list {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #inventory_list > a {
		grid-template-columns: minmax(0, 1fr);
		padding: var(--u-space-4);
	}

	.u-app-page #inventory_list .u-inventory-item-name,
	.u-app-page #inventory_list .u-inventory-assignment {
		grid-column: 1;
		text-align: left;
	}

	.u-app-page #inventory_list .u-inventory-assignment {
		grid-row: 2;
	}
}

.u-app-page #ajax_content.u-inventory-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(48rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-inventory-dialog *,
.u-app-page #ajax_content.u-inventory-dialog *::before,
.u-app-page #ajax_content.u-inventory-dialog *::after {
	box-sizing: border-box;
}

.u-app-page #ajax_content.u-inventory-dialog #ajax_no_tabs {
	font-size: var(--u-font-size-sm);
	padding-bottom: var(--u-space-2);
}

.u-app-page #ajax_content.u-inventory-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-panel,
.u-app-page #ajax_content.u-inventory-dialog .ajax_instructions,
.u-app-page #ajax_content.u-inventory-dialog #ajax_green_container {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-inventory-dialog .inv_item {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	height: auto;
	overflow: visible;
}

.u-app-page #ajax_content.u-inventory-dialog .inv_item .Left,
.u-app-page #ajax_content.u-inventory-dialog .inv_item .Right,
.u-app-page #ajax_content.u-inventory-dialog .inv_item .left,
.u-app-page #ajax_content.u-inventory-dialog .inv_item .right {
	float: none;
	min-width: 0;
	overflow: visible !important;
	width: auto !important;
}

.u-app-page #ajax_content.u-inventory-dialog .inv_item table,
.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-fields table {
	max-width: none !important;
	width: 100%;
}

.u-app-page #ajax_content.u-inventory-dialog .inv_item td {
	height: auto;
	overflow-wrap: anywhere;
	padding: var(--u-space-2);
}

.u-app-page #ajax_content.u-inventory-dialog input[type="text"],
.u-app-page #ajax_content.u-inventory-dialog input[type="file"],
.u-app-page #ajax_content.u-inventory-dialog select,
.u-app-page #ajax_content.u-inventory-dialog textarea {
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: 100% !important;
}

.u-app-page #ajax_content.u-inventory-dialog textarea {
	min-height: 6rem;
	resize: vertical;
}

.u-app-page #ajax_content.u-inventory-dialog .form_button_group {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-inventory-dialog .inv_item .form_button_group {
	grid-column: 1 / -1;
	margin: 0;
}

.u-app-page #ajax_content.u-inventory-dialog #checkout_button,
.u-app-page #ajax_content.u-inventory-dialog input.large_submit {
	min-height: 2.75rem;
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-history {
	display: block;
	overflow-x: auto;
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-history h3 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: 0 0 var(--u-space-3);
}

.u-app-page #ajax_content.u-inventory-dialog #checkout_history {
	min-width: 36rem;
}

.u-app-page #ajax_content.u-inventory-dialog .del_checkout_history:focus-visible {
	border-radius: var(--u-radius-sm);
	box-shadow: var(--u-focus-ring);
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-name {
	align-items: center;
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: auto minmax(0, 1fr);
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-name input {
	margin: 0 !important;
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-fields {
	overflow-x: auto;
}

.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-fields table {
	min-width: 42rem;
}

.u-app-page #ajax_content.u-inventory-dialog .ajax_instructions {
	color: var(--u-color-text);
	line-height: var(--u-line-height);
}

.u-app-page #ajax_content.u-inventory-dialog .download_package,
.u-app-page #ajax_content.u-inventory-dialog .upload_package {
	float: none;
	margin: var(--u-space-4) var(--u-space-5);
	max-width: none;
	width: auto;
}

.u-app-page #ajax_content.u-inventory-dialog #ajax_green_container {
	overflow: auto;
}

.u-app-page #ajax_content.u-inventory-dialog #import_review {
	min-width: 48rem;
}

.u-app-page #ajax_content.u-inventory-dialog .clearboth {
	display: none;
}

@media (max-width: 48rem) {
	.u-app-page #ajax_content.u-inventory-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-inventory-dialog .ajax_category_header {
		font-size: 1.5rem;
		margin: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-inventory-dialog .u-inventory-panel,
	.u-app-page #ajax_content.u-inventory-dialog .ajax_instructions,
	.u-app-page #ajax_content.u-inventory-dialog #ajax_green_container,
	.u-app-page #ajax_content.u-inventory-dialog .download_package,
	.u-app-page #ajax_content.u-inventory-dialog .upload_package,
	.u-app-page #ajax_content.u-inventory-dialog .form_button_group {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-inventory-dialog .inv_item {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-app-page #ajax_content.u-inventory-dialog .u-inventory-category-name {
		align-items: stretch;
		grid-template-columns: minmax(0, 1fr);
	}
}

.u-app-page .u-finance-section {
	margin: 0 var(--u-space-5) var(--u-space-6);
}

.u-app-page .u-finance-section h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: 0;
	padding-top: var(--u-space-2);
}

.u-app-page .u-finance-section .small_description {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: var(--u-space-1) 0 var(--u-space-3);
}

.u-app-page .u-finance-actions {
	display: flex;
	float: none;
	justify-content: flex-end;
	margin: 0 0 var(--u-space-3);
	padding: 0 !important;
}

.u-app-page .u-finance-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page .u-finance-table-region {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	max-width: 100%;
	overflow-x: auto;
}

.u-app-page .u-finance-table-region:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page .u-finance-table {
	margin: 0 !important;
	min-width: 46rem;
	padding: 0 !important;
	width: 100%;
}

.u-app-page .u-finance-table th,
.u-app-page .u-finance-table td {
	height: auto;
	font-size: var(--u-font-size-base);
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page .u-finance-table th {
	background: #edf2f7;
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm);
	text-shadow: none;
}

.u-app-page .u-finance-table td:first-child {
	overflow-wrap: anywhere;
}

.u-app-page .u-finance-table .delete a,
.u-app-page .u-finance-table .edit a {
	align-items: center;
	border-radius: var(--u-radius-sm);
	display: inline-flex;
	justify-content: center;
	min-height: 2.75rem;
	min-width: 2.75rem;
}

.u-app-page .u-finance-table .bar_container {
	max-width: 100%;
}

.u-app-page .u-finance-empty {
	color: var(--u-color-text-muted);
	padding: var(--u-space-6) !important;
	text-align: center;
}

@media (max-width: 48rem) {
	.u-app-page .u-finance-section {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-finance-actions .app_button {
		width: 100%;
	}
}

.u-app-page .u-finance-transactions {
	margin: var(--u-space-3) var(--u-space-5) var(--u-space-5);
}

.u-app-page .u-finance-transactions > a,
.u-app-page .u-finance-transactions .u-finance-summary {
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-1) var(--u-space-4);
	grid-template-areas:
		"name amount"
		"meta date";
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: var(--u-space-1);
	min-height: 4.5rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-decoration: none;
}

.u-app-page .u-finance-transactions > a.odd,
.u-app-page .u-finance-transactions .u-finance-summary {
	background: #f8fafc;
}

.u-app-page .u-finance-transactions > a:hover,
.u-app-page .u-finance-transactions > a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page .u-finance-transactions .u-finance-transaction-name {
	color: var(--u-color-primary);
	font-size: var(--u-font-size-base);
	grid-area: name;
	overflow-wrap: anywhere;
}

.u-app-page .u-finance-transactions .u-finance-summary .u-finance-transaction-name {
	color: var(--u-color-text);
}

.u-app-page .u-finance-transactions .u-finance-amount {
	float: none;
	font-size: var(--u-font-size-lg) !important;
	grid-area: amount;
	margin: 0;
	min-width: 0;
	overflow: visible;
	text-align: right;
	white-space: nowrap;
}

.u-app-page .u-finance-transactions .u-finance-transaction-date {
	clear: none;
	float: none;
	grid-area: date;
	margin: 0;
	min-width: 0;
	overflow: visible;
	text-align: right;
	white-space: nowrap;
}

.u-app-page .u-finance-transactions .u-finance-transaction-meta {
	grid-area: meta;
	overflow-wrap: anywhere;
}

.u-app-page .u-finance-transactions .ajax_nothing_there {
	margin-left: 0;
	margin-right: 0;
}

.u-app-page #ajax_content.u-finance-transaction-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(40rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-finance-transaction-dialog *,
.u-app-page #ajax_content.u-finance-transaction-dialog *::before,
.u-app-page #ajax_content.u-finance-transaction-dialog *::after {
	box-sizing: border-box;
}

.u-app-page #ajax_content.u-finance-transaction-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form,
.u-app-page #ajax_content.u-finance-transaction-dialog .ajax_instructions {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form table {
	width: 100%;
}

.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form td {
	height: auto;
	padding: var(--u-space-2);
}

.u-app-page #ajax_content.u-finance-transaction-dialog input[type="text"],
.u-app-page #ajax_content.u-finance-transaction-dialog select {
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: 100% !important;
}

.u-app-page #ajax_content.u-finance-transaction-dialog .ajax_instructions {
	color: var(--u-color-text);
	line-height: var(--u-line-height);
}

.u-app-page #ajax_content.u-finance-transaction-dialog .form_button_group {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-finance-transaction-dialog #ajax_center_few {
	margin: var(--u-space-4) var(--u-space-5);
	width: auto;
}

.u-app-page #ajax_content.u-finance-transaction-dialog #ajax_center_few .app_button {
	background: #f8fafc;
	background-image: none;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	display: block;
	line-height: var(--u-line-height);
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-3);
	text-shadow: none;
}

.u-app-page #ajax_content.u-finance-transaction-dialog #ajax_center_few .app_button:hover,
.u-app-page #ajax_content.u-finance-transaction-dialog #ajax_center_few .app_button:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page #ajax_content.u-finance-transaction-dialog input[type="radio"] {
	margin-right: var(--u-space-2) !important;
}

@media (max-width: 48rem) {
	.u-app-page .u-finance-transactions {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-finance-transactions > a,
	.u-app-page .u-finance-transactions .u-finance-summary {
		grid-template-areas:
			"name"
			"amount"
			"meta"
			"date";
		grid-template-columns: minmax(0, 1fr);
		padding: var(--u-space-4);
	}

	.u-app-page .u-finance-transactions .u-finance-amount,
	.u-app-page .u-finance-transactions .u-finance-transaction-date {
		text-align: left;
	}

	.u-app-page #ajax_content.u-finance-transaction-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-finance-transaction-dialog .ajax_category_header {
		font-size: 1.5rem;
		margin: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form,
	.u-app-page #ajax_content.u-finance-transaction-dialog .ajax_instructions,
	.u-app-page #ajax_content.u-finance-transaction-dialog .form_button_group,
	.u-app-page #ajax_content.u-finance-transaction-dialog #ajax_center_few {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form table,
	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form tbody,
	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form tr,
	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form td {
		display: block;
		width: 100%;
	}

	.u-app-page #ajax_content.u-finance-transaction-dialog .u-finance-transaction-form td:empty {
		display: none;
	}
}

.u-app-page .u-finance-personal-actions {
	display: flex;
	float: none;
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-finance-personal-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page .u-finance-personal-note {
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm) !important;
	line-height: var(--u-line-height);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page .u-finance-personal-list {
	margin: var(--u-space-3) var(--u-space-5) var(--u-space-5);
}

.u-app-page .u-finance-personal-list > a {
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-2) var(--u-space-4);
	grid-template-areas: "name owed credit";
	grid-template-columns: minmax(0, 1fr) auto auto;
	margin-bottom: var(--u-space-1);
	min-height: 4.5rem;
	padding: var(--u-space-3) var(--u-space-4);
	text-decoration: none;
}

.u-app-page .u-finance-personal-list > a.odd {
	background: #f8fafc;
}

.u-app-page .u-finance-personal-list > a:hover,
.u-app-page .u-finance-personal-list > a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page .u-finance-personal-list .u-finance-personal-name {
	color: var(--u-color-primary);
	font-size: var(--u-font-size-base);
	grid-area: name;
	overflow-wrap: anywhere;
}

.u-app-page .u-finance-personal-list .u-finance-personal-owed,
.u-app-page .u-finance-personal-list .u-finance-personal-credit {
	float: none;
	margin: 0;
	min-width: 0;
	overflow: visible;
	text-align: right;
	white-space: nowrap;
}

.u-app-page .u-finance-personal-list .u-finance-personal-owed {
	grid-area: owed;
}

.u-app-page .u-finance-personal-list .u-finance-personal-credit {
	grid-area: credit;
}

.u-app-page .u-finance-personal-list .ajax_nothing_there {
	margin-left: 0;
	margin-right: 0;
}

@media (max-width: 48rem) {
	.u-app-page .u-finance-personal-actions,
	.u-app-page .u-finance-personal-note,
	.u-app-page .u-finance-personal-list {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-finance-personal-actions .app_button {
		width: 100%;
	}

	.u-app-page .u-finance-personal-list > a {
		grid-template-areas:
			"name name"
			"owed credit";
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		padding: var(--u-space-4);
	}

	.u-app-page .u-finance-personal-list .u-finance-personal-owed,
	.u-app-page .u-finance-personal-list .u-finance-personal-credit {
		text-align: left;
		white-space: normal;
	}
}

.u-app-page .u-reports-section {
	margin: 0 var(--u-space-5) var(--u-space-6);
}

.u-app-page .u-reports-section h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: 0 0 var(--u-space-3);
}

.u-app-page .u-reports-grid {
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}

.u-app-page .u-reports-grid .reports_container {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	float: none;
	margin: 0;
	min-width: 0;
	padding: var(--u-space-4);
	width: auto;
}

.u-app-page .u-reports-grid .reports_container a {
	display: inline-block;
	font-size: var(--u-font-size-base);
	margin-bottom: var(--u-space-1);
}

.u-app-page .u-reports-grid .reports_container span {
	color: var(--u-color-text-muted);
	line-height: var(--u-line-height);
	overflow-wrap: anywhere;
}

.u-app-page .u-report-actions {
	display: flex;
	float: none;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-report-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page .u-report-filters {
	align-items: center;
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-3);
}

.u-app-page .u-report-filters .report_filter_tag {
	margin: 0;
}

.u-app-page .u-report-filters select {
	font-size: var(--u-font-size-base);
	min-height: 2.75rem;
	padding: var(--u-space-2);
}

.u-app-page #report_container {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	height: min(36rem, calc(100vh - 18rem));
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-6);
	max-width: calc(100% - 3rem);
	overflow: auto;
	width: auto;
}

.u-app-page #report_container:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page #report_container table {
	min-width: 100%;
}

.u-app-page #report_container th {
	position: sticky;
	top: 0;
	z-index: 1;
}

.u-app-page #report_container th,
.u-app-page #report_container td {
	font-size: var(--u-font-size-sm);
	padding: var(--u-space-2);
}

@media (max-width: 48rem) {
	.u-app-page .u-reports-section,
	.u-app-page .u-report-actions,
	.u-app-page .u-report-filters,
	.u-app-page #report_container {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-report-actions .app_button {
		flex: 1 1 100%;
	}

	.u-app-page #report_container {
		height: min(32rem, calc(100vh - 16rem));
		max-width: calc(100% - 2rem);
	}
}

.u-app-page .u-file-actions {
	display: flex;
	float: none;
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-file-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page #file-uploader,
.u-app-page .u-files-usage,
.u-app-page .file_list_container {
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page .u-files-usage {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	display: grid;
	gap: var(--u-space-2);
	grid-template-columns: auto minmax(10rem, 1fr);
	padding: var(--u-space-4);
}

.u-app-page .u-files-usage .usage_wrapper {
	margin: 0;
	max-width: 100%;
	width: 100%;
}

.u-app-page .file_list_container {
	font-size: var(--u-font-size-sm);
}

.u-app-page .file_list_container > div {
	background-color: #f8fafc;
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin-bottom: var(--u-space-1);
	min-height: 3.5rem;
	overflow-wrap: anywhere;
}

.u-app-page .file_list_container .file_folder {
	align-items: center;
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
	display: flex;
	gap: var(--u-space-3);
}

.u-app-page .file_list_container .file_folder > a:not(.edit_folder)::before {
	content: "Folder";
	color: var(--u-color-text-muted);
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.u-app-page .file_list_container .file_folder > a:not(.edit_folder) {
	flex: 1 1 auto;
	min-width: 0;
}

.u-app-page .file_list_container .edit_folder {
	align-items: center;
	display: inline-flex;
	float: none !important;
	justify-content: center;
	margin-left: auto;
	min-height: 2.75rem;
	min-width: 2.75rem;
	order: 2;
}

.u-app-page .file_list_container table {
	min-width: 38rem;
}

.u-app-page .file_list_container > div:not(.file_folder) {
	overflow-x: auto;
}

.u-app-page .file_list_container .move_file a,
.u-app-page .file_list_container td:last-child a {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	min-height: 2.75rem;
	min-width: 2.75rem;
}

.u-app-page #ajax_content.u-file-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(40rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-file-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-file-dialog .u-file-dialog-panel {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-file-dialog table,
.u-app-page #ajax_content.u-file-dialog input[type="text"],
.u-app-page #ajax_content.u-file-dialog select {
	max-width: 100%;
	width: 100%;
}

.u-app-page #ajax_content.u-file-dialog input[type="text"],
.u-app-page #ajax_content.u-file-dialog select,
.u-app-page .u-file-move-dialog select {
	font-size: var(--u-font-size-base);
	min-height: 2.75rem;
	padding: var(--u-space-2);
}

.u-app-page .u-file-move-dialog {
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	width: min(32rem, calc(100vw - 3rem));
}

.u-app-page .u-file-move-dialog select {
	max-width: 100% !important;
	width: 100% !important;
}

@media (max-width: 48rem) {
	.u-app-page .u-file-actions,
	.u-app-page #file-uploader,
	.u-app-page .u-files-usage,
	.u-app-page .file_list_container {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-file-actions .app_button {
		width: 100%;
	}

	.u-app-page #ajax_content.u-file-dialog,
	.u-app-page .u-file-move-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}
}

.u-app-page #ajax_content.u-attendance-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(48rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-attendance-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-attendance-dialog .top_save,
.u-app-page #ajax_content.u-attendance-dialog .u-attendance-panel {
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-attendance-dialog .u-attendance-panel {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	line-height: var(--u-line-height);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-attendance-dialog #batch_present {
	align-items: center;
	display: inline-flex;
	float: none !important;
	justify-content: center;
	margin: 0 0 var(--u-space-3);
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page .u-attendance-table-region {
	margin-top: var(--u-space-4);
	overflow-x: auto;
}

.u-app-page #ajax_content.u-attendance-dialog #attendance_table {
	border-collapse: collapse;
	min-width: 32rem;
	width: 100% !important;
}

.u-app-page #ajax_content.u-attendance-dialog #attendance_table th,
.u-app-page #ajax_content.u-attendance-dialog #attendance_table td {
	padding: var(--u-space-2);
	text-align: center;
}

.u-app-page #ajax_content.u-attendance-dialog #attendance_table td:first-child,
.u-app-page #ajax_content.u-attendance-dialog #attendance_table th:first-child {
	text-align: left;
}

.u-app-page #ajax_content.u-attendance-dialog input[type="radio"] {
	min-height: 1.25rem;
	min-width: 1.25rem;
}

@media (max-width: 48rem) {
	.u-app-page #ajax_content.u-attendance-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-attendance-dialog .top_save,
	.u-app-page #ajax_content.u-attendance-dialog .u-attendance-panel,
	.u-app-page #ajax_content.u-attendance-dialog .ajax_category_header {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}
}

.u-app-page #calslot {
	margin: 0 var(--u-space-5) var(--u-space-5);
	max-width: calc(100% - 3rem);
	overflow: auto;
}

.u-app-page #calslot:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page #calslot .calendar_head,
.u-app-page #calslot .calendar_body {
	min-width: 48rem;
}

.u-app-page #calslot .calendar_body .event {
	cursor: pointer;
	overflow-wrap: anywhere;
}

.u-app-page #calslot .calendar_body .event:focus-visible {
	box-shadow: inset var(--u-focus-ring);
	outline: 2px solid transparent;
}

.u-app-page #ajax_content.u-calendar-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(48rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-calendar-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-calendar-dialog .top_save,
.u-app-page #ajax_content.u-calendar-dialog .u-calendar-panel {
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-calendar-dialog .u-calendar-panel {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-calendar-dialog .greentable,
.u-app-page #ajax_content.u-calendar-dialog .event_color_pick {
	max-width: 100%;
	width: 100%;
}

.u-app-page #ajax_content.u-calendar-dialog input[type="text"],
.u-app-page #ajax_content.u-calendar-dialog select,
.u-app-page #ajax_content.u-calendar-dialog textarea {
	font-size: var(--u-font-size-base);
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: 100% !important;
}

.u-app-page #ajax_content.u-calendar-dialog textarea {
	min-height: 6rem;
	resize: vertical;
}

.u-app-page #ajax_content.u-calendar-dialog .event_color_pick input[type="radio"] {
	min-height: 1.25rem;
	min-width: 1.25rem;
}

.u-app-page #ajax_content.u-calendar-dialog .group_section {
	display: grid;
	gap: var(--u-space-2);
}

.u-app-page #ajax_content.u-calendar-dialog .group_people {
	display: block;
	float: none;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: auto;
}

.u-app-page .u-calendar-event-dialog {
	box-sizing: border-box;
	height: auto;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: 4rem;
	width: min(28rem, calc(100vw - 3rem));
}

.u-app-page .u-calendar-event-dialog .event_button_group {
	bottom: auto;
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	left: auto;
	margin: var(--u-space-4);
	position: static;
}

.u-app-page .u-calendar-event-dialog .editor {
	align-items: center;
	display: inline-flex;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

@media (max-width: 48rem) {
	.u-app-page #calslot {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
		max-width: calc(100% - 2rem);
	}

	.u-app-page #ajax_content.u-calendar-dialog,
	.u-app-page .u-calendar-event-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-calendar-dialog .top_save,
	.u-app-page #ajax_content.u-calendar-dialog .u-calendar-panel,
	.u-app-page #ajax_content.u-calendar-dialog .ajax_category_header {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-calendar-dialog .greentable,
	.u-app-page #ajax_content.u-calendar-dialog .greentable tbody,
	.u-app-page #ajax_content.u-calendar-dialog .greentable tr,
	.u-app-page #ajax_content.u-calendar-dialog .greentable td {
		display: block;
		width: 100%;
	}

	.u-app-page #ajax_content.u-calendar-dialog .greentable td:empty {
		display: none;
	}
}

.u-app-page .u-gradebook-actions {
	display: flex;
	float: none;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-gradebook-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page #app_toolbar {
	float: none;
	margin: var(--u-space-4) var(--u-space-5);
	width: auto;
}

.u-app-page #app_toolbar form {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-3);
}

.u-app-page #assignment_list {
	margin: var(--u-space-4) var(--u-space-5);
	max-width: calc(100% - 3rem);
	overflow: auto;
	padding: 0;
}

.u-app-page #assignment_list:focus-visible {
	box-shadow: var(--u-focus-ring);
}

.u-app-page #assignment_list .u-gradebook-table {
	min-width: 48rem;
	width: 100%;
}

.u-app-page #assignment_list .grade_td a {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	min-height: 2.75rem;
	min-width: 2.75rem;
}

.u-app-page .u-grade-entry-list {
	display: grid;
	gap: var(--u-space-2);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
	margin: var(--u-space-4) var(--u-space-5);
	padding: 0;
}

.u-app-page .u-grade-entry-list .grade_input {
	align-items: center;
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: flex;
	float: none;
	margin: 0;
	min-height: 3.5rem;
	padding: var(--u-space-3);
	width: auto;
}

.u-app-page .u-grade-entry-list .grade_input input {
	font-size: var(--u-font-size-base);
	height: 2.75rem;
	width: 4rem;
}

.u-app-page #ajax_content.u-gradebook-dialog,
.u-app-page #ajax_content.u-gradebook-setup {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(52rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-gradebook-dialog .ajax_category_header,
.u-app-page #ajax_content.u-gradebook-setup .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-gradebook-dialog .u-gradebook-panel,
.u-app-page #ajax_content.u-gradebook-setup .ajax_instructions {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-gradebook-dialog table {
	width: 100%;
}

.u-app-page #ajax_content.u-gradebook-dialog input[type="text"],
.u-app-page #ajax_content.u-gradebook-dialog select,
.u-app-page #ajax_content.u-gradebook-setup input[type="text"] {
	font-size: var(--u-font-size-base);
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2);
}

.u-app-page #ajax_content.u-gradebook-dialog .group_section {
	display: grid;
	gap: var(--u-space-2);
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-gradebook-dialog .person_group {
	float: none;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: auto;
}

.u-app-page #ajax_content.u-gradebook-setup {
	display: grid;
	grid-template-columns: 10rem minmax(0, 1fr);
}

.u-app-page #ajax_content.u-gradebook-setup #app_nav_container.ajax_nav {
	height: auto;
	min-width: 0;
	width: auto;
}

.u-app-page #ajax_content.u-gradebook-setup #right_with_tabs {
	min-width: 0;
	overflow: auto;
	width: auto;
}

.u-app-page #ajax_content.u-gradebook-setup #grading_scale,
.u-app-page #ajax_content.u-gradebook-setup #grading_periods,
.u-app-page #ajax_content.u-gradebook-setup #grade_weights {
	float: none;
	margin: var(--u-space-4) var(--u-space-5);
	width: auto;
}

.u-app-page #ajax_content.u-gradebook-setup .period {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	line-height: var(--u-line-height);
	padding: var(--u-space-3);
}

@media (max-width: 48rem) {
	.u-app-page .u-gradebook-actions,
	.u-app-page #app_toolbar,
	.u-app-page #assignment_list,
	.u-app-page .u-grade-entry-list {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page .u-gradebook-actions .app_button {
		flex: 1 1 100%;
	}

	.u-app-page #assignment_list {
		max-width: calc(100% - 2rem);
	}

	.u-app-page #ajax_content.u-gradebook-dialog,
	.u-app-page #ajax_content.u-gradebook-setup {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-gradebook-dialog table,
	.u-app-page #ajax_content.u-gradebook-dialog tbody,
	.u-app-page #ajax_content.u-gradebook-dialog tr,
	.u-app-page #ajax_content.u-gradebook-dialog td {
		display: block;
		width: 100%;
	}

	.u-app-page #ajax_content.u-gradebook-setup {
		display: block;
	}

	.u-app-page #ajax_content.u-gradebook-setup #app_nav_container.ajax_nav {
		display: flex;
		overflow-x: auto;
	}
}

.u-app-page #setup_container {
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: minmax(0, 1fr) 12rem;
	margin: var(--u-space-5) 0;
	padding: 0;
}

.u-app-page #setup_container #right_container {
	float: none;
	grid-column: 2;
	grid-row: 1;
	min-width: 0;
	width: auto;
}

.u-app-page #setup_container #setup_left_container {
	float: none;
	grid-column: 1;
	grid-row: 1;
	min-width: 0;
	width: auto;
}

.u-app-page #setup_container .setup_side_nav {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	margin: 0;
	max-width: 100%;
	padding: var(--u-space-2);
	width: auto;
}

.u-app-page #setup_container .setup_side_nav a {
	border: 1px solid transparent;
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page #setup_container .setup_side_nav a:hover {
	background: var(--u-color-primary-soft);
	color: var(--u-color-primary-hover);
}

.u-app-page #setup_container .setup_side_nav a.setup_selected,
.u-app-page #setup_container .setup_side_nav a[aria-current="page"] {
	background: var(--u-color-primary);
	border-color: var(--u-color-primary);
	color: #fff;
	font-weight: 700;
}

.u-app-page #setup_container .setup_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-5) var(--u-space-5) 0;
}

.u-app-page #setup_container {
	font-size: var(--u-font-size-base);
}

.u-app-page #setup_container .setup_info_table,
.u-app-page #setup_container .my_account_table {
	margin: var(--u-space-3) var(--u-space-5);
	max-width: calc(100% - 3rem);
	width: calc(100% - 3rem);
}

.u-app-page #setup_container #payment_table {
	font-size: var(--u-font-size-sm);
	max-width: 100%;
	table-layout: fixed;
	width: 100%;
}

.u-app-page #setup_container #payment_table th,
.u-app-page #setup_container #payment_table td {
	overflow-wrap: anywhere;
	white-space: normal;
	word-break: break-word;
}

.u-app-page #setup_container input[type="text"],
.u-app-page #setup_container input[type="password"],
.u-app-page #setup_container select,
.u-app-page #setup_container textarea {
	font-size: var(--u-font-size-base);
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2);
}

.u-app-page #setup_container .setup_function_description {
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	margin: 0 var(--u-space-5);
}

.u-app-page #setup_container .u-billing-overview {
	display: grid;
	gap: var(--u-space-4);
	margin: 0 var(--u-space-5) var(--u-space-6);
}

.u-app-page #setup_container .u-billing-plan-card,
.u-app-page #setup_container .u-billing-actions {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-5);
}

.u-app-page #setup_container .u-billing-plan-card span {
	color: var(--u-color-text-muted);
	display: block;
	font-size: var(--u-font-size-sm);
	font-weight: 700;
	margin-bottom: var(--u-space-1);
	text-transform: uppercase;
}

.u-app-page #setup_container .u-billing-plan-card strong {
	color: var(--u-color-text);
	display: block;
	font-size: var(--u-font-size-xl);
	line-height: 1.2;
}

.u-app-page #setup_container .u-billing-plan-card p {
	color: var(--u-color-text-muted);
	line-height: var(--u-line-height);
	margin: var(--u-space-3) 0 0;
}

.u-app-page #setup_container .u-billing-actions {
	display: grid;
	gap: var(--u-space-3);
}

.u-app-page #setup_container .u-billing-actions form {
	margin: 0;
}

.u-app-page #setup_container .u-billing-actions .app_button {
	align-items: center;
	border-radius: var(--u-radius-md);
	display: flex;
	gap: var(--u-space-3);
	justify-content: flex-start;
	margin: 0;
	padding: var(--u-space-3) var(--u-space-4);
	text-align: left;
	width: 100%;
}

.u-app-page #setup_container .u-billing-actions .app_button img {
	flex: 0 0 auto;
	height: 2rem;
	margin: 0;
	width: auto;
}

.u-app-page #setup_container .u-billing-actions .app_button span strong {
	display: block;
	font-size: var(--u-font-size-base);
	margin-bottom: var(--u-space-1);
}

.u-app-page #setup_container .u-billing-action-primary {
	background: var(--u-color-primary) !important;
	border-color: var(--u-color-primary) !important;
	color: #fff !important;
}

.u-app-page #setup_container .u-billing-action-secondary {
	background: var(--u-color-surface) !important;
	border-color: var(--u-color-border) !important;
	color: var(--u-color-text) !important;
}

.u-app-page #setup_container .u-billing-alert {
	font-size: var(--u-font-size-base) !important;
	margin: var(--u-space-4) var(--u-space-5);
}

@media (max-width: 48rem) {
	.u-app-page #setup_container {
		display: flex;
		flex-direction: column;
	}

	.u-app-page #setup_container #right_container {
		order: 1;
	}

	.u-app-page #setup_container #setup_left_container {
		order: 2;
	}

	.u-app-page #setup_container .setup_side_nav {
		display: flex;
		overflow-x: auto;
		width: 100%;
	}

	.u-app-page #setup_container .setup_side_nav a {
		flex: 0 0 auto;
		white-space: nowrap;
	}

	.u-app-page #setup_container .setup_info_table,
	.u-app-page #setup_container .setup_info_table tbody,
	.u-app-page #setup_container .setup_info_table tr,
	.u-app-page #setup_container .setup_info_table td,
	.u-app-page #setup_container .my_account_table,
	.u-app-page #setup_container .my_account_table tbody,
	.u-app-page #setup_container .my_account_table tr,
	.u-app-page #setup_container .my_account_table td {
		display: block;
		width: auto;
	}

	.u-app-page #setup_container #payment_table th,
	.u-app-page #setup_container #payment_table td {
		padding: var(--u-space-2);
	}
}

.u-app-page #setup_container .u-setup-actions {
	display: flex;
	float: none;
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page #setup_container .u-setup-actions .app_button {
	align-items: center;
	background: var(--u-color-primary);
	background-image: linear-gradient(135deg, var(--u-color-primary) 0%, #2f8bcf 100%);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #ffffff;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-4);
	text-shadow: none;
}

.u-app-page #setup_container .u-setup-table-region {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	max-width: calc(100% - 3rem);
	overflow-x: auto;
}

.u-app-page #setup_container .u-setup-table-region table {
	margin: 0 !important;
	min-width: 42rem;
	width: 100% !important;
}

.u-app-page #setup_container .setup_function_description,
.u-app-page #setup_container .setup_function_go {
	background: #f8fafc;
	border-left: 3px solid var(--u-color-border);
	margin-left: var(--u-space-5);
	margin-right: var(--u-space-5);
	padding: var(--u-space-3);
}

.u-app-page #setup_container .setup_function_go {
	border-left-color: var(--u-color-primary);
}

.u-app-page #setup_container .widget_images,
.u-app-page #setup_container .u-setup-example-image {
	height: auto;
	max-width: 100%;
}

.u-app-page #setup_container .code_container {
	max-width: 100%;
	overflow-x: auto;
}

.u-app-page #setup_container .app_button,
.u-app-page #setup_container button.app_button {
	align-items: center;
	display: inline-flex;
	max-width: 100%;
	min-height: 2.75rem;
	white-space: normal;
}

.u-app-page #ajax_content.u-setup-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(44rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-setup-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-setup-dialog .u-setup-dialog-panel {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-setup-dialog input[type="text"],
.u-app-page #ajax_content.u-setup-dialog input[type="password"] {
	font-size: var(--u-font-size-base);
	min-height: 2.75rem;
	padding: var(--u-space-2);
}

.u-app-page #ajax_content.u-setup-dialog .access_option {
	align-items: center;
	display: flex;
	float: none;
	gap: var(--u-space-2);
	margin: var(--u-space-2) 0;
	width: auto;
}

.u-app-page #ajax_content.u-setup-dialog .access_option span {
	float: none;
	width: auto;
}

@media (max-width: 48rem) {
	.u-app-page #setup_container .u-setup-actions,
	.u-app-page #setup_container .u-setup-table-region {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
		max-width: calc(100% - 2rem);
	}

	.u-app-page #setup_container .u-setup-actions .app_button {
		width: 100%;
	}

	.u-app-page #ajax_content.u-setup-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}
}

.u-app-page .u-website-address {
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	float: none !important;
	font-size: var(--u-font-size-sm) !important;
	margin: var(--u-space-4) var(--u-space-5);
	overflow-wrap: anywhere;
	padding: var(--u-space-3);
}

.u-app-page .u-website-actions {
	display: flex;
	justify-content: flex-end;
	margin: var(--u-space-4) var(--u-space-5) var(--u-space-3);
}

.u-app-page .u-website-posts-heading {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-5) var(--u-space-5) var(--u-space-1);
}

.u-app-page .u-website-posts-description {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-base);
	margin: 0 var(--u-space-5) var(--u-space-4);
}

.u-app-page #ajax_content.u-website-dialog {
	background: var(--u-color-surface);
	box-sizing: border-box;
	max-height: calc(100vh - 3rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(44rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-website-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-website-dialog .u-website-dialog-panel {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-website-dialog #post_container {
	margin: 0;
}

.u-app-page #ajax_content.u-website-dialog input[type="text"],
.u-app-page #ajax_content.u-website-dialog textarea {
	font-size: var(--u-font-size-base);
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2);
	width: 100%;
}

.u-app-page #ajax_content.u-website-dialog textarea {
	min-height: 16rem;
	resize: vertical;
}

@media (max-width: 48rem) {
	.u-app-page .u-website-address {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-website-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}
}

.u-app-page #ajax_content.u-student-detail .ajax_tab_content > h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-detail .ultralist {
	margin: var(--u-space-3) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-detail .ultralist a,
.u-app-page #ajax_content.u-student-detail .ultralist .s_list {
	align-items: center;
	border: 1px solid transparent;
	border-bottom-color: var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-2) var(--u-space-4);
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: var(--u-space-1);
	min-height: 3.5rem;
	padding: var(--u-space-3) var(--u-space-4);
}

.u-app-page #ajax_content.u-student-detail .ultralist a:hover,
.u-app-page #ajax_content.u-student-detail .ultralist a:focus-visible {
	background: var(--u-color-primary-soft);
	border-color: #bdd3ed;
}

.u-app-page #ajax_content.u-student-detail .ultralist .right {
	float: none;
	grid-column: 2;
	grid-row: 1;
	margin: 0;
	min-width: 0;
	text-align: right;
	white-space: normal;
}

.u-app-page #ajax_content.u-student-detail .ultralist .name {
	grid-column: 1;
	grid-row: 1;
	overflow-wrap: anywhere;
}

.u-app-page #ajax_content.u-student-detail .ultralist .bottom_left {
	float: none;
	margin: 0;
	min-width: 0;
}

.u-app-page #ajax_content.u-student-detail .student_balance {
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	float: none;
	font-size: var(--u-font-size-base);
	margin: var(--u-space-4) var(--u-space-5);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-student-detail .student_transaction {
	display: flex;
	float: none;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-3) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-detail .student_transaction .app_button {
	align-items: center;
	display: inline-flex;
	justify-content: center;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-app-page #ajax_content.u-student-detail .div_table {
	margin: var(--u-space-3) var(--u-space-5);
	max-height: none;
}

.u-app-page #ajax_content.u-student-detail .div_table .dtc {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
}

.u-app-page #ajax_content.u-student-detail .div_table .dtc > span {
	float: none;
	margin: 0;
}

.u-app-page #ajax_content.u-student-detail .div_table .dtc > .long {
	flex: 1 1 12rem;
}

.u-app-page #ajax_content.u-student-detail .div_table .expandable {
	flex: 1 0 100%;
	overflow-x: auto;
}

@media (max-width: 48rem) {
	.u-app-page #ajax_content.u-student-detail .ajax_tab_content > h2,
	.u-app-page #ajax_content.u-student-detail .ultralist,
	.u-app-page #ajax_content.u-student-detail .student_balance,
	.u-app-page #ajax_content.u-student-detail .student_transaction,
	.u-app-page #ajax_content.u-student-detail .div_table {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-student-detail .ultralist a,
	.u-app-page #ajax_content.u-student-detail .ultralist .s_list {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-app-page #ajax_content.u-student-detail .ultralist .right,
	.u-app-page #ajax_content.u-student-detail .ultralist .name {
		grid-column: 1;
		text-align: left;
	}

	.u-app-page #ajax_content.u-student-detail .ultralist .right {
		grid-row: 2;
	}

	.u-app-page #ajax_content.u-student-detail .student_transaction .app_button {
		flex: 1 1 auto;
	}
}

.u-app-page #ajax_content.u-student-dialog {
	background: var(--u-color-surface);
	height: auto;
	max-height: calc(100vh - 4rem);
	max-width: calc(100vw - 3rem);
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: min(48rem, calc(100vw - 3rem));
}

.u-app-page #ajax_content.u-student-dialog #ajax_no_tabs {
	font-size: var(--u-font-size-sm);
	padding-bottom: var(--u-space-2);
}

.u-app-page #ajax_content.u-student-dialog .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-student-dialog .ajax_instructions,
.u-app-page #ajax_content.u-student-dialog .ajax_green_container,
.u-app-page #ajax_content.u-student-dialog #ajax_green_container,
.u-app-page #ajax_content.u-student-dialog #ajax_center_few {
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-dialog .ajax_instructions {
	background: var(--u-color-primary-soft);
	border: 1px solid #bdd3ed;
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	line-height: var(--u-line-height);
	padding: var(--u-space-4);
}

.u-app-page #ajax_content.u-student-dialog input[type="text"],
.u-app-page #ajax_content.u-student-dialog input[type="file"],
.u-app-page #ajax_content.u-student-dialog select,
.u-app-page #ajax_content.u-student-dialog textarea {
	max-width: 100%;
}

.u-app-page #ajax_content.u-student-dialog .u-membership-import {
	display: block;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	height: 12.5rem;
	margin: var(--u-space-3) 0;
	min-height: 8rem;
	padding: var(--u-space-3);
	width: 100%;
}

.u-app-page #ajax_content.u-student-dialog .download_package,
.u-app-page #ajax_content.u-student-dialog .upload_package {
	float: none;
	margin: var(--u-space-4) var(--u-space-5);
	max-width: none;
	width: auto;
}

.u-app-page #ajax_content.u-student-dialog .top_save {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-4) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-dialog .group_section {
	display: inline-block;
	margin: var(--u-space-1);
}

.u-app-page #ajax_content.u-student-dialog .group_people {
	float: none;
	margin: 0;
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	width: auto;
}

.u-app-page #ajax_content.u-student-dialog #ajax_green_container {
	overflow: auto;
}

.u-app-page #ajax_content.u-student-dialog #import_review {
	min-width: 90rem;
}

@media (max-width: 48rem) {
	.u-app-page #ajax_content.u-student-dialog {
		max-height: calc(100vh - 1rem);
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #ajax_content.u-student-dialog .ajax_category_header {
		font-size: 1.5rem;
		margin: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-student-dialog .ajax_instructions,
	.u-app-page #ajax_content.u-student-dialog .ajax_green_container,
	.u-app-page #ajax_content.u-student-dialog #ajax_green_container,
	.u-app-page #ajax_content.u-student-dialog #ajax_center_few,
	.u-app-page #ajax_content.u-student-dialog .download_package,
	.u-app-page #ajax_content.u-student-dialog .upload_package,
	.u-app-page #ajax_content.u-student-dialog .top_save {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}
}

@media (max-width: 30rem) {
	.u-app-page #top_wrapper {
		height: 10.5rem;
	}

	.u-app-page #top_links.u-app-utilities {
		float: none;
		margin: var(--u-space-2) 0 0;
		overflow-x: auto;
		width: 100%;
	}

	.u-app-page #top_links.u-app-utilities a span {
		clip: auto;
		height: auto;
		overflow: visible;
		position: static;
		white-space: normal;
		width: auto;
	}

	.u-app-page #toolbar input#query {
		flex-basis: calc(100% - 5rem);
		order: 1;
	}

	.u-app-page #toolbar .search {
		order: 1;
	}

	.u-app-page #student_list a {
		grid-template-areas:
			"name"
			"groups"
			"login"
			"student"
			"grade"
			"last";
		grid-template-columns: minmax(0, 1fr);
	}
}

.u-app-page #ajax_content.u-student-detail {
	background: var(--u-color-surface);
	align-items: stretch;
	box-sizing: border-box;
	display: grid;
	grid-template-columns: 11rem minmax(0, 1fr);
	height: min(42rem, calc(100vh - 5rem));
	max-width: calc(100vw - 3rem);
	overflow: auto;
	width: min(68rem, calc(100vw - 3rem));
}

.u-app-page #fancybox-wrap:has(#ajax_content.u-student-detail) {
	left: 50% !important;
	max-width: calc(100vw - 1rem) !important;
	transform: translateX(-50%);
	width: min(68rem, calc(100vw - 3rem)) !important;
}

.u-app-page #fancybox-wrap:has(#ajax_content.u-student-detail) #fancybox-outer,
.u-app-page #fancybox-content:has(#ajax_content.u-student-detail) {
	max-width: 100% !important;
	width: 100% !important;
}

.u-app-page #fancybox-content:has(#ajax_content.u-student-detail) {
	max-height: calc(100vh - 5rem);
	overflow: auto !important;
}

.u-app-page #fancybox-content #ajax_content.u-student-detail {
	max-width: 100% !important;
	width: 100% !important;
}

.u-app-page #ajax_content.u-student-detail #app_nav_container.ajax_nav {
	background: #f8fafc;
	border: 0;
	border-right: 1px solid var(--u-color-border);
	border-radius: 0;
	box-shadow: none;
	display: block;
	height: 100%;
	margin: 0;
	min-width: 0;
	padding: var(--u-space-3);
	width: auto;
}

.u-app-page #ajax_content.u-student-detail #app_nav_container.ajax_nav > div:first-child {
	display: none;
}

.u-app-page #ajax_content.u-student-detail #right_with_tabs {
	float: none;
	min-width: 0;
	overflow: auto;
	padding-bottom: var(--u-space-5);
	width: auto;
}

.u-app-page #ajax_content.u-student-detail .ajax_category_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin: var(--u-space-5);
}

.u-app-page #ajax_content.u-student-detail .student_section {
	max-width: 100%;
	overflow-x: auto;
	padding: 0 var(--u-space-3);
}

.u-app-page #ajax_content.u-student-detail .student_section table {
	margin: var(--u-space-2);
}

.u-app-page #ajax_content.u-student-detail .group_section {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-2);
	margin: var(--u-space-3) var(--u-space-5);
}

.u-app-page #ajax_content.u-student-detail .group_section > div {
	min-width: 0;
}

.u-app-page #ajax_content.u-student-detail .person_group {
	float: none;
	margin: 0;
	max-width: 100%;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	width: auto;
}

.u-app-page #ajax_content.u-student-detail .form_button_group {
	margin: var(--u-space-5);
}

@media (max-width: 48rem) {
	.u-app-page #ajax_content.u-student-detail {
		display: block;
		height: min(44rem, calc(100vh - 2rem));
		max-width: calc(100vw - 1rem);
		width: calc(100vw - 1rem);
	}

	.u-app-page #fancybox-wrap:has(#ajax_content.u-student-detail) {
		max-width: calc(100vw - 0.5rem) !important;
		width: calc(100vw - 1rem) !important;
	}

	.u-app-page #fancybox-content:has(#ajax_content.u-student-detail) {
		max-height: calc(100vh - 1rem);
	}

	.u-app-page #fancybox-content #ajax_content.u-student-detail {
		max-width: 100% !important;
		width: 100% !important;
	}

	.u-app-page #ajax_content.u-student-detail #app_nav_container.ajax_nav {
		border-bottom: 1px solid var(--u-color-border);
		border-right: 0;
		display: flex;
		margin: 0;
		overflow-x: auto;
		padding: var(--u-space-2);
	}

	.u-app-page #ajax_content.u-student-detail #app_nav_container.ajax_nav a.mn {
		flex: 0 0 auto;
	}

	.u-app-page #ajax_content.u-student-detail .ajax_category_header {
		font-size: 1.5rem;
		margin: var(--u-space-4);
	}

	.u-app-page #ajax_content.u-student-detail .student_section {
		padding: 0 var(--u-space-2);
	}

	.u-app-page #ajax_content.u-student-detail .group_section,
	.u-app-page #ajax_content.u-student-detail .form_button_group {
		margin: var(--u-space-4);
	}
}

.u-student-page .u-student-profile-form {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.u-student-page .u-student-profile-form > .app_category_header,
.u-student-page .u-student-profile-form > input[type="hidden"],
.u-student-page .u-student-profile-form > .u-student-profile-message,
.u-student-page .u-student-profile-form > .clearboth {
	grid-column: 1 / -1;
}

.u-student-page .u-student-profile-message:empty {
	display: none;
}

.u-student-page .u-student-profile-form > .student_personal {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	float: none;
	margin: 0;
	min-width: 0;
	padding: var(--u-space-4);
}

.u-student-page .u-student-profile-form .student_personal table {
	border-collapse: collapse;
	width: 100%;
}

.u-student-page .u-student-profile-form .student_personal td {
	padding: var(--u-space-2);
	vertical-align: middle;
}

.u-student-page .u-student-profile-form .student_personal td:first-child {
	width: 9rem;
}

.u-student-page .u-student-profile-form input[type="text"],
.u-student-page .u-student-profile-form input[type="password"] {
	box-sizing: border-box;
	min-height: 2.75rem;
	width: 100%;
}

.u-student-page .u-student-profile-form .large_submit {
	float: right;
	margin: var(--u-space-4) 0 0;
	min-height: 2.75rem;
}

.u-student-page .u-student-summary-list {
	margin: 0 var(--u-space-5) var(--u-space-5);
}

.u-student-page .u-student-summary-list .s_list {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-2) var(--u-space-4);
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: var(--u-space-2);
	min-height: 2.75rem;
	padding: var(--u-space-3) var(--u-space-4);
}

.u-student-page .u-student-summary-list .s_list.odd {
	background: #f8fafc;
}

.u-student-page .u-student-summary-list .name,
.u-student-page .u-student-summary-list .right,
.u-student-page .u-student-summary-list .bottom_left {
	float: none;
	margin: 0;
	padding: 0;
	width: auto;
}

.u-student-page .u-student-summary-list .name {
	font-size: var(--u-font-size-lg);
	font-weight: 700;
	min-width: 0;
}

.u-student-page .u-student-summary-list .right {
	font-weight: 700;
	text-align: right;
}

.u-student-page .u-student-summary-list .bottom_left {
	color: var(--u-color-text-muted);
	grid-column: 1 / -1;
}

.u-student-page .u-student-finance-summary {
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin: 0 var(--u-space-5) var(--u-space-4);
}

.u-student-page .u-student-finance-summary .s_student_balance {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	float: none;
	font-size: var(--u-font-size-lg);
	margin: 0;
	padding: var(--u-space-4);
	width: auto;
}

.u-student-page .student_transaction {
	margin: 0 var(--u-space-5) var(--u-space-4);
}

.u-student-page .student_transaction .app_button {
	display: inline-flex;
	min-height: 2.75rem;
	padding: 0 var(--u-space-4);
}

.u-student-page .u-student-paypal {
	box-sizing: border-box;
	font-size: var(--u-font-size-sm);
	line-height: var(--u-line-height);
	margin: 0 var(--u-space-5) var(--u-space-5);
	max-width: 44rem;
	padding: var(--u-space-5);
}

.u-student-page .u-student-paypal img {
	height: auto;
	margin-bottom: var(--u-space-3);
	max-width: 100%;
}

.u-student-page .u-student-paypal select,
.u-student-page .u-student-paypal input[type="text"] {
	box-sizing: border-box;
	margin-top: var(--u-space-2);
	max-width: 100%;
	min-height: 2.75rem;
}

.u-student-page .u-student-paypal select {
	width: 100%;
}

@media (max-width: 48rem) {
	.u-student-page .u-student-profile-form,
	.u-student-page .u-student-finance-summary {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-student-page .u-student-profile-form .student_personal td {
		display: block;
		width: auto;
	}

	.u-student-page .u-student-profile-form .student_personal td:first-child {
		padding-bottom: 0;
		text-align: left;
		width: auto;
	}

	.u-student-page .u-student-summary-list,
	.u-student-page .u-student-finance-summary,
	.u-student-page .student_transaction,
	.u-student-page .u-student-paypal {
		margin-left: var(--u-space-4);
		margin-right: var(--u-space-4);
	}

	.u-student-page .u-student-summary-list .s_list {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-student-page .u-student-summary-list .right {
		grid-row: 2;
		text-align: left;
	}

	.u-student-page .u-student-summary-list .bottom_left {
		grid-column: 1;
	}
}

.u-app-page .u-email-layout {
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: minmax(0, 2fr) minmax(15rem, 1fr);
	margin: 0 var(--u-space-5) var(--u-space-5);
}

.u-app-page .u-email-layout #email_main,
.u-app-page .u-email-layout #email_side {
	float: none;
	margin: 0;
	min-width: 0;
	width: auto;
}

.u-app-page .u-email-layout #emailer,
.u-app-page .u-email-layout #email_side {
	background: transparent;
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	padding: var(--u-space-5);
}

.u-app-page .u-email-layout #emailer {
	border: 0;
}

.u-app-page .u-email-layout #email_side {
	border: 1px solid var(--u-color-border);
}

.u-app-page .u-email-layout #emailer > h2,
.u-app-page .u-email-layout #email_side > h2,
.u-app-page .u-email-layout .u-email-attachments > h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.3;
	margin: 0 0 var(--u-space-3);
}

.u-app-page .u-email-layout #emailer > label {
	color: var(--u-color-text);
	display: block;
	font-weight: 700;
	margin: var(--u-space-5) 0 var(--u-space-2);
}

.u-app-page .u-email-layout #expander {
	align-items: center;
	cursor: pointer;
	display: inline-flex;
	font: inherit;
	gap: var(--u-space-2);
	justify-content: center;
	min-height: 2.75rem;
	padding: 0 var(--u-space-4);
	text-shadow: none !important;
}

.u-app-page .u-email-layout #expander img {
	margin: 0;
}

.u-app-page .u-email-recipients {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-sizing: border-box;
	line-height: var(--u-line-height);
	margin-top: var(--u-space-3);
	max-height: 32rem;
	overflow: auto;
	padding: var(--u-space-4);
}

.u-app-page .u-email-recipients .group_section {
	display: grid;
	gap: var(--u-space-2);
	grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
	margin: var(--u-space-3) 0 var(--u-space-5);
}

.u-app-page .u-email-recipients .group_section > div {
	min-width: 0;
}

.u-app-page .u-email-recipients .group_section > .clearboth {
	display: none;
}

.u-app-page .u-email-recipients .group_people {
	align-items: flex-start;
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	box-sizing: border-box;
	display: flex;
	float: none;
	gap: var(--u-space-2);
	margin: 0;
	min-height: 2.75rem;
	overflow: visible;
	padding: var(--u-space-2) var(--u-space-3);
	white-space: normal;
	width: 100%;
}

.u-app-page .u-email-recipients .group_people input {
	flex: 0 0 auto;
	margin-top: 0.2rem;
	position: static;
}

.u-app-page .u-email-recipients .ajax_instructions {
	margin: var(--u-space-4) 0 var(--u-space-2) !important;
}

.u-app-page .u-email-layout #subject,
.u-app-page .u-email-layout #text {
	box-sizing: border-box;
	max-width: 100%;
	width: 100%;
}

.u-app-page .u-email-layout #subject {
	min-height: 2.75rem;
}

.u-app-page .u-email-layout #text {
	display: block;
	min-height: 15rem;
	padding: var(--u-space-3);
	resize: vertical;
}

.u-app-page .u-email-layout .u-email-attachments {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	float: none;
	margin: var(--u-space-5) 0;
	max-width: none;
	padding: var(--u-space-4);
	width: auto;
}

.u-app-page .u-email-layout .u-email-attachments h2 {
	text-shadow: none;
}

.u-app-page .u-email-layout .u-email-attachments h2 img {
	height: auto;
	margin-right: var(--u-space-2);
	max-width: 1.25rem;
	vertical-align: middle;
}

.u-app-page .u-email-layout .u-email-attachments p {
	color: var(--u-color-text-muted);
	line-height: var(--u-line-height);
	margin: 0 0 var(--u-space-3);
}

.u-app-page .u-email-layout .u-email-attachments input[type="file"] {
	box-sizing: border-box;
	max-width: 100%;
}

.u-app-page .u-email-layout #emailer > .large_submit {
	min-height: 2.75rem;
}

.u-app-page .u-email-layout #email_side > h2 {
	border-bottom: 1px solid var(--u-color-border);
	padding-bottom: var(--u-space-3);
}

.u-app-page .u-email-layout #email_side > div {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	line-height: var(--u-line-height);
	margin: 0 0 var(--u-space-2);
	padding: var(--u-space-3);
}

.u-app-page .u-email-layout #email_side > div span {
	color: var(--u-color-text-muted);
	display: inline-block;
	margin-right: var(--u-space-2);
}

.u-app-page .u-email-empty {
	color: var(--u-color-text-muted);
	margin: 0;
}

@media (max-width: 64rem) {
	.u-app-page .u-email-layout {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 48rem) {
	.u-app-page .u-email-layout {
		margin: 0 var(--u-space-4) var(--u-space-4);
	}

	.u-app-page .u-email-layout #emailer,
	.u-app-page .u-email-layout #email_side {
		padding: var(--u-space-4);
	}

	.u-app-page .u-email-recipients {
		max-height: 24rem;
		padding: var(--u-space-3);
	}

	.u-app-page .u-email-recipients .group_section {
		grid-template-columns: minmax(0, 1fr);
	}
}

.u-widget-page {
	background: var(--u-color-canvas) !important;
	box-sizing: border-box;
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	line-height: var(--u-line-height);
	margin: 0;
	min-height: 100%;
	padding: var(--u-space-3);
}

.u-widget-page *,
.u-widget-page *::before,
.u-widget-page *::after {
	box-sizing: border-box;
}

.u-widget-events {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-shadow: 0 0.25rem 0.75rem rgba(36, 49, 66, 0.06);
	overflow: hidden;
}

.u-widget-events .widget_event_event {
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	overflow-wrap: anywhere;
	padding: var(--u-space-3) var(--u-space-4) var(--u-space-1);
}

.u-widget-events .widget_event_date {
	border-bottom: 1px solid var(--u-color-border);
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0;
	padding: 0 var(--u-space-4) var(--u-space-3);
	text-align: left;
}

.u-widget-events .widget_event_date:last-child {
	border-bottom: 0;
}

.u-widget-events .widget_event_date img {
	height: auto;
	margin-left: var(--u-space-1);
	max-width: 1rem;
	vertical-align: middle;
}

.u-widget-empty {
	color: var(--u-color-text-muted);
	margin: 0;
	padding: var(--u-space-5);
	text-align: center;
}

.u-widget-calendar {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: flex;
	flex-direction: column;
	height: calc(100vh - (2 * var(--u-space-3)));
	min-height: 20rem;
	overflow: hidden;
}

.u-widget-calendar #toolbar {
	align-items: center;
	border-bottom: 1px solid var(--u-color-border);
	display: grid;
	flex: 0 0 auto;
	gap: var(--u-space-2);
	grid-template-columns: auto auto minmax(0, 1fr);
	height: auto;
	margin: 0;
	min-height: 3.5rem;
	padding: var(--u-space-2);
}

.u-widget-calendar #toolbar .left,
.u-widget-calendar #toolbar .right {
	align-items: center;
	display: inline-flex;
	height: 2.75rem;
	justify-content: center;
	margin: 0;
	min-width: 2.75rem;
	padding: 0 !important;
}

.u-widget-calendar #toolbar .toolbar_text {
	border: 0;
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
	margin: 0;
	min-width: 0;
	padding: 0 var(--u-space-2);
	text-align: right;
}

.u-widget-calendar-scroll {
	flex: 1 1 auto;
	min-height: 0;
	overflow: auto;
}

.u-widget-calendar .calendar_head,
.u-widget-calendar .calendar_body {
	border: 0;
	border-radius: 0;
	min-width: 42rem;
}

.u-widget-calendar .calendar_head th {
	background: #f8fafc;
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	height: 2.75rem;
	position: sticky;
	top: 0;
	z-index: 1;
}

.u-widget-calendar .calendar_body td {
	height: 5rem;
	padding: var(--u-space-1);
}

.u-widget-calendar .calendar_body .number {
	color: var(--u-color-text-muted);
	font-weight: 700;
	margin: 0 0 var(--u-space-1);
}

.u-widget-calendar .calendar_body .event {
	border: 2px solid transparent;
	font-size: var(--u-font-size-sm);
	line-height: 1.25;
	margin: var(--u-space-1) 0;
	max-height: none;
	overflow-wrap: anywhere;
	padding: var(--u-space-2);
}

.u-widget-calendar .calendar_body .event:focus-visible {
	border-color: var(--u-color-primary);
	box-shadow: 0 0 0 2px var(--u-color-surface);
	outline: none;
}

@media (max-width: 30rem) {
	.u-widget-page {
		padding: var(--u-space-2);
	}

	.u-widget-calendar {
		height: calc(100vh - (2 * var(--u-space-2)));
	}

	.u-widget-calendar #toolbar {
		grid-template-columns: auto auto minmax(8rem, 1fr);
	}

	.u-widget-calendar #toolbar .toolbar_text {
		font-size: var(--u-font-size-base);
	}
}

.u-tenant-public-page {
	background: var(--u-color-canvas);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	min-width: 0;
	text-align: left;
}

.u-tenant-public-page *,
.u-tenant-public-page *::before,
.u-tenant-public-page *::after {
	box-sizing: border-box;
}

.u-tenant-public-page a {
	color: var(--u-color-primary);
}

.u-tenant-public-page a:hover {
	color: var(--u-color-primary-hover);
}

.u-tenant-public-page a:focus-visible,
.u-tenant-public-page .app_function:focus-visible {
	border-radius: var(--u-radius-sm);
	box-shadow: var(--u-focus-ring);
	outline: none;
}

.u-tenant-public-page #top_wrapper {
	display: none;
}

.u-tenant-public-page #container {
	margin: 0 auto;
	max-width: 72rem;
	padding: var(--u-space-5) var(--u-space-4) var(--u-space-8);
	width: 100%;
}

.u-tenant-layout {
	align-items: start;
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: minmax(0, 1fr) 18rem;
}

.u-tenant-main {
	min-width: 0;
}

.u-tenant-public-page .publicsite_title {
	color: var(--u-color-text);
	font-size: var(--u-font-size-xl);
	font-weight: 800;
	line-height: 1.2;
	margin: 0 0 var(--u-space-4);
	overflow-wrap: anywhere;
	padding: 0;
}

.u-tenant-public-page .publicsite_side {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	float: none;
	margin: 0;
	padding: var(--u-space-4);
	width: auto;
}

.u-tenant-public-page .publicsite_powered {
	border-bottom: 1px solid var(--u-color-border);
	font-size: var(--u-font-size-sm);
	line-height: var(--u-line-height);
	margin: 0 0 var(--u-space-4);
	padding-bottom: var(--u-space-4);
	text-align: left;
}

.u-tenant-public-page .publicsite_powered img {
	height: auto;
	max-width: 6rem;
	vertical-align: middle;
}

.u-tenant-public-page .app_function {
	align-items: center;
	display: inline-flex;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
}

.u-tenant-public-page .publicsite_header {
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	margin: 0 0 var(--u-space-3);
	padding: 0;
}

.u-tenant-public-page .post_subject {
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	overflow-wrap: anywhere;
}

.u-tenant-public-page .post_date {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
}

.u-tenant-public-page .post_text {
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm);
	overflow-wrap: anywhere;
}

.u-tenant-calendar-region {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	overflow-x: auto;
	padding: var(--u-space-2);
}

.u-tenant-calendar-region iframe,
.u-tenant-calendar-frame {
	border: 0;
	display: block;
	margin-top: var(--u-space-2);
	max-width: none;
}

.u-tenant-public-page #footer {
	background: transparent;
	border-top: 1px solid var(--u-color-border);
	bottom: auto;
	color: var(--u-color-text-muted);
	margin-top: var(--u-space-6);
	position: static;
	width: auto;
}

@media (max-width: 48rem) {
	.u-tenant-layout {
		display: flex;
		flex-direction: column;
	}

	.u-tenant-main {
		order: 1;
		width: 100%;
	}

	.u-tenant-public-page .publicsite_side {
		order: 2;
		width: 100%;
	}
}

.u-public-page {
	background:
		linear-gradient(180deg, #173657 0, #173657 6.75rem, transparent 6.75rem),
		radial-gradient(circle at 84% 10%, rgba(56, 163, 165, 0.18), transparent 24rem),
		linear-gradient(180deg, #eef5fb 0%, #f8fafc 40%, #f3f6f9 100%);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	min-width: 0;
	text-align: left;
}

.u-public-page *,
.u-public-page *::before,
.u-public-page *::after {
	box-sizing: border-box;
}

.u-public-page a {
	color: var(--u-color-primary);
}

.u-public-page a:hover {
	color: var(--u-color-primary-hover);
}

.u-public-page a:focus-visible,
.u-public-page button:focus-visible,
.u-public-page input:focus-visible,
.u-public-page textarea:focus-visible,
.u-public-page select:focus-visible {
	border-radius: var(--u-radius-sm);
	box-shadow: var(--u-focus-ring);
	outline: none;
}

.u-public-page #container {
	margin: 0 auto;
	max-width: 72rem;
	min-height: calc(100vh - 8rem);
	padding: 0 var(--u-space-5) var(--u-space-1);
	width: 100%;
}

.u-public-header {
	align-items: center;
	display: flex;
	gap: var(--u-space-4);
	justify-content: space-between;
	min-height: 6.75rem;
	padding: var(--u-space-4) 0;
}

.u-public-page #logo {
	border-radius: var(--u-radius-md);
	flex: 0 0 auto;
	height: auto;
	margin: 0;
	padding: var(--u-space-2) var(--u-space-4);
	width: auto;
}

.u-public-page #logo img {
	display: block;
	height: auto;
	max-width: 10.5rem;
}

.u-public-page #overall_navbar {
	align-items: center;
	display: flex;
	flex: 1 1 auto;
	flex-wrap: wrap;
	float: none;
	font-size: var(--u-font-size-sm);
	gap: var(--u-space-2);
	justify-content: flex-end;
	margin: 0;
	width: auto;
}

.u-public-page #overall_navbar a {
	align-items: center;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--u-radius-md);
	color: rgba(255, 255, 255, 0.88);
	display: inline-flex;
	float: none;
	font-weight: 700;
	gap: var(--u-space-2);
	justify-content: center;
	line-height: 1.2;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	text-shadow: none;
}

.u-public-page #overall_navbar a:hover {
	background: rgba(255, 255, 255, 0.1);
	color: #ffffff;
	text-decoration: none;
}

.u-public-page #overall_navbar .login_button {
	background: #ffffff;
	border-color: rgba(255, 255, 255, 0.72);
	box-shadow: 0 0.75rem 1.5rem rgba(4, 22, 41, 0.22);
	color: var(--u-color-primary-strong) !important;
	margin: 0 !important;
	padding: var(--u-space-2) var(--u-space-4) !important;
	text-shadow: none !important;
	width: auto !important;
}

.u-public-page #overall_navbar .login_button:hover {
	background: #f3f8ff;
	color: var(--u-color-primary-strong) !important;
}

.u-public-page #overall_navbar .login_button img {
	height: 1rem;
	margin: 0;
	width: 1rem;
}

.u-public-main {
	width: 100%;
}

.u-landing-hero {
	align-items: center;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.9) 0%, rgba(234, 242, 251, 0.88) 55%, rgba(232, 245, 238, 0.82) 100%);
	border: 1px solid rgba(203, 213, 225, 0.72);
	border-radius: var(--u-radius-lg);
	box-shadow: 0 1.5rem 4rem rgba(36, 49, 66, 0.14);
	display: grid;
	gap: var(--u-space-6);
	grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.95fr);
	margin: var(--u-space-5) 0 var(--u-space-4);
	padding: var(--u-space-6);
}

.u-landing-hero-copy {
	max-width: 42rem;
}

.u-landing-kicker {
	color: #1b6b52;
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	letter-spacing: 0.08em;
	margin: 0 0 var(--u-space-3);
	text-transform: uppercase;
}

.u-landing-hero h1,
.u-landing-section h2,
.u-landing-cta h2 {
	color: var(--u-color-text);
	line-height: 1.12;
	margin: 0;
}

.u-landing-hero h1 {
	font-size: 3.35rem;
	max-width: 20ch;
}

.u-landing-intro {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) 0 0;
	max-width: 38rem;
}

.u-landing-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--u-space-3);
	margin-top: var(--u-space-5);
}

.u-landing-button {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--u-radius-md);
	display: inline-flex;
	font-size: var(--u-font-size-base);
	font-weight: 800;
	justify-content: center;
	min-height: 2.75rem;
	padding: var(--u-space-3) var(--u-space-5);
	text-decoration: none;
}

.u-landing-button:hover {
	text-decoration: none;
}

.u-landing-button-primary {
	background: linear-gradient(135deg, #1f63b5 0%, #2f8bcf 48%, #38a3a5 100%);
	border-color: var(--u-color-primary);
	box-shadow: 0 1rem 2rem rgba(31, 99, 181, 0.28);
	color: #fff !important;
}

.u-landing-button-primary:hover {
	background: linear-gradient(135deg, #174f91 0%, #2478b7 48%, #2e8f91 100%);
	color: #fff !important;
}

.u-landing-button-secondary {
	background: var(--u-color-surface);
	border-color: var(--u-color-border);
	color: var(--u-color-text) !important;
}

.u-landing-button-secondary:hover {
	background: var(--u-color-primary-soft);
	color: var(--u-color-primary-hover) !important;
}

.u-landing-preview {
	background: var(--u-color-surface);
	border: 1px solid rgba(203, 213, 225, 0.9);
	border-radius: var(--u-radius-lg);
	box-shadow: 0 1.25rem 3rem rgba(15, 63, 122, 0.18);
	margin: 0;
	overflow: hidden;
}

.u-landing-preview img {
	display: block;
	height: auto;
	width: 100%;
}

.u-landing-preview-header {
	align-items: center;
	background: rgba(248, 250, 252, 0.9);
	border-bottom: 1px solid var(--u-color-border);
	display: flex;
	justify-content: space-between;
	padding: var(--u-space-4);
}

.u-landing-preview-header span {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	font-weight: 700;
}

.u-landing-preview-header strong {
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
}

.u-landing-preview-grid {
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	padding: var(--u-space-4);
}

.u-landing-preview-body {
	display: grid;
	grid-template-columns: 5.5rem minmax(0, 1fr);
	min-height: 24rem;
}

.u-landing-preview-sidebar {
	background: #10243c;
	display: grid;
	gap: var(--u-space-3);
	grid-auto-rows: 2.5rem;
	padding: var(--u-space-4);
}

.u-landing-preview-sidebar span {
	background: rgba(255, 255, 255, 0.18);
	border-radius: var(--u-radius-sm);
	display: block;
}

.u-landing-preview-sidebar span:first-child {
	background: #fff;
}

.u-landing-preview-main {
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	padding: var(--u-space-4);
}

.u-landing-preview-stat,
.u-landing-preview-list {
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-4);
}

.u-landing-preview-stat span,
.u-landing-preview-list span {
	color: var(--u-color-text-muted);
	display: block;
	font-size: var(--u-font-size-sm);
}

.u-landing-preview-stat strong {
	color: var(--u-color-text);
	display: block;
	font-size: 2rem;
	line-height: 1.1;
	margin-top: var(--u-space-2);
}

.u-landing-preview-list {
	display: grid;
	gap: var(--u-space-3);
	grid-column: 1 / -1;
}

.u-landing-preview-list div {
	border-bottom: 1px solid var(--u-color-border);
	padding-bottom: var(--u-space-3);
}

.u-landing-preview-list div:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.u-landing-preview-list strong {
	color: var(--u-color-text);
	display: block;
	font-size: var(--u-font-size-base);
	margin-bottom: var(--u-space-1);
}

.u-landing-preview-tile {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-2);
	min-height: 10rem;
	padding: var(--u-space-4);
}

.u-landing-preview-tile img {
	height: 2rem;
	width: 2rem;
}

.u-landing-preview-tile strong {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
}

.u-landing-preview-tile span {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	line-height: 1.35;
}

.u-landing-section {
	padding: var(--u-space-8) 0;
}

.u-landing-proof {
	align-items: center;
	background: rgba(255, 255, 255, 0.86);
	border: 1px solid rgba(203, 213, 225, 0.9);
	border-radius: var(--u-radius-md);
	box-shadow: 0 0.75rem 2rem rgba(36, 49, 66, 0.08);
	display: flex;
	gap: var(--u-space-5);
	justify-content: space-between;
	margin: 0 0 var(--u-space-4);
	padding: var(--u-space-4) var(--u-space-5);
}

.u-landing-proof-copy {
	display: grid;
	gap: var(--u-space-1);
}

.u-landing-proof-copy span {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.u-landing-proof-copy strong {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
}

.u-landing-proof img {
	display: block;
	height: auto;
	max-width: 10.0625rem;
	width: 34vw;
}

.u-landing-section-header {
	max-width: 45rem;
}

.u-landing-section h2,
.u-landing-cta h2 {
	font-size: 2.5rem;
}

.u-landing-section-header p,
.u-landing-audience p,
.u-landing-cta p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-3) 0 0;
}

.u-landing-card-grid {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-top: var(--u-space-5);
}

.u-landing-card {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-5);
}

.u-landing-card h3 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
	margin: 0 0 var(--u-space-3);
}

.u-landing-card p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0;
}

.u-landing-audience {
	align-items: start;
	border-top: 1px solid var(--u-color-border);
	display: grid;
	gap: var(--u-space-6);
	grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.8fr);
}

.u-landing-audience ul {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	list-style: none;
	margin: 0;
	padding: var(--u-space-5);
}

.u-landing-audience li {
	border-bottom: 1px solid var(--u-color-border);
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	padding: var(--u-space-3) 0;
}

.u-landing-audience li:first-child {
	padding-top: 0;
}

.u-landing-audience li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.u-landing-cta {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	margin: var(--u-space-6) 0 var(--u-space-8);
	padding: var(--u-space-6);
}

.u-features-page {
	padding: var(--u-space-6) 0 var(--u-space-8);
}

.u-features-hero {
	max-width: 48rem;
	padding: var(--u-space-4) 0 var(--u-space-6);
}

.u-features-hero h1 {
	color: var(--u-color-text);
	font-size: 3.25rem;
	line-height: 1.12;
	margin: 0;
}

.u-features-hero p:last-child {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) 0 0;
}

.u-features-nav {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 0 0 var(--u-space-6);
}

.u-features-nav-group {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--u-space-2);
	padding: var(--u-space-4);
}

.u-features-nav-group h2 {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	letter-spacing: 0.08em;
	line-height: 1.2;
	margin: 0 0 var(--u-space-2);
	text-transform: uppercase;
}

.u-features-nav-group a {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	display: flex;
	font-size: var(--u-font-size-sm);
	font-weight: 700;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	text-decoration: none;
}

.u-features-nav-group a:hover {
	background: var(--u-color-primary-soft);
	color: var(--u-color-primary-hover);
	text-decoration: none;
}

.u-features-nav-group .features_nav_selected {
	background: var(--u-color-primary);
	border-color: var(--u-color-primary);
	color: #fff;
}

.u-features-nav-group .features_nav_selected:hover {
	background: var(--u-color-primary-hover);
	color: #fff;
}

.u-features-detail {
	align-items: start;
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	display: grid;
	gap: var(--u-space-6);
	grid-template-columns: minmax(0, 1fr) minmax(16rem, 0.65fr);
	margin-bottom: var(--u-space-8);
	padding: var(--u-space-6);
}

.u-features-detail h2 {
	color: var(--u-color-text);
	font-size: 2.25rem;
	line-height: 1.15;
	margin: 0 0 var(--u-space-4);
}

.u-features-detail ul {
	display: grid;
	gap: var(--u-space-3);
	list-style: none;
	margin: 0;
	padding: 0;
}

.u-features-detail li {
	background: #f8fafc;
	border-left: 4px solid var(--u-color-primary);
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	line-height: var(--u-line-height);
	overflow-wrap: anywhere;
	padding: var(--u-space-3) var(--u-space-4);
}

.u-features-detail li table {
	border-collapse: collapse;
	max-width: 100%;
	width: 100% !important;
}

.u-features-detail li td {
	padding: var(--u-space-1) var(--u-space-2) var(--u-space-1) 0;
	vertical-align: top;
}

.u-features-detail-media {
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-4);
}

.u-features-detail-media img {
	display: block;
	height: auto;
	max-width: 100%;
}

.u-signup-page {
	padding: var(--u-space-6) 0 var(--u-space-8);
}

.u-signup-hero {
	max-width: 48rem;
	padding: var(--u-space-4) 0 var(--u-space-6);
}

.u-signup-hero h1 {
	color: var(--u-color-text);
	font-size: 3.25rem;
	line-height: 1.12;
	margin: 0;
}

.u-signup-hero p:last-child,
.u-signup-intro {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) 0 0;
}

.u-signup-pricing {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-bottom: var(--u-space-6);
}

.u-signup-price-card {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-5);
}

.u-signup-price-card h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
	margin: 0 0 var(--u-space-3);
}

.u-signup-price {
	color: var(--u-color-primary);
	font-size: 2.5rem;
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: var(--u-space-3);
}

.u-signup-price-card p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0;
}

.u-public-page #signup_container.u-signup-form-shell {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	box-shadow: 0 0.5rem 1.5rem rgba(36, 49, 66, 0.08);
	font-size: var(--u-font-size-base);
	margin: 0 0 var(--u-space-8);
	padding: var(--u-space-6);
	text-align: left;
	width: 100%;
}

.u-signup-form {
	display: grid;
	gap: var(--u-space-5);
}

.u-signup-form fieldset {
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-4);
	margin: 0;
	padding: var(--u-space-5);
}

.u-signup-form legend {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	font-weight: 800;
	line-height: 1.2;
	padding: 0 var(--u-space-2);
}

.u-signup-field {
	display: grid;
	gap: var(--u-space-2);
}

.u-signup-form label,
.u-signup-field label {
	background: transparent;
	color: var(--u-color-text);
	float: none;
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	margin: 0;
	width: auto;
}

.u-signup-form input[type="text"],
.u-signup-form input[type="password"] {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-3);
	width: 100%;
}

.u-signup-domain-control {
	align-items: center;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
}

.u-signup-domain-control input {
	border-radius: var(--u-radius-md) 0 0 var(--u-radius-md) !important;
}

.u-signup-domain-control .ututti {
	align-items: center;
	background: #f8fafc;
	border: 1px solid var(--u-color-border);
	border-left: 0;
	border-radius: 0 var(--u-radius-md) var(--u-radius-md) 0;
	color: var(--u-color-text-muted);
	display: inline-flex;
	font-size: var(--u-font-size-base);
	font-weight: 800;
	min-height: 2.75rem;
	padding: 0 var(--u-space-3);
}

.u-signup-form .tip {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	line-height: var(--u-line-height);
}

.u-signup-note {
	background: var(--u-color-primary-soft);
	border-radius: var(--u-radius-sm);
	padding: var(--u-space-3);
}

.u-public-page #payment_info {
	color: var(--u-color-text);
	font-weight: 400;
}

.u-public-page #payment_info p {
	background: var(--u-color-success-soft);
	border-radius: var(--u-radius-sm);
	margin: 0;
	padding: var(--u-space-3);
}

.u-signup-agreement {
	align-items: start;
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: auto minmax(0, 1fr);
	line-height: var(--u-line-height);
}

.u-signup-agreement input {
	margin-top: 0.3rem;
	min-height: 1.25rem;
	min-width: 1.25rem;
}

.u-public-page #signup_submit {
	padding-top: 0;
	text-align: left;
}

.u-public-page #signup_submit button {
	align-items: center;
	background: var(--u-color-primary);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	font-weight: 800;
	justify-content: center;
	min-height: 2.75rem;
	padding: var(--u-space-3) var(--u-space-5);
	text-shadow: none;
}

.u-public-page #signup_submit button:hover {
	background: var(--u-color-primary-hover);
	border-color: var(--u-color-primary-hover);
}

.u-public-page .login_error_box,
.u-public-page .success_box,
.u-public-page .error_box {
	border-radius: var(--u-radius-md);
	font-size: var(--u-font-size-sm) !important;
	margin: 0 0 var(--u-space-4);
	padding: var(--u-space-3) var(--u-space-4);
	text-align: left !important;
	width: 100%;
}

.u-public-page .login_error_box,
.u-public-page .error_box {
	background: var(--u-color-danger-soft);
	border: 1px solid #f5b5ae;
	color: var(--u-color-danger);
}

.u-public-page .success_box {
	background: var(--u-color-success-soft);
	border: 1px solid #acd4bd;
	color: var(--u-color-success);
}

.u-public-page .large_submit {
	align-items: center;
	background: var(--u-color-primary);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	font-weight: 700;
	justify-content: center;
	line-height: 1.2;
	margin: var(--u-space-2) 0;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-5);
	text-shadow: none;
}

.u-public-page .large_submit:hover {
	background: var(--u-color-primary-hover);
	border-color: var(--u-color-primary-hover);
}

.u-signup-status {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	margin: var(--u-space-8) auto;
	max-width: 44rem;
	padding: var(--u-space-6);
	text-align: left;
}

.u-signup-status h1 {
	color: var(--u-color-text);
	font-size: 2rem;
	line-height: 1.2;
	margin: 0 0 var(--u-space-4);
}

.u-signup-status p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-base);
	margin: var(--u-space-3) 0 0;
}

.u-signup-status-success {
	border-color: #9ed2b7;
}

.u-signup-status-error {
	border-color: #f5b5ae;
}

.u-public-page #main_modal.u-signup-processing {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	box-shadow: var(--u-shadow-card);
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	left: 50%;
	padding: var(--u-space-5);
	position: fixed;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 1000;
}

.u-utility-page {
	padding: var(--u-space-6) 0 var(--u-space-8);
}

.u-utility-hero {
	max-width: 48rem;
	padding: var(--u-space-4) 0 var(--u-space-6);
}

.u-utility-hero h1 {
	color: var(--u-color-text);
	font-size: 3.25rem;
	line-height: 1.12;
	margin: 0;
}

.u-utility-hero p:last-child {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) 0 0;
}

.u-utility-card {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	padding: var(--u-space-5);
}

.u-utility-card h2 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	line-height: 1.2;
	margin: 0 0 var(--u-space-3);
}

.u-utility-card p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-base);
	margin: var(--u-space-3) 0 0;
}

.u-contact-layout {
	display: grid;
	gap: var(--u-space-4);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.u-contact-social {
	grid-column: 1 / -1;
}

.u-contact-list {
	display: grid;
	gap: var(--u-space-4);
	margin: 0;
}

.u-contact-list dt {
	color: var(--u-color-text);
	font-weight: 800;
}

.u-contact-list dd {
	margin: var(--u-space-1) 0 0;
}

.u-utility-link-list {
	display: grid;
	gap: var(--u-space-2);
	list-style: none;
	margin: 0;
	padding: 0;
}

.u-utility-link-list a {
	align-items: center;
	border-radius: var(--u-radius-sm);
	display: inline-flex;
	min-height: 2.75rem;
}

.u-findgroup-search form {
	display: grid;
	gap: var(--u-space-3);
	margin: 0;
}

.u-findgroup-search label {
	color: var(--u-color-text);
	font-size: var(--u-font-size-sm);
	font-weight: 800;
}

.u-findgroup-search-row {
	display: grid;
	gap: var(--u-space-3);
	grid-template-columns: minmax(0, 1fr) auto;
}

.u-findgroup-search input[type="text"] {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	color: var(--u-color-text);
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-3);
	width: 100%;
}

.u-findgroup-search input[type="submit"] {
	background: var(--u-color-primary);
	border: 1px solid var(--u-color-primary);
	border-radius: var(--u-radius-md);
	color: #fff;
	cursor: pointer;
	font-family: var(--u-font-sans);
	font-size: var(--u-font-size-base);
	font-weight: 800;
	margin: 0;
	min-height: 2.75rem;
	padding: var(--u-space-3) var(--u-space-5);
	text-shadow: none;
}

.u-findgroup-search input[type="submit"]:hover {
	background: var(--u-color-primary-hover);
	border-color: var(--u-color-primary-hover);
}

.u-findgroup-search p {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0;
}

.u-findgroup-results {
	display: grid;
	gap: var(--u-space-3);
	margin-top: var(--u-space-5);
}

.u-findgroup-result {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-2);
	margin: 0;
	padding: var(--u-space-4);
}

.u-findgroup-result .result_code {
	color: var(--u-color-text-muted);
	float: none;
	font-size: var(--u-font-size-sm);
	letter-spacing: 0;
	line-height: var(--u-line-height);
	text-align: left;
}

.u-findgroup-result .result_code span,
.u-findgroup-result .result_group {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	font-weight: 800;
}

.u-findgroup-result .result_owner {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
}

.u-findgroup-empty {
	min-height: 18rem;
}

.u-legal-page {
	max-width: 56rem;
}

.u-legal-content {
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	line-height: 1.75;
	white-space: pre-line;
}

.u-support-layout,
.u-video-layout {
	align-items: start;
	display: grid;
	gap: var(--u-space-5);
	grid-template-columns: minmax(14rem, 0.35fr) minmax(0, 1fr);
}

.u-support-nav,
.u-video-nav {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	display: grid;
	gap: var(--u-space-4);
	margin: 0;
	padding: var(--u-space-4);
	width: auto;
}

.u-support-nav-group,
.u-video-nav-group {
	display: grid;
	gap: var(--u-space-2);
}

.u-support-nav ul {
	display: grid;
	gap: var(--u-space-2);
	list-style: none;
	margin: 0;
	padding: 0;
}

.u-support-nav .support_nav_header,
.u-video-nav .video_nav_header {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	letter-spacing: 0.08em;
	line-height: 1.2;
	margin: 0;
	padding: 0;
	text-transform: uppercase;
}

.u-support-nav a,
.u-video-nav a {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	display: flex;
	font-size: var(--u-font-size-sm);
	font-weight: 800;
	min-height: 2.75rem;
	padding: var(--u-space-2) var(--u-space-3);
	text-decoration: none;
}

.u-support-nav a:hover,
.u-video-nav a:hover {
	background: var(--u-color-primary-soft);
	color: var(--u-color-primary-hover);
	text-decoration: none;
}

.u-support-nav .sl_active,
.u-video-nav .video_nav_selected {
	background: var(--u-color-primary);
	border-color: var(--u-color-primary);
	color: #fff;
}

.u-support-nav .sl_active:hover,
.u-video-nav .video_nav_selected:hover {
	background: var(--u-color-primary-hover);
	color: #fff;
}

.u-support-body,
.u-video-content {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-md);
	margin: 0;
	padding: var(--u-space-5);
	width: auto;
}

.u-public-page #support_nav.u-support-nav,
.u-public-page #support_body.u-support-body {
	float: none;
	margin: 0;
	max-width: 100%;
	width: auto;
}

.u-public-page #support_info {
	background: var(--u-color-primary-soft);
	border-radius: var(--u-radius-sm);
	color: var(--u-color-text);
	float: none;
	font-size: var(--u-font-size-sm);
	margin: 0 0 var(--u-space-4);
	padding: var(--u-space-3);
}

.u-support-body .support_content_header {
	border-bottom: 1px solid var(--u-color-border);
	color: var(--u-color-text);
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.2;
	margin: 0;
	padding: 0 0 var(--u-space-4);
}

.u-support-body .support_content {
	background: transparent;
	color: var(--u-color-text);
	font-size: var(--u-font-size-base);
	padding: var(--u-space-4) 0 0;
}

.u-support-body .support_content p,
.u-support-body .support_content h3 {
	max-width: 48rem;
}

.u-support-body .support_content h3 {
	color: var(--u-color-text);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-5) 0 var(--u-space-2);
}

.u-support-body .support_content img,
.u-support-body .support_content iframe {
	display: block;
	height: auto;
	max-width: 100%;
}

.u-public-page #support_body.u-support-body .support_ss {
	height: auto;
	max-width: calc(100% - 20px);
}

.u-support-body .support_content iframe {
	aspect-ratio: 16 / 9;
	border: 0;
	width: 100%;
}

.u-video-content .fheader_video {
	background: transparent;
	border-bottom: 1px solid var(--u-color-border);
	color: var(--u-color-text);
	font-size: 2rem;
	font-weight: 800;
	height: auto;
	line-height: 1.2;
	margin: 0 0 var(--u-space-4);
	padding: 0 0 var(--u-space-4);
}

.u-video-frame {
	aspect-ratio: 16 / 9;
	background: #0f172a;
	border-radius: var(--u-radius-md);
	margin: 0;
	overflow: hidden;
	width: 100%;
}

.u-video-frame iframe {
	border: 0;
	display: block;
	height: 100%;
	width: 100%;
}

.u-error-page {
	display: grid;
	min-height: 28rem;
	place-items: center;
}

.u-error-card {
	background: var(--u-color-surface);
	border: 1px solid var(--u-color-border);
	border-radius: var(--u-radius-lg);
	margin: 0;
	max-width: 44rem;
	padding: var(--u-space-6);
	text-align: left;
}

.u-error-card h1 {
	color: var(--u-color-text);
	font-size: 3rem;
	line-height: 1.12;
	margin: 0;
}

.u-error-card p:not(.u-landing-kicker) {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-lg);
	margin: var(--u-space-4) 0 0;
}

.u-public-page #top_wrapper,
.u-public-page .clearboth {
	display: none;
}

.u-public-page #footer.u-public-footer {
	color: var(--u-color-text-muted);
	font-size: var(--u-font-size-sm);
	margin: 0 auto;
	max-width: 72rem;
	padding: var(--u-space-5);
	text-align: center;
}

.u-public-footer nav {
	align-items: center;
	display: inline-flex;
	gap: var(--u-space-4);
	justify-content: center;
	margin-top: var(--u-space-2);
}

@media (max-width: 48rem) {
	.u-public-page {
		background:
			linear-gradient(180deg, #173657 0, #173657 15rem, transparent 15rem),
			radial-gradient(circle at 84% 8%, rgba(56, 163, 165, 0.18), transparent 18rem),
			linear-gradient(180deg, #eef5fb 0%, #f8fafc 42%, #f3f6f9 100%);
	}

	.u-public-page #container {
		padding: 0 var(--u-space-4);
	}

	.u-public-header {
		align-items: flex-start;
		flex-direction: column;
		gap: var(--u-space-3);
		min-height: 15rem;
	}

	.u-public-page #overall_navbar {
		justify-content: flex-start;
		width: 100%;
	}

	.u-public-page #overall_navbar a {
		flex: 1 1 9rem;
	}

	.u-landing-hero,
	.u-landing-audience {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-landing-hero {
		padding: var(--u-space-6);
	}

	.u-landing-card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.u-landing-hero h1 {
		font-size: 3rem;
		max-width: none;
	}

	.u-landing-section h2,
	.u-landing-cta h2 {
		font-size: 2.25rem;
	}

	.u-landing-proof {
		align-items: flex-start;
		flex-direction: column;
		gap: var(--u-space-3);
	}

	.u-landing-proof img {
		width: 10.0625rem;
	}

	.u-features-hero h1 {
		font-size: 2.5rem;
	}

	.u-features-nav,
	.u-features-detail {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-signup-hero h1 {
		font-size: 2.5rem;
	}

	.u-signup-pricing {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-contact-layout,
	.u-findgroup-search-row,
	.u-support-layout,
	.u-video-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-utility-hero h1 {
		font-size: 2.5rem;
	}
}

@media (min-width: 30.0625rem) and (max-width: 48rem) {
	.u-landing-hero {
		gap: var(--u-space-5);
		grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.8fr);
	}

	.u-landing-hero h1 {
		font-size: 2.5rem;
	}

	.u-landing-intro {
		font-size: var(--u-font-size-base);
	}

	.u-landing-preview-tile {
		min-height: 7rem;
	}
}

@media (max-width: 30rem) {
	.u-public-page #container {
		padding: 0 var(--u-space-3);
	}

	.u-public-page #overall_navbar a {
		flex-basis: 8.5rem;
	}

	.u-landing-hero {
		gap: var(--u-space-4);
		padding: var(--u-space-5);
	}

	.u-landing-hero h1 {
		font-size: 1.9rem;
		max-width: none;
	}

	.u-landing-section h2,
	.u-landing-cta h2 {
		font-size: 1.85rem;
	}

	.u-landing-intro,
	.u-landing-section-header p,
	.u-landing-audience p,
	.u-landing-cta p {
		font-size: var(--u-font-size-base);
	}

	.u-landing-actions {
		width: 100%;
	}

	.u-landing-button {
		flex: 1 1 9rem;
		padding-left: var(--u-space-3);
		padding-right: var(--u-space-3);
	}

	.u-landing-card-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-landing-preview-tile {
		align-content: center;
		gap: var(--u-space-1);
		justify-items: center;
		min-height: 5.5rem;
		padding: var(--u-space-2);
		text-align: center;
	}

	.u-landing-preview-tile img {
		height: 1.5rem;
		width: 1.5rem;
	}

	.u-landing-preview-tile strong {
		font-size: var(--u-font-size-sm);
	}

	.u-landing-preview-tile span {
		display: none;
	}

	.u-landing-section {
		padding: var(--u-space-6) 0;
	}

	.u-landing-cta {
		margin-bottom: var(--u-space-6);
		padding: var(--u-space-5);
	}

	.u-features-page {
		padding-top: var(--u-space-4);
	}

	.u-features-hero h1 {
		font-size: 2rem;
	}

	.u-features-hero p:last-child {
		font-size: var(--u-font-size-base);
	}

	.u-features-detail {
		padding: var(--u-space-4);
	}

	.u-features-detail h2 {
		font-size: 1.75rem;
	}

	.u-signup-page {
		padding-top: var(--u-space-4);
	}

	.u-signup-hero h1 {
		font-size: 2rem;
	}

	.u-signup-hero p:last-child,
	.u-signup-intro {
		font-size: var(--u-font-size-base);
	}

	.u-public-page #signup_container.u-signup-form-shell,
	.u-signup-form fieldset,
	.u-signup-status {
		padding: var(--u-space-4);
	}

	.u-signup-domain-control {
		grid-template-columns: minmax(0, 1fr);
	}

	.u-signup-domain-control input,
	.u-signup-domain-control .ututti {
		border-radius: var(--u-radius-md) !important;
	}

	.u-signup-domain-control .ututti {
		border-left: 1px solid var(--u-color-border);
		border-top: 0;
		justify-content: flex-start;
	}

	.u-public-page #signup_submit button {
		width: 100%;
	}

	.u-utility-page {
		padding-top: var(--u-space-4);
	}

	.u-utility-hero h1 {
		font-size: 2rem;
	}

	.u-utility-hero p:last-child {
		font-size: var(--u-font-size-base);
	}

	.u-utility-card {
		padding: var(--u-space-4);
	}

	.u-error-card {
		padding: var(--u-space-5);
	}

	.u-error-card h1 {
		font-size: 2rem;
	}

	.u-findgroup-search input[type="submit"] {
		width: 100%;
	}
}
