﻿@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');
@import "variables.css";

html,
body {
	font-family: 'Open Sans', Arial, Verdana, sans-serif;
	overflow: hidden auto;
}

#app {
	height: 100vh;
  display: flex;
  flex-direction: column;
}

h1:focus {
	outline: none;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
}

.h1,
h1 {
	font-size: 1.5rem;
	font-weight: 400;
	margin-bottom: 1.4rem;
}

.h2,
h2 {
	font-size: 1.25rem;
}

.h4,
h4 {
	font-size: 1.125rem;
}

p {
	margin-bottom: 0.5rem;
	word-break: break-word;
}

a {
	text-decoration: none;
}

a,
.btn-link {
	color: var(--primary-darker);
}

a:hover {
	color: var(--primary-darkest);
	text-decoration: underline;
}

input[type="date"] {
	display:block;
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
	min-height: 1.2em;
}

.loading-container {
	width: 100vw;
	height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: var(--black);
}

.loading img {
	max-width: 100%;
	height: auto;
}

/* bootstrap buttons */

.btn-primary {
	color: var(--black);
	background-color: var(--primary);
	border-color: transparent;
}

.btn-primary:hover {
	color: var(--black);
	background-color: var(--primary-dark);
	border-color: var(--primary-dark);
}

.btn-primary:active {
	color: var(--black);
	background-color: var(--primary);
	border-color: transparent;
}

.btn-primary:focus {
	color: var(--black);
	background-color: var(--primary);
	border-color: transparent;
	outline-color: var(--primary) !important;
	outline-width: 4px !important;
	outline-style: solid !important;
	outline-offset: 1px;
	box-shadow: none;
}

.btn-secondary {
	color: var(--black);
	background-color: var(--white);
	border-color: var(--primary);
	border-width: 3px;
}

.btn-secondary:hover {
	color: var(--black);
	background-color: var(--primary-dark);
	border-color: var(--primary-dark);
}

.btn-secondary:active {
	color: var(--black);
	background-color: var(--primary);
	border-color: transparent;
}

.btn-secondary:focus {
	color: var(--black);
	background-color: var(--primary);
	border-color: transparent;
	outline-color: var(--primary) !important;
	outline-width: 4px !important;
	outline-style: solid !important;
	outline-offset: 1px;
	box-shadow: none;
}

.btn-primary:disabled {
	color: var(--black);
	background-color: var(--primary);
	border-color: var(--primary);
}

.btn-lg {
	font-size: 1rem;
	padding: 0.75rem 1.5rem;
	height: 50px;
}

.btn-xl {
	font-size: 1rem;
	font-weight: 700;
	padding: 1.3rem 3rem;
	text-transform: uppercase;
}

.btn-sm {
	font-size: 0.875rem;
	padding: 0.65rem 1rem;
}

.btn-icon {
	display: flex;
	align-items: center;
	justify-content: center;
}

.btn-shadow {
	font-size: 1.125rem;
	box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

/* bootstrap badge */
.bg-primary {
	background-color: var(--primary) !important;
	color: var(--black);
}

.badge {
	font-weight: 500;
}

/* bootstrap form */
/* bootstrap radio */
.form-check-input:checked {
	background-color: var(--primary-dark);
	border-color: var(--primary-dark);
}

.form-text {
	margin-bottom: 0.25rem;
}

.form-static-control {
	padding: .375rem .75rem;
}

.form-select-custom {
	background-size: 25px 15px;
	background-position: right 0rem center;
	border: none;
	padding: 0 24px 0 0;
}

.form-select-custom:focus {
	border: none;
	box-shadow: none;
	outline: 2px solid var(--black);
	border-radius: 0px;
}

.content {
	padding-top: 1.1rem;
}

.invalid {
	outline: 1px solid var(--error);
}

.validation-message {
	color: var(--error);
	font-size: 1rem;
	margin-top: 8px;
}

.btn-p0 {
	padding: 0;
}

.theme-link {
	color: var(--primary-darker);
}

.theme-link:hover {
	color: var(--primary-darkest);
	text-decoration: underline;
}

.theme-link:focus {
	outline-color: var(--black);
	outline-width: 2px;
	outline-style: solid;
	outline-offset: 1px;
}

.heading {
	margin-bottom: 32px;
	word-break: break-word;
}

#blazor-error-ui {
	background: lightyellow;
	bottom: 0;
	box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
	display: none;
	left: 0;
	padding: 0.6rem 1.25rem 0.7rem 1.25rem;
	position: fixed;
	width: 100%;
	z-index: 1000;
}

#blazor-error-ui .dismiss {
	cursor: pointer;
	position: absolute;
	right: 0.75rem;
	top: 0.5rem;
}

.blazor-error-boundary {
	background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=)
			no-repeat 1rem/1.8rem,
		#b32121;
	padding: 1rem 1rem 1rem 3.7rem;
	color: white;
}

