table {
	border-collapse: collapse;
	border-spacing: 0;
	border: none;
}

h2 {
  margin-bottom: 20px;
}

h3 {
	font-size: 25px;
	line-height: 30px;
  margin: 20px 0;
}

h4 {
	font-size: 16px;
	margin: 40px 0 15px 0;
}

a i {
  margin-right: 5px;
}

#container-background {
  background: #2b2e32 url(../images/backgrounds/bg-aktionbikes.jpg) no-repeat center top;
}

.service-row__primary {
	padding-right: 30px;
}

.service-row__secondary h3 {
	margin: 0 0 10px 0;
	font-weight: normal;
}

.service-form {
	width: 100%;
}

.service-form input[type=radio],
.service-form input[type=checkbox] {
	margin: 0;
	width: 20px;
}
	
.service-form input[type=text],
.service-form input[type=email],
.service-form select,
.service-form button {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	display: block;
  padding: 8px;
  font-size: 14px;
	border-radius: 0px;
	margin: 5px 0 15px 0;
	height: 35px;
	background: white;
	border-radius: 4px;
	border: solid 1px #bbb;
}

.service-form input.error {
	border: solid 1px #e31e26;
	color: #e31e26;	
}

.service-form button {
	background: #eee;
	color: #505050;
	text-transform: uppercase;
	letter-spacing: 2px;
	cursor: pointer;
	margin: 30px 0 0 0;
	width: 100%;
}

.service-form button:hover {
	background-color: #ddd;
}

.service-form button[type=submit] {
	background: #e31e26;
	color: white;
}

.service-form button.disabled {
	background: #eee;
	color: #ccc;
	cursor: not-allowed;
}

.service-confirm td {
  vertical-align: top;
  padding: 0 0 30px 0;
}

.service-confirm h4 {
  position: relative;
  margin: 0 0 15px 0;
  padding: 5px 10px;
  font-size: 14px;
  background: #eee;
}

.service-confirm ul {
  list-style-type: disc;
  list-style-position: inside;
  margin: 0 10px;
  padding: 0;
}

.service-confirm .accordion__trigger {
  position: absolute;
  right: 10px;
  color: #505050;
  text-decoration: underline;
  font-weight: normal;
  cursor: pointer;
}

.service-confirm .accordion__trigger1 {
  display: block;
  color: #505050;
  text-decoration: underline;
  margin-top: 5px;
}

.service-confirm__part {
  margin: 0 0 40px 0;
}

.service-confirm p {
  margin: 0 10px;
  line-height: 1.5em;
  padding: 0;
}

.service-confirm small {
  margin: 0 10px;  
}

.validation-status {
	position: absolute;
	right:10px;
	bottom: 0;
	height: 35px;
	font-size: 20px;
	line-height: 35px;
}

.validation-status.valid:before {
	content: '\f00c';
	color: #41a841;
	font-family: 'FontAwesome';
}

.validation-status.invalid:before {
	content: '\f00d';
	color: #e31e26;
	font-family: 'FontAwesome';
}

.service-form label {
	position: relative;
	width: 100%;
	margin: 0;
}

.service-form label.valid:before,
.service-form label.invalid:before {
	font-family: 'FontAwesome';
	position: absolute;
	right:10px;
	bottom: 0;
	height: 35px;
	font-size: 20px;
	line-height: 35px;
	z-index: 100;
}

.service-form label.valid:before {
	content: '\f00c';
	color: #41a841;
}

.service-form label.invalid:before {
	content: '\f00d';
	color: #e31e26;
}

.service-form label.valid input {
	border-color: #41a841;
}

.service-form label.invalid input {
	border-color: #e31e26;
}

#calendar-container.service-calendar {
	width: 100%;
}

.pickup-info {
  margin-top:10px;
  text-align: center;
}

#calendar {
	width: 100%;
	margin: -20px 0 0 0;
}

#calendar tbody {
	border: solid 1px #bbb;
}

#calendar thead tr.month td {
	padding: 10px 0;
}

#calendar thead tr.days {
	border: solid 1px #bbb;
	background: #efefef;
}

#calendar thead tr.days td {
	padding: 8px 0;
}

#calendar .switch.right,
#calendar .switch.left {
	background: none;
}

