.state-layer {
	background:	linear-gradient(rgba(var(--md-sys-color-primary-opacity), .05), rgba(var(--md-sys-color-primary-opacity), .05)),
				linear-gradient(var(--md-sys-color-surface-light), var(--md-sys-color-surface-light))!important;
}
.state-layer:hover {
	background:	linear-gradient(rgba(var(--md-sys-color-primary-opacity), .11), rgba(var(--md-sys-color-primary-opacity), .11)),
				linear-gradient(var(--md-sys-color-surface-light), var(--md-sys-color-surface-light))!important;
}
/* BUTTONS */
.m3.button-wrap {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}
.m3.button {
	display: inline-flex!important;
	align-items: center;
	justify-content: center;
	height: 40px!important;
	width: auto!important;
	min-width: 64px!important;
	border-radius: 20px!important;
	padding: 0 24px!important;
	margin: 8px!important;
	font-family: 'Lexend', sans-serif;
	line-height: normal!important;
	font-size: 14px!important;
	letter-spacing: 0.1px!important;
	font-weight: 500!important;
	overflow: hidden;
	text-transform: none;
	text-decoration: none!important;
	border: 0!important;
	white-space: nowrap;
	cursor: pointer!important;
	flex-shrink: 0;
}
input.m3.button {
	width: unset!important;
	text-align: center;
	box-sizing: initial;
	cursor: text;
	padding-left: 15px;
	padding-right: 15px;
}
.m3.button.with-icon {
	padding: 0 24px 0 16px!important;
}
.m3.button.with-icon i, .m3.button.with-icon::before {
	margin-right: 8px;
	font-size: 24px;
	font-family: 'Material Icons Outlined'!important;
	font-style: normal;
}

.m3.button label {
	display: inline-block;
	font-size: 12px;
	white-space: nowrap;
	overflow: hidden;
	pointer-events: none;
}

.m3.button i.trailingIcon {
	height: 20px;
	width: 20px;
	display: flex;
	border-radius: 20px;
	flex: 0 0 20px;
	overflow: hidden;
	margin: 0 -16px 0 8px!important;
}

.m3.button.filled {
	background: var(--md-sys-color-primary-light);
	color: var(--md-sys-color-on-primary-light);
}
.m3.button.filled:hover {
	/*box-shadow:  0px 1px 3px 0px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 2px 1px -1px rgba(0, 0, 0, 0.12);*/
}
.m3.button.filled.tonal {
	background: var(--md-sys-color-secondary-container-light)!important;
	color: var(--md-sys-color-on-secondary-container-light)!important;
}
.m3.button.text {
	background: none;
	color: var(--md-sys-color-primary-light);
}
.m3.button.text:hover {
	background: rgba(var(--md-sys-color-primary-opacity), 0.08);
	color: var(--md-sys-color-primary-light);
}
*:checked + .m3.button.text {
	background: rgba(var(--md-sys-color-primary-opacity), 0.14);
	color: var(--md-sys-color-primary-light);
}
.m3.button.elevated {
	background: var(--md-sys-color-surface-light);
	box-shadow: inset 0 0 100vmax rgba(var(--md-sys-color-primary-opacity), 0.08), 0px 1px 3px 0px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 2px 1px -1px rgba(0, 0, 0, 0.12);
	color: var(--md-sys-color-primary-light);
}
.m3.button.elevated:hover {
	box-shadow: inset 0 0 100vmax rgba(var(--md-sys-color-primary-opacity), 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12);
}
.m3.button.outlined {
	background: none;
	color: var(--md-sys-color-primary-light);
	border: 1px solid var(--md-ref-palette-neutral-variant50)!important;
	font-weight: 500!important;
}
.m3.button.outlined strong {
	font-weight: 500!important;
}




/* CHIPS */

.m3.chip {
	display: inline-flex!important;
	flex-direction: row!important;
	align-items: center;
	justify-content: center;
	height: 32px!important;
	width: auto!important;
	border-radius: 8px!important;
	padding: 0 16px!important;
	margin: 4px!important;
	font-family: 'Inter', sans-serif;
	line-height: 12px!important;
	font-size: 14px!important;
	letter-spacing: 0.1px!important;
	font-weight: 500!important;
	overflow: hidden;
	box-sizing: border-box;
	flex: 0 0 auto;
	min-width: 64px;
	border: 1px solid var(--md-ref-palette-neutral-variant60);
}
.m3.chip.with-icon {
	padding: 0 16px 0 8px!important;
}
.m3.chip.with-icon i, .m3.chip.with-icon::before, .m3.chip.with-icon strong::before {
	margin-right: 8px!important;
	font-size: 18px!important;
	font-family: 'Material Icons Outlined'!important;
	width: 18px!important;
	height: auto!important;
	margin: 0 8px 0 0!important;
	opacity: 1!important;
	display: flex;
	align-items: center;
	justify-content: center;
}

