@charset "utf-8";

:root {
	--ls-main-color: #422DDD;
	--ls-sub-color: #64a79f;
}

* {
	box-sizing: border-box;
	scroll-behavior: smooth;
}

body {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	overflow-y: scroll;
	margin: 0;

	& > header {
		padding: 5px;
		//border-bottom: 2px solid var(--ls-main-color);

		display: flex;
		flex-wrap: wrap;

		& > * {
			align-content: center;
		}

		& > .glow {
			flex-grow: 1;
		}

		& .top-logo {
			//width: 150px;
			height: 2.5rem;
			margin-top: auto;
			margin-bottom: auto;
			object-fit: contain;
			object-position: left;
		}

		& > .right-logo {
			flex-shrink: 1;
			clear: both;
			text-align: right;

			& > img {
				width: 48px;
				object-fit: contain;
				vertical-align: middle;
			}
		}
	}

	& > footer {
		background: #EEE;
		container: footer / inline-size;
	}

	& > .wrapper {
		flex-grow: 1;
		display: flex;

		& > aside {
			display: flex;
			flex-direction: column;
			width: 360px;
			margin: 5px;
			padding: 10px;
			border: 1px solid #ccc;
			border-radius: 3px;
			box-shadow: 0 0 3px 1px #ccc;

			& + .btn {
				display: none;
				position: sticky;
				top: 10px;
				left: 10px;
				width: fit-content;
				height: fit-content;
				z-index: 1000;
			}
		}


		& > .main-panel {
			flex-grow: 1;
			container: main / inline-size;
			view-transition-name: icsc-main;
		}
	}
}

h1 {
	font-size: 2em;
}

h2, h3 {
	main & {
		padding: 0 .8rem;
		border-bottom: 1px solid gray;

		&::after {
			margin: 0 -.8rem;
			display: block;
			position: absolute;
			content: "";
			width: 150px;
			height: 2px;
			background: var(--ls-main-color);
		}
	}
}

h4 {
	aside & {
		padding: 0 .8rem;
		border-bottom: 1px solid gray;

		&::after {
			margin: 0 -.8rem;
			display: block;
			position: absolute;
			content: "";
			width: 150px;
			height: 2px;
			background: var(--ls-sub-color);
		}
	}
}

dl > dt {
	main & {
		margin: .5rem 0 0 0;
		border-bottom: 1px solid #ccc;
		font-weight: bold;
	}
}

.col-sep-table {
	width: 100%;
	border-spacing: 0;
	border:1px solid #ccc;
	border-radius: 3px;
	box-shadow: 0 0 3px 1px #ccc;

	& th, & td {
		padding: .4rem;
		text-align: left;

		&:not(:last-child) {
			border-right: 1px solid #ccc;
		}
	}
}

main *, aside * {
	line-height: 1.75em;
}

.mx-auto {
	margin-left: auto;
	margin-right: auto;
}

.container {
	padding: 5px;
}

.indent {
	padding-left: 1rem;
}

.btn {
	display: inline-block;
	padding: .5em;
	border: 2px solid var(--ls-main-color);
	border-radius: 5px;
	background-color: var(--ls-main-color);
	color: white;
	text-decoration: none;

	transition: background-color .2s;

	cursor: pointer;

	&.light {
		background-color: white;
		color: black;
		border: 2px solid #ccc;
		border-radius: 3px;
		box-shadow: 0 0 3px 1px #ccc;
	}

	&.lg {
		font-size: 1.2em;
	}

	&:hover {
		background-color: color-mix(in lch, var(--ls-main-color) 80%, black);

		&.light {
			background-color: color-mix(in lch, var(--ls-main-color) 20%, white);
		}
	}
}

#close-button {
	display: none;
	width: fit-content;
	text-align: center;
}


.bi {
	vertical-align: -.125em;
}

.sticky {
	position: sticky;
	top: 0;
	max-height: 100vh;
	overflow: auto;
}


@view-transition {
	navigation: auto;
}

@media (prefers-reduced-motion: reduce) {
	* {
		scroll-behavior: auto;
	}

	::view-transition-old(*),
	::view-transition-new(*) {
		animation-duration: 0.01ms !important;
	}

	.btn {
		transition: none;
	}
}

@media (width < 576px) {
	h1 {
		font-size: 1.8em;
	}

	body > header > .right-logo > img {
		width: 36px;
	}
}

@media (576px <= width < 768px) {
	body > header > .right-logo > img {
		width: 42px;
	}
}

@media (768px <= width < 992px) {
}

@media (width < 992px) {
	#close-button {
		display: inline-block;
	}

	body > header {
		& > .collapse {
			display: none;
		}
	}

	body > .wrapper {
		flex-direction: column;

		& > aside {
			display: none;
			background: white;
			position: fixed;
			top: 0;
			left: 0;
			z-index: 1001;
			height: calc(100vh - 10px);
			view-transition-name: menu;

			& + .btn {
				display: inline-block;
				view-transition-name: menu;
			}

			&.shown {
				display: flex;

				& + .btn {
					display: none;
				}
			}
		}
	}
}

@media (992px <= width < 1200px) {
	body > .wrapper > aside {
		width: 280px;
	}
}

@media (1200px <= width < 1400px) {
}

@media (1400px <= width) {
}

@container (/*width < 576px) {
}

@container (576px <= width < 768px) {
	.container {
		max-width: 540px;
	}
}

@contianer (768px <= */width < 992px) {
	.container {
		max-width: 720px;
	}
}

@container (992px <= width < 1200px) {
	.container {
		max-width: 960px;
	}
}

@container (1200px <= width < 1400px) {
	.container {
		max-width: 1140px;
	}
}

@container (1400px <= width) {
	.container {
		max-width: 1320px;
	}
}
