/*----------------------------------------------------------------------------
******************************************************************************
Layout
******************************************************************************
----------------------------------------------------------------------------*/
/* ==== Base === */
body {
	padding: 0 1em;
}

img.thumbnail {
	display: block;
	margin: 1rem auto;
	max-width: 1024px;
	width: 100%;
	height: auto;
}

div.home-layout {
	margin: 1em auto;
	max-width: 1024px;
	display: grid;
	grid-template-columns: 3fr 1fr;
	gap: 1em;
}

div.layout {
	margin: 1em auto;
	max-width: 1024px;
	display: grid;
	grid-template-columns: 1fr 3fr;
	gap: 1em;
}

/* ==== Header === */

header {
	max-width: 1024px;
	margin: 0 auto;
}

header h1 img {
	margin: 1rem 0;
	max-width: 400px;
	width: 100%;
	height: auto;
}

/* ==== Navigation === */

nav.nav-bar {
	max-width: 1024px;
	margin: 0 auto;
	overflow-x: auto;
}

nav.nav-bar ul {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2px;
}

nav.nav-bar li {
	flex-grow: 2;
	flex-shrink: 0;
	flex-basis: 120px;
	width: 100%;
	text-align: center;
}

nav.nav-bar a {
	display: block;
	padding: 0.75rem 0;
	color: #FFFFFF;
	background: #0080E5;
	font-size: 1.125rem;
	text-decoration: none;
	transition-property: background-color;
	transition-duration: 0.2s;
}

nav.nav-bar a:hover {
	background: #00B8EA;
}

nav.nav-bar li.current a {
	background: #00B8EA;
}

/* ==== Content === */

aside.side-nav h4 {
	margin-top: 0;
}

aside.side-nav a {
	display: flex;
	align-items: center;
	padding: 0.5em 0.5em;
	color: #000C;
	text-decoration: none;
	border-bottom: 1px solid #0001;
}

aside.side-nav a::before {
	display: block;
	content: url(../images/side-nav-bullet.svg);
	margin-right: 0.5em;
	height: 16px;
	width: 8px;
}

aside.side-nav a:hover {
	text-decoration: underline;
}

main img {
	margin: 1em 0;
	width: 100%;
	height: auto;
}

main p {
	margin: 1em 0;
}

main ol,
main ul {
	margin: 1em 0;
	padding-left: 1.5em;
}

main ul {
	list-style-type: disc;
}

main li {
	padding: 0.5em 0;
}

iframe.news {
	height: 20rem;
	width: 100%;
	border: 0;
}

.pagetop img {
	width: 64px;
}


/* ==== Footer === */

#ft {
	margin-top: 20px;
	padding-top: 40px;
	padding-bottom: 40px;
	text-align: center;
	background: url(../images/ft_bg.jpg) repeat-x;
}

/*----------------------------------------------------------------------------
******************************************************************************
Head
******************************************************************************
----------------------------------------------------------------------------*/

h2 {
	font-size: 2.3em;
	font-weight: normal;
	padding: 0.5em 0 0.4em 0.4em;
	margin: 0em 0 0.8em 0;
	color: #00B8EA;
	border: 1px solid #00B8EA;
	background: linear-gradient(90deg, #FFFFFF, #FFFFFF, #E3CE5B);
}

h3 {
	font-size: 1.4em;
	margin: 1.0em 0 0.6em 0;
	padding: 0.3em 0 0.2em 1.2em;
	border: 1px solid #0001;
	background: #00000008;
	position: relative;
}

h3::before {
	content: '';
	display: inline-block;
	background: linear-gradient(#00B8EA, #0080E5);
	height: 1.4em;
	width: 0.3em;
	position: absolute;
	top: 0.3em;
	left: 0.3em;
}

h4 {
	font-size: 1.2em;
	font-weight: normal;
	padding: 0.2em 0 0.1em 0.2em;
	margin: 0.4em 0 0.2em 0;
	color: #0080E5;
	border-bottom: 2px solid #0080E5;
}

h5 {
	font-size: 1.1em;
	margin: 10px 0px;
}

/*----------------------------------------------------------------------------
******************************************************************************
Original
******************************************************************************
----------------------------------------------------------------------------*/

div.news {
	padding: 1em 0.5em;
	display: flex;
	gap: 1em;
	font-size: 0.85em;
	border-bottom: 1px solid #0001;
}

div.news:last-child {
	border-bottom: none;
}

div.news div.date {
	flex: 0 0 120px;
}

div.news div.body img {
	margin: 1em 0;
	display: block;
	max-width: 240px;
	width: 100%;
	height: auto;
	border-radius: 1em;
}

div.external-links a {
	display: block;
	margin-bottom: 0.5rem;
	padding: 0.75rem 1rem;
	color: #0080E5;
	border: 1px solid #0003;
	font-size: 1.125rem;
	text-decoration: none;
	transition-property: border-color;
	transition-duration: 0.2s;
	line-height: 1;
}

div.external-links a:hover {
	border-color: #0080E5;
}

.columns-container {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr 1fr 1fr;
}

@media all and (max-width: 960px) {
	div.home-layout {
		display: block;
	}

	div.layout {
		display: block;
	}

	aside.side-nav {
		display: none;
	}

	div.external-links {
		margin-top: 2rem;
	}
}

@media all and (max-width: 540px) {
	.columns-container {
		grid-template-columns: 1fr 1fr;
	}
}