#widget-area *,
#widget-area *:before, 
#widget-area *:after,
body.widget {
/*	border: 0;*/
/*	box-sizing: border-box;*/
	font-family: 'primary-font', Arial, Helvetica, sans-serif;
	font-size: 14px;
/*	margin: 0;*/
/*	padding: 0;*/
}

/** /
* {
	outline: 1px dotted rgba( 0, 0, 0, .2 );
}
/**/

#widget-area {
	font-size: 14px;
	line-height: 21px;
}

/*
#widget-area * {
	background-color: var(--background-color);
	color: var(--text-color);
	font: 14px/18px 'primary-font', Arial, Helvetica, sans-serif;
}
*/

.superbar {
	margin-bottom: 25px;
}

.superbar label {
	font-weight: bold;
}

#overlink-area h1,
#widget-area h1 {
	color: var(--text-color);
	font: bold 18px/22px 'primary-font', Arial, Helvetica, sans-serif;
	text-transform: uppercase;
}

#overlink-area h2,
#widget-area h2 {
	color: var(--text-color);
	font: bold 20px/24px 'primary-font', Arial, Helvetica, sans-serif;
	margin-bottom: 25px;
}

#overlink-area h3,
#widget-area h3 {
	margin-bottom: 10px;
	padding-top: 10px;
}

#overlink-area ul,
#widget-area ul {
	list-style: none inside;
}

#overlink-area p,
#widget-area p {
	margin-bottom: 20px;
}

#overlink-area a.btn,
#overlink-area button,
#widget-area a.btn,
#widget-area button {
	background-color: var(--spot-color);
	color: var(--spot-text-color);
	cursor: pointer;
	display: inline-block;
	font: bold 12px/18px 'primary-font', Arial, Helvetica, sans-serif;
	margin-bottom: 20px;
	padding: 5px 20px;
	text-align: center;
}

#overlink-area .segment a.btn,
#overlink-area .segment button,
#widget-area .segment a.btn,
#widget-area .segment button {
	width: 100%;
}

#overlink-area a.btn.secondary,
#overlink-area button.secondary,
#widget-area a.btn.secondary,
#widget-area button.secondary {
	background-color: var(--secondary-color);
}

#overlink-area a,
#widget-area a {
	color: var(--text-color);
	text-decoration: none;
}

#overlink-area a:not([class]):hover,
#overlink-area a[class=""]:hover,
#widget-area a:not([class]):hover,
#widget-area a[class=""]:hover {
	text-decoration: underline;
}

body.thankyou header {
	background-color: var(--spot-color);
	padding: 30px 10px 45px;
}

body.thankyou main .content-wrapper {
	max-width: 210px;
	padding: 20px 0;
	text-align: center;
}


#overlink-area #logo,
#widget-area #logo {
	background-image: var(--logo);
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	height: 100px;
	width: 160px;
}

#widget-area #info {
	padding-top: 20px;
	text-align: right;
}

#widget-area #info .date {
	margin-left: 20px;
}

#widget-area .topbar {
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
	text-align: center;
}

#overlink-area .content-wrapper,
#widget-area .content-wrapper {
	margin: 0 auto;
	max-width: 930px;
	position: relative;
}

#overlink-area fieldset,
#widget-area fieldset {
	margin: 0 auto;
}

#widget-area input[type="email"],
#widget-area input[type="password"],
#widget-area input[type="date"],
#widget-area input[type="text"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;

	border: 1px solid var(--line-color);
	border-radius: 0;
	display: inline-block;
	font: 14px/18px 'primary-font', Arial, Helvetica, sans-serif;
	margin-bottom: 10px;
	padding: 5px;
}

#widget-area input[type="submit"],
#widget-area button[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;

	background-color: var(--spot-color);
	border: 0;
	color: var(--spot-text-color);
	cursor: pointer;
	display: inline-block;
	font: bold 12px/18px 'primary-font', Arial, Helvetica, sans-serif;
	margin-bottom: 10px;
	padding: 5px 20px;
}

#widget-area input[disabled] {
	border-color: transparent !important;
	display: inline-block;
	padding: 5px 20px 5px 0;
/*	width: auto !important;*/
}

#widget-area textarea {
	border: 1px solid var(--line-color);
	display: block;
	font: 14px/18px 'primary-font', Arial, Helvetica, sans-serif;
	height: 200px;
	margin-bottom: 10px;
	padding: 5px;
	width: 100%;
}

#widget-area button[type="submit"]:hover {
	background-color: #333;
	color: var(--spot-color);
}

#widget-area .btn {
	background-color: #ccc;
	color: #333;
	display: inline-block;
	font-weight: bold;
	margin-bottom: 20px;
	text-decoration: none;
	padding: 5px 20px;
}

#widget-area .btn.hilite {
	background-color: var(--spot-color);
	color: var(--spot-text-color);
}

