body{
	font-family: 'Roboto', sans-serif;
	font-weight: 400;

}
.viewport{
	position: absolute;
	inset: 0;
	background: var(--bg);
	color: var(--text);
}
.button{
	background: var(--primary);
	color: var(--text-secondary-medium);
	width: fit-content;
	padding: 10px 25px;
	border-radius: 6px;
	margin: 5px 0;
	cursor: pointer;
	font-weight: 600;
	transition: 0.5s;
	user-select: none;
}
.button:hover{
	filter: brightness(70%);
}
.viewport input:not([type="checkbox"]), .viewport textarea, .viewport select{
	height: 40px;
	border: none;
	border-radius: 6px;
	background: rgba(255, 255, 255, 0.133);
	font-family: Roboto, sans-serif;
	color: var(--text);
}
.viewport label{
	display: block;
}
.logo{
	font-size: 40px;
	letter-spacing: 8px;
	font-weight: 700;
}
.logo span{
	color: var(--primary);
}
.material-symbols-outlined {
	font-variation-settings:
			'FILL' 0,
			'wght' 400,
			'GRAD' 0,
			'opsz' 24;
	font-size: 1.4em;
}


/*---LOGIN---*/
.viewport-login{
	display: flex;
	align-items: center;
	justify-content: center;
}
.login-box{
	background: var(--lvl1);
	padding: 20px;
	box-shadow: 0 2px 5px #0004;
	border-radius: 6px;
	width: 460px;
}
.login-box .logo{
	text-align: center;
	padding: 0 0 10px 0;
}
.login-button{
	margin: 10px auto 0;
}
.login-box label{
	padding: 0 0 20px 0;
}

/*---HOME---*/
.viewport-home{
	--appbar-size: 40px;
	--title-size: 0;
	display: flex;
	align-items: stretch;
}
.appbar{
	width: var(--appbar-size);
	background: var(--lvl1);
	box-shadow: 0 2px 5px #0004;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
}
.appbar .logo{
	font-size: 20px;
	letter-spacing: -1px;
	width: 100%;
	text-align: center;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(130deg, var(--primary) 0%, var(--secondary) 100%);
}

.app-buttons{
	width: 100%;
	height: calc(100% - 40px);
	display: flex;
	flex-direction: column;
	align-items: center;
}
.app-button {
	background: var(--primary);
	width: 32px;
	height: 32px;
	margin: 10px 0 0 0;
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: var(--text-secondary-medium);
	transition: 0.5s;
	user-select: none;
}
.app-button:hover{
	filter: brightness(70%);
}

.content{
	width: calc(100% - var(--appbar-size));
}
.viewport-home h1{
	height: var(--title-size);
	font-size: 30px;
	text-transform: uppercase;
	display: flex;
	align-items: center;
	justify-content: center;
}
.main{
	/*height: calc(100% - var(--title-size));*/
	height: 100%;
}
.canvas-content{
	width: 100%;
	margin: auto;
	height: 100%;
}

