/*
	Theme Name: Pays Flechois
	Description:  Pays Flechois 2015 WP Theme
	Version: 1.0
	Author: <a href="https://www.babaweb.fr/">Maxime GOURLOO - BABAWEB</a>
	Author URI: https://www.babaweb.fr/
*/

/* Reset */
*, *::before, *::after { box-sizing: border-box; padding: 0; border: 0; border-radius: 0; margin: 0; background: none; text-align: inherit; text-decoration: none; font: inherit; color: inherit; list-style: none; outline: none;}
input, button, select, textarea { -webkit-appearance: none; -moz-appearance: none;}
a, button { overflow: visible; cursor: pointer;}
select::-ms-expand { display: none;}

/* Images */
.img--cover,
.img--contain {
    position: relative;
    overflow: hidden
}

.img--cover > img,
.img--contain > img {
    display: block;
    width: auto;
    height: auto;

    position: absolute;
    top: -10000%;
    left: -10000%;
    bottom: -10000%;
    right: -10000%;

    margin: auto;
}

.img--contain > img {
    max-width: 100%;
    max-height: 100%;
}

.img--cover > img {
    min-width: 1000%;
    min-height: 1000%;

    transform: scale(.1);
}

/* General */
html {
	font-size: 85%;
}

body {
	display: block;
	width: 100%;
	min-height: 100vh;

	padding: 0 0 0 20rem;

	background-color: #F4F0ED;

	font-family: 'Source Sans Pro', sans-serif;
	font-size: 1em;
	line-height: 1.5;
}

/* Header */
.header {
	display: flex;
	width: 20rem;
	height: 100vh;

	position: fixed;
	top: 0;
	left: 0;

	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;

	background-color: #282723;

	color: #FFF;
}

.header-logo {
	display: flex;
	width: 100%;
	height: 20rem;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
}

.header-logo-img--desktop {
	display: block;
}

.header-logo-img--responsive {
	display: none;
}

.hamburger {
	display: none;
}

.header-menu {
	display: flex;
	width: 100%;

	position: relative;
	z-index: 1;

	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;

	flex: 1 1 auto;

	overflow: hidden;
}

.header-menu::before {
	display: block;
	width: 4.8rem;
	height: 100%;

	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;

	background-color: #FFF;

	content: '';
}

.header-menu-list {
	display: block;
	width: 100%;

	border-top: 1px solid #4F4C49;
}

.header-menu-link,
.header-back {
	display: flex;
	width: 100%;
	height: 4.8rem;
	
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;

	transition: color .2s ease;
}

.header-menu-icon,
.header-back-icon {
	display: flex;
	width: 4.8rem;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-self: stretch;

	background-color: #FFF;

	font-size: 20px;
	color: #393834;

	transition: background-color .2s ease, color .2s ease;
}

.header-menu-link:hover .header-menu-icon,
.header-menu-link.header-menu-link--current .header-menu-icon,
.header-back:hover .header-back-icon {
	background-color: #393834;
	color: #FFF;
}

.header-menu-label,
.header-back-label {
	display: flex;

	padding: 10px 25px;
	border-top: 1px solid transparent;

	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	flex: 1 1 auto;
}

.header-menu-item {
	display: block;
	width: 100%;
}

.header-back-label {
	border-top: 1px solid #4F4C49;
	margin: -1px 0 0 0;
}

.header-menu-label {
	border-bottom: 1px solid #4F4C49;
	margin: 0 0 -1px 0;
}

.header-menu-link--home {
	background-color: #393834;

	font-size: 1.3em;
}

.header-menu-link--directory .header-menu-icon,
.header-menu-link--directory:hover,
.header-menu-link--directory.header-menu-link--current {
	color: #EE562F;
}

.header-menu-link--directory:hover .header-menu-icon,
.header-menu-link--directory.header-menu-link--current .header-menu-icon {
	background-color: #EE562F;
}

.header-menu-link--events .header-menu-icon,
.header-menu-link--events:hover,
.header-menu-link--events.header-menu-link--current {
	color: #3EAC2C;
}

.header-menu-link--events:hover .header-menu-icon,
.header-menu-link--events.header-menu-link--current .header-menu-icon {
	background-color: #3EAC2C;
}

.header-menu-link--login .header-menu-icon,
.header-menu-link--login:hover,
.header-menu-link--login.header-menu-link--current {
	color: #01A7E3;
}

