/* base css */
:root {
  font-size: 10px;
}

html, body {
  height: 100%;
}

body {
  color: #222222;
  font-size: 10px;
  line-height: 1.6;
  position: relative;
  font-family: karlaregular, sans-serif;
  background: #fff;
}

b, strong {
  font-family: karlabold, sans-serif;
  font-weight: normal;
}

a,
button,
p,
span,
li {
  font-size: 1.6rem;
  letter-spacing: 0.05rem;
}

p a,
p span,
a i,
a span,
li span,
li a {
  font-size: 1em;
}

a {
  color: #ed353a;
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
}

a:hover,
a:active,
a:focus {
  color: inherit;
  text-decoration: none;
  outline: none;
}

p {
  margin-bottom: 2rem;
  letter-spacing: 0.05rem;
}

p:last-of-type,
p:last-child {
  margin-bottom: 0;
}

hr {
  margin: 5rem 0;
  border: 0;
  border-top: 1px solid #e8e7e7;
}

/* lists */
ul {
  margin: 0 0 3rem;
  padding: 0 0 0 1.7rem;
}

/* images */
.img-fluid {
  border-radius: 0.3rem;
}

/* emoji */
.emoji {
  font-size: 2rem;
  display: inline-block;
  line-height: 1;
}

/* table */
table td,
.table td {
  padding: 1rem 2rem;
}

table ul,
.table ul {
  margin-top: 1.5rem;
}

/* headings */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  margin-bottom: 2rem;
  line-height: 1.4;
  font-weight: normal;
  font-family: poppinsmedium, sans-serif;
  color: #ed353a;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a,
.h1 a, .h2 a, .h3 a, .h4 a, .h5 a, .h6 a {
  font-size: 1em;
  color: inherit;
}

h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child,
.h1:first-child, .h2:first-child, .h3:first-child, .h4:first-child, .h5:first-child, .h6:first-child {
  margin-top: 0;
}

h1, .h1 {
  font-size: 3.6rem;
}

h2, .h2 {
  font-size: 3.2rem;
}

h3, .h3 {
  font-size: 2.8rem;
}

h4, .h4 {
  font-size: 2.4rem;
}

h5, .h5 {
  font-size: 2rem;
}

h6, .h6 {
  font-size: 1.8rem;
}

/* buttons */
.btn {
  font-size: 1.6rem;
  padding: 1.3rem 2rem;
  border-radius: 0.4rem;
  letter-spacing: 0.1rem;
  transition-duration: 0.3s;
  min-width: 15rem;
  font-family: 'poppinsregular', sans-serif;
}

.btn svg,
.btn svg.svg-inline--fa {
  vertical-align: middle;
  height: 2rem;
  width: 2rem;
  position: relative;
  top: -1px;
}

/* firefox button alignment fix ------------------- */
@-moz-document url-prefix() {
  .btn svg.svg-inline--fa {
    vertical-align: top;
    top: 0;
  }
}

.desktop-text {
  display: none;
}

.btn-sm,
.btn-group-sm > .btn {
  padding: 0.8rem 2rem;
  height: 3.5rem;
}

.btn-lg,
.btn-group-lg > .btn {
  padding: 2rem 3rem;
  height: 6rem;
  min-width: 20rem;
  font-size: 1.5rem;
  letter-spacing: 0.1rem;
}

.btn-lg svg.svg-inline--fa,
.btn-group-lg > .btn svg.svg-inline--fa {
  height: 2.2rem;
  width: 2.2rem;
}

.button-group {
  margin-top: 2rem;
  margin-left: -0.8rem;
}

.button-group .btn {
  margin: 0.8rem;
}

.button-group.single-btn {
  margin-left: 0;
}

.button-group.mt5 {
  margin-top: 5rem;
}

/* with icon */
.with-icon-left svg {
  margin-right: 0.8rem;
}

.with-icon-right svg {
  margin-left: 0.8rem;
}

/* with icon hover */
.icon-hover-right svg {
  position: relative;
  left: 0;
  transition: left 0.2s ease-in-out;
}

.icon-hover-right:hover svg {
  left: 5px;
}

.icon-hover-left svg {
  position: relative;
  left: 0;
  transition: left 0.2s ease-in-out;
}

.icon-hover-left:hover svg {
  left: -5px;
}

