/* ==========================================================================
  START: Fonts
========================================================================== */

@font-face {
  font-family: 'Das Handwerk Grunge';
  src: url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerkGrunge-Bold.eot');
  src: url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerkGrunge-Bold.eot?#iefix') format('embedded-opentype'),
    url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerkGrunge-Bold.woff') format('woff'),
    url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerkGrunge-Bold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'Das Handwerk';
  src: url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerk-Bold.eot');
  src: url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerk-Bold.eot?#iefix') format('embedded-opentype'),
    url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerk-Bold.woff') format('woff'),
    url('https://customers-ssl.airlst.com/meisterfeier/fonts/DasHandwerk-Bold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
}

/* ==========================================================================
  START: Base
========================================================================== */

html,
body {
  font-family: 'Das Handwerk Grunge', sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.563em;
  vertical-align: baseline;
  color: #fff;

  min-height: 100%;
  font-stretch: 100%;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-touch-callout: none;
  -webkit-font-smoothing: antialiased;

  background-color: #B4BD00;
}

p {
  margin: 0 0 15px;
}

strong {
  font-weight: 600;
}

a {
  color: #3498db;
  text-decoration: none;
  transition: all 0.25s ease-in-out;
}

a:hover,
a:active,
a:focus,
a:active:focus {
  color: #3498db;
  text-decoration: underline;
  box-shadow: none;
}

a:focus {
  outline: none;
  outline-offset: -2px;
  text-decoration: none;
  box-shadow: 0 3px 0 0 rgba(102, 175, 233, 0.25);
}

hr {
  border-top: 3px solid #fff;
}

/* ==========================================================================
  START: Headings
========================================================================== */

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Das Handwerk', serif;
  margin-top: 0;
  line-height: 1.528em;
}

/* ==========================================================================
  START: Layout
========================================================================== */

/* ==========================================================================
  START: Form Elements
========================================================================== */

label {
  display: inline-block;
  max-width: 100%;
  margin-bottom: 5px;
  font-weight: inherit;
  font-size: 14px;
}

.form-control {
  display: block;
  width: 100%;
  height: 54px;

  padding: 8px 12px;

  font-size: 24px;
  line-height: 1.42857143;
  color: #555555;

  background-color: #fff;
  background-image: none;
  border: 2px solid #fff;
  border-radius: 0;

  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-transition: all ease-in-out .15s;
  -o-transition: all ease-in-out .15s;
  transition: all ease-in-out .15s;
}

input:focus::-webkit-input-placeholder { color:transparent; }
input:focus:-moz-placeholder { color:transparent; } 
input:focus::-moz-placeholder { color:transparent; } 
input:focus:-ms-input-placeholder { color:transparent; }


/* START: Select (Dropdown)
========================================================================== */

select {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background-image: url('https://customers-ssl.airlst.com/meisterfeier/images/arrow.png') !important;
  background-position: calc(100% - 10px) 50%;
  background-repeat: no-repeat;
  background-size: 12px 6px;
}

select::-ms-expand {
  display: none;
}


/* START: Radio buttons
========================================================================== */

input[type=radio] {
  opacity: 0;
}

input[type=radio].radioButton+label {
  padding-top: 10px;
  padding-left: 40px;
  margin-top: -25px;
}

input[type=radio].radioButton+label:before {
  content: "";
  width: 20px;
  height: 20px;
  position: absolute;
  background-color: #ffffff;
  border: 2px solid #cccccc;
  border-radius: 50%;
  top: 9px;
  left: 2px;
  /* fix for IE10 */
  left: 3px \9;
}

input[type=radio].radioButton+label:after {
  cursor: pointer;
  position: absolute;
  content: "";
  width: 8px;
  height: 8px;
  background-color: transparent;
  top: 15px;
  left: 8px;
  border-radius: 50%;
  transition: all 0.25s ease-in-out;
}

/* input[type=radio].radioButton:checked+label:before {
    border: 2px solid #333333;
} */

input[type=radio].radioButton:checked+label:after {
  background-color: #333333;
}

.radio-inline {
  display: inline-block;
  position: relative;
  margin-left: -18px;
  margin-bottom: 0;
  padding-right: 10px;
  vertical-align: middle;
}


/* START: Checkboxes
========================================================================== */

input[type=checkbox] {
  opacity: 0;
}

input[type=checkbox].checkbox-1+label {
  padding-left: 40px;
  margin-top: -10px;
}

input[type=checkbox].checkbox-1+label:before {
  content: "";
  width: 20px;
  height: 20px;
  position: absolute;
  background-color: #fff;
  border: 2px solid #fff;
  border-radius: 0;
  top: 0;
  left: 0;
}

input[type=checkbox].checkbox-1+label:after {
  cursor: pointer;
  position: absolute;
  content: "✔";
  font-size: 14px;
  line-height: 1.42857143;
  color: transparent;
  top: 0px;
  left: 4px;
  transition: all 0.25s ease-in-out;
}