#widget-area .btn:hover {
	background-color: #333;
	color: var(--background-color);
}

#date-filter,
#table-filter {
	border-bottom: 1px solid var(--line-color);
	color: var(--text-color);
	display: flex;
}

#date-filter > span,
#table-filter > span {
	background-color: var(--secondary-color);
	display: inline-block;
	height: 30px;
	line-height: 30px;
	padding: 0 25px;
}

#table-filter > span {
	cursor: pointer;
}

#date-filter > span {
	background-color: transparent;
	color: var(--hilite-color);
	line-height: 30px;
}

#date-filter > span a {
	color: var(--hilite-color);
}

#table-filter > span.selected {
/*	border-color: rgba( 0, 0, 0, .25 );*/
	font-weight: bold;
}

#table-filter > span.pending {
	background-color: var(--pending-color);
}

#table-filter > span.done {
	background-color: var(--done-color);
}

.table-wrapper {
	max-height: calc( 100vh - 369px );
	overflow-y: scroll;
	position: relative;
}

table {
	
}

#widget-area table thead {
	outline: 1px solid var(--line-color);
	position: -webkit-sticky;
	position: sticky;
	top: 0;
}

#widget-area table tbody {
	margin-left: -1;
}

#widget-area table tr th {
	background-color: var(--background-color);
	color: var(--text-color);
	text-align: center;
}

#widget-area table tr.state td {
	border-top: 1px solid var(--line-color);
}

#widget-area tr.state > td:last-of-type {
	border-right: 1px solid var(--line-color);
}

#widget-area tr.state:last-of-type > td {
	border-bottom: 1px solid var(--line-color);
}

#widget-area tr.state > td:first-of-type {
	width: 10px;
}

#widget-area tr.state.done > td:first-of-type {
	background-color: var(--done-color);
}

#widget-area tr.state.pending > td:first-of-type {
	background-color: var(--pending-color);
}

#widget-area table.pending tr.done,
#widget-area table.done tr.pending {
	display: none;
}

#widget-area span.label {
	display: inline-block;
/*	width: 30%;*/
}

.boxed.state {
	color: var(--background-color);
	display: inline-block;
	font-weight: bold;
	padding: 5px 20px;
	width: 100%;
}

.boxed.state.done {
	background-color: #090;
}

.boxed.state.pending {
	background-color: #900;
}


/* BEGIN SLOTS */

#slots {
	border-collapse: collapse;
}

#slots td {
	height: 30px;
/*	display: inline-block;*/
	position: relative;
	width: 30px;
}

#slots input {
	display: none;
}

#slots label {
	cursor: pointer;
}

#slots label span {
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 2;
}

#slots label.off input:checked ~ span {
	background-color: var(--background-color);
	z-index: 1;
}

#slots label.on input:checked ~ span {
	background-color: var(--spot-color);
	z-index: 1;
}

/* END SLOTS */

/* BEGIN EXCLUSIONS */

.past {
	color: #ccc;
}

.today {
	outline: 1px solid var(--hilite-color);
}

#exclusions {
	border-collapse: collapse;
}

#exclusions td span {
	cursor: pointer;
	display: inline-block;
	padding: 2px 5px;
}

#exclusions input {
	display: none;
}

#exclusions label input:checked ~ span {
	background-color: var(--blocked-color);
}
/* END EXCLUSIONS */

#slot_selection {
	min-height: 37px;
}

#cal,
#calendar_widget {
/*	width: 212px;*/
	width: 211px;
}

#cal {
	background-color: var(--background-color);
	position: absolute;
	z-index: 100;
}

.calendar-header {
	
}

.calendar-header {
	font-weight: bold;
	margin: 10px auto 10px;
	position: relative;
	text-align: center;
	text-transform: uppercase;
	width: 170px;
}

.calendar-header a {
	display: inline-block;
	height: 12px;
	position: absolute;
	top: 2px;
	width: 12px;
}

.calendar-header a:first-of-type {
	left: 0;
}
.calendar-header a:last-of-type {
	right: 0;
}

#consultant-calendar-wrapper {
	border: 1x solid var(--line-color);
}

.calendar-wrapper {
	margin-bottom: 20px;
}

.calendar-container {
	border: 1px solid var(--line-color);
	margin-bottom: 10px;
}

#consultant-calendar {
	border-collapse: collapse;
}

#consultant-calendar tr td span {
	background-color: var(--secondary-color);
}

#consultant-calendar tr td span.slot {
	background-color: var(--spot-color);
	color: var(--spot-text-color);
}

#consultant-calendar tr td span.done {
	background-color: var(--done-color);
	color: var(--text-color);
	cursor: pointer;
}

#consultant-calendar tr td span.pending {
	background-color: var(--pending-color);
	color: var(--text-color);
	cursor: pointer;
}