.header-menu-link--login:hover .header-menu-icon,
.header-menu-link--login.header-menu-link--current .header-menu-icon {
	background-color: #01A7E3;
}

.header-menu-link--logout .header-menu-icon,
.header-menu-link--logout:hover {
	color: #F00;
}

.header-menu-link--logout:hover .header-menu-icon {
	background-color: #F00;
}

.header-back {
	position: relative;
	z-index: 1;

	margin: auto 0 0 0;

	background-color: #393834;
	box-shadow: 0 0 20px rgba(0,0,0,.5);
}

.header-back-label {
	justify-content: center;
	text-align: center;
}

.wrapper {
	display: block;
	width: 100%;

	padding: 80px;
}

/* Buttons */
.button {
	display: inline-flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}

.button-label,
.button-icon {
	display: flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	transition: background-color .2s ease, color .2s ease;
}

.button-label {
	padding: 10px 20px;
}

.button-icon {
	width: 3rem;
	min-width: 3rem;
	min-height: 3rem;

	background-color: #FFF;

	font-size: .8em;
	color: #B2B2B2;
}

.button-icon--login,
.button-icon--directory,
.button-icon--events {
	color: #FFF;
}

.button-icon--login {
	background-color: #01A7E3;
}

.button-icon--directory {
	background-color: #EE562F;
}

.button-icon--events {
	background-color: #3EAC2C;
}

.button-icon:not(:first-child) {
	margin-left: 1px;
}

.button-icon:not(:last-child) {
	margin-right: 1px;
}

.button:hover .button-label {
	background-color: #FFF;
}

.button--login:hover .button-icon:not(.button-icon--login),
.button--directory:hover .button-icon:not(.button-icon--directory),
.button--events:hover .button-icon:not(.button-icon--events),
.button--login:hover .button-label,
.button--directory:hover .button-label,
.button--events:hover .button-label {
	color: #FFF;
}

.button--login:hover .button-icon:not(.button-icon--login),
.button--login:hover .button-label {
	background-color: #01A7E3;
}

.button--directory:hover .button-icon:not(.button-icon--directory),
.button--directory:hover .button-label {
	background-color: #EE562F;
}

.button--events:hover .button-icon:not(.button-icon--events),
.button--events:hover .button-label {
	background-color: #3EAC2C;
}

/* Text */
b,
strong {
	font-weight: 700;
}

.title {
	display: block;
}

.title--h1 {
	font-size: 2rem;
}

.title--h2,
.formatted-text h2 {
	font-size: 1.5rem;
}

.title--h3,
.formatted-text h3 {
	font-size: 1.25rem;
}

.title--h4,
.formatted-text h4 {
	text-transform: uppercase;
	font-size: 1rem;
}

.title--grey,
.formatted-text h2,
.formatted-text h3 {
	color: #B2B2B2;
}

.title--h1 + .title {
	margin-top: 10px;
}

.formatted-text hr {
	display: block;
	width: 100%;
	height: 1px;

	margin: 40px 0;

	background-color: #F4F0ED;
}

.formatted-text a:not([class]) {
	color: #EE562F;
}

.formatted-text a:not([class]):hover {
	text-decoration: underline;
}

.formatted-text ul,
.formatted-text ol {
	display: block;
	width: 100%;

	padding-left: 15px;
}

.formatted-text li {
	width: 100%;
}

.formatted-text ul li {
	list-style: square;
}

.formatted-text ol li {
	list-style: decimal;
}

.formatted-text li:not(:last-child) {
	margin-bottom: .4rem;
}

.formatted-text h2:not(:last-child),
.formatted-text h3:not(:last-child),
.formatted-text h4:not(:last-child),
.formatted-text h5:not(:last-child),
.formatted-text ul:not(:last-child),
.formatted-text ol:not(:last-child),
.formatted-text p:not(:last-child) {
	margin-bottom: 1.5rem;
}

.title--line {
	display: flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-end;
}

.title--line::after {
	display: block;
	height: 1px;

	margin: 0 0 calc(.75em - 1px) 20px;

	flex: 1 1 auto;

	background-color: #FFF;

	content: '';
}

.login-color {
	color: #01A7E3;
}

.directory-color {
	color: #EE562F;
}

.events-color {
	color: #3EAC2C;
}

