/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bold}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

* { box-sizing: border-box }
img { max-width: 100%; height: auto; }

:root {
	
	--font-family: system-ui;
	
	--text-color: #000;
	--text-color-muted: #555;
	--background-color: #fff;
	--background-tint-color: #f1f1f3;
	--accent-color: #241f8b;
	--accent-tint-color: #3d38aa;
	--accent-contrast-color: #fff;
	--accent-secondary-color: rgb(255, 255, 0);
	--accent-secondary-muted-color: rgb(255, 255, 192);
	
	--navbar-color: #fff;
	--navbar-background-color: #000;
	
	--main-border-color: rgba(0,0,0, 0.25);
	--link-highlight-background-color: rgba(255,255,0, 0.25);
	
	--list-item-separator-color: rgba(0,0,0, 0.15);
	
	--input-border-color: #000;
	
	--alert-color: #000;
	--error-color: #b00;
	--success-color: #0b0;
	
}

html {
	margin: 0;
	padding: 0;
	font-size: 62.5%;
}

body {
	font-family: var(--font-family);
	font-size: 1.7rem;
	line-height: 1.4;
	margin: 0;
	padding: 0;
}

h1 {
	font-size: 3.5rem;
	margin-block-start: 0;
	margin-block-end: 1em;
	line-height: 1.0;
}

h2 {
	font-size: 3rem;
	font-weight: 600;
	margin-block-start: 0;
	margin-block-end: 0.75em;
	line-height: 1.2;
}

h3 {
	font-size: 2.3rem;
	font-weight: 600;
	margin-block-start: 2em;
	margin-block-end: 0.5em;
}

p {
	margin-block-start: 0;
}

@media screen and (min-width: 601px) {
	body {
		font-size: 1.8rem;
	}
	h1 {
		font-size: 6rem;
	}
	h2 {
		font-size: 3.2rem;
	}
	h3 {
		font-size: 2.3rem;
	}
}









/* Containers
-------------------------------------------------- */
.container {
	padding: 0 20px;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}

.section.with-padding {
	padding: 50px 0;
}

.top-margin { margin-top: 3rem; }
.top-margin-sm { margin-top: 2rem; }
.top-margin-xs { margin-top: 1rem; }

.bottom-margin-sm { margin-bottom: 2rem; }

@media screen and (min-width: 601px) {
	.top-margin { margin-top: 5rem; }
	.bottom-margin-sm { margin-bottom: 4rem; }
}




/* Base layout
-------------------------------------------------- */
.layout {
	display: grid;
	grid-template-columns: 100%;
	gap: 2rem;
}

@media screen and (min-width: 601px) {
	.layout.with-aside {
		gap: 4rem;
		grid-template-columns: 2fr 1fr;
	}
}





/* Base images
-------------------------------------------------- */
.icon {
	display: block;
	border: 1px solid var(--main-border-color);
	border-radius: 5%;
	aspect-ratio: 1 / 1;
}
.empty-icon {
	background-color: var(--background-tint-color);
}




















/* Navbar
-------------------------------------------------- */
#site-navbar {
	background-color: var(--navbar-background-color);
	color: #fff;
	height: auto;
	height: 50px;
}

#site-navbar.with-hero {
	background-color: var(--accent-color);
}

#site-navbar .container {
	display: flex;
	justify-content: space-between;
	border-bottom: 8px solid var(--accent-color);
}

.navbar-link {
	display: block;
	justify-content: center;
	align-items: center;
	color: var(--navbar-color);
	padding: 0;
	font-size: 1.6rem;
	line-height: 1.1;
	height: 50px;
	line-height: 48px;
	text-decoration: none;
	border-bottom: 2px solid transparent;
}

.navbar-link:hover {
	color: inherit;
	border-bottom-color: var(--navbar-color);
}


















/* Text
-------------------------------------------------- */
.secondary-info {
	display: block;
	font-size: 0.9em;
	color: var(--text-color-muted);
}


/* Text: links
-------------------------------------------------- */
a {
	text-decoration: underline;
	text-underline-offset: .1578em;
	color: var(--accent-color);
	font-weight: 500;
}
a:hover {
	color: var(--accent-tint-color);
	text-decoration-thickness: 3px;
}

.with-arrow {
	position: relative;
	display: block;
	align-items: center;
}

.with-arrow:before {
	position: relative;
	content: '→';
	display: inline-flex;
	justify-content: center;
	align-items: center;
	font-size: 1em;
	width: 2em;
	height: 2em;
	border-radius: 50%;
	color: var(--text-color);
	text-decoration: none;
	background-color: var(--background-tint-color);
	margin-right: 0.75em;
}



