.blazor-error-boundary::after {
	content: "An error has occurred.";
}

/* layout styles */
.p-insert + p {
	display: inline;
}

/* Common styles for forms */
.form-block {
	background-color: #f8f8f8;
	border-top: 6px solid #000;
	padding: 1rem;
	padding-top: 1.5rem;
	margin-bottom: 2rem;
}

.form-block-side {
	border-top: none;
	border-left: 6px solid #ccc;
}

.form-block label.required {
	position: relative;
}

.form-block label.required:after {
	content: '*';
	position: absolute;
	top: 0;
	right: -.75em;
}

.form-block .input-group {
	position: relative;
}

.form-block .input-group .char-count {
	position: absolute;
	bottom: -25px;
	right: 0;
	font-weight: 600;
	font-size: 0.875rem;
}

.form-block .example,
.form-block .preview {
	width: 90%;
	margin-top: 1.25rem;
	margin-bottom: 0.25rem;
	font-size: 0.875rem;
}

.form-btn .oi-chevron-left {
	top: 3px;
	padding-right: 0.5rem;
}

.form-btn .oi-chevron-right {
	top: 3px;
	padding-left: 0.5rem;
}

.label-field {
	display: flex;
	flex-direction: column;
	border: 1px solid #dbdbdb;
	padding: 0.5rem 0.75rem;
	transition: border-color .2s ease-in;
}

.label-text {
	font-weight: 700;
	font-size: 0.875rem;
	margin-bottom: 4px;
}

.label-field-input {
	border: none;
	font-size: 1rem;
}

.label-field-input:focus,
.label-field-input:active {
	outline: none;
}

.label-field-input:focus {
	outline-color: var(--black);
	outline-width: 2px;
	outline-style: solid;
	outline-offset: 1px;
}

/* table */
table {
	font-size: 0.875rem;
}

.table > :not(:last-child) > :last-child > * {
	border-bottom-color: inherit;
}

@media (min-width: 768px) {
	.h1,
	h1 {
		font-size: 3.25rem;
	}

	.h2,
	h2 {
		font-size: 1.75rem;
	}

	.h4,
	h4 {
		font-size: 1.5rem;
	}
	.form-block {
		padding: 3rem 2.5rem;
	}
	.form-block-side {
		padding: 24px;
	}
}

main {
	flex: 1;
}

.header {
	position: relative;
	background-color: #000;
	border-bottom: 6px solid #1bcba5;
}

.main {
	margin-bottom: 2rem;
}

.footer {
	background-color: #f2f2f2;
	border-bottom: 6px solid #1bcba5;
	min-height: 4rem;
	padding: 0 1rem;
	display: flex;
	align-items: center;
	font-size: 0.875rem;
}

.nav-top-row {
	position: relative;
}

.nav-mobile > button {
	color: var(--primary);
	font-size: x-large;
}

.logo {
	display: flex;
	align-items: center;
	color: var(--white);
	cursor: pointer;
	white-space: nowrap;
}

	.logo:hover {
		text-decoration: none;
	}

.logo-image {
	height: 48px;
}

.logo-title {
	margin-left: 8px;
}

.logo-title-english {
	font-size: 1rem;
	font-weight: 700;
}

.logo-title-maori {
	font-size: 0.85rem;
}

@media (min-width: 992px) {
	.nav-top-row {
		position: initial;
	}

	.nav-mobile > button {
		margin-left: 1rem;
	}

	.logo-title {
		margin-left: 16px;
	}

	.logo-title-english {
		font-size: 2rem;
	}

	.logo-title-maori {
		font-size: 1.5rem;
	}

	.logo-image {
		height: 80px;
	}
}

.nav-megamenu > ul {
	list-style: none;
	margin: 2.5em 0 0 0;
	padding: 0;
}

	.nav-megamenu > ul > li:not(:first-child) {
		border-left: 1px solid #ccc;
		border-color: rgba(255,255,255,.3);
	}

	.nav-megamenu > ul > li > .nav-megamenu-btn {
		white-space: nowrap;
	}

.nav-megamenu-btn {
	color: var(--white);
	padding: .5rem 1rem;
	font-size: large;
	border-radius: 4px 4px 0 0;
	border-color: transparent;
}

	.nav-megamenu-btn.selected,
	.nav-megamenu-btn:hover {
		color: var(--black);
		background-color: var(--primary);
	}

	.nav-megamenu-btn > * {
		vertical-align: middle;
	}

.nav-megamenu-blocker {
	display: none;
}

@media (max-width: 1200px) {
	.nav-megamenu-btn {
		font-size: medium;
	}
}