.m3.chip.filled {
	background: var(--md-sys-color-primary-light);
	color: var(--md-sys-color-on-primary-light);
	border: 0;
}
.m3.chip.filled:hover {
	box-shadow:  0px 1px 3px 0px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 2px 1px -1px rgba(0, 0, 0, 0.12);
}
.m3.chip.filled.tonal {
	background: var(--md-sys-color-secondary-container-light);
	color: var(--md-sys-color-on-secondary-container-light);
}
.m3.filter.chip {
	background: var(--md-sys-color-surface-light);
	color: var(--md-sys-color-on-surface-light);
}




/* CARDS */
.m3.card {
	border-radius: 12px;
	overflow: hidden;
	border: 0;
	padding: 16px;
	position: relative;
}
.m3.card.elevated {
    background: var(--md-sys-color-surface-light);
	box-shadow:  0px 1px 3px 0px rgba(0, 0, 0, 0.2),
    0px 1px 1px 0px rgba(0, 0, 0, 0.14),
    0px 2px 1px -1px rgba(0, 0, 0, 0.12);
}
.m3.card.elevated:hover {
	box-shadow:  0px 1px 5px 0px rgba(0, 0, 0, 0.2),
    0px 2px 2px 0px rgba(0, 0, 0, 0.14),
    0px 3px 1px -2px rgba(0, 0, 0, 0.12);
}
.m3.card.elevated::before {
	content: "";
	display: block;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(var(--md-sys-color-primary-opacity), 0.08);
	position: absolute;
	width: unset;
	height: unset;
	border: 0;
	transform: none;
	pointer-events: none;
}
.m3.card.dense {
    display: flex;
    align-items: center;
    text-decoration: none;
    height: 56px;
    padding: 0;
    border-radius: 12px;
    border: 0;
    overflow: hidden;
}
.m3.card.dense:hover {
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2),
    0px 4px 5px 0px rgba(0, 0, 0, 0.14),
    0px 1px 10px 0px rgba(0, 0, 0, 0.12);
}
.m3.card.filled {
    background: var(--md-sys-color-surface-variant-light);
    color: var(--md-sys-color-on-surface-variant-light);
}
.m3.card.dense .text {
    order: 2;
    padding: 0;
    width: auto;
    font-size: 12px;
    letter-spacing: 0;
    font-weight: 600;
    flex: 1 1 auto;
    line-height: initial;
	max-height: 100%;
	padding-right: 8px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}
.m3.card.dense::before {
    background: var(--md-sys-color-primary-light);
    color: var(--md-sys-color-on-primary-light);
    height: 24px;
    width: 24px;
    padding: 0;
    position: relative;
    margin: 16px;
    top: unset;
    order: 1;
    opacity: 1;
    line-height: 40px!important;
    flex: 0 0 24px;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    left: 0;
}
.m3.card.dense .image {
    order: 3;
    width: 56px;
    background: #fff;
    border-radius: 0;
    height: 56px;
    flex: 0 0 56px;
    max-width: unset;
    display: flex;
    align-items: center;
    justify-content: center;
}
.m3.card.dense .image::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgb(0 0 0 / 5%);
	pointer-events: none;
}








































































































.m3.header {
    padding: 0 40px;
	margin: 16px 0;
    border-radius: 64px;
    background-repeat: no-repeat;
    background-position: 0 50%;
    background-size: cover;
    color: var(--md-sys-color-on-background-light);
}
.m3.header .wrapper {
    display: flex;
    align-items: center;
    max-width: 1024px;
    margin: 0 auto;
    min-height: 240px;
}
.m3.header .title {
	width: 50%;
	padding: 40px 0;
}
.m3.header h1 {
    margin: 0;
    text-transform: none;
}
.m3.header h1::after {
	content: none;
}
.m3.header .description {
    max-width: 760px;
    margin-top: 16px;
}
.m3.header .content {
    display: flex;
    align-self: stretch;
    justify-content: center;
    width: 50%;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    line-height: 0;
    text-align: center;
    contain: content;
}