/* Breadcrumbs
   -------------------------------------------------------------------------------- */
.breadcrumbs {
	margin-block-start: 0;
	margin-block-end: 1em;
	padding: 1em 0;
}

.breadcrumbs ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

.breadcrumbs li {
	display: inline-block;
	margin: 0;
	padding: 0;
	font-size: 1.4rem;
	color: var(--text-color-muted);
}

.breadcrumbs li + li:before {
	content: "›";
	padding: 0 0.5em;
	color: var(--text-color-muted);
}

.breadcrumbs a {
	color: var(--text-color);
	font-weight: normal
}





















/* Hero
-------------------------------------------------- */
.hero {
	color: var(--accent-contrast-color);
	background-color: var(--accent-color);
	padding: 30px 0;
}

.hero-heading {
	font-size: 4rem;
	line-height: 1.1;
	max-width: 768px;
}

.hero-heading .subtitle {
	display: block;
	font-size: 0.9em;
	line-height: 1.1;
	margin-block-start: 0.25em;
	opacity: 0.9;
}

@media screen and (min-width: 601px) {
	.hero-heading {
		font-size: 6rem;
	}
}



















/* Featured links
-------------------------------------------------- */
.featured-links {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1rem;
	font-size: 2rem;
}

.featured-links .item:hover {
	background-color: var(--link-highlight-background-color);
}

@media screen and (min-width: 993px) {
	.featured-links {
		grid-template-columns: 1fr 1fr 1fr;
	}
}
























/* Lists: text list
-------------------------------------------------- */
.text-list .item {
	padding: 2em 0;
	border-bottom: 1px solid var(--list-item-separator-color);
}

.text-list .item:last-child {
	border-bottom: none;
}

.text-list .title {
	margin-block-start: 0;
}






/* Lists: link list
-------------------------------------------------- */
.link-list .item {
	display: flex;
	padding: 0;
	margin-block-end: 3rem;
	gap: 0.5em;
}

.link-list .item-icon {
	width: 2em;
	height: 2em;
	border-radius: 4px;
	filter: invert(1);
}

.link-list .title {
	display: block;
	margin-block-end: 0.25em;
}

.link-list .description {
	margin: 0;
}




/* Lists: description list
-------------------------------------------------- */
.description-list {
	margin-bottom: 2em;
}

.description-list dt {
	font-weight: bold;
	color: var(--text-color-muted);
}

.description-list dd {
	margin-inline-start: 0;
	margin-block-end: 0.25em;
	padding-bottom: 0.25em;
	border-bottom: 1px solid var(--list-item-separator-color);
}



/* Lists: chevron list
-------------------------------------------------- */
.chevron-list .item {
	border-top: 1px solid var(--list-item-separator-color);
	margin: 0;
	padding: 5px 0 20px 0;
}

.chevron-list .item:first-child {
	border-top: none;
	padding-top: 0;
}

.chevron-list .item:first-child .chevron-list .wrapper {
	padding-top: 0;
}

@media print {
	.chevron-card:first-child .chevron-card__wrapper {
		padding-top: 19px;
	}
}

.chevron-list .wrapper {
	padding: 19px 0 4px;
	position: relative;
}

@media (max-width: 40.0525em) {
	.chevron-list .wrapper, .chevron-list .description {
		font-size: 1em;
	}
}

.chevron-list .title {
	font-size: 1.15em;
	margin-block-start: 0;
	margin-block-end: 5px;
}

.chevron-list .description {
	margin: 0 30px 0 0;
}

.chevron-list .link:after {
	bottom: 0;
	content: "";
	display: block;
	left: 0;
	position: absolute;
	right: 0;
	top:0
}

.chevron-list .link:before {
	border-right: 3px solid var(--accent-color);
	border-top: 3px solid var(--accent-color);
	content: "";
	display: block;
	height: 7px;
	position: absolute;
	right: 5px;
	top: 50%;
	margin-top: 5px;
	-webkit-transform: translateY(0) rotate(45deg) scale(1);
	-ms-transform: translateY(0) rotate(45deg) scale(1);
	transform: translateY(0) rotate(45deg) scale(1);
	width:7px
}

.chevron-list .link:hover:before {
	border-color:var(--accent-color)
}

.chevron-list .link:focus:before {
	border-color:#0b0c0c
}