#calendar .switch.right:after {
	content: '\f0da';
	font-family: 'FontAwesome';
	margin-right: 10px;
	font-size: 20px;
}

#calendar .switch.left:after {
	content: '\f0d9';
	font-family: 'FontAwesome';
	margin-left: 10px;
	font-size: 20px;
}

#calendar tbody td a {
  color: #505050;
}

#calendar .switch.right:hover:after,
#calendar .switch.left:hover:after {
	color: #e31e26;
}

#calendar tbody td a:hover {
  border-top: solid 1px #ddd;
  background-color: #ddd;
  text-shadow: none;
  color: #505050;
}

#calendar tbody td.empty a:hover {
	color: #bbb;
}

#calendar tbody td.active a:hover {
  border-top: solid 1px #e31e26;
  background-color: #e31e26;
  color: #fff;
  text-shadow: none;
}

.text-block {
	margin: 60px 0;
}

.text-block:last-child {
	margin-bottom: 0;
}

.service-package__container {
	margin: 40px 0;
  display: inline-block;
}


.service-package:first-child,
.service-package:last-child {
	margin-top: 42px;
	box-shadow: none;
}


.service-package__featured {
  margin: 0 15px;
  box-shadow: 0 0 30px #bbb;
}

.service-package {
	width: 270px;	
	text-align: center;
	float: left;
}

.service-package a {
	color: #505050;
	text-decoration: underline;
}

.service-package td {
	margin:0;
	padding: 15px;
}

.service-package thead tr {
	background: #2b2e32;
	color: white;

}

.service-package thead td {
	padding: 0;
}

.service-package thead tr:first-child td {
  border-top-left-radius: 2px;
  border-top-right-radius: 2px;
}

.service-package thead tr:first-child td {
	padding-top: 15px;
}

.service-package thead tr:last-child td {
	padding-bottom: 15px;
}

.service-package tbody tr {
	background: #eee;
}

.service-package tbody td {
	border-top: dashed 1px #ddd;
	font-size: 12px;
}

td.service-package__info {
  padding: 10px 20px;
}

.service-package__info p {
  font-size: 14px;
  line-height: 1.75em;
  margin: 10px 0;
}

.service-package tbody tr:first-child td {
	border-top: none;
}

.service-package tfoot td {
	padding: 0;
}

a.service-package__button {
	display: block;
	width: 100%;
	background-color: #2b2e32;
	color: white;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
  border-bottom-left-radius: 2px;
  border-bottom-right-radius: 2px;
	padding: 15px;
	box-sizing: border-box;
	letter-spacing: 2px;
	transition: background-color 0.2s ease-out;
}

a.service-package__button:hover {
	background-color: #e31e26;
}

a.service-package__button i {
	margin-right: 5px;
}

.service-package__name {
	text-transform: uppercase;
	font-size: 14px;
	letter-spacing: 4px;
	color: #ddd;
}

.service-package__price {
	font-size: 70px;
	vertical-align: top;
}

.service-package thead td.service-package__price {
	padding: 20px 0;  
}

.service-package__price sup {
	font-size: 25px;	
	margin-right: 5px;
}

.service-package__additional {
	font-size: 10px;
	font-style: italic;
}

.service-kohl-info,
.service-securitycheck-info {
	text-align: center;
	margin: 20px 0;
}

.service-securitycheck-info a {
  color: #505050;
  text-decoration: underline;
}

.service-features {
	width: 100%;
}

.service-features td {
	width: 33%;
	text-align: center;
	padding: 15px 10px;
	vertical-align: top;
}

.service-features td i {
	font-size: 25px;
	height: 55px;
	width: 55px;
	text-align: center;
	line-height: 55px;
	margin-bottom: 10px;
	border: solid 2px #505050;
	border-radius: 2px;
}

.service-features td p {
	margin: 0;
}

.feedback-bubble {
	position: relative;
	background: white;
	text-align: center;
	padding: 20px;
	height: 100px;
	line-height: 100px;
	border-radius: 2px;
	font-style: italic;
	margin: 0 5px;
}

.feedback-bubble:after {
  content: '';
  position: absolute;
  left: 50%;
  top: 100%;
  width: 0;
  height: 0;
  margin-left: -10px;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid white;
}

