.current_driver { padding: 80px 20px; }
.current_driver:empty { display: none; }

@media (min-width: 769px) {
	.current_driver .cols {
		width: calc(100% + 60px);
		transform: translateX(-30px);
	}

	.current_driver .cols::after {
		content: '';
		display: block;
		clear: both;
	}

	.current_driver .col {
		float: left;
		width: calc(100% - 60px);
		margin: 0 30px;
	}

	.current_driver .width_70 { width: calc(70% - 60px); }
	.current_driver .width_60 { width: calc(60% - 60px); }
	.current_driver .width_40 { width: calc(40% - 60px); }
	.current_driver .width_30 { width: calc(30% - 60px); }
}

.current_driver .date {
	line-height: 1.2;
	text-transform: uppercase;
	font-family: 'Roboto', sans-serif;
	font-weight: 100;
	font-size: 7rem;
	color: #000;
	opacity: 0.5;
}

.current_driver .date span {
	font-family: 'proxima-nova', sans-serif;
	font-weight: 900;
	font-size: 7.5rem;
}

@media (max-width: 560px) {
	.current_driver .date      { font-size: 18vw; }
	.current_driver .date span { font-size: 19.5vw; }
}

.current_driver h2 { text-transform: uppercase; }
.current_driver .description > *:last-child { margin-bottom: 0; }

.current_driver .image {
	position: relative;
	padding-bottom: 91.3223%;
}

  .current_driver.year .date
, .current_driver.rm_year .date
, .current_driver.ded_year .date { display: none; }

  .current_driver.year .image
, .current_driver.rm_year .image
, .current_driver.ded_year .image { padding-bottom: 120%; }

.current_driver .image img {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	
	width: 100%;
	height: 100%;
	
	object-fit: cover;
	object-position: top center;
}

@media (max-width: 768px) {
	.current_driver .image { margin-bottom: 60px; }
}

.current_driver .share {
	margin: 15px 0;
	overflow: hidden;
}

.current_driver .share hr {
	margin: 8px 0;
	border: 1px #000 solid;
	opacity: 0.5;
}

.current_driver .share label {
	float: left;
	line-height: 20px;
	letter-spacing: 0.125rem;
	text-transform: uppercase;
	font-weight: 900;
	font-size: 1rem;
	color: #000;
	opacity: 0.5;
	margin-right: 15px;
}
.current_driver .share a {
	float: right;
	
	width: 20px;
	height: 20px;
	margin-left: 15px;
	
	background: no-repeat center center;
	background-size: contain;
	
	font-size: 0;
	
	opacity: 0.5;
	transition: opacity 0.3s ease-in-out;
}
.current_driver .share a:hover { opacity: 0.75; }
.current_driver .controls {
	margin-top: 60px;
	text-align: center;
}

.current_driver > .close {
	position: absolute;
	top: 80px;
	right: 20px;
	
	width: 40px;
	height: 40px;
	font-size: 0;
	
	background-color: transparent;
	opacity: 0.5;
	transition: opacity 0.3s ease-in-out;
}

.current_driver > .close:hover { opacity: 0.75; }

  .current_driver > .close::before
, .current_driver > .close::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 46px;
	height: 4px;
	background: #000;
	
	margin-left: -23px;
	margin-top: -2px;
}

.current_driver > .close::before { transform: rotate( 45deg); }
.current_driver > .close::after  { transform: rotate(-45deg); }

@media (max-width: 1350px) {
	.current_driver > .close { display: none; }
}

