:root{
	--vh: 1vh;
}
*{
	box-sizing: border-box;
	scrollbar-width: var(--scrollbar-width);
	scrollbar-color: var(--scrollbar-color);
}
html{
	font-size: var(--base-font-size);
	--currentColor: var(--color-main);
}
body{
	background: var(--background);
	color: var(--text);
	margin: 0;
	padding: 0;
	height: 100vh;
	font-family: var(--font-family);
	font-weight: var(--font-regular);
	font-size: var(--font-size);
	font-variation-settings: "wdth" var(--font-width);
}
a, a:visited, a:hover, a:active{
	text-decoration: none;
	color: inherit;
}
h1{
	font-size: 10rem;
	font-family: var(--font-title-family);
	font-weight: var(--font-title-bold);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
h2{
	font-size: 6rem;
	font-family: var(--font-title-family);
	font-weight: var(--font-title-regular);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
h3{
	font-size: 4rem;
	font-family: var(--font-title-family);
	font-weight: var(--font-title-regular);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
h4{
	font-size: 3rem;
	font-family: var(--font-family);
	font-weight: var(--font-bold);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
h5{
	font-size: 2rem;
	font-family: var(--font-title-family);
	font-weight: var(--font-regular);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
h6{
	font-size: 1.5rem;
	font-family: var(--font-family);
	font-weight: var(--font-regular);
	font-variation-settings: "wdth" var(--font-title-width);
	margin: 0;
}
[color-second]{--currentColor: var(--color-second);}
[color-third]{--currentColor: var(--color-third);}
[color-flash]{--currentColor: var(--color-flash);}
[color-info]{--currentColor: var(--color-info);}
[color-success]{--currentColor: var(--color-success);}
[color-error]{--currentColor: var(--color-error);}
[color-disabled]{--currentColor: var(--color-disabled);}
[color-text]{--currentColor: var(--text);}
[color-facebook]{--currentColor: var(--color-social-facebook);}
[color-twitter]{--currentColor: var(--color-social-twitter);}
[color-youtube]{--currentColor: var(--color-social-youtube);}
[color-linkedin]{--currentColor: var(--color-social-linkedin);}
[color-instagram]{--currentColor: var(--color-social-instagram);}
[color-tiktok]{--currentColor: var(--color-social-tiktok);}
[color-snapchat]{--currentColor: var(--color-social-snapchat);}
[color-whatsapp]{--currentColor: var(--color-social-whatsapp);}
[color-reddit]{--currentColor: var(--color-social-reddit);}
[color-twitch]{--currentColor: var(--color-social-twitch);}
[color-discord]{--currentColor: var(--color-social-discord);}
[color-spotify]{--currentColor: var(--color-social-spotify);}
my-form{
	display: block;
	padding: var(--padding);
}
.my-input{
	display: block;
	width: 250px;
	margin: var(--margin-medium) 0;
	padding: var(--padding) 0 var(--padding-medium) 0;
	position: relative;
	font-size: var(--font-size);
}
my-form[layout="one-column"]{
	padding: var(--padding-medium);
}
my-form[layout="one-column"] .my-input{
	width: 100%;
}
.my-input[xsmall],
.my-input[small]{
	padding: 0;
	margin: 0;
}
.my-input fieldset{
	border: var(--border-width) solid;
	border-radius: var(--border-radius-medium);
	padding: 0 var(--padding-medium) var(--padding-medium);
	color: var(--text-medium);
	transition: .3s;
	margin: 0;
}
.my-input-dropdown-active{
	z-index: 10000;
}
.my-input[filled] fieldset,
.my-input[text] fieldset{
	border: var(--border-width) solid transparent;
	padding: 0;
}
.my-input[filled] .my-input-flexbox,
.my-input[text] .my-input-flexbox{
	padding: var(--padding-medium);
	border-radius: var(--border-radius-medium);
	transition: .3s;

}
.my-input[xsmall] .my-input-flexbox,
.my-input[small] .my-input-flexbox{
	gap: var(--padding);
}
.my-input[filled] .my-input-flexbox{
	background: color-mix(in srgb, var(--text) 5%, transparent);
}
.my-input input::placeholder{
	color: var(--text-medium);
}
.my-input[filled]:hover .my-input-flexbox,
.my-input[text]:hover .my-input-flexbox{
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
	color: var(--currentColor);
}
.my-input[filled].my-input-dropdown-active .my-input-flexbox,
.my-input[text].my-input-dropdown-active .my-input-flexbox{
	background: color-mix(in srgb, var(--currentColor) 25%, transparent);
}
.my-input fieldset legend{
	padding: 0 var(--padding-medium);
}
.my-input label{
	display: block;
	width: 100%;
}
.my-input-flexbox{
	display: flex;
	width: 100%;
	align-items: center;
	gap: var(--padding-medium);
}
.my-input-flexbox-reverse .my-input-field{
	order: 0;
}
.my-input-flexbox-reverse .my-input-icon{
	order: 1;
}
.my-input input{
	display: block;
	height: var(--input-height);
	width: 100%;
	border: none;
	transition: .3s;
	color: var(--text);
	font-family: var(--font-family);
	padding: 0;
	background: transparent;
	font-size: inherit;
}
.my-input[xsmall] input{height: calc(var(--input-height-small) * 0.8);}
.my-input[small] input{height: var(--input-height-small);}
.my-input[large] input{height: var(--input-height-large);}

.my-input input:active, .my-input input:focus{
	outline: none;
}
.my-input-icon{
	height: var(--input-height);
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--border-circle);
	transition: .3s;
}
.my-input[xsmall] .my-input-icon{height: calc(var(--input-height-small) * 0.8);}
.my-input[small] .my-input-icon{height: var(--input-height-small);}
.my-input[large] .my-input-icon{height: var(--input-height-large);}

.my-input[iconclick] .my-input-icon{
	cursor: pointer;
}
.my-input[iconclick] .my-input-icon:hover{
	background: color-mix(in srgb, var(--currentColor) 30%, transparent);
}
my-select, my-select fieldset{
	cursor: pointer;
}
my-select > option{
	display: none;
}
my-select input{
	pointer-events: none;
}
.my-input-dropdown{
	display: none;
	position: absolute;
	left: 0;
	right: 0;
	background: var(--background-lvl3);
	box-shadow: var(--box-shadow-lvl3);
	top: calc(var(--input-height) + 30px);
	border-radius: var(--border-radius-medium);
	color: var(--text);
	overflow: hidden;
}
.my-input-dropdown-scroll{
	height: 100%;
	overflow: auto;
}
.my-input-dropdown-active .my-input-dropdown{
	display: block;
}
.my-input-dropdown-active .my-input-icon{
	transform: rotate(180deg);
}
.my-input-dropdown-item{
	padding: var(--padding-medium);
	transition: .3s;
	text-align: left;
}
.my-input-dropdown-item:hover{
	background: var(--text-invisible);
}
.my-input-dropdown-item.my-input-dropdown-item-selected{
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
}
.my-input-dropdown-item.my-input-dropdown-item-selected:hover{
	background: color-mix(in srgb, var(--currentColor) 25%, transparent);
}
.my-input:hover fieldset{
	color: var(--text);
}
.my-input fieldset:has(input:focus), .my-input.my-input-dropdown-active fieldset{
	color: var(--currentColor);
}
.my-input.my-invalid fieldset{
	color: var(--color-error);
}
.my-input .my-input-error{
	font-size: var(--font-size-small);
	color: var(--color-error);
	padding: var(--padding);
}
.my-input-date-display{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: var(--padding);
	width: 100%;
}
.my-input-date-display input{
	width: 40px;
	text-align: center;
}
.my-input-date-display input::placeholder{
	color: var(--text-disabled);
}
my-checkbox{
	--checkbox-size: 16px;
}
my-checkbox[small], my-checkbox[xsmall]{
	--checkbox-size: 12px;
	font-size: var(--font-size-small);
}
my-checkbox[large]{
	--checkbox-size: 18px;
	font-size: var(--font-size-medium);
}
my-checkbox label.my-checkbox{
	display: flex;
}
.my-checkbox{
	display: flex;
	align-items: flex-start;
	width: fit-content;
	gap: var(--padding-medium);
	color: var(--text-medium);
	transition: .3s;
	padding: var(--padding-medium) 0;
}
my-checkbox input[type="checkbox"]{
	width: var(--checkbox-size);
	height: var(--checkbox-size);
	background: transparent;
	color: var(--text-medium);
	border: var(--border-width-medium) solid;
	appearance: none;
	border-radius: var(--border-radius);
	outline: calc(var(--border-width-large) * 1.5) solid  color-mix(in srgb, var(--currentColor) 0%, transparent);
	transition: .3s;
	margin: 0;
	flex-shrink: 0;
}
my-checkbox input[type="checkbox"]:checked{
	appearance: revert;
	accent-color: var(--currentColor);
}
.my-checkbox:hover{
	color: var(--text);
}
.my-checkbox:hover input[type="checkbox"]{
	color: var(--text);
	outline: calc(var(--border-width-large) * 1.5) solid  color-mix(in srgb, var(--currentColor) 20%, transparent);
}
.my-button{
	height: var(--button-height);
	border: var(--border-width) solid var(--currentColor);
	border-radius: var(--border-radius-medium);
	padding: 0 var(--padding-medium);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--font-size);
	color: var(--currentColor);
	transition: .3s;
	cursor: pointer;
	width: fit-content;
	user-select: none;
	gap: var(--padding-medium);
}
.my-button:hover{
	background: var(--currentColor);
	color: var(--text);
}
.my-button:active{
	background: color-mix(in srgb, var(--currentColor) 85%, #000);
}
.my-button[large]{
	height: var(--button-height-large);
	padding: 0 var(--padding-large);
}
.my-button[small]{
	height: var(--button-height-small);
	padding: 0 var(--padding);
}
.my-button[xsmall]{
	height: calc(var(--button-height-small) * 0.8);
	padding: 0 var(--padding);
}
.my-button[rounded]{
	padding: 0;
	aspect-ratio: 1/1;
	border-radius: var(--border-circle);
}
.my-button[text]{
	border: var(--border-width) solid transparent;
}
.my-button[text]:hover{
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
	color: var(--currentColor);
}
.my-button[text]:active{
	background: color-mix(in srgb, var(--currentColor) 35%, transparent);
	color: var(--currentColor);
}
.my-button[filled]{
	color: var(--currentColor);
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
	border: var(--border-width) solid transparent;
}
.my-button[filled]:hover{
	background: color-mix(in srgb, var(--currentColor) 25%, transparent);
}
.my-button[filled]:active{
	background: color-mix(in srgb, var(--currentColor) 70%, #000);
}
.my-button[square]{
	aspect-ratio: 1/1;
	padding: 0;
}

/* == TOOLTIP == */
.my-tooltip-box{
	--my-ui-background-color: var(--background-lvl2);
	--my-ui-color: var(--text);
	position: fixed;
	display: none;
	z-index: 10000;
	opacity: 0;
	transition: opacity 1s ease-in-out;
	max-width: 400px;
}
.my-tooltip-box.my-tooltip-reverse{
	--my-ui-background-color: var(--background-reverse);
	--my-ui-color: var(--text-secondary);
}
.my-tooltip-box.my-tooltip-success{
	--my-ui-background-color: var(--color-success);
	--my-ui-color: var(--text);
}
.my-tooltip-box.my-tooltip-error{
	--my-ui-background-color: var(--color-error);
	--my-ui-color: var(--text);
}
.my-tooltip-box.my-tooltip-info{
	--my-ui-background-color: var(--color-info);
	--my-ui-color: var(--text);
}

.my-tooltip-box.my-active{
	display: block;
	opacity: 1;
}
.my-tooltip{
	background: var(--my-ui-background-color);
	color: var(--my-ui-color);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow-lvl2);
	display: flex;
	align-items: stretch;
	justify-content: center;
	pointer-events: none;
}
.my-tooltip-text{
	padding: var(--padding-medium) var(--padding-large);
	display: flex;
	align-items: center;
	text-align: justify;
	justify-content: center;
}
.my-tooltip-icon{
	padding: var(--padding-medium);
	font-size: var(--font-size-large);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background: var(--text-secondary-invisible);
}
.my-tooltip-box:not(.my-tooltip-arrowless) .my-tooltip::before{
	content: "";
	position: absolute;
	border-width: var(--padding-medium);
	border-style: solid;
}
.my-tooltip-top:not(.my-tooltip-arrowless) .my-tooltip::before{
	bottom: calc(var(--padding-large)* -1);
	left: 50%;
	transform: translateX(-50%);
	border-color: var(--my-ui-background-color) transparent transparent transparent;
}
.my-tooltip-bottom:not(.my-tooltip-arrowless)  .my-tooltip::before{
	top: calc(var(--padding-large)* -1);
	left: 50%;
	transform: translateX(-50%);
	border-color: transparent transparent var(--my-ui-background-color) transparent;
}
.my-tooltip-left:not(.my-tooltip-arrowless) .my-tooltip::before {
	top: 50%;
	right: calc(var(--padding-large)* -1);
	transform: translateY(-50%);
	border-color: transparent transparent transparent var(--my-ui-background-color);
}
.my-tooltip-right:not(.my-tooltip-arrowless) .my-tooltip::before {
	top: 50%;
	left: calc(var(--padding-large)* -1);
	transform: translateY(-50%);
	border-color: transparent var(--my-ui-background-color) transparent transparent;
}

/* == TOAST == */
.my-toast-box {
	--my-ui-background-color: var(--background-lvl5);
	--my-ui-color: var(--text);
	position: fixed;

	opacity: 0;
	transition: opacity 0.3s, transform 0.3s;
	z-index: 1000;

}
.my-toast-bottom-left, .my-toast-bottom-right, .my-toast-bottom{
	transform: translateY(20px);
	bottom: 20px;
}
.my-toast-top-left, .my-toast-top-right, .my-toast-top{
	transform: translateY(-20px);
	top: 20px;
}
.my-toast-bottom-left, .my-toast-top-left{
	left: 20px;
}
.my-toast-bottom-right, .my-toast-top-right{
	right: 20px;
}
.my-toast-top {
	left: 50%;
	transform: translateX(-50%) translateY(-20px);
}
.my-toast-bottom {
	left: 50%;
	transform: translateX(-50%) translateY(20px);
}
.my-toast-box.my-toast-active {
	opacity: 1;
	transform: translateY(0);
}
.my-toast-top.my-toast-active, .my-toast-bottom.my-toast-active{
	transform: translateX(-50%) translateY(0);
}
.my-toast{
	display: flex;
	align-items: stretch;
	justify-content: center;
	background-color: var(--my-ui-background-color);
	color: var(--my-ui-color);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow-lvl2);
}
.my-toast-text{
	padding: var(--padding-large);
	width: 300px;
	min-height: 60px;
	display: flex;
	align-items: center;
	text-align: left;
	justify-content: flex-start;
}
.my-toast-icon{
	padding: var(--padding-medium);
	font-size: var(--font-size-large);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background: var(--text-secondary-invisible);
}
.my-ui-reverse{
	--my-ui-background-color: var(--background-reverse);
	--my-ui-color: var(--text-secondary);
}
.my-ui-success{
	--my-ui-background-color: var(--color-success);
	--my-ui-color: var(--text);
}
.my-ui-error{
	--my-ui-background-color: var(--color-error);
	--my-ui-color: var(--text);
}
.my-ui-info{
	--my-ui-background-color: var(--color-info);
	--my-ui-color: var(--text);
}

/* == GRID == */
my-grid{
	height: 100%;
	width: 100%;
	position: relative;
}
.my-grid-content{
	height: 100%;
	width: 100%;
	display: flex;
	align-items: stretch;
	gap: var(--padding-large);
	--filter-panel-width: 260px;
}
.my-grid-main{
	height: 100%;
	width: 100%;
	position: relative;
	display: flex;
	flex-direction: column;
	border: var(--border-width) solid var(--text-invisible);
	border-radius: var(--border-radius-large);
	transition: width .3s;
}
.my-grid-filterpanel.my-grid-filterpanel-open ~ .my-grid-main{
	width: calc(100% - var(--filter-panel-width));
}
.my-grid-filterpanel{
	height: 100%;
	width: var(--filter-panel-width);
	border: var(--border-width) solid var(--text-invisible);
	border-radius: var(--border-radius-large);
	display: none;
}
.my-grid-filterpanel.my-grid-filterpanel-open{
	display: block;
}
.my-grid-error-modal{
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--padding-medium);
}
.my-grid-error{
	padding: var(--padding-large);
	border-radius: var(--border-radius-medium);
	background: var(--color-error-dark);
	text-align: center;
}
.my-grid-header{
	border-bottom: var(--border-width) solid var(--text-invisible);
}
.my-grid-topbar:has(*) {
	padding: var(--padding) 0;
	margin: 0 var(--margin-medium);
	display: flex;
	align-items: center;
	gap: var(--padding-medium);
	justify-content: flex-start;
}
my-grid:not(.my-grid-mobile) .my-grid-topbar:has(*) {
	border-bottom: var(--border-width) solid var(--text-invisible);
}
.my-grid-headers-scroll{
	overflow-x: auto;
	scrollbar-width: none;
}
.my-grid-headers-scrollbar-filler{
	display: none;
}
.my-grid-hcell{
	font-weight: var(--font-bold);
	flex: 1;
	padding: var(--padding);
	text-align: left;
}
.my-grid-col-header{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: var(--padding);
	border-radius: var(--border-radius-medium);
	transition: .3s;
	cursor: pointer;
	gap: var(--padding-medium);
	height: 100%;
}
.my-grid-title{
	font-size: var(--font-size-medium);
}
.my-grid-topbar my-input.my-grid-search-input{
	margin-left: auto;
}
.my-grid-headers-sort{
	display: none;
}
.my-grid-col-sort-active .my-grid-headers-sort{
	display: inherit;
}
.my-grid-headers-sort-desc{
	transform: rotate(180deg);
}
.my-grid-hcell:hover .my-grid-col-header.my-grid-col-sortable:not(.my-grid-col-sort-active) .my-grid-headers-sort{
	display: inherit;
	--currentColor: var(--text-disabled);
}
.my-grid-headers-menu{
	cursor: pointer;
	opacity: 0;
	pointer-events: none;
	margin-left: auto;
}
.my-grid-hcell:hover .my-grid-headers-menu{
	opacity: 1;
	pointer-events: initial;
}
.my-grid-hcell:hover .my-grid-col-header{
	background: color-mix(in srgb, var(--text) 5%, transparent);
}
.my-grid-col-filter{
	width: 100%;
}
.my-grid-col-filter .my-input-flexbox{
	padding: var(--padding) !important;
}
my-grid:not(.my-grid-mobile) .my-grid-body{
	background: color-mix(in srgb, var(--text) 5%, transparent);
}
.my-grid-body{
	flex-grow: 1;
	overflow: hidden;
}
.my-grid-rows{
	height: 100%;
	overflow: auto;
}
.my-grid-row {
	display: flex;
	width: fit-content;
	min-width: 100%;
}
.my-grid-row:not(.my-grid-headers):not(.my-grid-row-mobile):nth-child(even){
	background: color-mix(in srgb, var(--text-secondary) 15%, transparent);
}
.my-grid-row:not(.my-grid-headers):not(.my-grid-row-mobile):hover .my-grid-cell{
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
}
.my-grid-row:not(.my-grid-headers):not(.my-grid-row-mobile).my-grid-row-selected .my-grid-cell{
	background: color-mix(in srgb, var(--currentColor) 35%, transparent);
}
.my-grid-cell{
	flex: 1;
	padding: var(--padding-medium);
	text-align: left;
	min-height: var(--grid-cell-min-height);
	display: flex;
	align-items: center;
	transition: background-color .1s;
}
.my-grid-cell.my-grid-cell-mobile{
	padding: var(--padding);
}

.my-grid-cell[data-key="action"] .my-grid-cell-value, .my-grid-cell-value.my-grid-cell-flex{
	display: flex;
	align-items: center;
	gap: var(--padding);
	flex-wrap: wrap;
}
.my-grid-select-cell{
	flex: none;
	width: fit-content;
}
.my-grid-cell-image{
	flex: none;
	width: 80px;
	text-align: center;
}
.my-grid-img{
	max-width: 35px;
	max-height: 35px;
}
.my-grid-footer{
	border-top: var(--border-width) solid var(--text-invisible);
}
.my-grid-infos{
	display: flex;
	align-items: center;
	font-size: var(--font-size-small);
	padding: var(--padding-medium);
}
.my-grid-align-right{
	margin-left: auto;
}
.my-grid-pagination{
	display: flex;
	align-items: center;
	gap: var(--padding-large);
}
.my-grid-pagination-controls{
	cursor: pointer;
	height: 22px;
	width: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--border-circle);
	transition: .3s;
}
.my-grid-pagination-content{
	height: 22px;
	display: flex;
	align-items: center;
}
.my-grid-pagination-controls.my-disabled{
	opacity: .5;
}
.my-grid-pagination-controls:not(.my-disabled):hover{
	background: var(--text-invisible);
}
/* == DATEPICKER == */
.my-datepicker{
	border: 1px solid var(--text-medium);
	border-radius: var(--border-radius-medium);
	width: fit-content;
	padding: var(--padding);
	--cell-size: 40px;
	transition: .3s;
}
.my-datepicker-modal{
	position: absolute;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
}
.my-datepicker.my-datepicker-popup{
	background: var(--background-lvl3);
	box-shadow: var(--box-shadow-lvl3);
	border: none;
	display: none;
	opacity: 0;
	transition: opacity 0.3s;
	z-index: 100000;
}
.my-datepicker.my-datepicker-popup:not(.my-datepicker-mobile){
	position: absolute;
}
.my-datepicker.my-datepicker-popup.my-datepicker-visible{
	opacity: 1;
}
.my-datepicker.my-active{
	display: flex;
}
.my-datepicker-header{
	display: flex;
	align-items: center;
	justify-content: center;
}
.my-datepicker-months-box{
	display: flex;
	align-items: center;
	justify-content: stretch;
	gap: var(--padding-large);
}
.my-datepicker-month{

}
.my-datepicker-month-header{
	text-align: center;
	padding: var(--padding-medium) 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--padding);
}
.my-datepicker-month-header .my-datepicker-monthpicker{
	width: 106px;
	font-size: var(--font-size-small);
}
.my-datepicker-month-header .my-datepicker-yearpicker{
	width: 70px;
	font-size: var(--font-size-small);
}
.my-datepicker-month-header .my-datepicker-month-controls{
	aspect-ratio: 1 / 1;
	height: var(--input-height);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--border-circle);
	background: color-mix(in srgb, var(--text) 5%, transparent);
	cursor: pointer;
	transition: .3s;
}
.my-datepicker-month-header .my-datepicker-month-controls:hover{
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
	color: var(--currentColor);
}
.my-datepicker-month-header .my-datepicker-month-controls:active{
	background: color-mix(in srgb, var(--currentColor) 25%, transparent);
}
.my-datepicker-grid{
	display: grid;
	grid-template-columns: repeat(7, var(--cell-size));
	grid-template-rows: repeat(7, var(--cell-size));
}
.my-datepicker-day-name{
	display: flex;
	align-items: flex-end;
	justify-content: center;
	text-align: center;
	font-weight: bold;
	padding: var(--padding) 0;
}
.my-datepicker-day{

}
.my-datepicker-day-content{
	height: 100%;
	width: 100%;
	border-radius: var(--border-circle);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid transparent;
	transition: .1s;
	cursor: pointer;
	user-select: none;
}
.my-datepicker-day:hover .my-datepicker-day-content{
	border: 1px solid var(--text-invisible);
}
.my-datepicker-today .my-datepicker-day-content{
	border: 1px solid var(--text-medium);
}
.my-datepicker-today:hover .my-datepicker-day-content{
	border: 1px solid var(--text);
}
.my-datepicker-day.my-datepicker-selected .my-datepicker-day-content{
	background: var(--currentColor);
	border: 1px solid var(--currentColor);
	font-weight: var(--font-bold);
}