@font-face {
  font-family: 'karlabold';
  src: url("../fonts/karla-bold-webfont.eot");
  src: url("../fonts/karla-bold-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/karla-bold-webfont.woff2") format("woff2"), url("../fonts/karla-bold-webfont.woff") format("woff"), url("../fonts/karla-bold-webfont.ttf") format("truetype"), url("../fonts/karla-bold-webfont.svg#karlabold") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'karlaregular';
  src: url("../fonts/karla-regular-webfont.eot");
  src: url("../fonts/karla-regular-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/karla-regular-webfont.woff2") format("woff2"), url("../fonts/karla-regular-webfont.woff") format("woff"), url("../fonts/karla-regular-webfont.ttf") format("truetype"), url("../fonts/karla-regular-webfont.svg#karlaregular") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'poppinslight';
  src: url("../fonts/poppins-light-webfont.eot");
  src: url("../fonts/poppins-light-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-light-webfont.woff2") format("woff2"), url("../fonts/poppins-light-webfont.woff") format("woff"), url("../fonts/poppins-light-webfont.ttf") format("truetype"), url("../fonts/poppins-light-webfont.svg#poppinslight") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'poppinsregular';
  src: url("../fonts/poppins-regular-webfont.eot");
  src: url("../fonts/poppins-regular-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-regular-webfont.woff2") format("woff2"), url("../fonts/poppins-regular-webfont.woff") format("woff"), url("../fonts/poppins-regular-webfont.ttf") format("truetype"), url("../fonts/poppins-regular-webfont.svg#poppinsregular") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'poppinsmedium';
  src: url("../fonts/poppins-medium-webfont.eot");
  src: url("../fonts/poppins-medium-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-medium-webfont.woff2") format("woff2"), url("../fonts/poppins-medium-webfont.woff") format("woff"), url("../fonts/poppins-medium-webfont.ttf") format("truetype"), url("../fonts/poppins-medium-webfont.svg#poppinsmedium") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'poppinssemibold';
  src: url("../fonts/poppins-semibold-webfont.eot");
  src: url("../fonts/poppins-semibold-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-semibold-webfont.woff2") format("woff2"), url("../fonts/poppins-semibold-webfont.woff") format("woff"), url("../fonts/poppins-semibold-webfont.ttf") format("truetype"), url("../fonts/poppins-semibold-webfont.svg#poppinssemibold") format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'poppinsbold';
  src: url("../fonts/poppins-bold-webfont.eot");
  src: url("../fonts/poppins-bold-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-bold-webfont.woff2") format("woff2"), url("../fonts/poppins-bold-webfont.woff") format("woff"), url("../fonts/poppins-bold-webfont.ttf") format("truetype"), url("../fonts/poppins-bold-webfont.svg#poppinsbold") format("svg");
  font-weight: normal;
  font-style: normal;
}

/* form css */
button[type='submit'] {
  font-family: 'poppinsmedium', sans-serif;
}

.form-group {
  margin-bottom: 2rem;
}

label {
  font-size: 1.4rem;
  letter-spacing: 0.02rem;
}

label .accent {
  font-style: normal;
  color: #ff0000;
  font-size: 1.8rem;
  font-family: 'poppinsmedium', sans-serif;
}

.form-check {
  padding-left: 2.5rem;
}

.form-check-input {
  height: 2rem;
  width: 2rem;
  margin-top: 0.2rem;
  margin-left: -2.5rem;
}

.form-check-label {
  font-size: 1.5rem;
}

.form-check-label a {
  font-size: 1em;
  white-space: nowrap;
}

.form-control {
  font-size: 1.6rem;
  height: 5rem;
  padding: 14px 18px 10px;
  border-radius: 0.4rem;
  color: #222222;
  letter-spacing: 0.05rem;
  font-family: 'poppinsregular', sans-serif;
}

.form-control::-webkit-input-placeholder {
  letter-spacing: 0.05rem;
  color: #6a767d;
  font-size: 1.5rem;
  font-family: 'poppinsregular', sans-serif;
}

.form-control::-moz-placeholder {
  letter-spacing: 0.05rem;
  color: #6a767d;
  font-size: 1.5rem;
  font-family: 'poppinsregular', sans-serif;
}

.form-control:-ms-input-placeholder {
  letter-spacing: 0.05rem;
  color: #6a767d;
  font-size: 1.5rem;
  font-family: 'poppinsregular', sans-serif;
}

.form-control:-moz-placeholder {
  letter-spacing: 0.05rem;
  color: #6a767d;
  font-size: 1.5rem;
  font-family: 'poppinsregular', sans-serif;
}

.form-control:focus {
  box-shadow: none;
  border-color: #ed353a;
  color: #222222;
}

.form-control.large {
  position: relative;
  padding: 1.5rem 2.5rem 1rem;
  height: 8rem;
  font-size: 3rem;
  line-height: 1;
  letter-spacing: 0.2rem;
}

.form-control.large::-webkit-input-placeholder {
  font-size: 1.8rem;
}

.form-control.large::-moz-placeholder {
  font-size: 1.8rem;
}

.form-control.large:-ms-input-placeholder {
  font-size: 1.8rem;
}

.form-control.large:-moz-placeholder {
  font-size: 1.8rem;
}

select.noValue {
  color: #6a767d;
  font-size: 1.5rem;
  font-family: 'poppinsregular', sans-serif;
}

select,
select.form-control {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding-right: 4rem;
  background: #ffffff url(../images/img/arrow-down.svg) right 15px top 55% no-repeat;
  background-size: 1.3rem;
}

.logo-container {
  border-radius: 0.1rem;
  background: #ffffff;
  display: inline-block;
}

.logo {
  height: 5.4rem;
  width: 7rem;
}

/* modal lighbox */
.text-modal .fancybox-content {
  border-radius: 2px;
  padding: 2rem;
}

.text-modal-infobox {
  display: none;
}

.terms-modal ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

