@import url('https://fonts.googleapis.com/css2?family=Eagle+Lake&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css');

:root {
	--time-transition: 100ms;
	--bg-grad-a: rgba(42, 123, 155, 1);
	--bg-grad-b: rgba(87, 199, 133, 1);
	--bg-grad-c: rgba(237, 221, 83, 1);
}

body {
	font-family: "Eagle Lake", system-ui;
}

.panel {
	margin: auto;
	padding: 15px;
	background: linear-gradient(
		90deg,
		rgba(16, 130, 101, 1) 0%,
		rgba(0, 55, 158, 1) 100%
	);
	color: white;
	height: 70px;
}

.user-panel {
	padding: 0px;
	display: flex;
	align-items: center;
	justify-content: right;
}

.user-panel-logout {
	width: 100%;
	padding-left: 20px;
}

.user-panel-name {
	font-size: 1.2em;
	margin: 26px;
	margin-right: 20px;
}

.user-panel-img {
	height: 64px;
	width: 64px;
	margin: 5px 10px 5px 0px;
}

.user-avatar-shape {
	object-fit: cover;
	border-radius: 50%;
	aspect-ratio: 1;
}

/* ok, nějakej vibecoded výstup z chatgpt by to asi vyřešil líp */
.user-panel-logo {
	object-fit: contain;
	width: 50%;
	right: 25%;
	position: fixed;
	text-align: center;
}

.user-panel-logo img {
	height: 64px;
}

.panel a {
	text-decoration: none;
	color: var(--bg-grad-c);
	transition: 
		color var(--time-transition),
		filter var(--time-transition)
	;
}

.panel a:hover {
	color: var(--bg-grad-b);
	filter: drop-shadow(0px 0px 2px black);
}

.user-panel-img {
	border: 4px solid #0000;
	box-sizing: border-box;
	transition: 
		border var(--time-transition)
	;
}

.user-panel-img-span:hover .user-panel-img {
	border: 4px solid var(--bg-grad-b);
}


.generic-button {
	padding: 10px;
	background-color: var(--bg-grad-b);
	border-width: 2px;
	border-color: rgba(0, 0, 0, 0);
	border-radius: 10px;
	filter: drop-shadow(0px 3px 2px rgba(0, 0, 0, 0.5));
	transition: 
		border var(--time-transition),
		background-color var(--time-transition),
		color var(--time-transition),
		filter var(--time-transition)
	;
}

.big-button {
	font-size: 1.3em;
}

.generic-button:hover:enabled {
	background-color: var(--bg-grad-c);
	filter: drop-shadow(0px 5px 3px rgba(0, 0, 0, 0.8));
	border-color: white;
	color: black;
}

.generic-button:active:enabled {
	background-color: var(--bg-grad-a);
	filter: drop-shadow(0px 0px 1px rgba(0, 0, 0, 0.3));
	border-color: black;
	color: white;
}
.generic-button:disabled {
	background-color: rgba(128, 128, 128, 1);
	color: black;
	filter: drop-shadow(0px 0px 1px rgba(0, 0, 0, 0.5));
}

.input-error {
	filter: drop-shadow(1px 3px 2px #f00);
}