input[type=checkbox].checkbox-1:checked+label:after {
  color: #333333;
}

.checkbox-inline {
  display: inline-block;
  left: -20px;
  top: 10px;
}

/* ==========================================================================
  START: Buttons
========================================================================== */

.btn {
  display: inline-block;

  font-size: 24px;
  font-weight: normal;
  line-height: 1.42857143;
  text-align: center;
  vertical-align: middle;

  padding: 8px 12px;
  /* margin: 10px 0 30px; */

  border-radius: 0;
  border: 2px solid transparent;

  white-space: nowrap;
  background-image: none;
  cursor: pointer;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  transition: all 0.25s ease-in-out;
  /* fix */
  text-transform: uppercase;
}

.btn:active {
  outline: 0;
  background-image: none;
  -webkit-box-shadow: none;
  box-shadow: none;
}

/* START: Default button
========================================================================== */

.btn-default {
  color: #fff;
  background-color: #B4BD00;
  border-color: #fff;
}

.btn-default:active,
.btn-default:hover,
.btn-default:active:hover {
  color: #B4BD00;
  background-color: #fff;
  border-color: #fff;
}


/* START: Primary button
========================================================================== */

.btn-primary {
  color: #B4BD00;
  background-color: #fff;
  border-color: #fff;
}

.btn-primary:active,
.btn-primary:hover,
.btn-primary:active:hover {
  color: #fff;
  background-color: #DC004F;
  border-color: #DC004F;
}

/* ==========================================================================
  START: Paddings and Margins
========================================================================== */

.mt0 { margin-top: 0; }
.mt30 { margin-top: 30px; }

.mb0 { margin-bottom: 0; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb50 { margin-bottom: 50px; }

/* ==========================================================================
  START: Focus
========================================================================== */

.form-control.focus,
.form-control:focus {
  border-color: #DC004F;
  outline: 0;
  -webkit-box-shadow: 0 0 0 3px hsla(338, 100%, 33%, 0.75);
  box-shadow: 0 0 0 3px hsla(338, 100%, 33%, 0.75);
}

input[type=radio].radioButton.focus+label:before,
input[type=checkbox].checkbox-1.focus+label:before,
input[type=radio].radioButton:focus+label:before,
input[type=checkbox].checkbox-1:focus+label:before {
  outline: 0;
  border: 2px solid #DC004F;
  box-shadow: 0 0 0 3px hsla(338, 100%, 33%, 0.75);
}

.btn:focus,
.btn:active:focus {
  outline: 0;
  border: 2px solid #DC004F;
  box-shadow: 0 0 0 3px hsla(338, 100%, 33%, 0.75);
}

.btn-default:focus,
.btn-default:active:focus {
  color: #333333;
  background-color: #fafafa;
  border-color: rgb(173, 173, 173);
  box-shadow: 0 0 0 3px rgba(173, 173, 173, 0.25);
}

.btn-primary:focus,
.btn-primary:active:focus {
  color: #fff;
  background-color: #DC004F;
  border-color: #DC004F;
  box-shadow: 0 0 0 3px hsla(338, 100%, 33%, 0.75);
}

/* ==========================================================================
  START: Validation
========================================================================== */

form.ng-submitted input.ng-invalid,
form.ng-submitted select.ng-invalid {
  border-color: rgba(231, 76, 60, 0.75);
  background-color: rgba(231, 76, 60, 0.15);
}

form.ng-submitted input.ng-invalid::placeholder {
  color: rgba(231, 76, 60, 0.75);
}

form.ng-submitted select.ng-invalid {
  background-image: url('https://customers-ssl.airlst.com/meisterfeier/images/error_arrow.png') !important;
}

form.ng-submitted input[type="radio"].radioButton.ng-invalid+label:before,
form.ng-submitted input[type="checkbox"].checkbox-1.ng-invalid+label:before {
  border-color: rgba(231, 76, 60, 0.75);
  background: rgba(231, 76, 60, 0.15);
}


/* ==========================================================================
  START: Sweet Alert
========================================================================== */

.sweet-alert {
  border-radius: 0px;
}

.sweet-alert button {
  background-color: #3498db !important;
  color: #ffffff;
  padding: 6px 12px;
  font-size: 18px;
  line-height: 1.42857143;
  font-weight: bold;
  border-radius: 4px;
}

.sweet-alert button:hover {
  color: #ffffff;
  background-color: #2980b9;
  transition: all 0.25s ease-in-out;
}


/* ==========================================================================
  START: Media queries
========================================================================== */

/* From 768px to 991px
========================================================================== */

@media (min-width: 768px) {

  .mt0-sm { margin-top: 0; }

  .text-right-sm { text-align: right; }

}


/* From 992px to 1199px
========================================================================== */

@media (min-width: 992px) {}


/* From 1200px and Up
========================================================================== */

@media (min-width: 1200px) {}