#consultant-calendar tr td span.pending.done {
	background: linear-gradient(135deg, var(--done-color) 50%, var(--pending-color) 50%);
}

table.calendar {
	border-collapse: collapse;
}

table.calendar thead tr th {
	background-color: transparent;
}

table.calendar tbody tr th,
table.calendar tr td {
	border: 1px solid var(--line-color) !important;
}

table.calendar tr td {
	background-color: var(--background-color);
	padding: 0 !important;
}

table#slots tr th {
	width: 60px;
}

table.calendar tr td span {
	color: var(--text-color);
}

table.calendar tbody tr th,
table.calendar tr td:first-of-type {
	border-left: 0 !important;
}

table.calendar tr td:last-of-type {
	border-right: 0 !important;
}

table.calendar tbody tr:last-of-type th,
table.calendar tr:last-of-type td {
	border-bottom: 0 !important;
}

.cal-nav img,
.calendar-nav img {
	height: 12px;
}

#calendar-legend {
	margin: 10px 0 20px;
}

.legend {
	display: flex;
	flex-wrap: wrap;
}

.legend > span {
	margin: 0 0 10px 0;
	width: 50%;
}

.legend > span > span {
	background-color: var(--secondary-color);
	display: inline-block;
	height: 30px;
	margin-right: 5px;
	vertical-align: middle;
	width: 30px;
}

.legend > span.done		> span { background-color: var(--done-color); }
.legend > span.pending > span { background-color: var(--pending-color); }
.legend > span.slot		> span { background-color: var(--spot-color); color: var(--spot-text-color); }

.validation-error {
	color: var(--hilite-color);
}

.underline {
	border-bottom: 1px solid var(--line-color);
	padding-bottom: 10px;
}

.hidden {
	display: none !important;
}

.loading {
	position: relative;
}

.loading:after {
	background-color: rgba( 255, 255, 255, .75 );
	bottom: 0;
	content: '';
	display: block;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 0;
}

#main-form {
	margin-top: 0;
}

@media ( max-width: 459px ) {
	#main-form {
		margin-top: 20px;
	}
}

#overlink-area,
#widget-area .content-wrapper {
/*	margin: 0 auto;*/
	background-color: var(--background-color);
	margin: 10px;
	max-width: 440px;
}

#overlink-area {
	padding: 20px;
	max-width: 480px;
}

@media ( max-width: 439px ) {
	#overlink-area,
	#widget-area .content-wrapper {
		max-width: 210px;
	}
}

#overlink-area input[type="text"],
#widget-area .content-wrapper input[type="email"],
#widget-area .content-wrapper input[type="text"] {
	width: 100%;
}

#overlink-area input.one-third,
#widget-area .content-wrapper input.one-third {
	width: calc( 33% - 5px );
}

#overlink-area input.two-third,
#widget-area .content-wrapper input.two-third {
	width: calc( 66% - 5px );
}

label.date {
	display: block;
	position: relative;
}

label.date > span.label {
	display: block;
	height: 20px;
	width: 100%;
}

#date-selector-icon {
	background: var(--background-color) url(../img/icon-calendar.svg) no-repeat center center;
	background-size: cover;
	cursor: pointer;
	height: 28px;
	position: absolute;
	right: 1px;
/*	top: 22px;*/
	width: 28px;
}

label.checkbox {
	display: block;
	margin-bottom: 20px;
	padding-left: 24px;
	position: relative;
}

label.checkbox input[type="checkbox"] {
	left: 0;
	position: absolute;
	top: 3px;
  max-width: 24px;
}

#calendar_widget td span.past,
#cal td span.past {
	background-color: #efefef;
}

#overlink-area select,
#widget-area select {
	background: var(--background-color) url(../img/pfeil-unten.svg) no-repeat right center;
	background-size: 12px auto;
	border: 1px solid var(--line-color);
	border-radius: 0;
	font: 14px/18px 'primary-font', Arial, Helvetica, sans-serif;
	margin: 2.5px 0 10px;
	padding: 2px 5px;
	position: relative;
	-webkit-appearance: none;
	width: 50%;
}

#overlink-area select[disabled],
#widget-area select[disabled] {
	border: 1px solid #efefef;
}

#widget-area .row {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-left: 0;
	margin-right: 0;
	padding: 0 !important;
}

.hide {
	display: none !important;
}

#curres1,
#curbitrate1 {
	background-color: rgba( 255, 255, 255, .5 );
	border-radius: 2px;
	padding: 2px 4px;
	width: auto;
}

.widget-colgrp {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.widget-col {
	width: 210px;
}

.widget-col * {
	box-sizing: border-box !important;
}

#appointment-wrapper {
	opacity: 0;
}

body.change_appointment header {
  background-color: var(--spot-color);
  padding: 0 20px;
}

body.change_appointment main .content-wrapper {
  margin: 20px auto;
  width: 210px;
}

#miel {
  display: none !important;
}