@media screen and (min-width: 601px) {
	.chevron-list .title {
		font-size: 1.2em;
	}
}










/* Component: link highlighted
-------------------------------------------------- */
.link-highlighted {
	background-color: var(--accent-secondary-muted-color);
	padding: 0.5em 1em;
}
















/* Articles
-------------------------------------------------- */
.article {
	margin-bottom: 50px;
}

.article .preview {
	position: relative;
	max-height: 18em;
	overflow: hidden;
	margin-bottom: 1em;
}

.article .preview:after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 8em;
	background-image: linear-gradient(to top, rgba(255,255,255, 1), rgba(255,255,255, 0));
}






















/* Buttons
-------------------------------------------------- */
.btn {
	position: relative;
	display: inline-block;
	font-size: 1.7rem;
	line-height: 1.1;
	text-decoration: none;
	border: 2px solid transparent;
	border-bottom-color: rgba(0,0,0, 0.4);
	border-radius: 0;
	background: none;
	background-color: #ddd;
	color: #000;
	width: auto;
	padding: 0.75em 1em;
}

.btn.prominent {
	color: #fff;
	background-color: #00703c;
}

.btn.destructive {
	color: #fff;
	background-color: var(--error-color);
}

.btn.small {
	font-size: 1.4rem;
	padding: 0.35em 0.75em 0.45em 0.75em;
}

.btn.text {
	background-color: transparent;
	border: none;
	margin: 5px 0 0 0;
	padding: 0;
	color: var(--accent-color);
}

.btn.text:hover {
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 2px;
}

.btn:hover {
	filter: brightness(0.85);
}
.btn:active {
	top: 2px;
}






/* Forms
-------------------------------------------------- */
.fieldset {
	border: none;
	margin: 0;
	padding: 0;
}
.input-field {
	margin-block-end: 3rem;
}

.btn-row {
	margin-block-end: 3rem;
}

.input-label {
	display: block;
	margin-block-end: 3px;
}

.input-hint {
	display: block;
	margin-block-end: 3px;
	color: var(--text-color-muted);
}

.input {
	display: block;
	width: 100%;
	font-size: 1.7rem;
	line-height: 1.3;
	height: 2.6em;
	margin: 0;
	padding: 0 1ch;
	border: 2px solid var(--input-border-color);
	border-radius: 0;
}

.input:focus {
	box-shadow: inset 0 0 0 2px;
}

textarea.input {
	height: auto;
	padding-top: 8px;
	padding-bottom: 8px;
}

select.input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg fill='black' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");
	background-repeat: no-repeat;
	background-position-x: 100%;
	background-position-y: 50%;
	padding-right: 24px;
}

.file-input {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: auto;
	height: 100px;
	padding: 0;
	aspect-ratio: 1 / 1;
	background-color: var(--background-tint-color);
	border: 3px dashed var(--input-border-color);
	border-radius: 8px;
}

.file-input:hover {
	border-color: var(--text-color);
}

.file-input.ratio-16-9 {
	aspect-ratio: 16 / 9;
}

.file-input-field {
	display: none;
}

.file-input img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 4px;
	border-radius: 8px;
	object-fit: cover;
}

.file-input img[src=""] {
	display: none;
}

@media screen and (min-width: 601px) {
	.input {
		width: auto;
	}
}

.radio-item {
	display: flex;
	align-items: center;
	height: 40px;
	position: relative;
	margin-bottom: 5px;
	padding-left: 54px;
	cursor: pointer;
}

.radio-item input {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	width: 40px;
	height: 40px;
	margin: 0;
	opacity: 0;
}

  /* [ ] Check box */
.radio-label:before {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
	width: 40px;
	height: 40px;
	border: 2px solid black;
	background: transparent;
}

  /* [ ] Radio box */
.radio-label.is-radio:before {
	border-radius: 8px;
}

  /* ✔ Check mark
  //
  // The check mark is a box with a border on the left and bottom side (└──),
  // rotated 45 degrees */
.radio-label:after {
	content: "";
	box-sizing: border-box;
	position: absolute;
	top: 11px;
	left: 9px;
	width: 23px;
	height: 12px;
	transform: rotate(-45deg);
	border: solid;
	border-width: 0 0 5px 5px;
	border-top-color: transparent;
	opacity: 0;
	background: transparent;
}

/* Disabled state */
.radio-label input:disabled {
	cursor: not-allowed;
}

input:checked + .radio-label:after {
	opacity: 1;
}