.terms-modal ol li {
  counter-increment: step-counter;
  font-size: 1.7rem;
  margin-bottom: 2rem;
  position: relative;
  padding-left: 4rem;
}

.terms-modal ol li p {
  font-size: 1.7rem;
}

.terms-modal ol li::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0;
  font-size: 1.3rem;
  background-color: #ed353a;
  color: white;
  padding: 0.3rem;
  width: 2.5rem;
  height: 2.5rem;
  display: inline-block;
  border-radius: 100%;
  text-align: center;
}

.privacy-modal table td {
  padding: 1rem 0.5rem;
}

.privacy-modal table p {
  font-size: 1.5rem;
}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {

  /* modal lighbox */
  .text-modal .fancybox-content {
    max-width: 90rem;
    max-height: 90%;
    height: auto;
    padding: 4.5rem;
  }
  /* full page bg */
  .full-page-bg {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: -1;
  }
  .full-page-bg .overlay {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: rgba(0, 0, 0, 0.6);
  }
}















/* two column promotion template */
/*.full-page-bg{*/
/*  background: url(../images/img/full-page-bg-desktop.jpg) no-repeat 0% 10%;*/
/*  background-size: cover;*/
/*  height: 30rem;*/
/*}*/

.col2-pt-container .container{
  background-color: #fff;
  padding: 5rem 1.5rem;
  border-radius: 0.3rem;
}

.col2-pt-container .container > div{
  margin-bottom: 5rem;
}

.col2-pt-container .container > div:last-child{
  margin-bottom: 0;
}

.col2-pt-header{
  margin-bottom: 5rem;
  text-align: center;
}

.promotion-title{
  margin: 4rem 0 1rem;
  color: #201d1d;
  font-size: 26px;
  font-family: poppinssemibold, sans-serif;
}

.col2-pt-header-social .header-social{
  display: flex;
  align-items: center;
  justify-content: center;
}

.col2-pt-header-social .header-social a{
  font-size: 2.4rem;
  margin-left: 1rem;
  color: #201d1d;
}

.col2-pt-header-social .header-social a:hover{
  color: #ed353a;
}

.promotion-content img{
  margin-bottom: 3rem;
  width: 100%;
}

.col2-pt-footer{
  margin-top: 5rem;
}

.col2-pt-footer .col2-pt-footer-links{
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: center;
  row-gap: 2rem;
}

.col2-pt-footer .footer-social{
  margin-top: 4rem;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
}

.col2-pt-footer .col2-pt-footer-links a,
.col2-pt-footer .footer-social a{
  font-size: 1.4rem;
  font-family: poppinsregular, sans-serif;
  color: #201d1d;
  display: flex;
  flex-direction: row;
  align-items: center;
  font-size: 2.4rem;
  margin-right: 2rem;
}

.col2-pt-footer .col2-pt-footer-links a{
  font-size: 1.4rem;
  text-decoration: underline;
}

.col2-pt-footer .col2-pt-footer-links a:hover{
  color: #ed353a;
}

.col2-pt-footer .footer-social a:hover{
  color: #ed353a;
}

.col2-pt-form-container{
  margin-top: 5rem;
}

.col2-pt-form-header .title{
  color: #201d1d;
  font-size: 22px;
}

.col2-pt-form{
  padding: 3rem 1.5rem;
  background-color: #efefef;
  border-radius: 0.5rem;
}

.col2-pt-form button[type='submit']{
  background-color: #ed353a;
  color: #fff;
  margin-top: 4rem;
}

.col2-pt-form button[type='submit']:hover{
  background-color: #201d1d;
}

/* two column promotion template: responsive */
@media (min-width: 480px){
  
  .col2-pt-form{
    padding: 3rem;
  }
}

@media (min-width: 600px){

  .col2-pt-footer .col2-pt-footer-links{
    flex-direction: row;
    justify-content: center;
  }
  
  .col2-pt-footer .footer-social{
    margin-top: 4rem;
  }
}

@media (min-width: 992px){

  /*.full-page-bg{*/
  /*  background: url(../images/img/full-page-bg-desktop.jpg) no-repeat 50% 50%;*/
  /*  background-size: cover;*/
  /*  height: 100%;*/
  /*}*/

  .col2-promotion-template{
    padding: 10rem 0;
  }

  .col2-pt-container .container{
    padding: 5rem;
  }

  .col2-pt-header{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    text-align: left;
  }

  .promotion-title{
    margin: 0;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    max-width: 100%;
    padding: 0 3rem;
  }  
}

@media (min-width: 1200px){

  .col2-pt-form-container{
    padding-left: 3.5rem;
    margin: 0;
  }

  /*.col2-pt-footer .col2-pt-footer-links,*/
  /*.col2-pt-footer .footer-social{*/
  /*  justify-content: flex-start;*/
  /*}*/

  .col2-pt-footer .footer-social{
    margin-top: 2rem;
  }

  .col2-pt-footer{
    padding-top: 4rem;
    border-top: 0.1rem solid #ccc;
  }
}

/* hide the background image/gap on top of the page */
@media (max-width: 991px){
    .full-page-bg{
        display: none;
    }
}