/* == POPUP == */
.my-popup{
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	z-index: 10000;
	pointer-events: none;
	display: none;
	transition: .3s;
	overflow: auto;
}
.my-popup.my-popup-visible{
	opacity: 1;
}
.my-popup-modal{
	pointer-events: all;
	background: var(--text-secondary-disabled);
}
.my-popup-container{
	position: absolute;
	top: 0;
	left: 0;
	min-height: 200px;
	min-width: 300px;
	max-width: calc(100% - 20px);
}
.my-popup-box{
	height: 100%;
	background: var(--background-lvl1);
	box-shadow: var(--box-shadow-lvl3);
	border-radius: var(--border-radius-large);
	opacity: 0;
	display: flex;
	flex-direction: column;
	pointer-events: all;
}
.my-popup.my-popup-visible .my-popup-box{
	opacity: 1;
}
.my-popup-header{
	width: 100%;
	padding: var(--padding-medium);
	border-bottom: var(--border-width) solid var(--text-invisible);
	display: flex;
	align-items: center;
	gap: var(--padding-medium);
}
.my-popup-large .my-popup-header{
	padding: var(--padding-large);
	font-size: calc(var(--font-size-large)* 1.2);
	font-weight: var(--font-bold);
}
.my-popup-drag-handler{
	cursor: grab;
	user-select: none;
}
.my-popup-close{
	margin-left: auto;
}
.my-popup-content{
	flex: 1;
}
.my-popup-footer:has(*){
	display: flex;
	padding: var(--padding-medium);
	border-top: var(--border-width) solid var(--text-invisible);
	gap: var(--padding-medium);
	align-items: center;
	justify-content: flex-end;
}
/* == TABPANEL == */
my-tabpanel{
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
.my-tabpanel-tabs{
	display: flex;
	border-bottom: var(--border-width) solid var(--text-invisible);
	align-items: center;
	justify-content: flex-start;
	overflow-x: auto;
	scrollbar-width: none;
}
.my-tabpanel-tab {
	padding: var(--padding-medium);
	cursor: pointer;
	margin: 0 var(--margin-medium);
	border-bottom: var(--border-width-medium) solid  transparent;
	border-top: var(--border-width-medium) solid  transparent;
	white-space: nowrap;
}
/*.my-tabpanel-mobile .my-tabpanel-tab:not(.my-tabpanel-tab-active):not(.my-tabpanel-menu-button){
	display: none;
}*/
.my-tabpanel-tab:hover{
	border-bottom: var(--border-width-medium) solid  color-mix(in srgb, var(--currentColor) 60%, transparent);
}
.my-tabpanel-tab.my-tabpanel-tab-active{
	border-bottom: var(--border-width-medium) solid  var(--currentColor);
	color: var(--currentColor);
}
.my-tabpanel-menu-button{
	margin: 0 0 0 auto;
	aspect-ratio: 1 / 1;
	height: 100%;
	display: none;
	align-items: center;
	justify-content: center;
}
my-tabpanel:not(.my-tabpanel-mobile) .my-tabpanel-menu-button{
	display: none;
}
.my-tabpanel-menu-header{
	padding: var(--padding-large);
	text-align: center;
	font-size: var(--font-size-medium);
}
.my-tabpanel-menu{
	position: fixed;
	inset: var(--padding-large);
	background: var(--background-lvl1);
	border-radius: var(--border-radius-large);
	display: none;
}
.my-tabpanel-menu.active{
	display: block;
}
.my-tabpanel-mobile .my-tabpanel-menu .my-tabpanel-tab:not(.my-tabpanel-tab-active):not(.my-tabpanel-menu-button){
	display: block;
}
.my-tabpanel-mobile .my-tabpanel-menu .my-tabpanel-tab{
	font-size: var(--font-size-large);
}

.my-tabpanel-content{
	flex: 1;
	overflow: auto;
}
my-tabpanel:has(.my-tabpanel-content > my-grid){
	gap: 0;
}
my-tabpanel:has(.my-tabpanel-content > my-grid) .my-tabpanel-tabs{
	border-bottom: none;
}
/* == DASHBOARD == */
my-dashboard{
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
.my-dashboard-content{
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
.my-dashboard-preview{
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
.my-dashboard-main{
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
.my-dashboard-aside{
	display: flex;
	flex-direction: column;
	gap: var(--padding-medium);
}
my-tile{
	border: var(--border-width) solid var(--text-invisible);
	border-radius: var(--border-radius-medium);
	display: flex;
	flex-direction: column;
}
my-tile[no-border]{
	border: var(--border-width) solid transparent;
}
.my-tile-header:has(*){
	padding: var(--padding) 0;
	margin: 0 var(--margin-medium);
	display: flex;
	align-items: center;
	border-bottom: var(--border-width) solid var(--text-invisible);
	gap: var(--padding-medium);
	justify-content: flex-end;
	min-height: calc(var(--button-height) + (2 * var(--padding)) + var(--border-width));
}
.my-tile-title{
	margin-right: auto;
	font-size: var(--font-size-medium);
}
.my-tile-content{
	padding: var(--padding-medium);
	flex: 1;
	overflow: auto;
}
/* == AVATAR == */
my-avatar{
	height: var(--avatar-size);
	aspect-ratio: 1 / 1;
	border-radius: var(--border-circle);
	font-size: var(--font-size);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: var(--font-bold);
	color: var(--text-secondary-disabled);
	background: no-repeat center /cover;
	cursor: pointer;
	transition: .3s;
}
my-avatar.my-avatars-add{
	color: var(--currentColor);
	background: color-mix(in srgb, var(--currentColor) 15%, transparent);
}
my-avatar:not([icon]){
	padding: 1px 0 0 0;
	letter-spacing: -1.8px;
}
my-avatar[small], my-avatars[small] my-avatar{
	font-size: var(--font-size-small);
	height: 22px;
}
my-avatar[small]:not([icon]), my-avatars[small] my-avatar:not([icon]){
	letter-spacing: -1.4px;
	padding: 2px 0 0 0;
}
my-avatar[large], my-avatars[large] my-avatar{
	height: 32px;
}
my-avatars{
	display: flex;
	align-items: center;
	width: fit-content;
}
my-avatars > my-avatar:not(:first-child){
	margin-left: calc(var(--margin-medium) * -1);
}
my-avatars > my-avatar:not(:last-child){
	mask: radial-gradient(circle at 39px, transparent 19px, white 0px);
	mask-size: 40px;
}
my-avatars > my-avatar[small]:not(:last-child), my-avatars[small] > my-avatar:not(:last-child){
	mask: radial-gradient(circle at 25px, transparent 14px, white 0px);
	mask-size: 40px;
}
my-avatars > my-avatar[large]:not(:last-child), my-avatars[large] > my-avatar:not(:last-child){
	mask: radial-gradient(circle at 39px, transparent 19px, white 0px);
	mask-size: 40px;
}

my-avatars:hover:not(:has(.my-avatars-add:hover)) > my-avatar:not(:first-child){
	margin-left: var(--margin);
}
my-avatars:hover:not(:has(.my-avatars-add:hover)) > my-avatar:not(:last-child){
	mask-size: 500px;
	mask-position: 15px;
}
/* == TAG == */
my-tag{
	height: 28px;
	width: fit-content;
	border-radius: var(--border-width-medium);
	font-size: var(--font-size);
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: var(--font-bold);
	color: var(--text-secondary-medium);
	transition: .3s;
	padding: 0 var(--padding-medium);
	min-width: 60px;
}
my-tag[large]{
	height: 32px;
	padding: 0 var(--padding-large);
	min-width: 80px;
}
my-tag[xsmall]{
	height: 20px;
	font-size: var(--font-size-small);
	padding: 0 var(--padding);
	min-width: 0;
}
/* == EDITOR == */
.my-editor-toolbar{
	display: flex;
	align-items: center;
	gap: var(--padding-medium);
}
@media (min-width: 700px){
	my-dashboard{
		flex-direction: row;
	}
	.my-dashboard-content{
		flex: 1;
	}
	.my-dashboard-aside{
		width: 300px;
	}
	.my-dashboard-aside > *{
		flex-grow: 1;
	}
}
@media (min-width: 1000px){
	.my-dashboard-preview{
		flex-direction: row;
		flex-wrap: wrap;
	}
	.my-dashboard-preview > *{
		width: calc(50% - var(--padding));
	}
	.my-dashboard-main{
		flex-direction: row;
		flex-wrap: wrap;
	}
	.my-dashboard-main > *{
		width: calc(50% - var(--padding));
	}
}
@media (min-width: 1200px){
	my-dashboard{
		height: 100%;
	}
	.my-dashboard-main{
		flex: 1;
		min-height: 0;
	}
	.my-dashboard-aside{
		width: 400px;
	}
}
@media (min-width: 1400px){
	.my-dashboard-aside{
		width: 400px;
	}
	.my-dashboard-preview{
		flex-wrap: nowrap;
	}
	.my-dashboard-preview > *{
		width: initial;
		flex: 1;
	}
}