.driver_wrapper h1 { color: #84d0de; }
.driver_wrapper h1 span { color: #000; }

.driver_wrapper .group_heading {
	position: relative;
	
	display: block;
	padding: 5px 10px;
	
	line-height: 1.2;
	font-family: 'proxima-nova', sans-serif;
	font-weight: 900;
	font-size: 3rem;
	text-align: center;
	color: #84d0de;
	background: #e0e0e0;
	
	cursor: pointer;
}

@media (max-width: 640px) {
	.driver_wrapper .group_heading { font-size: 7.5vw; }
}

  .driver_wrapper .group_heading::before
, .driver_wrapper .group_heading::after {
	content: '';
	position: absolute;
	right: 30px;
	top: 50%;
	margin-top: -1px;
	width: 15px;
	height: 2px;
	background: #000;
	
	transition: all 300ms ease-in-out;
}

.driver_wrapper .group_heading ~ .group_heading { margin-top: 20px; }

.driver_wrapper input:checked       + .group_heading::after { opacity: 0; }
.driver_wrapper input:not(:checked) + .group_heading::after { transform: rotate(90deg); }

.driver_wrapper input[type=checkbox] {
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	height: 1px;
	opacity: 0.001;
	pointer-events: none;
}

.driver_wrapper input:not(:checked) + label + .drivers {
	max-height: 1px;
	overflow: hidden;
	opacity: 0;
}

.drivers {
	font-size: 0;
	max-height: 100%;
	transition: opacity 0.3s ease-in-out, max-height 0s ease-in-out 0.3s;
}

.driver_wrapper input:checked + label + .drivers { transition: opacity 0.3s ease-in-out; }

  .drivers.year
, .drivers.rm_year
, .drivers.ded_year {
	width: 108%;
	margin-left: -4%;
}

.drivers.month {
	width: calc(100% + 50px);
	transform: translateX(-25px);
}

@media (max-width: 900px) {
	.drivers.month {
		width: calc(100% + 20px);
		transform: translateX(-10px);
	}
	
	  .drivers.year
	, .drivers.rm_year
	, .drivers.ded_year	{
		width: calc(100% + 20px);
		transform: translateX(-10px);
		margin: 0;
	}
}

.driver {
	display: inline-block;
	
	background-color: #000;
	vertical-align: top;
	text-align: center;
	line-height: 1;
	
	transition: opacity 0.3s ease-in-out;
}

  .driver.year
, .driver.rm_year
, .driver.ded_year {
	padding: 1.25% 2.5%;
	width: 17%;
	margin: 4%;
}

.driver.month {
	padding: 15px;
	width: calc(25% - 50px);
	margin: 25px;
}

@media (max-width: 900px) {
	.driver.month {
		width: calc(25% - 20px);
		margin: 10px;
	}
	
	  .driver.year
	, .driver.rm_year
	, .driver.ded_year {
		width: calc(25% - 20px);
		margin: 10px;
		padding: 15px;
	}
}

@media (max-width: 768px) {
	.driver.month { width: calc(33.3333% - 20px); }
	  .driver.year
	, .driver.rm_year
	, .driver.ded_year { width: calc(33.3333% - 20px); }
}

@media (max-width: 560px) {
	.driver.month { width: calc(50% - 20px); }
	  .driver.year
	, .driver.rm_year
	, .driver.ded_year { width: calc(50% - 20px); }
}

.driver:hover {
	text-decoration: none !important;
	opacity: 0.75;
}

.driver .thumb {
	display: block;
	position: relative;
}

  .driver.year     .thumb
, .driver.rm_year  .thumb
, .driver.ded_year .thumb { padding-bottom: 120%; }
.driver.month      .thumb { padding-bottom: 82.2222%; }

.driver .thumb img {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	
	width: 100%;
	height: 100%;
	
	object-fit: cover;
	object-position: top center;
}

  .driver .name
, .driver .date {
	display: block;
	text-transform: uppercase;
}

.driver .name {
	font-weight: 900;
	margin-top: 15px;
}

  .driver.year     .name
, .driver.rm_year  .name
, .driver.ded_year .name {
	font-family: 'Roboto Condensed', sans-serif;
	font-size: 2rem;
	color: #fff;
}

  .driver.year     .date
, .driver.rm_year  .date
, .driver.ded_year .date {
	font-family: 'proxima-nova', sans-serif;
	font-weight: 900;
	font-size: 3rem;
	color: #dfb700;

	margin-bottom: 15px;
}

.driver.month .name {
	font-family: 'proxima-nova', sans-serif;
	font-weight: 900;
	font-size: 2rem;
	color: #fff;
}

.driver.month .date {
	font-family: 'Roboto', sans-serif;
	font-weight: 100;
	font-size: 3rem;
	opacity: 0.3333;
	margin-top: 10px;
}

@media (max-width: 1260px) {
	  .driver.year     .name
	, .driver.rm_year  .name
	, .driver.ded_year .name { font-size: 2.55vw; }
	  .driver.year     .date
	, .driver.rm_year  .date
	, .driver.ded_year .date { font-size: 3.8vw; }
	.driver.month .name { font-size: 2.5vw;  }
	.driver.month .date { font-size: 3.75vw; }
}

@media (max-width: 768px) {
	  .driver.year     .name
	, .driver.rm_year  .name
	, .driver.ded_year .name { font-size: 4vw; }
	  .driver.year     .date
	, .driver.rm_year  .date
	, .driver.ded_year .date { font-size: 5vw; }
	.driver.month .name { font-size: 3.25vw; }
	.driver.month .date { font-size: 4.5vw;  }
}

@media (max-width: 560px) {
	  .driver.year     .name
	, .driver.rm_year  .name
	, .driver.ded_year .name { font-size: 6vw; }
	  .driver.year     .date
	, .driver.rm_year  .date
	, .driver.ded_year .date { font-size: 7vw; }
	.driver.month .name { font-size: 5vw; }
	.driver.month .date { font-size: 7vw; }
}