.feedback-bubble span {
  display: inline-block;
  vertical-align: middle;
  line-height: 1.5em;
}

.feedback-name {
	width: 100%;
	text-align: center;
	margin-top: 25px;
}

.feedback-image img {
	width: 50px;
	height: 50px;
	border-radius: 100px;
	/*border: solid 2px #505050;*/
}

.service-faqs li {
	position: relative;
	padding: 10px;
	margin-left: 30px;
}

.service-faqs__trigger:before {  
	position: absolute;  
	font-family: 'FontAwesome';
	content: '\f067';
	font-size: 20px;
	text-align: center;
	line-height: 20px;
	width: 30px;
	left: -30px;
	vertical-align: middle;
}

.service-faqs li.open .service-faqs__trigger:before {  
	content: '\f068';
}

.service-faqs li a {
	color: #505050;
	text-decoration: underline;
}

.service-faqs__faq {
	margin: 10px 0;
	display: none;
}

.service-faqs__faq p {
  margin-bottom: 0;
}

.service-faqs li.open .service-faqs__faq {
  display: block;
}

.service-row {
	margin: 60px 0;
}

.service-row--first {
	margin-top: -30px;
}

.service-row--last {
	margin-bottom: 0;
}

.service-row--feedback {
	background: #eee;
	padding: 50px 0;
}

.service-list {
	list-style-type: disc;
	list-style-position: inside;
	margin-bottom: 20px;
}

.service-special {
	text-align: center;
	padding-bottom: 16px;
	width:100%;
	border-radius: 4px;
	padding: 15px 10px;
	border: solid 1px #ddd;
	margin-bottom: 30px;
	box-sizing: border-box;
}

.service-special:last-child {
	margin-bottom: 0;
}

.service-special p {
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: solid 1px #ddd;
}

.service-special i {
	display: block;	
	font-size: 30px;
	margin: 0 0 10px 0;
}

.service-price {
	font-size:50px;
	line-height: 50px;
	margin: 10px 0 20px 0;
}

.service-price .kr {
  display: none;
}

.service-price--special {
	display: none;
}

.service-price sup {
	font-size: 25px;
	margin-right: 5px;
}

.service-success {
	display: none;
}

.service-success h3 {
	color: #41a841;
}

.shop-info {
	margin-top: 30px;
	border-top: solid 1px #eee;
}
	
.shop-info td {
	vertical-align: top;
	width: 50%;
	padding: 20px 10px 10px 0;
}

.shop-info td p {
	margin-bottom: 10px;
}

.shop-info i {
	margin-right: 5px;
}

.extra {
  position: relative;
	width: 100%;
	border: solid 1px #bbb;
	border-radius: 2px;
	box-sizing: border-box;
	margin-bottom: 20px;
	cursor: pointer;
  -webkit-user-select: none;  /* Chrome all / Safari all */
  -moz-user-select: none;     /* Firefox all */
  -ms-user-select: none;      /* IE 10+ */
  user-select: none;          /* Likely future */  
}

.extra__content {
	overflow: hidden;
	padding: 20px;
	min-height: 80px;
}

.extra__check {
  width: 5%;
	float: left;
}
.extra__image {
	width: 20%;
	float: left;
	margin-right: 4%;
}

.extra__image img {
	width: 100%;
}

.extra__primary {
	width: 76%;
	float: left;
	margin-right: 4%;
}

.extra__secondary {
	width: 20%;
	float: left;
	text-align: right;
}

.extra__name {
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 10px;
}

.extra__description {
	margin-bottom: 0;
}

.extra__description ul {
  list-style-type: disc;
  margin-left: 1.2em;
}

.extra__price {
	font-weight: bold;
	margin-bottom: 0;
	font-size: 16px;
}

.extra__price-old {
	text-decoration: line-through;
}

.extra__choose {
  position: absolute;
  bottom: 0;
  right: 0;
	background: #eee;
	padding: 10px;
	text-align: center;
	box-sizing: border-box;
  border-top-left-radius: 2px;
	border-top: solid 1px #bbb;
	border-left: solid 1px #bbb;
	text-decoration: underline;
}

.extra__choose input[type=checkbox] {
  width: auto;
  margin-right: 7px;
}