@media (max-width: 992px) {
	.nav-megamenu {
		position: absolute;
		top: 100%;
		left: 0;
		background: black;
		width: 100%;
		padding: 1rem;
		z-index: 1000;
	}

		.nav-megamenu > ul {
			margin: 1em 0 0 0;
		}

			.nav-megamenu > ul > li {
				border: none;
				margin-bottom: 8px;
			}

	.nav-megamenu-btn {
		position: relative;
		color: var(--black);
		background-color: var(--primary);
		border-radius: 4px;
		width: 100%;
		text-align: left;
	}

		.nav-megamenu-btn.selected {
			border-radius: 4px 4px 0 0;
		}

		.nav-megamenu-btn .icon {
			position: absolute;
			top: 17px;
			right: 22px
		}

	.nav-megamenu-blocker {
		display: block;
		position: absolute;
		top: 100%;
		left: 0;
		background: black;
		opacity: 0.2;
		width: 100%;
		height: 100vh;
	}
}

.gutterless {
	padding: 0;
}

.nav-session ul {
	list-style: none;
	margin: 0;
	padding: 0;
	flex-direction: column;
}

	.nav-session ul > li:not(:last-child) {
		border-bottom: 1px solid #ccc;
		border-color: rgba(255,255,255,.3);
	}

	.nav-session ul > li {
		position: relative;
	}

		.nav-session ul > li > .btn {
			color: var(--white);
			font-size: medium;
			border-radius: 0;
			width: 100%;
			text-align: left;
			overflow: auto;
			padding: 0.75rem 0 0.75rem 1rem;
			display: flex;
			flex-wrap: nowrap;
			align-items: center;
			gap: 4px;
		}

			.nav-session ul > li > .btn:hover {
				color: var(--black);
				background: var(--primary);
				text-decoration: none;
			}

			.nav-session ul > li > .btn > .icon {
				color: var(--white) !important;
				font-size: 36px;
				vertical-align: middle;
			}

			.nav-session ul > li > .btn.btn-disabled,
			.nav-session ul > li > .btn.btn-disabled > .icon,
			.nav-session ul > li > .btn.btn-disabled:hover {
				color: var(--grey-dark) !important;
				background: none;
				cursor: default;
			}

.nav-session-image {
	position: relative;
	height: 70%;
}

	.nav-session-image > img {
		object-fit: cover;
		width: 100%;
		height: 100%;
	}

.nav-session-text {
	color: var(--white);
	font-size: medium;
	font-weight: bold;
}

@media (max-width: 992px) {
	.nav-session ul {
		flex-direction: row;
		justify-content: center;
		margin: 1rem 0;
	}

		.nav-session ul > li:not(:last-child) {
			border-bottom: 0;
			border-right: 1px solid #ccc;
			border-color: rgba(255,255,255,.3);
		}

		.nav-session ul > li {
			flex-grow: 1;
		}

			.nav-session ul > li > .btn {
				text-align: center;
				padding: 1rem;
			}

				.nav-session ul > li > .btn > .icon {
					display: block;
					margin: auto;
				}
}

.nav-search {
	color: var(--white);
}

.nav-search-link {
	color: var(--primary);
	font-size: small;
}

	.nav-search-link:hover {
		color: var(--primary-darker);
	}

	.nav-search-link > * {
		vertical-align: middle;
	}

.nav-search-blocker {
	display: none;
}

.nav-search-box {
	margin-top: 0.5rem;
	border-radius: 4px;
	position: relative;
}

	.nav-search-box input:focus {
		outline-color: var(--primary);
		outline-width: 4px;
		outline-style: solid;
		outline-offset: 1px;
	}

	.nav-search-box input {
		border-radius: 4px;
		padding: .5em;
		padding-right: 2.5em;
		border: none;
		font-size: medium;
		line-height: 1.75;
	}

	.nav-search-box button {
		position: absolute;
		right: 0;
		color: var(--primary);
		font-size: 32px;
	}

.focus-white-outline:focus {
	outline: 2px solid var(--white) !important;
}

.focus-primary-outline:focus {
	outline: 2px solid var(--primary) !important;
}

@media (max-width: 992px) {
	.nav-search {
		position: absolute;
		top: 100%;
		margin-top: 6px;
		left: 0;
		background: black;
		width: 100%;
		padding: 1rem;
	}

	.nav-search-link {
		font-size: large;
	}

	.nav-search-blocker {
		display: block;
		position: absolute;
		top: 100%;
		left: 0;
		background: black;
		opacity: 0.2;
		width: 100%;
		height: 100vh;
	}

	.nav-search-box {
		width: 100%;
	}

		.nav-search-box > input {
			width: 100%
		}
}

.c-lang {
	color: var(--white);
	font-size: large;
}

.c-lang-title {
	display: block;
	color: #ccc;
	margin-bottom: 8px;
}

@media (min-width: 768px) {
	.c-lang {
		font-size: medium;
	}
}