/* Toolbar, pagination
   -------------------------------------------------------------------------------- */
.toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1em;
	margin-block-end: 1em;
}

.toolbar .group {
	display: flex;
	flex: 0 1 auto;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.25em;
}

.toolbar .input {
	width: auto;
}

.toolbar .input.stretch {
	width: 100%;
}

.pagination {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.5em;
	margin-block-end: 1em;
}

.form-toolbar {
	display: flex;
	justify-content: space-between;
	margin-block-start: 3rem;
	margin-block-end: 3rem;
}















/* Tab bars include icons and navigate between grouped content
   -------------------------------------------------------------------------------- */
.tab-bar {
	display: flex;
	flex-wrap: nowrap;
	justify-content: start;
	gap: 0;
	margin-block-end: 2rem;
	padding-top: 10px;
	padding-bottom: 10px;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}

.tab-bar .tab {
	display: flex;
	flex: 0 0 auto;
	flex-direction: column;
	align-items: center;
	font-size: 1.4rem;
	font-weight: 500;
	padding: 0.5em 1em;
	text-decoration: none;
	border-bottom: 3px solid transparent;
}

.tab-bar .tab.active {
	border-bottom-width: 3px;
	border-bottom-color: var(--accent-color);
}

.tab-bar .tab:hover {
	cursor: pointer;
	background-color: var(--link-highlight-background-color);
	border-bottom-color: var(--accent-color);
}

/* Tab bar groups for displaying tab content
   -------------------------------------------------------------------------------- */
.tab-groups {
	margin-block-end: 10rem;
}

.tab-groups .group {
	display: none;
	margin-left: auto;
	margin-right: auto;
}

.group.with-editor {
	padding: 0 5px;
	border: 2px solid var(--input-border-color);
}

.tab-groups .group.active {
	display: block;
}

















/* Tables
-------------------------------------------------------------------------------- */
.table {
	width: 100%;
	border-collapse: collapse;
	margin-block-end: 5rem;
}

.table tr {
	border-bottom: 1px solid var(--list-item-separator-color);
}

.table tbody tr:hover {
	background-color: var(--link-highlight-background-color);
}

.table.with-default-action tbody tr:hover {
	cursor: pointer;
}

.table th, .table td {
	padding: 8px 10px 0 0;
}

.table th {
	text-align: left;
	font-weight: 500;
}

.table .icon {
	width: 30px;
	margin-right: 10px;
}

.table .actions {
	text-align: right;
	white-space: nowrap;
	padding-right: 0;
}




















/* Alert notifications
-------------------------------------------------- */
.alert {
	font-size: 1.7rem;
	margin-block-end: 3rem;
	border: 4px solid var(--alert-color);
}

.alert.toasted {
	position: fixed;
	top: 3rem;
	right: 3rem;
	width: auto;
	min-width: 300px;
	max-width: 500px;
}

.alert .alert-title {
	display: block;
	margin: 0;
	padding: 0.5rem 2rem 1.0rem 2rem;
	font-size: 1.2em;
	font-weight: 700;
	line-height: 1.2;
	color: #fff;
	background-color: var(--alert-color);
}

.alert .alert-message {
	margin: 2rem 2rem;
}

.alert.error { border-color: var(--error-color); }
.alert.error .alert-title { background-color: var(--error-color); }
.alert.success { border-color: var(--success-color); }
.alert.success .alert-title { background-color: var(--success-color); }


















/* Width helpers
-------------------------------------------------- */
@media screen and (min-width: 601px) {
	.width-25 { width: 25%; }
	.width-50 { width: 50%; }
	.width-75 { width: 75%; }
	.width-100 { width: 100%; }
}











/* Colours
-------------------------------------------------- */
.text-color-muted { color: var(--text-color-muted); }
.accent-color { color: var(--accent-color); }
.accent-secondary-color { color: var(--accent-secondary-color); }










.control-actions {
	position: fixed;
	z-index: 10;
	top: 80px;
	right: 30px;
}

.by-line {
	font-size: 1.4rem;
	color: var(--text-color-muted);
}



/* Helpers
-------------------------------------------------- */
hr {
	width: 100%;
	background: none;
	border: none;
	margin: 50px 0;
}
hr.small {
	height: 25px;
	margin: 0;
}
hr.with-bar {
	height: 4px;
	background-color: var(--accent-color);
}
.hidden {
	display: none;
}

.with-top-border {
	border-top: 4px solid var(--accent-color);
}

.nowrap-whitespace {
	white-space: nowrap;
}