/* Tags */
.directory-tags {
	display: flex;
	width: calc(100% + 10px);

	margin: 35px -5px -5px -5px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

.directory-tags-item {
	display: flex;
	
	margin: 5px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}

.directory-tags-button {
	display: flex;

	padding: 10px 20px;
	border-radius: 9999px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	background-color: #E7E3E0;

	transition: background-color .2s ease, color .2s ease;
}

.directory-tags-button::after {
	display: block;
	
	margin: 0 0 0 10px;

	content: '\e802';
	font-family: 'icons', sans-serif;
	font-size: .6em;
	color: #B2B2B2;
}

.directory-tags-button:hover {
	background-color: #EE562F;
	color: #FFF;
}

.directory-tags-button:hover::after {
	color: #FFF;
}

/* Directory */
.directory {
	display: flex;
	width: 100%;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.directory-body {
	display: block;
	width: calc(75% - 20px);

	margin: 0 40px 0 0;
}

.data-wrapper--loading {
	position: relative;
}

.data-wrapper--loading::before {
	display: block;
	width: 100%;
	height: 100%;

	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;

	background-color: #F4F0ED;

	opacity: .5;

	content: '';
}

.data-wrapper--loading::after {
	display: block;
	width: 50px;
	height: 50px;

	position: absolute;
	top: calc(50% - 25px);
	left: calc(50% - 25px);
	z-index: 11;

	border: 2px solid;
	border-radius: 100%;

	content: '';

	animation: spin .6s linear infinite;
}

.directory .data-wrapper--loading::after {
	border-color: #EE562F #EE562F #EE562F transparent;
}

.events .data-wrapper--loading::after {
	border-color: #3EAC2C #3EAC2C #3EAC2C transparent;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

.directory-list,
.events-list {
	display: flex;
	width: calc(100% + 40px);

	margin: 20px -20px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

.directory-card {
	display: flex;
	width: calc((100% - 1px) / 3 - 40px);

	margin: 20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

.directory-card-link {
	display: block;
	width: 100%;

	padding: 40px;

	transition: background-color .2s ease, color .2s ease;
}

.directory-card-link:hover {
	background-color: #EE562F;
	color: #FFF;
}

.directory-card-logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 60px;

	margin: 0 auto 20px 0;
}

.directory-card-image::before {
	display: block;
	width: 0;

	padding: 56.25% 0 0 0;

	content: '';
}

.directory-card-title {
	font-size: 2em;
	line-height: 1.2;
	color: #EE562F;
}

.directory-card-link:hover .directory-card-title {
	color: #FFF;
}

.directory-card-title:not(:last-child) {
	margin: 0 0 .65em 0;
}

.directory-card-address:not(:last-child) {
	margin: 0 0 1em 0;
}

.directory-footer,
.events-footer {
	display: flex;
	width: 100%;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}

.directory-data,
.events-data {
	display: block;

	margin: 0 40px 0 0;
}

.directory-data-controls,
.events-data-controls {
	display: flex;

	margin: 0 40px 0 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}

.directory-data-controls-wrapper,
.events-data-controls-wrapper {
	display: block;

	position: relative;
	z-index: 1;

	margin: 0 0 0 10px;

	background-color: #FFF;
}

.directory-data-controls-wrapper::after,
.events-data-controls-wrapper::after {
	display: flex;
	height: 100%;

	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;

	padding: 0 20px 0 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	content: '\e804';
	font-family: 'icons', sans-serif;
	font-size: .8em;
}

.directory-data-controls-wrapper::after {
	color: #EE562F;	
}

.events-data-controls-wrapper::after {
	color: #3EAC2C;	
}

.directory-data-controls-input,
.events-data-controls-input {
	display: block;

	padding: 10px 50px 10px 20px;
}

.directory-pagination,
.events-pagination {
	display: flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center;
	flex: 1 1 auto;
}

.directory-pagination::before,
.events-pagination::before {
	display: block;
	height: 1px;

	margin: 0 40px 0 0;

	flex: 1 1 auto;

	background-color: #FFF;

	content: '';
}

.directory-pagination-button,
.events-pagination-button {
	display: flex;
	width: calc(1.5em + 20px);
	min-width: calc(1.5em + 20px);
	height: calc(1.5em + 20px);

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	color: #FFF;

	cursor: pointer;
}

.directory-pagination-button::before,
.events-pagination-button::before {
	font-size: .8em;
}

.directory-pagination-button {
	background-color: #EE562F;
}

.events-pagination-button {
	background-color: #3EAC2C;
}

.directory-pagination-button--disabled,
.events-pagination-button--disabled {
	background-color: #FFF;
	color: #B2B2B2;

	cursor: not-allowed;
}

.directory-pagination-list,
.events-pagination-list {
	display: flex;

	margin: 0 35px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center;
}

.directory-pagination-item,
.events-pagination-item {
	display: block;

	margin: 5px 0;
}

.directory-pagination-link,
.events-pagination-link {
	display: block;
	padding: 0 5px;
}

.directory-pagination-link--current,
.events-pagination-link--current {
	cursor: default;
}

.directory-pagination-link:hover,
.directory-pagination-link--current {
	color: #EE562F;
}

.events-pagination-link:hover,
.events-pagination-link--current {
	color: #3EAC2C;
}

.directory-filters {
	display: block;
	width: calc(25% - 20px);
}

.directory-filters-toggle {
	display: none;
}

.directory-filters-wrapper {
	display: block;
	width: 100%;
}

.directory-search {
	display: block;
	width: 100%;

	position: relative;

	border-radius: 9999px;
	margin: 40px 0;

	background-color: #E7E3E0;
}

.directory-search-submit {
	display: flex;
	height: 100%;

	position: absolute;
	top: 0;
	right: 0;

	padding: 0 20px;
	border-radius: 9999px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	color: #EE562F;

	transition: background-color .2s ease, color .2s ease;
}

.directory-search-submit:hover {
	background-color: #EE562F;
	color: #FFF;
}

.directory-search-input {
	display: block;
	width: 100%;

	padding: 10px 60px 10px 20px;
}

.directory-filters-category {
	display: block;
	width: 100%;

	margin: 40px 0 0 0;
}

.directory-filters-category-header {
	display: inline-flex;
	
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;

	font-size: 1.5em;

	transition: color .2s ease;
	cursor: pointer;
}

.directory-filters-category-header:hover {
	color: #EE562F;
}

.directory-filters-category-header::before {
	display: block;

	margin: 0 20px 0 0;

	content: '\e804';
	font-family: 'icons', sans-serif;
	font-size: .5em;
	line-height: 3;
	color: #EE562F;

	transition: transform .2s ease;
}

.directory-filters-category--opened .directory-filters-category-header::before {
	transform: scaleY(-1);
}

.directory-filters-category-body {
	display: none;
	width: 100%;
	
	margin: 20px 0 0 0;
}

.directory-filters-category--opened .directory-filters-category-body {
	display: block;
}

.directory-filters-list {
	display: flex;
	width: calc(100% + 20px);

	margin: -5px -10px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.directory-filters-item {
	display: block;
	width: calc(50% - 20px);

	margin: 5px 10px;
}

.directory-filters-checkbox {
	display: inline-block;

	position: relative;

	cursor: pointer;
}

.directory-filters-checkbox-input {
	width: 0;
	height: 0;

	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.directory-filters-checkbox-label {
	display: inline-flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.directory-filters-checkbox-label::before {
	display: block;
	width: .75em;
	min-width: .75em;
	height: .75em;

	border: 1px solid #EE562F;
	margin: .325em 20px 0 0;

	content: '';

	transition: box-shadow .2s ease;
}

:checked + .directory-filters-checkbox-label::before {
	box-shadow: inset 0 0 0 .40em #EE562F;
}

.events {
	display: block;
	width: 100%;
}

.events-body {
	display: block;
	width: 100%;
}

.events-card {
	display: flex;
	width: calc(25% - 40px);

	margin: 20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

.events-card-link {
	display: block;
	width: 100%;

	position: relative;

	padding: 0 40px 40px 40px;

	transition: background-color .2s ease, color .2s ease;
}

.events-card-link:hover {
	background-color: #3EAC2C;

	color: #FFF;
}

.events-card-link--black:hover {
	background-color: #141414;
}

.events-card-image {
	display: block;
	width: calc(100% + 80px);

	margin: 0 -40px;
}

.events-card-image::before {
	display: block;
	width: 0;
	
	padding: 56.25% 0 0 0;

	content: '';
}

.events-card-tag {
	display: inline-flex;

	padding: 10px 20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;

	background-color: #282723;
	
	color: #FFF;
}

.events-card-tag:first-child {
	margin: 20px 0 0 -50px;
}

.events-card-image ~ .events-card-tag {
	position: absolute;
	top: 10px;
	left: -10px;
	z-index: 1;
}

.events-card-dates,
.event-dates {
	display: flex;
	height: 4.8rem;

	position: relative;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;

	font-size: 1rem;
	line-height: 1;
	color: #FFF;
}

.events-card-dates {
	margin: 20px 0;
}

.events-card-dates:first-child {
	margin: 40px 0 20px 0;
}

.events-card-image ~ .events-card-dates {
	margin: -2.4rem 0 20px 0;
}

.events-card-date,
.event-date {
	display: flex;
	width: 4.8rem;
	min-width: 4.8rem;

	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.events-card-date,
.events-card-dates-link {
	background-color: #282723;
}

.event-date,
.event-dates-link {
	background-color: #3EAC2C;
}

.events-card-day,
.event-day {
	display: block;

	margin: -3px 0 5px 0;

	font-size: 1.85em;
}

.events-card-month,
.event-month {
	font-size: .88em;
}

.events-card-dates-link,
.event-dates-link {
	display: flex;
	width: 20px;
	min-width: 20px;

	margin: 0 1px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	font-size: .8em;
}

.events-card-title {
	display: block;

	margin-top: 20px;

	font-size: 2em;
	line-height: 1.2;
}

.events-card-title:not(:last-child) {
	margin-bottom: 20px;
}

.events-card-partner {
	display: block;

	color: #3EAC2C;
}

.events-card-partner:not(:last-child) {
	margin: 0 0 10px 0;
}

.events-card-link:hover .events-card-partner {
	color: #282723;
}

.events-card-link--black .events-card-partner {
	color: #282723;
}

.events-card-link--black:hover .events-card-partner {
	color: #FFF;
}

.events-card-info {
	display: flex;
	width: calc(100% + 20px);

	margin: -5px -10px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.events-card-info-item {
	display: inline-flex;

	margin: 5px 10px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.events-card-info-icon {
	display: block;

	margin: 0 10px 0 0;

	color: #3EAC2C;
}

.events-card-link:hover .events-card-info-icon {
	color: #282723;
}

.events-card-link--black .events-card-info-icon {
	color: #282723;
}

.events-card-link--black:hover .events-card-info-icon {
	color: #FFF;
}

.events-card-excerpt {
	display: block;

	margin: 20px 0 0 0;

	line-height: 1.7;
	color: #B2B2B2;
}

.events-card-link:hover .events-card-excerpt {
	color: #FFF;
}

.single {
	display: block;
	width: 100%;
}

.single-header {
	display: flex;
	width: 100%;

	margin: 0 0 40px 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
}

.single-update {
	color: #B2B2B2;
}

.single-nav {
	display: flex;
	width: 100%;

	margin: 0 0 20px 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}

.single-nav .button + .button {
	margin-left: 1px;
}

.separator {
	display: block;
	height: 1px;
	
	flex: 1 1 auto;
	
	background-color: #FFF;
}

.separator--login {
	background-color: #01A7E3;
}

.separator--directory {
	background-color: #EE562F;
}

.separator--events {
	background-color: #3EAC2C;
}

.event {
	display: flex;
	width: 100%;

	padding: 40px;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

.event-slider {
	display: block;
	width: calc(50% + 60px);

	position: relative;

	margin: 0 0 0 -40px;

	flex: 0 0 auto;
}

.event-slider::before,
.event-slider::after {
	display: block;
	width: 20px;
	height: 100%;
	
	position: absolute;
	top: 0;
	z-index: 1;
	
	content: '';
}

.event-slider::before {
	right: 20px;

	background-image: linear-gradient(to left, rgba(255,255,255,1), rgba(255,255,255,0));
}

.event-slider::after {
	right: 0;
	
	background-color: #FFF;
}

.event-slider-track {
	display: block;
	width: 100%;

	margin: 0 0 20px 0;

	overflow: hidden;
}

.event-slider-item {
	display: block;

	border-left: 40px solid transparent;
	border-right: 40px solid transparent;
}

.event-slider-track:not(.slick-slider) .event-slider-item {
	display: none;
}

.event-slider-track:not(.slick-slider)::before,
.event-slider-item::before {
	display: block;
	width: 0;

	padding: 56.25% 0 0 0;

	content: '';
}

.event-slider-controls {
	display: flex;
	width: 100%;

	padding: 0 40px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}

.event-slider-buttons {
	display: block;
}

.event-slider-button {
	display: flex;
	width: 3rem;
	min-width: 3rem;
	height: 3rem;

	border: 1px solid #3EAC2C;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	font-size: .8em;
	color: #3EAC2C;

	transition: background-color .2s ease, color .2s ease;
}

.event-slider-button.slick-disabled {
	opacity: .5;
	cursor: not-allowed;
}

.event-slider-button:not(:last-child) {
	margin-bottom: -1px;
}

.event-slider-button:not(.slick-disabled):hover {
	background-color: #3EAC2C;
	color: #FFF;
}

.event-slider-thumbnails {
	display: block;
	
	flex: 1 1 auto;

	overflow: hidden;
}

.event-slider-thumbnail {
	display: block;
	width: auto;
	height: calc(6rem - 1px);

	border-left: 20px solid transparent;

	opacity: .6;
	cursor: pointer;

	transition: opacity .2s ease;
}

.event-slider-thumbnails:not(.slick-slider) .event-slider-thumbnail {
	display: none;
}

.event-slider-thumbnail:not(.slick-current):hover {
	opacity: .7;
}

.event-slider-thumbnail.slick-current {
	opacity: 1;
}

.event-body {
	display: block;
	
	flex: 1 1 auto;
}

.event-header {
	display: flex;
	width: 100%;

	margin: 0 0 40px 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
}

.event-tags {
	display: flex;
	width: 100%;

	margin: -20px 0 20px 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center;
}

.event-tags::before {
	display: block;
	height: 1px;

	flex: 1 1 auto;

	background-color: #F4F0ED;

	content: '';
}

.event-tag {
	display: inline-flex;

	padding: 10px 20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center;

	background-color: #282723;
	
	color: #FFF;
}

.event-info {
	display: flex;
	width: calc(100% + 40px);

	margin: 0 -20px -10px -20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.event-info-col {
	display: block;

	margin: 0 20px;

	flex: 1;
}

.event-info-item {
	display: flex;
	width: 100%;

	margin: 0 0 10px 0;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.event-info-label {
	display: block;

	margin-right: 10px;

	color: #B2B2B2;
}

.event-info-value {
	display: inline-flex;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

time.event-info-value {
	text-transform: capitalize;
}

.event-info-value:not(:last-child) {
	margin-right: 20px;
}

.event-info-icon {
	display: block;

	margin: 0 10px 0 0;
}

.event-links {
	display: flex;
	width: calc(100% + 40px);

	margin: 30px -20px -10px -20px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

.event-link {
	display: flex;
	width: calc(50% - 40px);

	margin: 10px 20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}

.event-link:first-child:last-child {
	width: auto;
	max-width: calc(100% - 40px);
}

.event-link-icon {
	display: flex;
	width: 3rem;
	min-height: 3rem;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	background-color: #3EAC2C;

	color: #FFF;
}

.event-link-label {
	display: flex;

	padding: 10px 20px;
	border: 1px solid #F4F0ED;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;

	flex: 1 1 auto;

	transition: border-color .2s ease, background-color .2s ease, color .2s ease;
}

.event-link-label:not(:first-child) {
	border-left: 0;
}

.event-link-label:not(:last-child) {
	border-right: 0;
}

.event-link:hover .event-link-label {
	background-color: #3EAC2C;
	border-color: #3EAC2C;
	color: #FFF;
}

.partner {
	display: flex;
	width: calc(100% + 40px);

	margin: -20px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
}

.partner-card {
	display: block;
	width: calc(50% - 40px);

	padding: 40px;
	margin: 20px;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

.partner-header {
	display: flex;
	width: 100%;

	margin-bottom: 40px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: flex-start;
}

.partner-title {
	position: relative;

	padding-left: 1em;
}

.partner-title::before {
	display: block;

	position: absolute;
	top: 1.35em;
	left: 0;

	content: '\e80d';
	font-family: 'icons', sans-serif;
	font-size: .4em;
}

.partner-logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 150px;
	max-height: 60px;

	margin: 0 0 -40px 0;
}

.partner-info {
	display: flex;
	width: calc(100% + 40px);

	margin: -20px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.partner-info-item {
	display: block;
	width: calc(50% - 40px);

	margin: 20px;
}

.partner-themes {
	display: block;
	width: 100%;
}

.partner-themes-list {
	display: flex;

	margin: calc(1.5rem - 10px) -5px -10px -5px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

.partner-themes-item {
	display: flex;

	padding: 10px 20px;
	border: 1px solid #F4F0ED;
	border-radius: 9999px;
	margin: 5px;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	text-align: center;
}

.partner-hours {
	margin: -20px -20px 20px -20px;
}

.partner-hours-item {
	padding: 20px 0;
	border: solid #F4F0ED;
	border-width: 1px 0;
}

.partner-hours-table {
	width: 100%;

	margin: 18px 0 -2px 0;

	table-layout: fixed;

	text-align: left;
}

.partner-hours-table th,
.partner-hours-table td {
	padding: 2px 0;
}

.partner-hours-table th {
	color: #B2B2B2;
}

.editorial {
	display: block;
	width: 100%;
	max-width: 900px;

	padding: 40px;
	margin: 40px 0 0 0;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

/* Login */
.login {
	display: flex;
	width: 100%;
	height: 100vh;

	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;

	overflow: auto;
}

.login-wrapper {
	display: block;
	width: 100%;
	max-width: 850px;

	margin: auto;

	background-color: #FFF;
	box-shadow: 3px 3px 5px rgba(0,0,0,.1);
}

.login-form {
	display: block;
	width: 100%;

	padding: 40px;
}

.login-password-forgotten {
	display: block;

	margin: 0 20px 0 0;
}

.login-password-forgotten-link {
	color: #01A7E3;
}

.login-password-forgotten-link:hover {
	text-decoration: underline;
}

.form-message {
	display: block;
	width: 100%;

	padding: 15px 40px 15px 35px;
	border-left: 5px solid;

	background-color: #E7E3E0;
}

.form-message--error {
	border-color: #F00;
	
	background-color: #FFE6E6;

	color: #F00;
}

.form-message--success {
	border-color: #2dc72d;

	background-color: #EAF9EA;

	color: #2dc72d;
}

.form-header {
	display: flex;
	width: 100%;

	margin: 0 0 40px 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
}

.form-body {
	display: flex;
	width: calc(100% + 40px);

	margin: -10px -20px;

	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.form-item {
	display: block;
	width: calc(100% - 40px);

	margin: 10px 20px;
}

.form-label {
	display: block;
	width: 100%;

	margin: 0 0 10px 0;

	font-size: 1.5rem;
	line-height: 1;
}

.form-password {
	display: block;

	position: relative;
}

.form-password-visibility {
	display: flex;
	width: 2em;
	height: 2em;

	position: absolute;
	top: calc(50% - 1em);
	right: 10px;
	z-index: 1;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;

	font-family: 'icons', sans-serif;
	color: #B2B2B2;

	transition: color .2s ease;
}

[type="password"] + .form-password-visibility::before {
	content: '\e811';
}

[type="text"] + .form-password-visibility::before {
	content: '\e812';
}

.form-password-visibility:hover {
	color: #282723;
}

.form-input {
	display: block;
	width: 100%;

	padding: 10px 20px;
	border: 1px solid #F4F0ED;
}

.form-footer {
	display: flex;
	width: 100%;

	margin: 40px 0 0 0;

	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
}

/* Cookies */
.cookies-disclaimer {
	display: block;
	width: 100%;

	position: fixed;
	bottom: 0;
	right: 0;
	z-index: 1000;

	padding: 40px;

	background-color: #282723;
	box-shadow: 0 0 20px rgba(0,0,0,.5);

	color: #FFF;
}

.cookies-container {
	display: block;
	width: 100%;
	max-width: 600px;

	margin: auto;
}

@media screen and (max-width: 1600px) and (min-width: 1280px) {
	.partner-hours-item {
		width: calc(100% - 40px);
	}

	.partner-hours-item:not(:last-child) {
		padding-bottom: 0;
		border-bottom: 0;
		margin-bottom: 0;
	}
}

@media screen and (max-width: 1500px) {
	.wrapper {
		padding: 60px;
	}

	.directory-card {
		width: calc(50% - 40px);
	}
	
	.events-card {
		width: calc((100% - 1px) / 3 - 40px);
	}
}