/*--Popup--*/
.app-popup-modal{
	position: fixed;
	inset: 0;
	background: #0006;
	backdrop-filter: blur(5px);
	display: flex;
	align-items: center;
	justify-content: center;
}
.app-popup{
	background: var(--lvl2);
	border-radius: 6px;
	box-shadow: 0 6px 10px #0009;
	max-width: 100%;
	max-height: 100%;
}
.app-popup-header, .app-popup-footer{
	display: none;
}
.app-popup:not(.app-popup-nohead) .app-popup-header{
	display: flex;
	height: 40px;
	width: 100%;
	padding: 0 5px;
	background: var(--lvl6);
	border-radius: 6px 6px 0 0;
	align-items: center;
}
.app-popup:not(.app-popup-nofoot) .app-popup-footer{
	display: flex;
	height: 60px;
	width: 100%;
	padding: 0 10px;
	background: var(--lvl6);
	border-radius: 0 0 6px 6px;
}
.app-popup .app-popup-body{
	height: calc(100% - 100px);
}
.app-popup.app-popup-nofoot .app-popup-body{
	height: calc(100% - 60px);
}
.app-popup.app-popup-nohead .app-popup-body{
	height: calc(100% - 40px);
}
.app-popup.app-popup-nofoot.app-popup-nohead .app-popup-body{
	height: 100%;
}
.app-popup-title{
	font-size: 16px;
	font-weight: 500;
}
.app-popup-close{
	height: 30px;
	width: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 6px;
	margin: 0 0 0 auto;
	color: var(--text-medium);
	transition: .3s;
	cursor: pointer;
}
.app-popup-close:hover{
	color: var(--text);
	background: var(--lvl9);
}
/*--CanvAI--*/
.canvai{
	--topbar-size: 40px;
	height: 100%;
	background: var(--bg);
	overflow: hidden;
}
.canvai-content{
	height: calc(100% - var(--topbar-size));
	padding: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.canvai-topbar{
	height: var(--topbar-size);
	background: var(--lvl1);
	padding: 0 0 2px 0;
	position: relative;
}
.canvai-topbar-content{
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 5px;
	position: relative;
}
.canvai-progress{
	position: absolute;
	left: 0;
	bottom: 0;
	height: 2px;
	width: 27%;
	background: linear-gradient(270deg, var(--primary) 0%, var(--secondary) 100%);
}
.canvai-topbar-action{
	display: flex;
	align-items: center;
	width: 300px;
}
.canvai-topbar-title{
	font-size: 20px;
	font-weight: 600;
	text-transform: uppercase;
}
.canvai-topbar-right{
	display: flex;
	align-items: center;
	justify-content: flex-end;
	width: 300px;
}
.canvai-topbar-pagin{
	padding: 0 20px 0 0;
}
.canvai-action-btn{
	height: 30px;
	width: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 6px;
	margin: 0 5px 0 0;
	color: var(--text-disabled);
	transition: .3s;
	cursor: not-allowed;
}
.canvai-action-btn.canvai-active{
	cursor: pointer;
	color: var(--text);
}
.canvai-action-btn.canvai-active:hover{
	background: var(--lvl9);
}

.button.canvai-next-btn{
	background: var(--secondary);
	padding: 6px 10px;
}
.canvai-canvas, .canvai-canvas-detail{
	width: 100%;
	height: 100%;
	position: relative;
}
.canvai-flexbox{
	--formsize: 350px;
	--detailsize: 0px;
	height: 100%;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.canvai-flexbox.canvai-flexbox-detail{
	--detailsize: 600px;
}
.canvai-canvas-detail-box{
	width: var(--detailsize);
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: var(--lvl4);
	border-radius: 6px;
	padding: 3px;
}
.canvai-canvas-box{
	width: calc(100% - var(--formsize) - var(--detailsize));
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
}
.canvai-form{
	width: calc(var(--formsize) - 3px);
	height: 100%;
	background: var(--lvl4);
	border-radius: 6px;
	padding: 10px;
	font-size: 16px;
}
.canvai-buttongroup{
	--nb_button: 3;
	display: flex;
	align-items: center;
	justify-content: center;
}
.canvai-buttongroup-button{
	display: flex;
	align-items: center;
	justify-content: center;
	width: calc(100% / var(--nb_button));
	background: var(--secondary);
	color: var(--text-secondary-medium);
	padding: 6px 0;
	cursor: pointer;
	font-weight: 600;
	transition: 0.2s;
	user-select: none;
	filter: brightness(70%);
}
.canvai-buttongroup-button:hover{
	filter: brightness(90%);
}
.canvai-buttongroup-button:first-child{
	border-radius: 6px 0 0 6px;
}
.canvai-buttongroup-button:last-child{
	border-radius: 0 6px 6px 0;
}
.canvai-buttongroup-button:not(:last-child){
	border-right: 2px solid #fff3;
}
.canvai-buttongroup-button.canvai-active{
	filter: brightness(100%);
}
.canvai-form label:not(:first-child){
	margin: 15px 0 0 0;
}
.canvai-form-btns{
	padding: 20px 0 0 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
.canvai-form-btns > div:not(:first-child){
	margin: 0 0 0 15px;
}
.canvai-form-delete-btn{
	background: var(--error);
}
.canvai-zoom-toast{
	position: absolute;
	bottom: 10px;
	background: var(--text-medium);
	color: var(--text-secondary);
	padding: 8px 20px;
	border-radius: 6px;
	font-weight: 600;
}
.canvai-autocomplete-list{
	position: absolute;
	width: 100%;
	top: 70px;
	max-height: 400px;
	background: var(--lvl10);
	left: 0;
	border-radius: 6px;
	overflow: auto;
	display: none;
}
.canvai-autocomplete-row{
	padding: 5px;
}
.canvai-autocomplete-row:not(:last-child){
	border-bottom: 1px solid #0002;
}
.canvai-autocomplete-row.canvai-selected{
	background: var(--secondary-variant);
}
.canvai-classlist{
	padding: 10px 0;
	display: flex;
	flex-wrap: wrap;
}
.canvai-class{
	padding: 0 6px;
	width: fit-content;
	border-radius: 3px;
	font-size: 16px;
	margin: 5px 0 0 5px;
}
.canvai-classe-verify{
	font-size: 14px;
	display: flex;
	margin: 10px 0;
	align-items: center;
	justify-content: space-between;
	padding: 5px;
	border: 1px solid var(--lvl6);
	border-radius: 6px;
}
.canvai-classe-verify-btn{
	display: flex;
	align-items: center;
	justify-content: center;
}
.canvai-classe-verify-btn > div{
	width: 40px;
	height: 26px;
	background: var(--lvl6);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: .2s;
	opacity: .6;
}
.canvai-classe-verify-no{
	border-radius: 6px 0 0 6px;
	border-right: 1px solid var(--bg);
}
.canvai-classe-verify-yes{
	border-radius: 0 6px 6px 0;

}
.canvai-classe-verify-no:hover{
	background: var(--error);
}
.canvai-classe-verify-yes:hover{
	background: var(--success);
}
.canvai-classe-verify[data-value="yes"] .canvai-classe-verify-yes{
	background: var(--success);
	opacity: 1;
}
.canvai-classe-verify[data-value="no"] .canvai-classe-verify-no{
	background: var(--error);
	opacity: 1;
}