.extra__choose i {
	margin-right: 5px;
}

.extra .checked {
	display: none;
}

.extra.buy .notchecked {
	display: none;
}

.extra.buy .checked {
	display: inline;
}

.extra.buy .extra__choose {
  background: #41a841;
  color: white;
  border-color: #41a841;
	text-decoration: none;
}

.extra.buy {
  border-color: #41a841;
  box-shadow: 0 0 1px #41a841;
}

.bike-type {
	width:100%;
	margin-bottom: 20px;
}

.bike-type td {
	width: 33%;
	padding: 0 0 10px 0;
}

.accordion {
	border: solid 1px #ddd;
	border-radius: 4px;
	overflow: hidden;
	box-shadow: 0 0 20px #efefef;
}

.accordion__section {
}

.accordion__section:hover h3 {
	background-color: #eee;
}

.accordion__section.inactive:hover h3 {
  background-color: inherit;
}

.accordion__section.inactive h3 {
  cursor: default;
}

.accordion__section.inactive h3:after {
  content: '';
}

.accordion__section h3 {
	position: relative;
	font-size: 16px;
	font-weight: normal;
	padding: 5px 10px;
	background: white;
	margin: 0;
	cursor: pointer;
	border-top: solid 1px #ddd;
  -webkit-user-select: none;  /* Chrome all / Safari all */
  -moz-user-select: none;     /* Firefox all */
  -ms-user-select: none;      /* IE 10+ */
  user-select: none;          /* Likely future */  
}

.accordion__section h3 i {
	width: 20px;
	text-align: center;
	margin-right: 5px;
}

.accordion__section:first-child h3 {
	border-top: none;
}

.accordion__section h3:after {
	font-family: 'FontAwesome';
	position: absolute;
	right:10px;
}

/*.accordion__section h3:after {
	content: ''; 
}

.accordion__section.open h3:after {
	content: '';
}*/

.accordion__section.valid h3:after {
	content: '\f00c';
}

.accordion__section.open h3{
	background: #2b2e32;
	color: white;
	cursor: default;
}

.accordion__section.open .accordion__details {
	display: block;
}

.accordion__details {
	display: none;
	padding: 40px;

}

/**** MODAL ****/

.modal-service {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  box-sizing: border-box;
  background: rgba(0,0,0,0.7);
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
  min-width: 600px;
  display: none;
  z-index: 1000;
}
.table-service {
  max-width: 1200px;
  margin: 0 auto;
  background: white;
  box-shadow: 0 0 20px black;
}
.table-service td {
  vertical-align: top;
}
.table-service thead td {
  background-color: #2b2e32;
  color: white;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-weight: normal;
  font-size: 16px;
  border-right: solid 1px #222;
  padding: 20px;
}
.table-service tbody {
  font-size: 12px;
}      
.table-service tbody td {
  padding: 20px;
  border-bottom: solid 2px #2b2e32;
  border-right: solid 1px #eee;
}
.table-service tbody td:first-child {
  font-weight: bold;
  font-size: 18px;
  vertical-align: top;
  text-align: left;
}
.table-service td:last-child {
  border-right: none;
}
.table-service ul {
  padding: 0;
  margin: 0;
}
.table-service ul li {
  padding: 10px;
  border-radius: 2px;
  margin-bottom: 10px;
  background: #eee;
  text-align: center;
  line-height: 1.5em;
}
.table-service ul li:last-child {
  margin-bottom: 0;
}
.table-service p {
  margin: 0;
}
.table-service .expanded-service {
  text-align: center;
  font-weight: bold;
  font-size: 14px;
}
.table-service .expanded-service__icon {
  background: none;
  padding: 5px 0;
}
.table-service .expanded-service__icon i {
  font-size: 2em;
  line-height: 1em;
}
.table-service tfoot td {
  padding: 20px;
  border-right: solid 1px #eee;
}
.table-service .service-package__button {
  text-align: center;
}
.table-service .close-modal {
  display: block;
  color: #e31e26;
  text-align: left;
  font-size: 14px;
  text-decoration: underline;
  text-transform: none;
  letter-spacing: normal;
}
.table-service .close-modal i {
  margin: 0 5px 0 0;
}