$bug-list: ("search-element-appearance": ()); 
@import "bumbleberry";
@import "settings";
$zindex-base: 0;
html, body {
	color: $black;
	position: relative;
	z-index: $zindex-base;
}
body {
	padding-bottom: 20vw;
}
h1, h2, h3, h4, h5, h6, label, button, .button, dt, th, .table-th, nav.sub-menu {
	@include font-family(secondary);
	font-weight: normal;
}
h2 {
	margin: 0;
	font-size: 6vw;
}
h3 {
	font-size: 4.5vw;
}
h3.subtitle {
	font-size: 1.5em;
}
h4 {
	font-size: 1.25em;
}
h5 {
	font-size: 1.125em;
}
h6 {
	font-size: 1em;
}
p {
	font-size: 4vw;
}
a {
	text-decoration: none;
	color: $link-colour;
	border-bottom: 0 solid;
	outline: 0;
	position: relative;
	cursor: pointer;
	@include after {
		content: '';
		position: absolute;
		border-bottom: 0 solid;
		right: 0;
		bottom: 0;
		left: 0;
		opacity: 0;
		@include _(transition, all 150ms ease-in-out);
		@include _(transform-origin, 25% 50%);
		@include _(transform, scaleX(0));
	}
	&:hover,
	&:active,
	&:focus {
		@include after {
			border-bottom: 0.1em solid;
			opacity: 1;
			@include _(transform, scaleX(1));
		}
	}
}
.screen-reader-text { 
	clip: rect(1px, 1px, 1px, 1px); 
	height: 1px; 
	width: 1px; 
	overflow: hidden; 
	position: absolute !important;
}
table, .table {
    margin-bottom: 2em;
	margin-left: 1em;
	th, td, .table-th, .table-td {
		text-align: left;
		padding: 0.25em 0.5em;
		border: 0.1rem solid #EEE;
		&.center {
			text-align: center;
		}
		&.big {
			font-size: 1.5em;
		}
		&.status {
			width: 0.1rem;
			background-color: transparent;
			border: 0;
		}
		&.state {
			background-size: 1.333em;
			background-repeat: no-repeat;
			background-position: center;
			width: 1.75em;
			&.happy {
				background-image: url("data:image/svg+xml;utf8,");
			}
			&.unhappy {
				background-image: url('data:image/svg+xml;utf8,');
			}
		}
	}
	th, .table-th {
		background-color: #F8F8F8;
		&.corner {
			background-color: transparent;
			border: 0;
		}
	}
	td, .table-td {
		&.inner-table {
			padding: 0;
			table {
				margin: 0;
				width: 100%;
			}
			tr:first-child {
				td, th {
					border-top: 0;
				}
			}
			tr:last-child {
				td, th {
					border-bottom: 0;
				}
			}
			
			td, th {
				&:first-child {
					border-left: 0
				}
				&:last-child {
					border-right: 0
				}
			}
		}
		&.bold {
			@include font-family(secondary);
		}
	}
	tbody th {
		width: 0.1rem;
	}
	&.admin-edit {
		width: 100%;
	}
	tr.hidden {
		display: none;
	}
	tr[data-key] {
		cursor: cell;
			
		&.editable:hover {
			background-color: lighten($colour-2, 33%);
		}
		+ .editor {
			display: none;
			background-color: lighten($colour-1, 50%);
			td {
				opacity: 0.5;
				&.has-editor {
					opacity: 1;
					@include after {
						content: '';
						position: absolute;
						top: 100%;
						right: 0;
						left: 0;
						height: 0.25em;
						background-color: rgba($black, 0.125);
					}
				}
				.cell-editor {
					&[type=number]::-webkit-inner-spin-button, 
					&[type=number]::-webkit-outer-spin-button { 
						-webkit-appearance: none; 
					}
				}
				select.cell-editor {
					-webkit-appearance: none;
					-moz-appearance: none;
					-ms-appearance: none;
					appearance: none;
					cursor: pointer;
				}
				&.date .cell-editor {
					text-align-last: right;
				}
			}
		}
		+ .editor, &.always-edit {
			td {
				position: relative;
				vertical-align: top;
				background: inherit;
				cursor: default;
				.cell-editor {
					top: 0;
					right: 0;
					bottom: 0;
					left: 0;
					padding: inherit;
					font: inherit;
					margin: inherit;
					background: inherit;
					border: 0;
					min-height: 0;
					width: 100% !important;
					border-radius: 0;
					line-height: inherit;
					overflow: hidden;
					box-shadow: none;
					text-align: inherit;
				}
			}
		}
		
		&.always-edit td .cell-editor {
			position: absolute;
		}
		&.editing {
			display: none;
			+ .editor {
				display: table-row;
				.cell-editor {
					position: absolute;
				}
			}
		}
	}
	&.always-editing {
		tr {
			cursor: default;
			&:hover {
				background-color: transparent;
			}
		}
		.cell-editor {
			position: absolute;
		}
		td.text {
			height: 5em;
		}
	}
	tr.editable, tr.editor {
		td {
			white-space: nowrap;
			&.date, &.datetime, &.money, &.number {
				font-family: monospace;
				font-size: 1.25em;
				text-align: right;
			}
			&.text {
				max-width: 20em;
			}
		}
	}
	tr.editable td.text,
	tr.editor td.text .value {
		overflow: hidden;
		text-overflow: ellipsis;
	}
			
	tr.editor {
		td.text .cell-editor {
			white-space: normal;
			bottom: auto;
			height: 10em;
			z-index: 1;
			background: inherit;
			overflow: auto !important;
		}
	}
}
.table-scroller {
	overflow: auto;
	background-color: #F8F8F8;
	@include _(box-shadow, inset 0 0 10em 0 rgba(0,0,0,0.125));
	table {
		background-color: $white;
		margin: 0 0 8.5em;
	}
	body.expanded-element .expanded & {
		overflow: visible;
	}
}
.goes-fullscreen {
	[data-contracts] {
		display: none;
	}
}
body.modal-open {
	overflow: hidden;
}
body.expanded-element {
	overflow: hidden;
	.goes-fullscreen.expanded {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		z-index: 1000;
		background-color: $white;
		overflow: auto;
		padding: 0 1em;
		[data-expands] {
			display: none;
		}
		[data-contracts] {
			display: block;
		}
	}
}
#main .columns .modal-edit {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	z-index: 1001;
	margin: 0;
	background-color: rgba($black, 0.5);
	&.open {
		display: flex;
	}
	.modal-edit-overlay {
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		bottom: 0;
		cursor: pointer;
	}
	table {
		margin: 0;
		background-color: $white;
		td.empty {
			background-color: #F8F8F8;
			border-bottom-color: #F8F8F8;
		}
	}
	thead th {
		text-align: center;
		font-size: 1.125em;
		color: $white;
		border-color: lighten($colour-1, 12.5%);
		background-color: $colour-1;
	}
	tbody th {
		white-space: nowrap;
	}
	.modal-edit-content {
		position: relative;
		min-width: 50em;
		max-width: 75em;
		margin: auto;
		overflow: auto;		
		z-index: 1002;
		background-color: #F8F8F8;
		flex: 1;
	}
	.actions {
		margin: 1em 1em 0;
	}
}
.table {
	display: table;
	border-collapse: collapse;
}
.table-tr {
	display: table-row;
}
.table-th, .table-td {
	display: table-cell;
}
button,
.button {
	@include button;
    vertical-align: top;
	#main &[type="submit"] {
		background-color: $colour-5;
		&[value="send"] {
			background-color: $colour-4;
		}
	}
	&.register {
		background-color: $colour-4;
	}
	form.logout & {
		background-color: #666;
	}
	#main &.modify {
		background-color: $colour-5;
	}
	&.delete,
	#main &.delete {
		background-color: $colour-4;
	}
	#main &.secondary {
		background-color: $colour-1;
	}
	&.subdued, #main &.subdued {
		background-color: #888;
	}
	#main &.accented {
		background-color: $colour-2;
	}
	&.facebook {
		background-color: #3A5795;
	}
	&.small {
		font-size: 0.9em;
	}
}
a.button {
	@include after {
		border-bottom: 1em solid transparent;
		left: auto;
		bottom: auto;
		@include _(transform, none);
	}
}
nav.sub-menu {
	display: inline-block;
	margin: 2rem 0 0;
	text-align: center;
	
	a {
	    margin: 0 1em 0.5em 0;
		background-color: #E8E8E8;
		color: #888;
		display: inline-block;
		padding: 0.25em 0.75em 0.333em;
		font-size: 0.9em;
		border: 1px solid #AAA;
		border-bottom-width: 0.2em;
		@include _(border-radius, 0.15em);
		@include default-box-shadow(top, 2);
		@include _(text-shadow, 0 0.05em 0.05em #FFF);
		&:hover, &:active, &:focus {
			background-color: #D8D8D8;
		}
		&.current {
			background-color: #CCC;
			color: #666;
			padding: 0.333em 0.75em 0.25em;
		}
		@include after {
			display: none;
		}
	}
	@include breakpoint(medium) {
		border: 1px solid #AAA;
		background-color: #AAA;
		border-bottom-width: 0.125em;
		@include _(border-radius, 0.15em);
		@include default-box-shadow(top, 2);
		a {
			border: 0;
			margin: 0 1px 0 0;
			float: left;
			@include _(border-radius, 0);
			@include _(box-shadow, none);
			&:last-child {
				margin: 0;
			}
		}
	}
}
textarea, .textarea {
	display: block;
	width: 100%;
	min-height: 15em;
	font-size: 1.25em;
	line-height: 1.5em;
	margin: 1em 0;
	padding: 0.75em;
	border: 0.1rem solid #E8E8E8;
	outline: 0;
	@include _(border-radius, 0.25rem);
	color: inherit;
	background-image: repeating-linear-gradient(135deg, rgba(#000, 0.025), rgba(#000, 0.025) 0.1em, transparent 0.1em, transparent 0.4em);
	@include _(box-shadow, 0 0 0 0 rgba(0,0,0,0.05));
	@include _(transition, box-shadow 200ms ease-in-out);
	will-change: box-shadow;
	&[data-edit-on="click"],
	&[data-edit-on="focus"] {
		cursor: text;
	}
	&:hover, &:focus, &:active {
		@include _(box-shadow, 0 0 0 0.3em rgba(0,0,0,0.05));
	}
	&.short {
		min-height: 10em;
	}
}
.textarea, .workshop-description {
	> :first-child {
		margin-top: 0;
	}
	> :last-child {
		margin-bottom: 0;
	}
	p {
		font-size: 1.125em;
	}
	h1 {
		font-size: 1.667em;
	}
	h2 {
		font-size: 1.25em;
	}
}
input {
	&[type="text"], &[type="password"], &[type="tel"], &[type="search"], &[type="email"], &[type="url"], &[type="number"] {
		display: block;
		font-size: 1.25em;
		outline: 0;
		border: 0;
		margin: 1em 0;
		width: 100%;
		padding: 0.25em 0.5em;
		border-bottom: 0.15em solid transparent;
	}
	&[type="number"], &[type="tel"] {
		@include font-family(secondary);
	}
}
.number-field,
.email-field,
.search-field,
.telephone-field,
.password-field,
.text-field {
	position: relative;
	margin-bottom: 2em;
	color: inherit;
	&.empty {
		label {
			z-index: $zindex-base + 3;
			@include _(transform, translateY(-100%) scale(1));
			background-color: transparent;
			color: #666;
		}
	}
	&.big input {
		@include font-family(secondary);
		.composition & {
			margin-top: 1em;
		}
	}
	label,
	&.focused label {
		position: absolute;
		z-index: $zindex-base + 3;
		font-size: 1em;
		padding: 0.25em 0.667em;
		width: auto;
		@include _(transition, 'transform 250ms ease-in-out, color 250ms ease-in-out, background-color 250ms ease-in-out');
		top: 100%;
		left: 0;
		@include _(transform, translateY(0) scale(0.75));
		@include _(transform-origin, 0 0);
		line-height: 1.5em;
		background-color: transparent;
		color: $black;
		cursor: text;
		will-change: transform, color, background-color;
	}
	input {
		margin: 0;
		position: relative;
		z-index: $zindex-base + 2;
		padding: 0.15em 0.5em;
		background-color: #F8F8F8;
		@include _(border-radius, 0.25rem);
		@include _(box-shadow, 0 0 0 0 rgba(0,0,0,0.05));
		@include _(transition, box-shadow 200ms ease-in-out);
		background-image: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.025), rgba(0, 0, 0, 0.025) 0.1rem, transparent 0.1rem, transparent 0.4rem);
		border: 0.1rem solid #E8E8E8;
		will-change: box-shadow;
	}
	&:focus, &:active, &:focus {
		label {
			color: $black;
		}
	}
	input {
		&:focus, &:active, &:hover {
			@include _(box-shadow, 0 0 0 0.3em rgba(0,0,0,0.05));
		}
	}
}
.number-field,
.email-field,
.password-field,
.telephone-field,
.search-field,
.text-field,
.text-area-field {
	text-align: left;
}
.telephone-field {
	max-width: 15em;
}
@include keyframes(bend) {
	to {
		@include _(transform, skewX(-5deg));
	}
}
.hidden {
	display: none !important;
}
.field-error {
	display: block;
	background-color: rgba($colour-2, 0.333);
	@include font-family(secondary);
	padding: 0.5em 1em;
	margin: 0 0.2em;
	text-align: center;
	@include default-box-shadow(top, 2);
}
.input-field {
	.field-error {
		float: right;
		@include _(transform, skewX(-15deg));
		@include _(transform-origin, 0 100%);
		@include _(animation, bend ease-in-out 500ms infinite alternate both);
	}
	&.check-box-field {
		&.has-error {
			margin-top: 3em;
		}
		.field-error {
			position: absolute;
			bottom: 100%;
			right: 0;
			margin-right: 0;
		}
	}
	&.small select,
	&.small input {
		font-size: 1em;
		@include font-family(secondary)
	}
}
.input-field.other-field label {
	input {
		float: left;
		margin: 0.33em 0;
		&:checked {
			+ div input {
				z-index: $zindex-base + 2;
				@include _(opacity, 1);
			}
		}
	}
	div {
		float: left;
		position: relative;
		margin: 0 0.25em;
		font-size: 1em;
		input {
			//display: none;
			@include _(opacity, 0);
			@include _(transition, opacity 250ms ease-in-out);
			z-index: $zindex-base;
			position: absolute;
			width: auto;
			margin: 0;
			border: 1px solid #CCC;
			height: 1.5em;
			left: 0;
			top: 0;
		}
	}
}
.number-field {
	display: inline-block;
	font-size: 1.5em;
	input {
		text-align: right;
	}
}
.input-field-help {
	margin: 0.5em 1em;
	line-height: 1.3333em;
	font-size: 1.125em;
}
.check-box-field,
.check-box-field.vertical,
.radio-button-field {
	@include clearfix;
	margin-bottom: 3em;
	position: relative;
	@include default-box-shadow(top);
	td &,
	.table-td & {
		@include _(box-shadow, none);
		margin: 0;
	}
	
	label {
		display: block;
		background-color: #FFF;
		height: 2.333em;
		font-weight: normal;
		font-size: 1.25em;
		@include font-family(secondary);
		text-align: center;
		position: relative;
		padding: 0.5em 0.5em 0.5em 3em;
		cursor: pointer;
		border: 0.1em solid;
		border-top: 0;
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
		@include _(transition, #{'transform, background-color 100ms, 100ms ease-in-out, ease-in-out'});
		@include before-and-after {
		 	content: '';
		 	position: absolute;
		 	@include _(transition, transform 200ms ease-in-out);
		 }
		@include before {
			content: '';
			position: absolute;
			top: 0;
			left: 0;
			width: 2.333em;
			height: 100%;
			border-right: inherit;
		}
		@include after {
			content: '';
			position: absolute;
			visibility: hidden;
			left: 0.75em;
			top: 0.25em;
			border: 0.2em solid #FFF;
			width: 0.75em;
			height: 1.5em;
			border-width: 0 .2em 0.2em 0;
			@include _(transform, rotate(45deg) scale(0));
		 	@include _(transition, transform 200ms cubic-bezier(0, 0.38, 0.9, 2));
		}
	}
	input:first-child + label {
		border: 0.1em solid;
	}
	input {
		position: fixed;
		opacity: 0 !important;
    	left: -100000px;
    	z-index: -10;
		&:checked + label {
			@include before {
				background-color: $colour-5;
			}
			@include after {
				visibility: visible;
				@include _(transform, rotate(45deg) scale(1));
			}
		}
		&:hover + label {
			@include before {
				background-color: $colour-3;
			}
		}
		&[type="radio"] + label {
			@include after {
				content: '+';
				border: 0;
				font-size: 2.5em;
				top: -0.025em;
				left: 0.175em;
				line-height: 1em;
				color: #FFF;
				height: 1em;
				width: 1em;
			}
		}
	}
	&.inline input[type="radio"] + label {
		@include after {
    		top: -0.15em;
    		left: 0.05em;
		}
	}
	.other {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 2.333em;
		input {
			z-index: 1;
			opacity: 1!important;
			position: static;
			margin: 0;
			font: inherit;
			height: 100%;
			text-align: inherit;
			cursor: inherit;
		}
	}
}
.check-box-field.vertical {
	display: block;
	margin: 0 2em 5em;
	font-size: 0.75em;
	input[type="radio"] + label {
		@include after {
			top: -0.15em;
			left: 0.05em;
		}
	}
}
.check-box-field.inline {
	display: inline-block;
	label {
		min-width: 7.5em;
	}
}
.check-box-field.small {
	font-size: 0.75em;
	&.small label {
		font-size: 1.125em;
	}
}
.check-box-field.big {
	font-size: 1em;
}
.radio-button-field {
	label {
		width: 7em;
		height: 5em;
	}
}
.single-check-box-field,
.single-radio-button-field {
	margin-left: 1em;
}
.date-span {
	margin-left: 1em;
	label, input {
		display: block;
		height: 1.5em;
		margin: 0 0.5em 1em 0;
	}
	label {
		height: 1.5em;
	}
	input {
		@include default-box-shadow(top);
		background-color: $colour-1;
		color: $white;
		border: 0;
		padding: 0 0.25em;
		font-weight: normal;
		@include font-family(secondary);
		@include _(text-stroke, 0.5px #000);
	}
	.date-labels {
		float: left;
	}
	.date-field {
		overflow: auto;
	}
}
.requesting {
	opacity: 0.5;
	-webkit-filter: blur(5px);
}
form {
	@include _(transition, 'opacity 250ms ease-in-out, filter 250ms ease-in-out, -webkit-filter 250ms ease-in-out');
	
	&.composition {
		textarea {
			height: 16em;
		}
	}
	&.mini-flex-form {
		@include _-(display, flex);
		@include _(align-items, flex-start);
		.input-field {
			@include _(flex, 1);
		}
		button, .button {
			margin-left: 1em;
			height: 2.6em;
		}
	}
	&.centered {
		text-align: center;
	}
}
#main .columns th form {
	display: inline;
	vertical-align: super;
	margin: 0 0 0 0.5em;
	button {
		float: right;
	}
}
#main .columns th.form,
#main .columns .table-th.form {
	display: none;
}
#main .columns td.form,
#main .columns .table-td.form {
	border: 0;
	width: 1px;
	
	form {
		margin: 0;
	}
	button {
		display: block;
		width: 100%;
		white-space: nowrap;
		+ button {
			margin-top: 0.5em;
		}
	}
}
fieldset {
	margin: 0;
	padding: 0;
	border: 0;
	&.centered {
		margin-top: 3em;
		text-align: center;
	}
	&.right-help {
		text-align: center;
		.input-field {
			margin: 0;
		}
		+ .input-field-help {
			overflow: auto;
			margin-bottom: 2em;
		}
	}
}
.fieldgroup {
	@include _(align-items, flex-end);
	@include _(flex-wrap, wrap);
	margin: 0 0 3em 1em;
	> .input-field {
		margin-right: 1em;
		@include _(flex, 1);
	}
}
.view-object {
	margin-bottom: 3em;
}
.comments {
	list-style: none;
	.comment {
		position: relative;
		border: 0.1rem solid #EEE;
		border-radius: 0.25rem;
		padding: 1em;
		margin-top: 2em;
	}
	.comment-body {
		font-size: 0.9em;
	}
	.comment-title {
		position: absolute;
		top: -0.75em;
		left: 0.5em;
		margin: 0;
		padding: 0 0.5em;
		background-color: #FFF;
	}
	time {
		position: absolute;
		top: -0.75em;
		right: 0.75em;
		background-color: #FFF;
		padding: 0 0.5em;
	}
	.sub-comment {
		font-size: 0.8em;
		.comment-title, time {
			top: -1em;
		}
	}
	.text-area-field {
		overflow: hidden;
		max-height: 0;
		padding: 0.3em;
		@include _(transition, max-height 150ms ease-in-out);
	}
	#main .columns & form {
		margin-top: 0;
		button {
			@include _(transition, background-color 150ms ease-in-out);
			background-color: #888;
		}
		&.open {
			@include _(opacity, 1);
			.text-area-field {
				max-height: 12em;  
			}
			button {
				background-color: $colour-5;
			}
		}
	}
	button {
		margin: 0;
	}
}
#comments {
	textarea {
		font-size: 1.25em;
		min-height: 7.5em;
	}
	.actions {
		margin: 0;
		button {
			margin: 0;
		}
	}
}
.flex-form, .flex-column {
	button, .button {
		width: 100%;
		text-align: center;
		
		+ button, + .button {
			margin-left: 0.75em;
		}
	}
}
.flex-inputs {
	@include _-(display, flex);
	@include _(align-items, flex-end);
	@include _(flex-wrap, wrap);
	@include _(justify-content, flex-end);
	margin-bottom: 2em;
	.input-field {
		margin: 0 0.5em;
	}
	.stretch-item {
		@include _(flex, 1);
		@include _(flex-basis, 100%);
		select {
			width: 100%;
		}
	}
}
.actions {
	text-align: center;
	margin: 0 1em;
	button, .button {
		margin: 0 0.25em 1em;
	    vertical-align: middle;
	}
	&.left {
		text-align: left;
	}
	&.right {
		text-align: right;
		.note {
			float: left;
			color: $colour-1;
			font-weight: bold;
			font-size: 1.25em;
		}
		.left {
			float: left;
		}
	}
	&.fill {
		@include _-(display, flex);
		@include _(flex-wrap, wrap);
		> button, > .button {
			flex: 1;
			margin-bottom: 0;
		}		
	}
	.conferences-view_workshop & {
	    margin-bottom: 5em;
	}
	&.next-prev {
		@include _-(display, flex);
		@include _(flex-wrap, wrap);
		@include _(flex-direction, row-reverse);
		margin: 0;
		clear: both;
		button, .button {
			margin-bottom: 1em;
		}
	}
}
.test-preview {
	padding: 0 1em;
	border: 0.1em solid #CCC;
	background-color: #F8F8F8;
	h4 {
		border-bottom: 0.1rem solid #CCC;
		padding: 1em 0 0.75em;
		font-size: 1.5em;
		margin: 0 0 1em 0;
	}
	h5 {
		font-size: 1.25em;
	}
	h6, p {
		font-size: 1.125em;
	}
}
ul.warnings {
	list-style: none;
	padding: 0;
}
ul.warnings li,
.warning-info {
 	position: relative;
 	min-height: 4em;
	border: 0.2em solid rgba(0, 0, 0, 0.1);
	background-color: rgba($colour-3, 0.333);
	padding: 1em 1em 1em 4em;
	@include font-family(secondary);
	text-align: left;
	margin: 1em;
	width: auto;
	@include default-box-shadow(top, 2);
	@include before {
		content: '!';
		display: block;
		position: absolute;
		top: 0.5em;
		left: 0.5em;
		width: 1.5em;
		height: 1.5em;
		background-color: $black;
		color: $white;
		text-align: center;
		line-height: 1.5em;
		font-size: 1.5em;
		background-color: $colour-3;
		@include _(border-radius, 50%);
		@include default-box-shadow(top, 2);
	}
	&.make-room {
		margin-bottom: 2em;
	}
}
.warning-info {
	display: inline-block;
	margin: 0;
	vertical-align: bottom;
}
::-webkit-resizer {
    visibility: hidden;
    cursor: nw-resize;
}
@include selection {
	background-color: rgba($colour-2, 0.75);
	color: rgba($white, 0.75);
}
#main-nav {
	@include font-family(secondary);
	overflow: hidden;
	.nav {
		position: fixed;
		z-index: 100;
		bottom: 0;
		left: 0;
		right: 0;
		padding: 0;
		font-size: 6vw;
		background-color: #FFF;
		@include _-(display, flex);
		@include _(box-shadow, 0 0 2em -0.5em rgba(0, 0, 0, 0.5));
		a.policy {
			background-color: $colour-5;
			@include _(order, 1);
		}
		a.about {
			background-color: $colour-3;
			@include _(order, 1);
		}
		form, .register {
			background-color: $colour-2;
		}
		a, form {
			width: 33%;
			@include _(flex, 1);
		}
		
		a, form, button {
			text-align: center;
			padding: 0;
			margin: 0;
		}
		a, button {
			display: inline-block;
			font-weight: normal;
			padding: 0.5em 0;
			color: #FFF;
			@include _(border-radius, 0);
			@include _(box-shadow, inset 0 0 1.5em 0.25em rgba(0, 0, 0, 0.125));
			@include _(text-shadow, 0 0 0.25em rgba(0,0,0,0.5));
			@include after {
				display: none;
			}
			.title {
				font-size: 0.8em;
			}
		}
		button {
			background-color: transparent;
			border: 0;
			font-size: 1em;
			width: 100%;
			@include _(text-stroke, 0);
			@include before {
				display: none;
			}
		}
		form {
			display: inline;
		}
		.strlen-12, .strlen-13 {
			.title {
				font-size: 0.7em;
			}
		}
		.strlen-14, .strlen-15 {
			.title {
				font-size: 0.6333em;
			}
		}
		body.error-locale-not-available & {
			display: none;
		}
	}
	.logo {
		font-size: 5em;
	}
}
.clearfix {
	@include clearfix;
}
.flow-steps {
	width: 100%;
	list-style: none;
	text-align: center;
	font-size: 0.85em;
	@include font-family(secondary);
	ul {
		@include _-(display, flex);
		list-style: none;
		margin: 2em 2em 5em 0;
		padding: 0;
	}
	li {
		position: relative;
		@include _(flex, 1);
		padding-top: 1.5em;
		@include after {
			content: '';
			position: absolute;
			top: 0;
			left: -50%;
			width: 100%;
			@include _(opacity, 0.5);
			border-top: 0.25em dashed #CCC;
		}
		&:first-child {
			@include after {
				left: 0;
				width: 50%;
			}
		}
		&.enabled {
			@include after {
				border-color: $colour-1;
				border-color: rgba($colour-1, 0.5);
			}
			&.post {
				@include after {
					border-color: $colour-1;
					border-color: rgba($colour-5, 0.5);
				}
			}
		}
		@include before {
			content: '';
			position: absolute;
			background-color: #CCC;
			@include _(box-shadow, 0 0 0.25rem #CCC);
			font-size: 1.3em;
			top: -0.2em;
			width: 0.55em;
			height: 0.55em;
			left: 0;
			right: 0;
			margin: auto;
			z-index: 1;
			@include _(border-radius, 50%);
		}
		&.enabled {
			@include after {
				border-top-style: solid;
			}
			
			@include before {
				background-color: $colour-1;
				@include _(box-shadow, 0 0 0.25rem $colour-1);
			}
			&.post {
				@include before {
					background-color: $colour-5;
					@include _(box-shadow, 0 0 0.25rem $colour-5);
				}
			}
			&.current {
				@include before {
					top: -0.25em;
					font-size: 3em;
					background-color: $white;
					border: 0.075em solid $colour-1;
				}
				&.post {
					@include before {
						border-color: $colour-5;
					}
				}
			}
		}
	}
	.step {
		color: #CCC;
		position: absolute;
		@include _(transform-origin, 10% 60%);
		@include _(transform, rotate(45deg));
		text-align: left;
		top: 0.5em;
		left: 50%;
		line-height: 1.2em;
	}
	a {
		position: static;
		color: inherit;
		@include _(color, 0.5);
		@include _(transition, color 150ms ease-in-out);
		@include before {
			content: '';
			position: absolute;
			top: -1em;
			right: 0;
			bottom: 0;
			left: 0;
			z-index: 1;
		}
		@include after {
			display: none;
		}
	}
	.current .step {
		//top: 1.5em;
		@include _(transform-origin, 10% 100%);
	}
	.current .step,
	a:hover,
	a:focus {
		color: $black;
	}
}
.link-dump {
	a {
		margin: 0.25em;
	}
}
#main article #registration-admin-menu {
	margin: 1em 0 0;
	padding: 0;
	list-style: none;
	a {
		display: block;
		padding: 0.5em 0.75em;
		border: 0.1rem solid #EEE;
		border-top: 0;
		border-right: 0;
		@include after {
			display: none;
		}
		&:hover {
			background-color: #EEE;
		}
	}
	li {
		margin: 0;
		&.current {
			a {
				color: $white;
				background-color: $colour-5;
			}
		}
	}
}
.data-set {
	display: table-row;
}
.data-set-key, .data-set-value {
	display: table-cell;
	padding: 0.25em 0.5em;
	vertical-align: top;
	border-bottom: 0.1rem solid #EEE;
}
.data-set-key {
	font-size: 1em;
	width: 1rem;
	white-space: nowrap;
}
.data-set:last-child {
	.data-set-key, .data-set-value {
		border: 0;
	}
}
.details {
	display: table;
	width: 100%;
	&.inline {
		width: auto;
	}
}
.space, .address {
	.data-set-key, .data-set-value {
		white-space: nowrap;
	}
}
.admin-blocks {
	@include _-(display, inline-flex);
	@include _(flex-wrap, wrap);
	@include _(align-items, flex-start);
	@include _(justify-content, flex-start);
	list-style: none;
	padding: 0;
	> li {
		max-width: 25em;
		border: 0.1rem solid #EEE;
		padding: 1em;
		margin: 0.25em;
		@include _(flex, 1);
		background-color: #F8F8F8;
		@include default-box-shadow(top, 2);
	}
	.actions {
		margin: 0 auto;
	}
	.title {
		margin: 0 0 1em;
		padding: 0 0 0.5em;
		border-bottom: 0.1rem solid #EEE;
	}
	.amenities {
		list-style: none;
		padding: 0;
		> li {
			font-weight: bold;
			white-space: nowrap;
			display: inline-block;
			padding: 0 0.5em;
			line-height: 1.5em;
			font-size: 0.8em;
			border: 0.1rem solid #CCC;
			background-color: #EEE;
			@include _(border-radius, 0.125rem);
		}
	}
}
#admin-housing, #admin-schedule {
	.guests-housed {
		margin-bottom: 1em;
		text-align: right;
		h5 {
			display: inline-block;
			margin: 0;
			padding-right: 0.5em;
		}
		.data {
			display: inline-block;
			font-size: 1.125em;
		}
	}
	#housing-table {
		@include _(transition, opacity 1s ease-in-out);
		&.loading {
			@include _(opacity, 0.5);
			pointer-events: none;
		}
		tr.host {
			th {
				vertical-align: top;
			}
			.address {
				margin-top: 1em;
				text-align: right;
				@include font-family(primary);
			}
		}
	}
	.host-table {
		tr.place-guest {
			td {
				background-color: lighten($colour-1, 40%);
				&:hover {
					background-color: $colour-1;
				}
				&.full {
					background-color: #E8E8E8;
					&:hover {
						background-color: #CCC;
					}					
				}
			}
			a {
				display: block;
				color: $white;
				text-align: center;
				@include font-family(secondary);
				@include after {
					display: none;
				}
			}
		}
		.remove-guest,
		button, .button {
			float: right;
		}
		td {
			vertical-align: top;
		}
		.state {
			position: relative;
			font-family: inherit;
			&.unhappy {
				cursor: pointer;
			}
			ul {
				display: none;
				position: absolute;
				right: 100%;
				top: 0;
				background-color: $white;
				border: 0.1em solid #CCC;
				padding: 0.25em 0.75em 0.25em 1.5em;
				margin: 0;
				list-style-type: square;
				@include default-box-shadow(top, 2);
				z-index: 10;
			}
			li {
				white-space: nowrap;
				margin: 0;
			}
			&:hover {
				ul {
					display: block;
				}			
			}
		}
	}
	#workshop-selector {
		td, th {
			white-space: nowrap;
		}
		td .text {
			max-width: 50em;
			overflow: hidden;
			text-overflow: ellipsis;
		}
	}
	#guest-selector, #workshop-selector {
		display: none;
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		background-color: rgba($black, 0.5);
		cursor: pointer;
		z-index: 1000;
		&.open {
			display: block;
		}
		.guest-dlg, .workshop-dlg {
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color: $white;
			width: 80%;
			margin: auto;
			padding: 1em;
			height: 80%;
			cursor: default;
			@include default-box-shadow(top, 2);
			h3 {
				margin: 0 0 1em;
			}
		}
	}
}
@include keyframes(whiten) {
	to { background-color: $white; }
}
#table {
	position: relative;
	overflow: auto;
	height: 80%;
	height: calc(100% - 4em);
	background-color: $white;
	@include _(transition, background-color 250ms ease-in-out);
	&.loading {
		background-color: #CCC;
		@include _(animation, whiten ease-in-out 1s infinite alternate both);
		.host-field, table, .legend {
			display: none;
		}
	}
	table {
		margin: 0 0 2em;
	}
	h4 {
		margin: 0;
		&.inline {
			display: inline-block;
			padding-right: 0.5em;
		}
	}
	.plain-value {
		font-size: 1.2em;
	}
	blockquote {
		margin-top: 0;
		font-size: 0.85em;
		> :first-child {
			margin-top: 0;
		}
	}
	tr.selectable {
		cursor: pointer;
		&:hover {
			th {
				background-color: $colour-2;
			}
		}
		&.other-host, &.other-space, &.bad-match {
			td, th {
				opacity: 0.5;
			}
		}
		&.selected-space, &.other-space {
			td {
				background-color: lighten($colour-5, 35);
			}
			th {
				background-color: $colour-5;
			}
		}
		&.other-host {
			td {
				background-color: lighten($colour-1, 40%);
			}
			th {
				background-color: $colour-1;
			}
		}
		&:hover {
			td {
				opacity: 1;
				background-color: lighten($colour-2, 25%);
			}
		}
	}
	.legend ul {
		@include _-(display, flex);
		list-style: none;
		padding: 0;
		li {
			@include _(flex, 1);
			text-align: center;
			margin-bottom: 0.5em;
			padding: 0.125em 0.5em;
			margin: 0.1em;
			border: 0.1em solid #EEE;
			background-color: #F8F8F8;
			@include font-family(secondary);
			&.other-host, &.other-space, &.bad-match {
				opacity: 0.5;
			}
			&.selected-space, &.other-space {
				background-color: $colour-5;
			}
			&.other-host {
				background-color: $colour-1;
			}
		}
	}
	.p {
		max-height: 4em;
		overflow: auto;
	}
}
#admin-housing {
	#table table {
		min-width: 100em;
	}
	#hosts {
		background-color: $white;
		ul {
			list-style: none;
			padding: 0;
		}
		.host {
			padding: 0.5em;
			border: 0.1em solid #EEE;
			background-color: #F8F8F8;
			&.status-good {
				background-color: rgba($colour-5, 0.1);
			}
			&.status-warning {
				background-color: rgba($colour-3, 0.1);
			}
			&.status-error {
				background-color: rgba($colour-2, 0.1);
			}
		}
		h4 {
			margin: 0 0.5em 0 0;
			float: left;
		}
		h5 {
			margin: 1em 0 0;
		}
		.email {
			color: #888;
			@include before {
				content: '(';
			}
			@include after {
				content: ')';
			}
		}
		.guests {
			clear: left;
			@include _-(display, flex);
		}
		.space {
			@include _(flex, 1);
		}
		.place-guest {
			background-color: $colour-5;
			
			&.booked {
				background-color: $colour-4;
			}
			
			&.unwanted {
				background-color: #888;
			}
			
			&.overbooked {
				background-color: $colour-2;
			}
		}
		.warning, .error {
			display: inline-block;
			font-style: italic;
			padding: 0 0.5em;
			margin-left: 0.5em;
			border: 0.1em solid rgba($black, 0.25);
			@include _(border-radius, 0.125em);
			@include _(transform, skewX(-15deg));
			@include _(transform-origin, 0 100%);
			@include _(animation, bend ease-in-out 500ms infinite alternate both);
		}
		.warning {
			background-color: lighten($colour-3, 25%);
		}
		.error {
			background-color: lighten($colour-2, 25%);
		}
	}
	#guests {
		.guests {
			@include _-(display, flex);
			//@include _(align-items, flex-start);
			@include _(flex-wrap, wrap);
			list-style: none;
			padding: 0;
		}
		.guest {
			flex: 1;
			margin: 0.5em;
			border: 0.1rem solid #EEE;
			background-color: #F8F8F8;
			padding: 0.5em;
		}
		
		h4 {
			margin: 0 0 0.5em;
		}
		.set-host {
			width: 100%;
		}
	}
}
#admin-workshop_times {
	.workshop-blocks {
		td, th {
			vertical-align: top;
		}
	}
	.table-tr.new {
		.table-th {
			background-color: transparent;
			border: 0;
		}
		.table-td {
			background-color: transparent;
			border: 0;
		}
	}
}
.details.org-members {
	padding: 1em;
	border: 0.1rem solid #EEE;
	border-bottom: 0;
}
table.schedule {
	width: 100%;
	margin: 0 0 1em;
	&.locations-1 td.workshop.filled {
		width: 100%;
	}
	&.locations-2 td.workshop.filled {
		width: 50%;
	}
	&.locations-3 td.workshop.filled {
		width: 33.333%;
	}
	&.locations-4 td.workshop.filled {
		width: 25%;
	}
	&.locations-5 td.workshop.filled {
		width: 20%;
	}
	&.locations-6 td.workshop.filled {
		width: 16.66667%;
	}
	td {
		//position: relative;
		text-align: center;
		&.empty {
			border-top: 0;
			border-bottom: 0;
			background-color: #F8F8F8;
		}
		&.workshop {
			background-color: lighten($colour-1, 40%);
			&.filled {
				background-color: lighten($colour-1, 25%);
			}
			&.open {
				cursor: pointer;
				white-space: nowrap;
				&:hover {
					background-color: lighten($colour-1, 25%);
				}
			}
		}
		&.event {
			background-color: lighten($colour-2, 25%);
		}
		&.meal {
			background-color: lighten($colour-3, 25%);
		}
		.title {
			@include font-family(secondary);
		}
		.event-detail-link {
			display: inline-block;
			display: inline-flex;
			position: relative;
			height: 100%;
			width: 100%;
			color: inherit;
			align-items: center;
			@include after {
				display: none;
			}
			.details {
				flex: 1;
			}
		}
		.status {
			display: inline-block;
			text-align: left;
			float: right;
			font-size: 0.9em;
			margin-top: 0.5em;
		}
		.conflict-score {
			text-align: right;
			.title {
				@include font-family(secondary);
			}
		}
		.errors {
			position: relative;
			border-top: 0.1rem solid #666;
			margin-top: 0.5em;
			padding-top: 0.25em;
			@include before {
				content: '!';
				display: inline-block;
				position: absolute;
				z-index: 1;
				top: 0;
				left: -1.2em;
				width: 1em;
				color: $white;
				@include font-family(secondary);
			}
			@include after {
				content: '';
				position: absolute;
				top: 0.1em;
				left: -1.333em;
				width: 0;
				height: 0;
				font-size: 1.25em;
				border: 0.5em solid;
				border-left-color: transparent;
				border-right-color: transparent;
				border-width: 0 0.5em 0.75em;
				color: darken($colour-2, 25%);
			}
		}
		#main .columns & form {
			margin-top: 0;
			
			button {
				margin-top: 0.5em;
				float: left;
				z-index: 1;
			}
		}
	}
}
body.home table.schedule td .event-detail-link:hover {
	outline: 0.33rem solid #02CA9E;
	outline-offset: 0.25rem;
	z-index: 1;
}
.event-dlg {
	@include _-(flex, 0);
	position: relative;
	z-index: 1000;
	background-color: $white;
	text-align: left;
	padding: 2em 2em 0.5em;
	min-width: 100%;
	max-height: 100%;
	overflow: auto;
	margin: auto;
	@include _(opacity, 0);
	@include _(transition, opacity 150ms ease-in-out);
	@include default-box-shadow(top, 2);
	.actions {
		margin: 2em 0 0;
	}
	&.open {
		@include _(opacity, 1);
	}
}
.event-details {
	.title {
		margin: 0 0 0.5em;
	}
	.address {
		text-align: center;
	}
}
#admin-schedule {
	.workshops-to-schedule {
		@include _-(display, flex);
		@include _(flex-wrap, wrap);
		list-style: none;
		padding: 0;
		li {
			@include _(flex, 1);
			@include _(flex-basis, 48%);
			margin: 1%;
			@include _(transition, background-color 250ms ease-in-out);
			background-color: #EEE;
			.title {
				@include _(transition, background-color 250ms ease-in-out);
			}
			&.booked {
				background-color: lighten($colour-1, 40%);
				.not-booked-only {
					display: none;
				}
				.data-set-key, .data-set-value {
					border-bottom-color: #888;
				}
			}
			&.not-booked {
				.booked-only {
					display: none;
				}
			}
			.field-error {
				background-color: lighten($colour-2, 22.5%);
				margin: 0;
			}
			.already-booked {
				overflow: hidden;
				max-height: 0;
				&.is-true {
					max-height: 3em;
					@include _(transition, max-height 150ms ease-in-out);
				}
			}
			.workshop-description {
				max-height: none;
			}
			.details {
				margin: 0 5% 1em;
				width: 90%;
			}
			.title {
				margin: 0 0 0.5em;
				padding: 0.5em;
				background-color: $black;
				color: $white;
			}
			.drop-downs {
				padding: 0 1em 1em;
				select {
					width: 100%;
				}
			}
			.actions {
				margin: 0;
				padding: 0 0.5em;
			}
		}
		#main .columns & form {
			margin: 0;
		}
	}
}
#main {
	position: relative;
	background-color: $white;
	padding-bottom: rems(2);
	@include _(flex, 1);
	article {
		padding: rems(2.5) 0;
		margin: 0 1em;
		&.supplementary {
			margin: rems(1) 7.5%;
			overflow: hidden;
			@include _(border-radius, 0.33em);
			border: 0.1rem solid #DDD;
			background-color: #F7F7F7;
			@include default-box-shadow(top, 2);
		}
		ul {
			font-size: 1.125em;
			line-height: 1.5em;
		}
		li {
			margin-bottom: 0.5em;
		}
	}
	.featured-image-container {
		@include _-(display, flex);
		@include _(flex-wrap, wrap);
		figure {
			@include _(order, 1);
			width: 100%;
			height: 12em;
			margin: 0;
			background-size: cover;
			background-position: center;
			background-repeat: no-repeat;
		}
		
		ul {
			clear: left;
		}
	}
}
a.logo {
	display: inline-block;
	font-size: rems(5);
	text-decoration: none;
	padding: 0.1em;
	border: 0;
	float: left;
	overflow: auto;
	@include clearfix;
	&:hover,
	&:active,
	&:focus {
		@include after {
			display: none;
		}
	}
}
@if capable_of(svg) {
	@include keyframes(active-logo) {
		0% { fill: $colour-1; }
		15% { fill: $colour-5; }
		30% { fill: $colour-3; }
		45% { fill: $colour-4; }
		60% { fill: $colour-2; }
	}
	@include keyframes(banner-load) {
		0% { fill: #888; }
	}
	svg.bb-icon-logo {
		fill: $colour-1;
	}
	svg.bb-icon-logo-text {
		fill: $black;
	}
	.logo:hover svg.bb-icon-logo {
		@include _(animation, active-logo 4s infinite);
	}
}
.logo .icons {
	display: inline-block;
	height: 1em;
	width: 1em;
	float: left;
}
#banner {
	clear: left;
	float: none;
	margin: 1em auto 0;
	text-align: center;
	body.home & {
		max-width: 40em;
	}
	figure {
		position: relative;
		width: 100%;
		max-width: rems(60);
		margin: 0;
	}
	img {
		width: 100%;
	}
	.title {
		font-size: 5vw;
		margin: 1em auto 2em;
		h1, h2 {
			margin: 0;
		}
		h2 {
			font-size: 1.15em;
		}
	}
	.secondary {
		font-size: 0.85em;
		line-height: 2em;
	}
}
$header-tilt: 8deg;
#header-title {
	font-size: 2.25vw;
	background-size: cover;
	background-position: 50% 20%;
	background-repeat: no-repeat;
	background-color: $colour-1;
	color: #EEE;
	overflow: hidden;
	position: relative;
	z-index: $zindex-base;
	.row, .columns {
		position: static;
	}
	rect {
		fill: $colour-1;
	}
	svg {
		.colour-1 { fill: $colour-1; }
		.colour-2 { fill: $colour-2; }
		.colour-3 { fill: $colour-3; }
		.colour-4 { fill: $colour-4; }
		.colour-5 { fill: $colour-5; }
	}
	.cover {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		z-index: $zindex-base;
		background-size: inherit;
		background-position: inherit;
	}
	@if capable_of(css-mixblendmode) {
		position: relative;
		.cover {
			-webkit-filter: saturate(25%);
			filter: saturate(25%);
			@include _(mix-blend-mode, multiply);
		}
	}
	
	&.no-image,
	&.short {
		h1 {
			text-align: center;
			font-size: 3.5em;
			margin: 1.75em 0 .75em;
			position: relative;
			z-index: $zindex-base + 2;
			@include _(text-shadow, 0 0 0.15em #000);
		}
	}
	svg {
		display: none;
		position: absolute;
		width: 100%;
		height: 100%;
	}
	.title {
		position: relative;
		padding: 1%;
		overflow: hidden;
		text-align: center;
		@include _(text-shadow, 0 0.2em 0.5em rgba(32, 32, 32, 0.5))
	}
	.background {
		position: absolute;
		@include _(transform, rotate($header-tilt));
		color: $colour-1;
		@include _(opacity, 0.65);
		margin: -4% -2%;
		@if capable_of(calc) {
			font-size: calc(5vw + #{rems(7)});
		} @else {
			font-size: rems(11);
		}
		display: none;
	}
	.details {
		position: relative;
		display: inline-block;
		color: $white;
		@include _(text-shadow, 0 0.2em 0.5em rgba(32, 32, 32, 0.75));
	}
	.primary {
		font-size: 2.5em;
		margin: 0;
	}
	.secondary {
		font-size: 1.5em;
	}
	body.error-locale-not-available & {
		background-color: $colour-5;
	}
	body.error-500 & {
		background-position: 50% 50%;
		background-color: $colour-2;
	}
	body.error-403 & {
		background-position: 50% 33%;
	}
}
#footer {
	padding: 1em;
	
	footer {
		@include _-(display, flex);
		@include _(flex-flow, row wrap);
		@include _(align-items, flex-end);
		font-size: 4.1vw;
	}
	.site-info, .user-controls, .external {
		width: 100%;
		text-align: center;
		a {
			text-align: right;
			white-space: nowrap;
			color: #666;
		}
	}
	.external {
		margin-bottom: 1em;
	}
	.my-account {
		margin-right: 0.5em;
	}
	.logout {
		margin-left: 0.5em;
	}
	.contact-us {
		line-height: 2.5em;
	}
	.facebook {
		a {
			&:hover, &:active, &:focus {
				svg {
					fill: #3B579D;
				}
			}
		}
	}
	.github, .facebook {
		display: inline-block;
		margin: 0.5em;
		a {
			@include after {
				display: none;
			}
			svg {
				@include _(transition, fill 250ms ease-in-out);
			}
		}
		.icons {
			width: 1.5em;
			height: 1.5em;
			fill: $black;
			vertical-align: middle;
		}
	}
	.github {
		a {
			@include after {
				display: none;
			}
		}
		&:hover .icons {
			fill: #4183C4;
		}
	}
	ul.locales {
		@include _(flex, 1);
		@include _(flex-basis, 100%);
		padding: 0;
		margin: 1em 0;
		list-style: none;
		text-align: center;
	}
	body.error-locale-not-available & {
		.github, .facebook, .locales {
			visibility: hidden;
		}
	}
}
body.error-locale-not-available {
	.locales {
		list-style: none;
		padding: 0;
		text-align: center;
		li {
			margin-bottom: 1em;
		}
	}
}
body {
	#primary-content {
		@include _(transition, 'filter 250ms ease-in-out, -webkit-filter 250ms ease-in-out');
		display: flex;
		flex-direction: column;
		min-height: 100vh;
		overflow: hidden;
	}
	&.has-overlay {
		overflow: hidden;
		#primary-content {
			-webkit-filter: blur(5px);
			@include _(filter, blur(5px));
		}
		#overlay {
			position: fixed;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			cursor: pointer;
			z-index: 1000;
		}
	}
}
#content-overlay {
	display: none;
	body.has-overlay & {
		display: block;
	}
	body.has-overlay.is-event-dlg & {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		@include _-(display, flex);
	}
	.dlg {
		@include before {
			content: '';
			position: fixed;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color: rgba($black, 0);
			@include _(transition, background-color 250ms ease-in-out);
		}
		
		&.open {
			@include before {
				background-color: rgba($black, 0.5);
			}
			.dlg-content {
				@include _(transform, rotateZ(0deg));
			}
		}
	}
	.dlg-content {
		position: fixed;
		right: 0;
		bottom: 0;
		left: 0;
		max-width: 50rem;
		max-height: 100%;
		font-size: 0.9em;
		overflow-y: auto;
		margin: auto;
		z-index: 1001;
		background-color: $white;
		text-align: center;
		@include _(transition, transform 500ms ease-in-out);
		@include _(transform, rotateX(-90deg));
		@include _(transform-origin, center 250%);
	}
	.dlg {
		.title {
			padding: 0.5em;
			background-color: $colour-5;
			color: $white;
			@include _(text-stroke, 1px rgba(0, 0, 0, 0.25));
		}
	}
	button, .button {
		margin: 0 0.25em 0.5em;
	}
	.dlg-inner {
		padding: 0 2em 2em;
	}
	.message {
		margin-bottom: 2em;
	}
	#info-dlg .title {
		background-color: $colour-1;
		font-size: 1.5em;
		text-align: left;
	}
	#info-dlg .message {
		text-align: left;
		p, h4 {
			font-size: 0.8em;
		}
		h3 {
			font-size: 1em;
		}
		h5 {
			font-size: 0.667em;
		}
		h6 {
			font-size: 0.8em;
		}
	}
	#login-dlg .title {
		font-size: 2em;
		margin-bottom: 1em;
	}
	#contact-dlg {
		.title {
			background-color: $colour-4;
		}
		.email-field {
			margin-top: 2em;
		}
		textarea {
			min-height: 7.5em;
		}
	}
}
@include keyframes(fade-out) {
	to {
		@include _(opacity, 0.25);
	}
}
@include keyframes(colour-out) {
	to {
		background-color: transparent;
	}
}
html :focus {
	outline: 0;
}
@mixin header-colour($page, $colour) {
	body.#{$page} {
		#header-title {
			background-color: $colour;
			rect {
				fill: $colour;
			}
		}
	}
}
@include header-colour(about, $colour-3);
@include header-colour(policy, $colour-5);
#bike_small + label {
	padding: 0.5em 2.5em;
}
#bike_medium + label {
	padding: 0.5em 1.5em;
}
#main .graded-options {
	text-align: center;
	button {
		background-color: $colour-4;
		width: 6em;
		font-size: 1.5em;
		margin: 0.25em;
		&.option-1 {
			background-color: $colour-3;
		}
		&:last-child {
			background-color: $colour-5;
		}
	}
	&.option-count-4 button.option-3,
	&.option-count-5 button.option-4 {
		background-color: mix($colour-3, $colour-5);
	}
	
	&.option-count-5 {
		button.option-2 {
			background-color: mix($colour-3, $colour-4);
		}
	}
}
#main .skip {
	button {
		background-color: #888;
	}
}
#main form.custom-payment {
	input[type="number"] {
		width: 4em;
		margin-right: 0.5em;
	}
	button {
		background-color: $colour-1;
	}
	.currency {
		color: #888;
		font-size: 1.5em;
	}
	.number-field {
		margin-bottom: 0;
	}
}
#main ul.workshops {
	list-style: none;
	padding: 0;// 1em;
	text-align: center;
	@include default-box-shadow(top, 2, true);
	background-color: #F8F8F8;
	li {
		display: inline-block;
		margin: 0.5em;
		vertical-align: middle;
		@include before {
			content: '';
			display: none;
			position: fixed;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			background-color: #000;
			z-index: 99;
			@include _(opacity, 0.5);
		}
		&.view {
			@include before {
				display: block;
			}
			
			.info {
				left: 0;
				right: 0;
				top: 50%;
				@include _(transform, translateY(-50%) scale(1));
				@include breakpoint(large) {
					left: 19rem;
				}
			}
		}
	}
	h4, h5 {
		color: $white;
		background-color: $colour-1;
		@include _(text-stroke, 1px rgba(0, 0, 0, 0.25));
	}
	h4 {
		max-width: 10em;
		cursor: pointer;
		margin: 0;
		padding: 1em;
		position: relative;
		@include default-box-shadow(top);
		@include _(transition, transform 100ms ease-in-out);
		&:hover {
			z-index: $zindex-base + 3;
			@include _(transform, scale(1.25));
		}
	}
	h5 {
		font-size: 1.5em;
		margin: 0;
		padding: 0.5em 1em;
		+ p {
			margin-top: 0;
		}
	}
	p {
		padding: 1em;
		max-height: 50vh;
		overflow-y: auto;
	}
	form {
		text-align: center;
	}
	button {
		margin: 1em 0.5em;
	}
	[contenteditable] {
		outline: none;
	}
	.info {
		position: fixed;
		background-color: $white;
		color: $black;
		left: auto;
		right: auto;
		top: auto;
		z-index: 100;
		max-width: 40em;
		max-height: 40em;
		margin: auto;
		text-align: left;
		@include _(transition, all 250ms ease-in-out);
		@include _(transform, translateY(0) scale(0));
		@include default-box-shadow(top);
	}
	[value="delete"] {
		background-color: $colour-2;
	}
	[value="cancel"] {
		background-color: $colour-4;
	}
}
.conferences-register .policy-agreement {
	padding: 0.25em 1em;
	margin: 0 0 3em;
	border: 0.1em solid #DDD;
	@include _(border-radius, 0.25em);
	@include default-box-shadow(top, 2);
}
body.policy .policy-agreement ul {
	padding: 0 1.5em 0;
}
.stats {
	list-style: none;
	h3 {
		display: inline-block;
	}
	.stat {
		position: relative;
		padding: 0 0.25em;
		margin: 0.5em;
		font-size: 2em;
		display: inline-block;
		color: $white;
		background-color: $colour-1;
		@include default-box-shadow(top, 2);
		@include _(text-stroke, 1px rgba(0, 0, 0, 0.25));
		&.important {
			width: 2em;
			height: 2em;
			line-height: 2em;
			text-align: center;
			@include _(border-radius, 50%);
		}
	}
	.money .stat {
		background-color: $colour-5;
	}
	.percent {
		font-size: 1.5em;
	}
	.value {
		position: relative;
		z-index: $zindex-base + 2;
	}
	.stat-with-label {
		display: inline-block;
		text-align: center;
		vertical-align: middle;
		background-color: $colour-3;
		margin: 0.5em;
		@include default-box-shadow(top, 2);
		.stat {
			margin-top: 0.25em;
		}
	}
	.label {
		padding: 0.5em 0.5em 0;
		font-weight: bold;
	}
	.breakdown {
		text-align: center;
	}
}
.email-preview {
	max-width: 40rem;
	margin: 2em auto 0;
	padding: 0.25em 1em;
	background-color: #F8F8F8;
	@include default-box-shadow(top, 2, true);
}
.facilitators {
	display: inline-block;
	.facilitator {
		margin: 0 0 0.5em 0.5em;
		padding: 1.5em 0.5em 0.5em;
		border-top: 0.1em solid #CCC;
		&:first-child {
			border: 0;
			padding-top: 0;
		}
	}
	.name {
		position: relative;
		font-weight: bold;
	}
	.details {
		margin-top: 0.5em;
	}
	.email {
		margin-bottom: 0.5em;
	}
	.name, .role {
		display: inline;
	}
	.role {
		color: #666;
		white-space: nowrap;
		@include before {
			content: '(';
		}
		@include after {
			content: ')';
		}
		&:last-child {
			@include after {
				content: ')';
			}
		}
	}
}
.workshop-previews {
	position: relative;
	list-style: none;
	padding: 0;
	p {
		padding: 0 1rem 0.5rem;
		font-size: 1em;
		color: $black;
	}
	h4 {
		color: $white;
		background-color: $colour-1;
		padding: 0.5em 1em;
		margin: 0;
		@include _(text-stroke, 1px rgba(0, 0, 0, 0.25));
	}
	a {
		display: block;
		max-height: 10em;
		overflow: hidden;
		margin: 0.5em 0;
		@include default-box-shadow(top, 2);
		@include _(transition, transform 150ms ease-in-out);
		&:hover, &:focus, &:active {
			z-index: $zindex-base + 2;
			@include _(transform, scale(1.1));
		}
		@include before {
			content: '';
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			z-index: $zindex-base + 2;
			cursor: pointer;
			@include _(box-shadow, inset 0em -2em 2em -1em $white);
		}
		@include after {
			 display: none;
		}
	}
}
.translated-content.block {
	display: inherit;
}
html[data-lingua-franca-example="html"] {
	$caption-height: 4rem;
	@include _(transform, translateY($caption-height));
	#lingua-franca-window-caption {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: $caption-height;
		background-color: #CCC;
		z-index: 1000;
		font-size: 1rem;
		@include _(transform, translateY($caption-height * -1));
		.window-tab {
			height: 1.75rem;
			position: relative;
			background-color: #EEE;
			float: left;
			padding: 0.25em 2em 0 1em;
			margin: 0.25em 1em;
			@include _(border-radius, 0.5em 0.5em 0 0);
			color: #444;
			@include font-family(secondary);
			@include after {
				content: '×';
				position: absolute;
				right: 0.5em;
				top: 0.25em;
			}
		}
		i {
			font-style: normal;
		}
		.window-minimize,
		.window-maximize {
			@include after {
				content: '';
				position: absolute;
				top: 0.75em;
				right: 2em;
				border-style: solid;
				border-width: 0 0.5em 0.5em 0.5em;
				border-left-color: transparent;
				border-right-color: transparent;
			}
		}
		
		.window-minimize {
			@include after {
				right: 3.5em;
				border-top-width: 0.5em;
				border-bottom-width: 0;
			}
		}
		.window-close {
			@include after {
				content: '×';
				position: absolute;
				right: 0.25em;
				top: 0.1em;
				font-size: 1.75em;
				line-height: 1em;
			}
		}
		.window-url-bar {
			position: absolute;
			top: $caption-height / 2;
			left: 0;
			width: 100%;
			height: $caption-height / 2;
			background-color: #EEE;
			.url-bar {
				position: absolute;
				top: 0.25rem;
				left: 3.5rem;
				bottom: 0.25rem;
				right: 0.25rem;
				background-color: #FFF;
				border: 1px solid #CCC;
				padding: 0 0.25rem;
				font-size: 0.8em;
				line-height: 1.75em;
			}
		}
		.window-back,
		.window-forward {
			@include after {
				content: '';
				position: absolute;
				left: 0.5em;
				top: 0.5em;
				border-style: solid;
				border-width: 0.5em 0.75em 0.5em 0;
				border-top-color: transparent;
				border-bottom-color: transparent;
				color: #666;
			}
		}
		.window-forward {
			@include after {
				left: 2em;
				border-right-width: 0;
				border-left-width: 0.75em;
			}
		}
	}
	@include translation-pointer;
}
.workshop-notes {
	p {
		font-size: 1em;
	}
}
.major-group {
	border-bottom: 0.333em solid #EEE;
	padding-bottom: 2em;
	margin-bottom: 1em;
	&:last-child {
		border-bottom: 0;
	}
}
#main .workshop-list {
	list-style: none;
	padding: 0;
	.workshop-description {
		font-size: 0.9em;
		max-height: 20em;
		padding: 1em;
		overflow: hidden;
	}
	> li {
		position: relative;
		margin-bottom: 1em;
		border-bottom: 0.1rem solid #EEE;
		ul {
			padding-left: 2.5em;
			margin-bottom: 1.5em;
		}
		li {
			border: 0;
		}
		&:last-child {
			border: 0;
		}
	}
	.actions {
		position: relative;
		margin: 0;
		@include _(box-shadow, 0 -1em 1em $white);
	}
	.title {
		margin: 0;
	}
	p {
		margin: 0;
		font-size: 1em;
	}
	h5, h6 {
		margin: 1em 0 0;
	}
}
.interest-button {
	button {
		margin: 0 0 0 1em;
		font-size: 0.8em;
		padding-top: 0.333em;
		padding-bottom: 0.333em;
		background-color: $colour-5;
	}
}
#main .workshop-interest, .workshop-interest {
	text-align: right;
	form {
		display: inline;
	}
	button {
		font-size: 0.9em;
		margin: 1em;
		background-color: $colour-1;
		vertical-align: middle;
		&.delete {
			background-color: $colour-4;			
		}
	}
}
.original-text {
	margin: 0 0 1em 1em;
	.value {
		border: 0.1em solid #DDD;
		padding: 1em;
		margin: 1em 0 3em 0;
		background-color: #F8F8F8;
		@include _(border-radius, 0.25em);
	}
	
	h4, h5, h6 {
		margin: 0;
	}
	h5 {
		font-size: 1em;
	}
	h6 {
		font-size: 0.9em;
	}
	p {
		margin: 0.5em 0;
		font-size: 0.9em;
	}
}
.facilitator .button {
	font-size: 0.9em;
	vertical-align: -0.75em;
}
#main .facilitators .actions {
	margin: 0;
}
#main form.add-facilitator {
	button {
		height: 2.4em;
		font-size: 0.9em;
	}
}
.conferences-edit_schedule {
	#main {
		.location {
			padding-top: 0.25em;
		}
		.errors {
			padding: 0.25em;
			background-color: $colour-2;
			color: $white;
			@include _(text-stroke, 0.5px #000);
		}
		.conflict-score {
			padding: 0.25em;
			background-color: $colour-3;
			color: $black;
		}
		.all-workshops, .all-events {
			list-style: none;
			padding: 0;
			li {
				margin: 0.5em;
				padding: 0.5em;
				border: 1px solid #CCC;
				background-color: lighten($colour-1, 35);
				@include default-box-shadow(top, 2);
				&.error {
					outline: 0.2em solid $colour-2;
					outline-offset: -0.2em;
				}
			}
			h3 {
				margin: 0;
			}
			.workshop-interest {
				color: #888;
				text-align: left;
				margin: 0.25em 0;
			}
			.error-description {
				background-color: $colour-2;
				color: $white;
				padding: 0.5em;
				margin-top: 0.5em;
			}
			.warnings {
				background-color: $colour-3;
				color: $black;
				padding: 0.5em;
				margin-top: 0.5em;
				list-style: none;
				li {
					padding: 0;
					margin: 0;
					background-color: transparent;
					@include _(box-shadow, none);
				}
			}
		}
		.day_parts {
			list-style: none;
			h4 {
				display: inline-block;
				min-width: 12.5em;
				margin: 0.25em 0;
			}
			select, .select {
				float: right;
				min-width: 5em;
			}
			.select {
				padding-left: 0.25em;
			}
		}
		.actions {
			margin: 2em;
		}
		.unsaved {
			@include font-family(secondary);
			background-color: lighten($colour-3, 25);
			margin: 0 5em 2em;
			padding: 0.5em;
		}
		.all-events {
			li {
				background-color: lighten($colour-5, 35);
				
				&.meal {
					background-color: lighten($colour-3, 25);
				}
			}
			h3 {
				margin-bottom: 0.5em;
			}
		}
	}
}
.conferences-schedule {
	.actions {
		margin: 2em;
	}
	
	ul.events, ul.locations {
		list-style: none;
		.button {
			float: left;
			font-size: 1em;
			margin-bottom: 0.5em;
			margin-right: 0.5em;
		}
		h3 {
			display: inline-block;
			margin: 0.25em 0 0;
		}
		li {
			clear: both;
		}
	}
}
.select-field {
	line-height: 1.75em;
	position: relative;
	select {
		display: block;
		width: 100%;
		height: 1.75em;
		font-family: inherit;
		font-size: 1.5em;
		padding: 0 0.5em;
		border: 0.1em solid;
		cursor: pointer;
		@include default-box-shadow(top, 1.5, false);
		td &,
		.table-td & {
			@include _(box-shadow, none);
		}
	}
	@if capable_of(pointer-events) {
		label {
			@include after {
				content: '';
				position: absolute;
				display: block;
				border: 0.1em solid;
				width: 1.75em;
				height: 1.75em;
				background-color: $colour-5;
				font-size: 1.5em;
				z-index: 1;
				right: 0em;
				bottom: 0em;
				pointer-events: none;
			}
			@include before {
				content: '';
				position: absolute;
				display: block;
				@include _(transform, rotate(-45deg));
				border: 0 solid $white;
				border-width: 0 0 0.25em 0.25em;
				width: 1em;
				height: 1em;
				right: 0.75em;
				bottom: 1em;
				z-index: 2;
				pointer-events: none;
			}
		}
		&:hover label {
			@include after {
				background-color: $colour-3;
			}
		}
		select {
			padding-right: 2.25em;
			-webkit-appearance: none;
			@include _(appearance, none);
		}
		&.small label {
			@include after {
				font-size: 1em;
			}
			@include before {
				font-size: 0.725em;
			}			
		}
	}
	&.full select {
		width: 100%;
		margin-bottom: 2em;
	}
	&.inline-label {
		display: inline-block;
		label {
			float: left;
			margin-right: 0.5em;
		}
	}
}
.toggleable {
	@include _(transition, 'transform 250ms ease-in-out, max-height 250ms ease-in-out, visibility 0s linear 250ms');
	@include _(transform, scaleY(0));
	@include _(transform-origin, 0 0);
	max-height: 0;
	visibility: hidden;
	&.open {
	@include _(transition, 'transform 250ms ease-in-out, max-height 250ms ease-in-out');
		max-height: 100em;
		visibility: visible;
		@include _(transform, scaleX(1));
	}
}
.on-top-only, .on-top-controls {
	display: none !important;
}
html[data-ontop] {
	body {
		overflow: hidden;
	}
	.on-top-target {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		padding: 1em;
		margin: 0 !important;
		z-index: 100;
		overflow: auto;
	}
	.on-top-control {
		position: fixed;
		right: 0;
		bottom: 0;
		left: 0;
		z-index: 101;
		margin: 0 !important;
		padding: 1em;
		background-color: #F8F8F8;
		@include default-box-shadow(bottom, 2);
	}
	.on-top-controls {
		overflow: auto;
		.on-top-close {
			float: right;
			background-color: $colour-4;
		}
	}
	.on-top-only, .on-top-controls {
		display: inherit !important;
		&.space {
			display: block !important;
		}
	}
	.not-on-top {
		display: none !important;
	}
}
@include breakpoint(medium) {
	:focus,
	input[type="submit"]:focus,
	.check-box-field input:focus + label,
	.radio-button-field input:focus + label,
	.select-field select:focus,
	.workshop-link:focus .title,
	#main-nav .nav a:focus .title {
		html[data-input="kb"] & {
			outline: 0.25rem solid rgba($colour-2, 0.5);
			outline-offset: 0.2rem;
			z-index: 1;
		}
	}
	html[data-input="kb"] {
		#main-nav .logo:focus {
			outline-offset: -0.2em;
		}
		.workshop-link:focus,
		#main-nav .nav a:focus {
			outline: none;
		}
	}
	body {
		padding-bottom: 0;
	}
	h2 {
		font-size: 2.25em;
	}
	h3 {
		font-size: 1.75em;
	}
	p {
		font-size: 1.25em;
	}
	fieldset {
		&.right-help {
			float: left;
			text-align: left;
			margin-right: 1.5em;
		}
	}
	form {
		&.flex-form {
			@include _-(display, flex);
			@include _(align-items, flex-start);
			.input-field {
				@include _(flex, 1);
			}
			button, .button {
				margin-left: 1em;
				height: 2.6em;
			}
		}
	}
	.input-field {
		&.big select,
		&.big input {
			font-size: 2em;
		}
	}
	.flex-column {
		@include _-(display, flex);
		@include _(align-items, flex-start);
		margin-top: 1em;
		p:first-child {
			margin-top: 0;
		}
		.stretch-item {
			@include _(flex, 1);
			margin-right: 1em;
		}
	}
	.flex-form, .flex-column {
		button, .button {
			width: auto;
		}
	}
	.flex-inputs {
		.stretch-item {
			@include _(flex, 1);
			@include _(flex-basis, auto);
		}
	}
	#main-nav {
		.logo {
			margin-top: 0.25em;
			font-size: 4.25em;
		}
		.nav {
			position: static;
			font-size: 1.8em;
			display: block;
			text-align: right;
			background-color: transparent;
			@include _(box-shadow, none);
			form {
				background-color: transparent;
			}
		}
		.nav a, .nav button {
			width: auto;
			min-width: 3.5em;
			overflow: visible;
			margin-left: 0.725em;
			line-height: 3em;
			padding: 0 0 1em;
			color: $black;
			@include _(box-shadow, none);
			@include _(text-shadow, none);
			@include before-and-after {
				content: '';
				display: block;
				position: absolute;
				background-color: rgba(0, 0, 0, 0.33);
				z-index: -1;
				margin: 0;
				border: 0;
				font-size: 1em;
				left: -0.51em;
				right: -0.51em;
				top: 0;
				height: 0;
				width: auto;
				@include _(opacity, 1);
				@include _(transition, height 150ms ease-in-out);
				@include _(transform, rotate(-20deg) scaleX(0.94) scaleY(1.5) translate(-0.5em, -0.5em));
				@include _(transform-origin, 0 0);
			}
			@include after {
				height: 3em;
				@include _(opacity, 0.1);
			}
			@include before {
			    box-shadow: 0 0 2em -0.5em rgba(#000, 0.75);
				@include _(opacity, 0.33);
			}
			&.current {
				z-index: 2;
				@include before {
					height: 3em;
					@include _(opacity, 0.67);
				}				
			}
			&:hover {
				@include before {
					height: 3em;
				}
			}
		}
		.nav a {
			&[class] {
				background-color: transparent;
			}
			&.policy {
				@include before-and-after {
					background-color: $colour-5;
				}
			}
			&.about {
				@include before-and-after {
					background-color: $colour-3;
				}
			}
		}
		.nav a.register, .nav button {
			@include before-and-after {
				background-color: $colour-2;
			}
			&:focus, &:active {
				@include _(transform, none);
			}
		}
	}
	#banner {
		margin: 3em auto;
		figure {
			min-height: 40em;
			margin: rems(-20) auto rems(2);
		}
		.title {
			font-size: 1.9em;
			margin: 3em 0 1em;
		}
		img {
			@include _(box-shadow, 0 0 2em -0.5em rgba(0, 0, 0, 0.5));
		}
	}
	#registration-admin-menu {
		a {
			margin: 0;
		}
	}
	ul.warnings {
		li {
			margin: 1em 4em;
		}
	}
	.warning-info {
		margin-left: 1em;
	}
	.workshop-list {
		padding: 0 2em;
	}
	.event-dlg {
		min-width: 75%;
	}
	#main {
		clear: right;
		article {
			padding: rems(2.5) 7.5%;
		}
		.columns {
			form {
				margin-top: 2em;
			}
		}
		.featured-image-container {
			display: block;
			figure {
				float: left;
				width: 33%;
				margin: 0 1.5em 1em -1.5em;
			}
		}
	}
	#header-title {
		min-height: rems(35);
		font-size: 1em;
		&.short {
			font-size: 2em;
			min-height: rems(15);
			h1 {
				position: absolute;
				bottom: 0;
				text-align: left;
				font-size: 2em;
			}
			@include before {
				content: '';
				position: absolute;
				top: 0;
				right: 0;
				bottom: 0;
				left: 0;
				z-index: $zindex-base + 2;
				@include _(box-shadow, inset 0 -13rem 3em -4rem rgba(0, 0, 0, 0.8));
				@include _(transition, opacity 250ms ease-in-out);
			}
		}
		&.no-image {
			min-height: 0;
			font-size: 1em;
		}
		svg {
			display: block;
		}
		svg rect {
			@include _(animation, banner-load 1s ease-in-out);
		}
		.title {
			text-align: left;
			width: 110%;
			background-color: rgba($white, 0.5);
			@include _(transform, rotate(-$header-tilt) translate3d(0, 0, 0));
			@include _(transform-origin, 0 100%);
		}
		.details {
			text-align: right;
			color: #000;
		}
		.background {
			display: block;
		}
		
		.primary {
			padding: 12% 0 0 0.25em;
		}
	}
	#footer {
		footer {
			font-size: 1em;
		}
		.github {
			@include _(flex, none);
			@include _(flex-basis, auto);
			margin: 0 1em;
		}
		.facebook, .external {
			margin: 0;
		}
		.site-info {
			width: auto;
			text-align: right;
		}
		.site-info, .user-controls, .external {
			width: auto;
		}
		ul.locales {
			@include _(flex, none);
			@include _(flex-basis, auto);
			@include _(flex-grow, 1);
			margin: 0 0 0 2em;
			text-align: left;
		}
	}
	.check-box-field,
	.radio-button-field {
		@include _-(display, flex);
		label {
			@include _(flex, 1);
			border: 0.1em solid;
			border-left: 0;
			text-align: left;
		}
		input:first-child + label {
			border: 0.1em solid;
		}
		&.inline {
			label {
				float: left;
			}
			&.vertical {
				label {
					float: none;
				}
			}
			input[type="radio"] + label {
				@include after {
					top: -0.025em;
					left: 0.175em;
				}
			}
		}
	}
	.fieldgroup {
		@include _-(display, flex);
		@include _-(display, inline-flex);
	}
	.select-field {
		select {
			width: auto;
		}
	}
	.admin-blocks {
		> li {
			@include _(flex, none);
			min-width: 12em;
		}
	}
	.flow-steps {
		ul {
			margin: 2em 0 1em 0;
		}
		.step {
			position: static;
			text-align: center;
			white-space: normal;
			@include _(transform, none);
		}
	}
}
@include breakpoint(large) {
	#main-nav {
		.nav {
			font-size: 1.9em;
			margin-top: 0;
		}
	}
	#banner {
		body.fixed-banner & {
			position: fixed;
			top: 0;
			right: 0;
			left: $sidebar-width;
			z-index: $zindex-base + 2;
		}
		figure {
			width: 90%;
		}
	}
	
	#main {
		padding-left: $sidebar-width;
	}
	#header-title {
		&.no-image {
			min-height: 0;
		}
		&.short {
			min-height: rems(25);
		}
		&.no-image,
		&.short {
			h1 {
				text-align: left;
				margin: 0.67em 0;
			}
		}
	}
	#main-nav .logo {
		font-size: 5em;
	}
	a.logo {
		display: block;
		float: none;
		padding: 0.2em;
	}
	.actions {
		margin: 4em 2em 0 0;
	}
	
	#footer {
		overflow: visible;
		padding: 0;
		width: 100%;
		margin-bottom: 2.5em;
		footer {
			max-width: $row-width;
			margin: 0 auto;
		}
	}
}