﻿@font-face {
  font-family: 'SwissBoldCondensed';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BoldCondensed.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BoldCondensed.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BoldCondensed.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BoldCondensed.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BoldCondensed.woff2) format('woff2')
}

@font-face {
  font-family: 'SwissBlackCondensed';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BlackCondensed.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BlackCondensed.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BlackCondensed.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BlackCondensed.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-BlackCondensed.woff2) format('woff2')
}

@font-face {
  font-family: 'SwissRegular';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Regular.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Regular.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Regular.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Regular.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Regular.woff2) format('woff2')
}

@font-face {
  font-family: 'SwissMedium';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Medium.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Medium.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Medium.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Medium.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Medium.woff2) format('woff2')
}

@font-face {
  font-family: 'SwissBold';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Bold.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Bold.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Bold.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Bold.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/swiss/Swiss721BT-Bold.woff2) format('woff2')
}

@font-face {
  font-family: 'AldineLight';
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/aldine/tt804m.eot);
  src: url(https://cache.marriott.com/aka-fonts/MarriottDigital/aldine/tt804m.svg) format('svg'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/aldine/tt804m.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/aldine/tt804m.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/MarriottDigital/aldine/tt804m.woff2) format('woff2')
}

@font-face {
  font-family: 'MiIcons';
  src: url(https://cache.marriott.com/aka-fonts/mi-icons/mi-icons.eot?) format('eot'), url(https://cache.marriott.com/aka-fonts/mi-icons/mi-icons.woff2) format('woff2'), url(https://cache.marriott.com/aka-fonts/mi-icons/mi-icons.woff) format('woff'), url(https://cache.marriott.com/aka-fonts/mi-icons/mi-icons.ttf) format('truetype'), url(https://cache.marriott.com/aka-fonts/mi-icons/mi-icons.svg#MiIcons) format('svg');
  font-display: swap;
}


/********************************************************************
* hide elements before angular loads
*******************************************************************/

[ng\:cloak],
[ng-cloak],
[data-ng-cloak],
[x-ng-cloak],
.ng-cloak,
.x-ng-cloak {
  display: none !important;
}


/********************************************************************
* bootstrap/angular-strap overrides
*******************************************************************/

.aside-backdrop.am-fade {
  background: transparent;
}

.aside .aside-dialog .aside-body {
  padding: 0;
}

.modal.center .modal-dialog {
  top: 180px !important;
  transform: translateX(-50%) translateY(0) !important;
  width: 90%;
  max-width: 790px;
}

.modal-body {
  max-height: 80vh;
  border-radius: 10px;
  background-color: #ffffff;
  padding: 67px;
  position: relative;
}

  .modal-body .confirm-query {
    margin-bottom: 30px;
    color: #1c1c1c;
    font-weight: 500;
  }

.modal .modal-body button.modal-close {
  background-image: url(../Content/Images/icon-modal-close.png);
  background-color: transparent;
  background-repeat: no-repeat;
  border: none;
  width: 83px;
  height: 83px;
  text-indent: -9999px;
  position: absolute;
  right: -40px;
  top: -40px;
}

/*.container {
  max-width: 1400px;
}*/

@media only screen and (max-width: 750px) {
  .modal.center .modal-dialog {
    top: 25px !important;
    min-width: 280px;
  }

  .modal-body {
    max-height: 90vh;
    padding: 30px;
  }

    .modal-body .btn {
      width: 100%;
      margin-bottom: 1em;
    }
}


/* specific to ipad 2 in portrait */

@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: portrait) and (-webkit-min-device-pixel-ratio: 1) {
  .modal.center .modal-dialog {
    top: 210px !important;
  }
}


/**
* Custom Bootstrap 3 grid for 480-767px layout
* Author: Iftakhar Hasan
*
* A new set of column classes (with class prefix .col-ms- ) for Bootstrap 3
* to make Medium Small grids for supporting 480-767px
*
* This will push the default Bootstrap 3 Extra Small column (class prefix .col-xs- )
* to support 1-479px instead of 1-767px
*/

.col-ms-1,
.col-ms-2,
.col-ms-3,
.col-ms-4,
.col-ms-5,
.col-ms-6,
.col-ms-7,
.col-ms-8,
.col-ms-9,
.col-ms-10,
.col-ms-11,
.col-ms-12 {
  position: relative;
  padding-left: 15px;
  padding-right: 15px;
}

@media (min-width: 480px) and (max-width: 767px) {
  .container {
    max-width: 748px;
  }

  .col-ms-1,
  .col-ms-2,
  .col-ms-3,
  .col-ms-4,
  .col-ms-5,
  .col-ms-6,
  .col-ms-7,
  .col-ms-8,
  .col-ms-9,
  .col-ms-10,
  .col-ms-11 {
    float: left;
  }

  .col-ms-1 {
    width: 8.33333333%;
  }

  .col-ms-2 {
    width: 16.66666667%;
  }

  .col-ms-3 {
    width: 25%;
  }

  .col-ms-4 {
    width: 33.33333333%;
  }

  .col-ms-5 {
    width: 41.66666667%;
  }

  .col-ms-6 {
    width: 50%;
  }

  .col-ms-7 {
    width: 58.33333333%;
  }

  .col-ms-8 {
    width: 66.66666667%;
  }

  .col-ms-9 {
    width: 75%;
  }

  .col-ms-10 {
    width: 83.33333333%;
  }

  .col-ms-11 {
    width: 91.66666667%;
  }

  .col-ms-12 {
    width: 100%;
  }
}


/********************************************************************
* global styles
*******************************************************************/

body {
  background-color: #ffffff;
  overflow-x: hidden;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  color: #1c1c1c;
}

html,
body {
  font-size: 16px;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  font-family: 'SwissRegular', sans-serif;
  font-weight: 300;
  margin: 0;
}

.is-hidden-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
}

img.banner {
  width: 100%;
}

h1 {
  font-family: 'SwissMedium';
  font-size: 3.75rem;
  margin-top: 30px;
  margin-bottom: 30px;
}

h2 {
  font-family: 'AldineLight';
  font-size: 2.5rem;
}

h3 {
  font-family: 'SwissRegular';
  font-weight: 700;
  font-size: 1.25rem;
}

h4 {
  font-family: 'SwissRegular';
  font-weight: 700;
  font-size: 1rem;
}

a {
  cursor: pointer;
}

  a,
  a:hover {
    color: #2574b4;
    background-color: transparent;
  }

:focus {
  outline: thin dotted #999999 !important;
}

input[type=number] {
  -moz-appearance: textfield;
  max-width: 4em;
}

  input[type=number]::-webkit-inner-spin-button,
  input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
  }

.btn {
  background-color: #1c1c1c;
  color: #ffffff;
  padding: 12px 3em 13px 3em;
  line-height: 1.25;
  border-radius: 30px;
  font-size: 0.75rem;
  font-family: "SwissRegular";
}

  .btn:hover,
  .btn:focus,
  .btn:active {
    background-color: #494949;
    color: #ffffff;
  }

  .btn.btn-secondary {
    background-color: #ffffff;
    color: #1c1c1c;
    border: solid 1px #1c1c1c;
  }

    .btn.btn-secondary:hover,
    .btn.btn-secondary:focus,
    .btn.btn-secondary:active {
      background-color: #1c1c1c;
      color: #ffffff;
    }

  .btn.disabled,
  .btn[disabled],
  fieldset[disabled] .btn {
    background: #777777 !important;
    opacity: 1;
  }

  .btn i.fa {
    font-size: 0.675em;
    vertical-align: 1px;
  }

select,
input[type="text"],
input[type="number"] {
  padding: 9px 16px 8px 16px;
  border-radius: 4px;
  border: solid 1px #777777;
  font-size: 1.25em;
  text-align: center;
}

  select:focus,
  input:focus {
    border: solid 1px #2574b4;
  }

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url(../Content/Images/icon-dropdown.png);
  background-repeat: no-repeat;
  background-position: right 16px center;
}

  select::-ms-expand {
    display: none;
  }

.ada-only {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
  text-indent: -9999em;
}

.error {
  color: #d0021b;
}

  .error.message {
    /*font-size: 0.75em;*/
    margin-bottom: 1em;
  }

input.error,
select.error {
  border-color: #d0021b !important;
}

button.clear-error {
  display: none;
}

input.error + button.clear-error {
  display: inline-block;
  text-indent: -9999em;
  background-image: url(../Content/Images/icon-clear-error.png);
  background-color: transparent;
  border: none;
  width: 13px;
  height: 13px;
  position: relative;
  top: 5px;
  left: -50px;
}

.home-page-content .announcement,
.disaster-list .announcement {
  width: 95%;
  max-width: 45rem;
  margin: 2rem auto;
  padding: 1.5rem 2rem;
  border: solid 2px #cc0000;
}

.home-only {
  display: none;
}

.home-page-content span.home-only {
  display: inline;
}

.site-header + .container {
  background: #e6e6e6;
}

.breadcrumbs a.home-link {
  font-weight: bold;
  background-image: url(../Content/Images/icon-home-grey.png);
  background-repeat: no-repeat;
  padding-left: 23px;
  color: #1c1c1c;
}

.breadcrumbs {
  margin-bottom: 20px;
}

@media only screen and (min-width: 992px) {
  body {
    margin: 0;
  }
}

@media only screen and (max-width: 800px) {
  .breadcrumbs.anon {
    display: none;
  }
}

/*@media only screen and (max-width: 640px) {
  .container {
    padding: 0;
  }
}*/


/********************************************************************
* header/nav
*******************************************************************/

.site-header {
  background-color: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 3;
  border-top: solid 8px #1c1c1c;
}

/*.header-content {
  max-width: 1400px;
  width: 100%;
  margin: auto;
  padding-right: 15px;
  padding-left: 15px;
}*/

.site-header a {
  color: #494949;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}

  .site-header a.logo {
    background-color: #1c1c1c;
    display: block;
    width: 174px;
    height: 142px;
    display: flex;
    align-items: center;
    padding: 10px;
  }

  .site-header a.logo img {
    width: 100%;
  }

.site-header .header {
  height: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.site-header .sign-in-out {
  padding-top: 10px;
}

.site-sub-header {
  position: fixed;
  width: 100%;
  z-index: 1;
  top: 100px;
  background-color: #1C1C1C;
  color: #ffffff;
  padding: 25px 5px 5px 5px;
}

  .site-sub-header.anon {
    display: none;
  }

  .site-sub-header .header-content {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }

  .site-sub-header .pax-info {
    margin-top: -7px;
  }

  .site-sub-header a {
    color: #ffffff;
    font-weight: bold;
  }

    .site-sub-header a.shopping-bag {
      width: 24px;
      height: 20px;
      background-image: url(../Content/Images/icon-shopping-bag.png);
      display: inline-block;
      color: #1c1c1c;
      line-height: 30px;
      text-align: center;
      font-size: 0.6875rem;
      vertical-align: super;
    }

      .site-sub-header a.shopping-bag span {
        background-color: #c2c2c2;
        color: #000000;
        width: 2em;
        height: 2em;
        line-height: 2em;
        display: block;
        position: relative;
        border-radius: 50%;
        top: -1.2em;
        right: -1.2em;
      }

.home-page-content {
  margin-top: 165px;
}

.auth .home-page-content {
  margin-top: 150px;
}

.site-sub-header + .container {
  margin-top: 120px;
}

.site-header .mobile-menu {
  display: none;
}

@media only screen and (max-width: 800px) {
  .home-page-content {
    margin-top: 110px;
  }

  .site-sub-header.anon {
    display: block;
  }

  .site-sub-header .pax-info,
  .site-header .sign-in-out {
    display: none;
  }

  .site-header .header {
    height: 30px;
    padding-left: 20px;
  }

  .site-header a.logo {
    background-color: #1c1c1c;
    height: 86px;
    width: 106px;
  }

    .site-header a.logo img.mobile-logo {
      display: block;
    }

    .site-header a.logo img.desktop-logo {
      display: none;
    }

  .site-header .mobile-menu {
    display: block;
    position: absolute;
    left: 0;
  }

    .site-header .mobile-menu button {
      border: none;
      background: none;
    }

  .site-sub-header {
    top: 30px;
    height: 110px;
  }

    .site-sub-header .header-content {
      margin-top: 80px;
    }

    .site-sub-header .breadcrumbs {
      margin-top: -50px;
    }

  .mobile-menu-modal .modal-dialog {
    padding: 0;
  }

  .mobile-menu-modal .modal-body {
    border-radius: 0;
    padding: 0 20px 20px 20px;
    border-top: solid 8px #1c1c1c;
  }

  .mobile-menu-modal .awning {
    background-color: #1c1c1c;
    padding: 0px 15px 30px 15px;
    margin-left: 15px;
    width: 105px;
    height: 50px;
  }

    .mobile-menu-modal .awning svg {
      width: 100%;
      margin-top: 2px;
    }

  .mobile-menu-modal.modal .modal-body button.modal-close {
    right: auto;
    left: 0;
    top: 0;
    width: 24px;
    height: 24px;
    background: none;
    text-indent: 0;
    padding: 0;
  }

  .mobile-menu-modal.modal .modal-body .menu-content {
    text-align: left;
    padding-left: 10px; 
  }

  .mobile-menu-modal .pax-info {
    padding-bottom: 20px;
    border-bottom: solid 1px #D2D2D2;
    margin-bottom: 20px;
    font-size: 0.8125rem;
    line-height: 1.5rem;
  }

    .mobile-menu-modal .pax-info strong {
      font-size: 1rem;
    }
}

@media only screen and (max-width: 500px) {
  .site-sub-header {
    height: 95px;
  }

    .site-sub-header .header-content {
      margin-top: 30px;
      padding-left: 5px;
      padding-right: 5px;
    }
}


/********************************************************************
* footer
*******************************************************************/

.footer-brandbar {
  background-color: #ffffff;
}


/* #region brandbar */

#footerLogo a {
  width: 130px;
  height: 60px;
  display: inline-block;
  position: relative;
  background-color: #ffffff;
  top: 40px;
  left: calc(50% - 65px);
}

#brandsContainer {
  border: 2px solid #d2d2d2;
  padding: 1.9375rem 1.25rem 0.875rem;
  color: #1c1c1c;
  width: 90%;
  margin: 0 auto 40px auto;
}

  #brandsContainer ul {
    display: block;
    list-style: none;
    padding: 0;
    width: auto;
    clear: both;
    text-align: center;
  }

    #brandsContainer ul h4 {
      width: auto;
      padding-right: 5px;
      margin-bottom: 0.75rem;
      float: left;
      font-size: 0.75rem;
      margin-top: 1rem;
      font-weight: 300;
      text-transform: uppercase;
      line-height: 1.15;
      color: #1c1c1c;
    }

    #brandsContainer ul li {
      display: inline-block;
      font-family: 'portfolio-logo-icons' !important;
      margin-right: 1.5rem;
      margin-bottom: 1rem;
      vertical-align: middle;
    }

      #brandsContainer ul li span {
        position: absolute;
        clip: rect(1px 1px 1px 1px);
      }

      #brandsContainer ul li a,
      #brandsContainer ul li a:hover {
        text-decoration: none;
        color: #1c1c1c;
      }

        #brandsContainer ul li a:before {
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale;
          font-size: 2rem;
          color: #1c1c1c;
        }

      #brandsContainer ul li#edition a:before {
        content: "\f90c";
        font-size: 0.75rem;
      }

      #brandsContainer ul li#ritzCarlton a:before {
        content: "\e914";
        font-size: 2.4rem;
      }

      #brandsContainer ul li#luxuryCollection a:before {
        content: "\f911";
      }

      #brandsContainer ul li#stRegis a:before {
        content: "\f918";
        font-size: 2.2rem;
      }

      #brandsContainer ul li#wHotels a:before {
        content: "\f91b";
      }

      #brandsContainer ul li#jwMarriott a:before {
        content: "\f90f";
      }

      #brandsContainer ul li#marriott a:before {
        content: "\f913";
        font-size: 2.4rem;
      }

      #brandsContainer ul li#sheraton a:before {
        content: "\f917";
      }

      #brandsContainer ul li#marriottVactionClub a:before {
        content: "嵐";
        font-size: 2.5rem;
      }

      #brandsContainer ul li#deltaHotels a:before {
        content: "\f904";
        font-size: 2.1rem;
      }

      #brandsContainer ul li#leMeridien a:before {
        content: "\f910";
        font-size: 0.6rem;
      }

      #brandsContainer ul li#westin a:before {
        content: "\f91c";
        font-size: 0.6rem;
      }

      #brandsContainer ul li#autographCollection a:before {
        content: "\f90a";
      }

      #brandsContainer ul li#designHotels a:before {
        content: "\f90b";
        font-size: 1.1rem;
      }

      #brandsContainer ul li#renissanceHotels a:before {
        content: "\f915";
      }

      #brandsContainer ul li#tributePortfolio a:before {
        content: "\f919";
        font-size: 0.8rem;
      }

      #brandsContainer ul li#gaylord a:before {
        content: "\f906";
      }

      #brandsContainer ul li#courtyard a:before {
        content: "\f903";
        font-size: 0.42rem;
      }

      #brandsContainer ul li#fourPoints a:before {
        content: "\f90e";
        font-size: 1.1rem;
      }

      #brandsContainer ul li#springHill a:before {
        content: "\e92b";
        font-size: 1.28rem;
      }

      #brandsContainer ul li#protea a:before {
        content: "\f907";
        font-size: 1.27rem;
      }

      #brandsContainer ul li#fairfieldInn a:before {
        content: "\f905";
        font-size: 0.67rem;
      }

      #brandsContainer ul li#acHotels a:before {
        content: "\f908";
        font-size: 2.1rem;
      }

      #brandsContainer ul li#aloftHotels a:before {
        content: "\f909";
        font-size: 1.3rem;
      }

      #brandsContainer ul li#moxy a:before {
        content: "\f914";
        font-size: 1.4rem;
      }

      #brandsContainer ul li#cityExpress a:before {
        content: "濫";
        font-size: 2rem;
      }

      #brandsContainer ul li#marriottExecutiveApt a:before {
        content: "\f912";
        font-size: 1.56rem;
      }

      #brandsContainer ul li#homesVillas a:before {
        content: "\f91f";
      }

      #brandsContainer ul li#residenceInn a:before {
        content: "\f900";
        font-size: 0.58rem;
      }

      #brandsContainer ul li#townePlace a:before {
        content: "\f902";
        font-size: 0.95rem;
      }

      #brandsContainer ul li#element a:before {
        content: "\f90d";
        font-size: 2.1rem;
      }

@media (max-width: 1000px) {
  #brandsContainer ul h4 {
    width: 100%;
  }
}


/* #endregion */

.container-fluid.footer-links {
  background-color: #1c1c1c;
  padding: 40px 0 40px 0;
}

.footer-links > div {
  width: 80%;
  margin: auto;
  padding: 0;
  color: #ffffff;
}

  .footer-links > div:first-child {
    padding-bottom: 20px;
    border-bottom: solid 1px;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }

.mt-social {
  display: flex;
}

.mt-social__title {
  margin-top: 1.25rem;
  font-weight: 700;
}

.mt-social__icons {
  padding-left: 1.5rem;
  list-style: none;
  display: inline-flex;
  margin: 0.125rem auto 0 0;
}

.mt-social__icons li {
  position: relative;
  margin-right: 1.5rem;
  margin-top: 1rem;
  margin-bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mt-social__icons li a,
.mt-social span {
  cursor: pointer;
  text-decoration: none;
}

.mt-social__icons li [class^=icon-] {
  font-size: 1.25rem;
  font-weight: 500;
}

.mt-social li [class^=icon-]:before {
  color: #ffffff;
  font-family: MiIcons;
}

.icon-facebook:before {
  content: "\e969";
}

.icon-instagram:before {
  content: "\e96c";
}

.icon-twitter:before {
  content: "\ea49";
}

.icon-linkedin:before {
  content: "\e96d";
}

.icon-youtube:before {
  content: "\e974";
}

.footer-links p.powered-by {
  align-self: flex-end;
  margin: 0;
  font-size: 0.875rem;
}

.footer-links .utility {
  padding-top: 20px;
}

  .footer-links .utility a,
  .footer-links .utility button#ot-sdk-btn.ot-sdk-show-settings {
    color: #ffffff !important;
    font-family: "SwissRegular";
    font-size: 0.875rem !important;
    padding: 0 20px 20px 0 !important;
    margin-right: 25px;
    white-space: nowrap !important;
    background-image: url(../Content/Images/icon-chevron-right-white.png);
    background-repeat: no-repeat;
    background-position: top 2px right;
    display: inline-block;
  }

@media only screen and (max-width: 850px) {
  .footer-links > div:first-child {
    flex-direction: column;
  }

  .mt-social__icons li {
    margin-right: 2rem;
  }

  .footer-links p.powered-by {
    align-self: flex-start;
    padding-top: 1rem;
  }
}


/********************************************************************
* featured charities section
*******************************************************************/

.featured-charities-list {
  text-align: center;
  background-color: #f2f2f2;
  padding-top: 20px;
  padding-bottom: 30px;
}

  .featured-charities-list .category {
    background-color: #ffffff;
    margin-bottom: 20px;
  }

  .featured-charities-list .cat-header {
    display: flex;
    flex-direction: row;
    padding-left: 5%;
  }

    .featured-charities-list .cat-header .logo {
      padding: 10px 20px 10px 0;
      max-width: 326px;
    }

    .featured-charities-list .cat-header .logo img {
      width: 100%;
    }

    .featured-charities-list .cat-header .toggle {
      color: #000000;
      display: flex;
      justify-content: center;
      align-items: center;
      flex-grow: 1;
      cursor: pointer;
    }

  .featured-charities-list #cat-nurture .cat-header .toggle {
    background-color: #B0D5DE;
  }

  .featured-charities-list #cat-sustain .cat-header .toggle {
    background-color: #C4DE7C;
  }

  .featured-charities-list #cat-empower .cat-header .toggle {
    background-color: #999BE5;
  }

  .featured-charities-list #cat-welcome .cat-header .toggle {
    background-color: #FFDAA0;
  }

  .featured-charities-list .cat-content {
    width: 90%;
    margin: auto;
    padding-top: 40px;
  }

  .featured-charities-list .category .expander,
  .featured-charities-list .category.collapsed .collapser {
    display: none;
  }

  .featured-charities-list .category .collapser,
  .featured-charities-list .category.collapsed .expander {
    display: block;
  }

  .featured-charities-list .category.collapsed .cat-content {
    display: none;
  }

  .featured-charities-list .category .cat-description {
    text-align: left;
    padding-bottom: 40px;
    font-size: 0.875rem;
  }

    .featured-charities-list .category .cat-description h2 {
      font-size: 2.5rem;
      margin-top: 0;
    }

    .featured-charities-list .category .cat-description p {
      max-width: 80rem;
    }

  .featured-charities-list .category .cat-items {
    padding-bottom: 100px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: left;
    gap: 10px;
  }

  .featured-charities-list .charity {
    flex-basis: 16%;
    background-color: #ffffff;
    border-radius: 14px;
    padding: 20px;
  }

    .featured-charities-list .charity:hover {
      box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    }

    .featured-charities-list .charity a,
    .featured-charities-list .charity a:hover {
      text-decoration: none;
    }

    .featured-charities-list .charity .logo {
      width: 201px;
      height: 161px;
      margin: auto;
      display: flex;
      align-items: center;
      justify-content: center;
      padding-bottom: 20px;
    }

      .featured-charities-list .charity .logo img {
        max-height: 100%;
        max-width: 100%;
        height: auto;
        width: auto;
      }

@media only screen and (max-width: 1635px) {
  .featured-charities-list .charity {
    flex-basis: 19%;
  }
}

@media only screen and (max-width: 1400px) {
  .featured-charities-list .charity {
    flex-basis: 24%;
  }
}

@media only screen and (max-width: 1100px) {
  .featured-charities-list .charity {
    flex-basis: 32%;
  }
}

@media only screen and (max-width: 991px) {
  .featured-charities-list .page-nav .nav-category:nth-child(2n+1) {
    background-image: none;
  }
}

@media only screen and (max-width: 800px) {
  .featured-charities-list .charity {
    flex-basis: 49%;
  }
}

@media only screen and (max-width: 767px) {
  .featured-charities-list h1 {
    font-size: 2em;
    padding: 30px;
  }

    .featured-charities-list h1 span {
      display: block;
    }

  .featured-charities-header p {
    text-align: left;
    width: auto;
    margin: 20px 30px;
  }
}

@media only screen and (max-width: 640px) {
  .featured-charities-list .category {
    box-shadow: none;
  }
}

@media only screen and (max-width: 530px) {
  .featured-charities-list .charity {
    flex-basis: 48%;
  }

    .featured-charities-list .charity .logo {
      width: 100%;
    }
}

@media only screen and (max-width: 480px) {
  .featured-charities-list h1 {
    font-size: 1em;
    padding: 20px;
  }
}


/********************************************************************
* terms, privacy, faq pages
*******************************************************************/

.terms-content,
.privacy-content,
.faq-content {
  margin-top: 20px;
  background: #ffffff;
}

.auth .terms-content,
.auth .privacy-content,
.auth .faq-content {
  margin-top: 200px;
}

.terms-content-inner,
.privacy-content-inner,
.faq-content-inner {
  padding: 40px;
  margin-bottom: 60px;
}

.faq-content h2 {
  font-size: 2.375em;
  margin-top: 50px;
}

.faq-content .faq-item {
  margin-top: 25px;
  padding-top: 25px;
  border-top: solid 1px #ebebea;
}

  .faq-content .faq-item .question {
    font-size: 1.25em;
    font-weight: bold;
  }

/********************************************************************
* home page
*******************************************************************/

.home-page-content .home-banner {
  background-image: url(../Content/Images/home-banner-2x.png);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 814px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

  .home-page-content .home-banner .home-banner-content {
    width: 90%;
    max-width: 1400px;
    margin: auto;
  }

.home-page-content .home-banner .home-banner-copy {
  width: 45%;
  text-align: left;
}

.home-page-content .home-banner .home-banner-copy h2 {
  font-size: 55px;
}

@media screen and (max-width: 1100px) {
  .home-page-content .home-banner .home-banner-copy h2 {
    font-size: 48px;
  }
}

@media screen and (max-width: 590px) {
  .home-page-content .home-banner {
    background-image: url(../Content/Images/home-banner-mobile.png);
    height: 294px;
  }

    .home-page-content .home-banner .home-banner-copy h2 {
      font-size: 20px;
    }

    .home-page-content .home-banner .home-banner-copy p {
      font-size: 10px;
    }
}

@media screen and (max-width: 400px) {
  .home-page-content .home-banner {
    background-image: url(../Content/Images/home-banner-mobile-smaller.png);
  }

    .home-page-content .home-banner .home-banner-copy h2 {
      font-size: 18px;
    }
}

.feature-banner {
  width: 90%;
  max-width: 950px;
  margin: 40px auto;
  height: 396px;
  display: flex;
  border-radius: 1rem;
  box-shadow: 1px 1px 5px 5px rgba(0, 0, 0, 0.1);
}

  .feature-banner .photo img {
    border-radius: 1rem 0 0 1rem;
  }

  .feature-banner .photo-credit {
    font-size: 0.75rem;
    color: #ffffff;
    margin-top: -2rem;
    margin-left: 1rem;
  }

  .feature-banner .content {
    background-color: #ffffff;
    border-radius: 0 1rem 1rem 0;
    padding: 50px;
  }

    .feature-banner .content p {
      margin: 20px 0;
    }

@media screen and (max-width: 1050px) {
  .feature-banner {
    flex-direction: column;
    max-width: 550px;
    height: auto;
  }

    .feature-banner .photo img {
      border-radius: 1rem 1rem 0 0;
      width: 100%;
    }

    .feature-banner .content {
      border-radius: 0 0 1rem 1rem;
    }
}

.about-lovetravels {
  background-color: #FF9962;
}

  .about-lovetravels > div {
    width: 90%;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    color: #000000;
  }

  .about-lovetravels img {
    max-width: 230px;
  }

  .about-lovetravels p {
    text-align: left;
    padding: 50px 30px;
  }

  .about-lovetravels .btn {
    background-color: #ffffff;
    color: #1c1c1c;
  }

  @media screen and (max-width: 950px) {
    .about-lovetravels > div {
      flex-direction: column;
      padding: 30px;
      align-items: flex-start;
    }

    .about-lovetravels > div p {
      padding-left: 0;
    }
  }

  @media screen and (max-width: 800px) {
    .home-banner .content-width {
      padding-top: 11vw;
    }

    .home-banner h2 {
      font-size: 1.5rem;
    }

    .featured-charities-list .cat-header .logo {
      width: 50%;
    }

    .featured-charities-list .cat-header .logo img {
      max-width: 100%;
    }
  }

/* begin featured charity section */
#featured-content-inner {
  width: 90%;
  max-width: 1080px;
  margin: 40px auto;
  display: flex;
  border-radius: 1rem;
  box-shadow: 1px 1px 5px 5px rgb(0 0 0 / 10%);
}

  #featured-content-inner .photo {
    width: 60%;
    position: relative;
  }

    #featured-content-inner .photo img {
      border-radius: 1rem 0 0 1rem;
      object-fit: cover;
      object-position: center;
      width: 100%;
      height: 100%;
    }

    #featured-content-inner .photo p {
      position: absolute;
      left: 20px;
      bottom: 16px;
      margin-bottom: 0;
      color: #ffffff;
      font-size: 0.625rem;
    }

  #featured-content-inner .content {
    width: 40%;
    background: #ffffff;
    padding: 3rem;
    border-radius: 0 1rem 1rem 0;
  }

    #featured-content-inner .content p {
      margin: 1rem 0;
      font-family: 'AldineLight', serif;
      font-size: 1.5rem;
    }

@media screen and (max-width: 1210px) {
  #featured-content-inner .content p {
    font-size: 1.25rem;
  }
}

@media screen and (max-width: 1050px) {
}

@media screen and (max-width: 900px) {
  #featured-content-inner {
    flex-direction: column;
    max-width: 649px;
    height: auto;
  }

    #featured-content-inner .photo,
    #featured-content-inner .content {
      width: 100%;
    }

      #featured-content-inner .photo img {
        border-radius: 1rem 1rem 0 0;
      }

    #featured-content-inner .content {
      border-radius: 0 0 1rem 1rem;
    }
}
/* end featured charity section */

/* begin promo banner section */
.home-page-content .promo-banner {
  background-color: #ffffff;
  padding: 70px;
  text-align: center;
}

  .home-page-content .promo-banner h2 {
    font-family: 'AldineLight';
    font-size: 3.75rem;
    letter-spacing: 1px;
  }

  .home-page-content .promo-banner p {
    font-family: 'SwissRegular';
    font-size: 1.375rem;
    margin: 0 auto 30px auto;
    max-width: 50em;
  }
/* end promo banner section */

.search-section {
  background-color: #f4f4f4;
  padding-top: 30px;
  padding-bottom: 40px;
  margin-bottom: 30px;
}

  .search-section p {
    font-size: 1.5em;
  }

.search-form label {
  display: block;
  font-size: 0.875em;
  font-weight: normal;
}

.search-form select,
.search-form input,
.search-form .btn {
  display: block;
  width: 100%;
  margin-bottom: 20px;
}

.search-results-content h3 {
  font-size: 2.375em;
}

.search-results-content h4 {
  font-size: 38px;
  padding-bottom: 30px;
  border-bottom: solid 1px #d2d2d2;
  margin-bottom: 20px;
}

.search-results-box {
  background-color: #ffffff;
  padding: 20px 30px 40px 30px;
}

.search-results-list {
  overflow-y: scroll;
  overflow-x: hidden;
  margin-top: 20px;
  margin-bottom: 30px;
  max-width: 730px;
  max-height: 430px;
}

  .search-results-list label {
    font-weight: normal;
    font-size: 1em;
    display: block;
    clear: both;
    padding: 5px 0;
  }

    .search-results-list label input[name="charities"] {
      display: inline-block;
      width: auto;
      margin-right: 10px;
    }

    .search-results-list label .charity-text {
      float: left;
      width: 90%;
    }

    .search-results-list label .charity-name {
      font-weight: bold;
      display: block;
    }

.search-results-box .btn {
  float: left;
  width: 12.25em;
  margin-right: 1em;
}

.disclaimer {
  color: #494949;
  font-size: 0.875em;
  line-height: 1.2;
  margin-top: 30px;
}

#disaster-section a {
  display: block;
  text-align: center;
  text-decoration: none;
  color: #ffffff;
  background-color: #2a97df;
  font-size: 1.5em;
  font-family: 'SwissRegular', sans-serif;
  font-weight: bold;
  padding: 0.5em 1em;
}

@media only screen and (min-width: 992px) {
  .search-form form > div {
    float: left;
  }

  .search-form select,
  .search-form input {
    font-size: 1em;
    display: inline-block;
    width: auto;
    margin-right: 20px;
  }

  .search-form .submit .btn {
    margin-top: 1.05em;
    margin-left: 25px;
  }
}

@media only screen and (max-width: 1100px) {
  .home-page-content .content-width {
    padding-top: 8vw;
  }
}

@media only screen and (max-width: 1000px) {
  .home-page-content .content-width {
    padding-top: 7vw;
  }
}

@media only screen and (max-width: 800px) {
  .home-page-content .content-width {
    padding-top: 5vw;
  }
}


/********************************************************************
* thumbnail page
*******************************************************************/

.thumbnail-page {
  margin-top: 220px;
}

.thumbnail-page .h1 {
  text-align: left;
}

.thumbnail-page .thumbnail-page-content {
  margin-bottom: 0px;
}

.thumbnail-page .featured-charity-content .banner-container {
  position: relative;
}

.thumbnail-page .featured-charity-content .banner {
  margin-bottom: 0;
  border-radius: 14px;
}

.thumbnail-page .featured-charity-content .banner-text {
  position: absolute;
  bottom: 30px;
  left: 60px;
}

  .thumbnail-page .featured-charity-content .banner-text span {
    display: block;
    float: left;
    clear: both;
    margin-bottom: 20px;
    color: #ffffff;
    font-weight: 500;
    font-size: 2.5rem;
    text-transform: capitalize;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 1.0);
  }

.thumbnail-page .featured-charity-details-outer {
  padding: 40px;
}

.thumbnail-page .featured-charity-details-inner {
  padding-bottom: 20px;
}

.thumbnail-page .featured-charity-content .logo-wrap {
  text-align: center;
}

.thumbnail-page .featured-charity-content .logo {
  margin-bottom: 20px;
}

.thumbnail-page .featured-charity-details-inner img {
  max-width: 201px;
  width: auto;
}

.thumbnail-page .charity-description p {
  line-height: 1.5;
  margin-bottom: 30px;
  overflow: hidden;
  /* prevents wrapping under logo*/
}

  .thumbnail-page .charity-description p.disaster-directions {
    font-weight: bold;
    font-size: 1.875em;
    color: #005592;
    max-width: 20em;
  }

.thumbnail-page .charity-description ul {
  margin-bottom: 30px;
}

  .thumbnail-page .charity-description ul li {
    padding-bottom: 16px;
  }

.thumbnail-page .charity-info {
  padding-bottom: 30px;
  margin-bottom: 30px;
}

  .thumbnail-page .charity-info h2 {
    font-size: 1em;
    font-weight: bold;
    text-transform: uppercase;
  }

.thumbnails .charity-thumbs,
.tree-donation-options {
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

  .thumbnails .charity-thumbs .thumb,
  .tree-donation-options .thumb {
    margin-bottom: 60px;
    flex-basis: 100%;
  }

  .thumbnails .charity-thumbs .thumb-inner:hover,
  .tree-donation-options .thumb-inner:hover {
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    background-color: #ffffff;
  }

  .thumbnails .charity-thumbs .thumb-inner,
  .tree-donation-options .thumb-inner {
    width: 190px;
    margin: auto;
    font-weight: 500;
    border-radius: 14px;
    padding: 1rem;
  }

    .thumbnails .charity-thumbs .thumb-inner a,
    .thumbnails .charity-thumbs .thumb-inner a:hover,
    .tree-donation-options .thumb-inner a,
    .tree-donation-options .thumb-inner a:hover {
      text-decoration: none;
    }

      .thumbnails .charity-thumbs .thumb-inner a img,
      .tree-donation-options .thumb-inner a img {
        margin-bottom: 20px;
      }

    .thumbnails .charity-thumbs .thumb-inner .image,
    .tree-donation-options .thumb-inner .image {
      text-align: center;
      padding: 20px;
      margin: 0 auto;
    }

    .thumbnails .charity-thumbs .thumb-inner .description,
    .thumbnails .charity-thumbs .thumb-inner .point-cost,
    .tree-donation-options .thumb-inner .description,
    .tree-donation-options .thumb-inner .point-cost {
      font-size: 0.875rem;
      color: #1c1c1c;
    }

.thumbnails .not-available.message {
  border: solid 1px #494949;
  padding: 1em;
  margin-top: 1em;
}

.thumbnails.charity-disclaimer p {
  font-size: 0.875em;
  padding-left: 40px;
}

.option-header {
  display: flex;
  flex-direction: row;
  margin-bottom: 24px;
}

  .option-header .label {
    background-color: #f4f4f4;
    color: #1c1c1c;
    padding-top: 1rem;
    padding-bottom: 1rem;
    padding-right: 1rem;
    padding-left: 4rem;
    text-align: left;
    font-size: 2.5rem;
    font-family: AldineLight;
    font-weight: normal;
    border-radius: 0;
    flex-basis: 10em;
  }

  .option-header .toggle {
    background-color: #c4de7c;
    color: #1c1c1c;
    padding: 1rem;
    display: flex;
    flex-grow: 1;
    justify-content: center;
    align-items: center;
    cursor: pointer;
  }

.donation-option .toggle .collapser,
.donation-option.collapsed .toggle .expander {
  display: block;
}

.donation-option .toggle .expander,
.donation-option.collapsed .toggle .collapser {
  display: none;
}

.donation-option.collapsed .option-content {
  display: none;
}

.donation-option .featured-region-intro {
  display: flex;
  flex-direction: row;
  margin-top: 36px;
  margin-bottom: 24px;
}

.donation-option .featured-region-intro .photo {
  padding-right: 48px;
}

.donation-option h3 {
  font-family: AldineLight;
  font-weight: normal;
  font-size: 1.5rem;
  margin-top: 0;
}

.tree-donation-options .thumb-inner .description {
  font-family: AldineLight;
  font-size: 2.5rem;
}

.donation-option .featured-region-details .detail-sections {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 24px;
  margin-top: 36px;
}

.donation-option .featured-region-details .detail-section .photo {
  margin-bottom: 16px;
}

  .donation-option .featured-region-details .detail-section .photo img {
    width: 100%;
    max-width: 515px;
  }

  .donation-option .featured-region-details .detail-section p {
    max-width: 515px;
  }

@media only screen and (min-width: 480px) {
  .thumbnails .charity-thumbs .thumb,
  .tree-donation-options .thumb {
    flex-basis: 50%;
  }
}

@media only screen and (min-width: 600px) {
  .thumbnails .charity-thumbs .thumb {
    flex-basis: 33%;
  }
}

@media only screen and (min-width: 900px) {
  .thumbnail-page .featured-charity-content .banner {
    margin-bottom: 30px;
  }

  .thumbnail-page .featured-charity-details-inner {
    display: flex;
  }

  .thumbnail-page .featured-charity-content .logo-wrap {
    align-self: flex-start;
    margin-right: 40px;
  }

  .thumbnail-page .featured-charity-content img.logo {
    max-width: 201px;
  }

  .thumbnail-page .featured-charity-content .charity-description {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .thumbnails .charity-thumbs .thumb,
  .tree-donation-options .thumb {
    flex-basis: 25%;
  }
}

@media only screen and (min-width: 1100px) {
  .thumbnails .charity-thumbs .thumb {
    flex-basis: 20%;
  }

  .tree-donation-options .thumb {
    flex-basis: 25%;
  }
}

@media only screen and (min-width: 1300px) {
  .thumbnails .charity-thumbs .thumb {
    flex-basis: 16%;
  }

  .tree-donation-options .thumb {
    flex-basis: 25%;
  }
}

@media (max-width: 920px) {
  .thumbnail-page .featured-charity-content .banner-text span {
    font-size: 3.5rem;
  }
}

@media (max-width: 875px) {
  .thumbnail-page .featured-charity-content .banner-text {
    bottom: 10px;
  }

    .thumbnail-page .featured-charity-content .banner-text span {
      font-size: 2.5rem;
    }
}

@media (max-width: 800px) {
  .thumbnail-page {
    margin-top: 110px;
  }

  .thumbnail-page .charity-description {
    margin-top: 30px;
  }

  .thumbnails {
    background-color: #f2f2f2;
    padding-top: 30px;
  }

  .option-header {
    margin-top: 24px;
  }

  .donation-option .featured-region-intro {
    flex-direction: column;
  }

    .donation-option .featured-region-intro .photo {
      padding-bottom: 24px;
    }

  .donation-option .featured-region-details .detail-sections {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .thumbnail-page .featured-charity-content .banner-text span {
    font-size: 2rem;
    margin-bottom: 16px;
  }
}

@media (max-width: 480px) {
  .thumbnail-page .featured-charity-content .banner-text {
    bottom: 5px;
  }

    .thumbnail-page .featured-charity-content .banner-text span {
      font-size: 1.5rem;
      margin-bottom: 10px;
    }
}


/********************************************************************
* item detail page
*******************************************************************/

.item-detail-content {
  padding: 60px 40px;
  margin-top: 200px;
}

.item-image-info-wrap {
  display: flex;
  flex-direction: row;
}

.item-detail-content .item-image {
  margin-bottom: 40px;
}

  .item-detail-content .item-image .image-inner {
    display: inline-block;
    padding: 40px;
  }

  .item-detail-content .item-image .image-inner img {
    max-width: 201px;
  }

.item-detail-content .charity-name {
  font-family: 'SwissRegular', sans-serif;
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 20px;
}

.item-detail-content .donation-amount {
  font-family: AldineLight;
  font-size: 2.5rem;
  font-weight: 500;
}

.item-detail-content .point-cost {
  font-family: 'SwissRegular', sans-serif;
  font-size: 1em;
  font-weight: 500;
  margin-bottom: 35px;
}

.item-detail-content .form-elements > div {
  float: left;
}

.item-detail-content .item-qty {
  margin-right: 60px;
}

  .item-detail-content .item-qty label {
    display: block;
    font-weight: normal
  }

  .item-detail-content .item-qty select {
    width: 4em;
    padding: 0.5em;
    border: solid 1px #777777;
    border-radius: 4px;
  }

.item-detail-content .donate-button {
  padding-top: 28px;
}

  .item-detail-content .donate-button .modal-body .info {
    font-weight: 600;
    font-size: 1em;
    margin-bottom: 1.5em;
  }

  .item-detail-content .donate-button .modal-body .donation-description {
    line-height: 1.2;
  }

  .item-detail-content .donate-button .modal-body .charity-name {
    font-size: 2em;
  }

  .item-detail-content .donate-button .modal-body .btn.checkout {
    padding: 1em 3em;
    margin-right: 30px;
  }

  .item-detail-content .donate-button .modal-body .btn.back-to-home {
    padding: 1em 3em;
  }

.item-detail-content .item-description {
  padding-top: 60px;
  max-width: 52em;
}

@media only screen and (max-width: 800px) {
  .item-image-info-wrap {
    flex-direction: column;
  }

  .item-detail-content .item-image .image-inner {
    padding: 0;
  }
}

@media only screen and (max-width: 430px) {
  .btn,
  .btn.btn-secondary,
  .btn:hover,
  .btn.btn-secondary:hover,
  .btn:focus,
  .btn.btn-secondary:hover,
  .btn:active,
  .btn.btn-secondary:active {
    padding: 0.5em 1em;
  }
}


/********************************************************************
* checkout
*******************************************************************/

.checkout-page {
  margin-top: 120px;
}

.auth .checkout-page {
  margin-top: 190px;
}

.checkout-content {
  padding: 40px 0;
  margin-bottom: 60px;
  /*background-color: #ffffff;*/
}

  .checkout-content > h2 {
    font-size: 2em;
    font-weight: 600;
    padding-left: 40px;
  }

  .checkout-content .checkout-item {
    padding: 30px 40px 30px 80px;
    clear: both;
    position: relative;
    border-bottom: solid 1px #d0d0d0;
  }

    .checkout-content .checkout-item:last-child {
      border: none;
    }

  .checkout-content .item-image {
    margin-bottom: 40px;
    float: left;
  }

    .checkout-content .item-image .image-inner {
      display: inline-block;
      margin: 0 50px 0 0;
      /*box-shadow: 2px 3px 6px 0px rgba(0, 0, 0, 0.1);
background-color: #e6e6e6;
padding: 20px;*/
    }

  .checkout-content .checkout-item .item-info {
    overflow: hidden;
  }

  .checkout-content .checkout-item .donation-description {
    font-family: 'SwissRegular', sans-serif;
    font-size: 1em;
    font-weight: 500;
  }

  .checkout-content .checkout-item .charity-name {
    font-size: 2em;
    font-weight: 600;
  }

  .checkout-content .checkout-item .donation-amount {
    font-size: 1em;
    font-weight: 400;
  }

  .checkout-content .checkout-item .item-quantity {
    margin-top: 20px;
  }

    .checkout-content .checkout-item .item-quantity label {
      font-weight: 400;
    }

    .checkout-content .checkout-item .item-quantity input {
      display: block;
      margin-top: 10px;
      border: solid 1px #494949;
      border-radius: 4px;
      background-color: #ffffff;
      padding: 1em;
      width: 5em;
    }

  .checkout-content .checkout-item a.remove-item-link {
    position: absolute;
    top: 50%;
    margin-top: -35px;
    right: 40px;
    background-image: url(../Content/Images/icon-remove.png);
    background-repeat: no-repeat;
    background-position: top center;
    padding-top: 55px;
    width: 4em;
    height: 70px;
    text-align: center;
    color: #494949;
    font-size: 0.875em;
  }

  .checkout-content .empty-basket {
    padding-left: 40px;
  }

  .checkout-content .confirm h2,
  .checkout-content .review h2 {
    font-size: 1.5em;
    font-weight: 500;
    padding: 14px 20px;
    color: #ffffff;
    margin: 1px 0 0 0;
  }

  .checkout-content .active h2 {
    background-color: #1c1c1c;
  }

  .checkout-content .inactive h2 {
    background-color: #919191;
  }

  .checkout-content .confirm-content,
  .checkout-content .review-content {
    padding: 30px 20px;
  }

  .checkout-content .confirm.inactive .confirm-content,
  .checkout-content .review.inactive .review-content {
    display: none;
  }

  .checkout-content .confirm-content h3 {
    font-size: 1em;
    text-transform: uppercase;
  }

  .checkout-content .confirm-content p {
    color: #494949;
    font-weight: 400;
    font-size: 1em;
    margin-bottom: 25px;
  }

    .checkout-content .confirm-content p.points {
      font-style: italic;
    }

  .checkout-content .confirm-content .checkbox input {
    opacity: 0;
  }

    .checkout-content .confirm-content .checkbox input + span.custom-checkbox {
      background-image: url(../Content/Images/checkbox-unchecked.png);
      width: 17px;
      height: 17px;
      display: inline-block;
      margin-left: -20px;
    }

    .checkout-content .confirm-content .checkbox input:checked + span.custom-checkbox {
      background-image: url(../Content/Images/checkbox-checked.png);
    }

  .checkout-content .review-content h3 {
    font-size: 1em;
    font-weight: 500;
    color: #737373;
    border-bottom: solid 1px #95989a;
    padding-bottom: 10px;
  }

  .checkout-content .review-content p.member-info.email {
    font-size: 1em;
    margin-bottom: 20px;
    font-weight: 500;
  }

  .checkout-content .review-content p.member-info.name {
    font-size: 1.25em;
    margin-bottom: 0;
    font-weight: 500;
  }

  .checkout-content .review-content p.wrong-info {
    margin-bottom: 30px;
    font-weight: 500;
  }

    .checkout-content .review-content p.wrong-info a {
      color: #0079d4;
    }

      .checkout-content .review-content p.wrong-info a.btn {
        color: #ffffff;
      }

  .checkout-content .choices {
    padding-top: 20px;
  }

    .checkout-content .choices a.btn-secondary {
      margin-right: 30px;
      float: left;
    }

  .checkout-content .review-content table {
    max-width: 800px;
    width: 100%;
    margin-bottom: 30px;
  }

    .checkout-content .review-content table tbody tr {
      border-top: solid 1px #e0e0e0;
    }

    .checkout-content .review-content table th,
    .checkout-content .review-content table td {
      padding: 10px 20px 10px 0;
      vertical-align: top;
    }

    .checkout-content .review-content table th {
      font-weight: 500;
      color: #737373;
    }

    .checkout-content .review-content table tfoot tr td {
      border-top: solid 4px #e0e0e0;
      font-size: 1.125em;
      font-weight: 500;
    }

  .checkout-content .review-content .choices {
    max-width: 700px;
    width: 100%;
    position: relative;
  }

    .checkout-content .review-content .choices .submit-order-button-wrapper {
      margin-right: 20px;
    }

    .checkout-content .review-content .choices .order-processing {
      background-image: url(../Content/Images/spinner.gif);
      background-repeat: no-repeat;
      background-position: center left;
      padding-left: 35px;
      color: #1c1c1c;
      font-weight: bold;
      font-size: 1em;
      margin-bottom: 10px;
      position: absolute;
      top: -20px;
    }

.modal-body .confirm-query .item-name {
  color: #3a5983;
}

.checkout-content .modal-body .buttons .btn {
  padding: 1em 2em;
}

.checkout-page .page-bottom {
  text-align: center;
  padding-top: 60px;
}

@media only screen and (max-width: 750px) {
  .checkout-content .checkout-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

    .checkout-content .checkout-item .item-image {
      flex-grow: 1;
    }

    .checkout-content .checkout-item .item-info {
      width: 100%;
    }

    .checkout-content .checkout-item a.remove-item-link {
      top: auto;
      bottom: 25px;
      margin-top: 0;
    }
}

@media only screen and (min-width: 750px) {
  .checkout-content .confirm-content,
  .checkout-content .review-content {
    padding: 30px 34px 30px 80px;
  }
}

@media only screen and (max-width: 700px) {
  .checkout-content .modal-body .buttons .btn {
    width: 100%;
    margin-bottom: 1em;
  }
}

@media only screen and (max-width: 640px) {
  .checkout-content .checkout-item .image img {
    width: 130px;
  }

  .checkout-content .review-content .choices .submit-order-button-wrapper {
    float: none;
    margin: 0;
  }
}

@media only screen and (max-width: 450px) {
  .checkout-content .checkout-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

    .checkout-content .checkout-item .item-image {
      text-align: center;
    }
}

@media only screen and (max-width: 360px) {
  .checkout-content .choices a,
  .checkout-content .choices button {
    display: block;
    float: none !important;
    clear: both;
    margin-bottom: 20px;
    width: 100%;
  }
}


/********************************************************************
* order-confirmation
*******************************************************************/

.order-confirmation-page {
  padding-bottom: 30px;
}

  .order-confirmation-page h1 {
    margin-bottom: 30px;
    float: left;
    color: #1c1c1c;
  }

  .order-confirmation-page a.print-link {
    float: right;
    display: block;
    background-image: url(../Content/Images/icon-print.png);
    background-repeat: no-repeat;
    background-position: center right;
    padding: 5px 35px 5px 0;
    font-size: 0.75em;
    text-transform: uppercase;
  }

.order-confirmation-content {
  clear: both;
  padding: 40px;
  margin-bottom: 60px;
}

.auth .order-confirmation-content {
  margin-top: 170px;
}

.order-confirmation-content p.order-number {
  margin: 30px 0;
  font-weight: 500;
}

.order-confirmation-content h2 {
  margin-bottom: 0;
  font-size: 2em;
  font-weight: 500;
}

.order-confirmation-content h3 {
  font-size: 1em;
  font-weight: normal;
  color: #737373;
  border-bottom: solid 1px #cccccc;
}

.order-confirmation-content .member-name {
  font-size: 1.25em;
  margin-bottom: 0;
  font-weight: 400;
}

.order-confirmation-content .member-email {
  font-size: 1em;
  font-weight: 500;
  margin-bottom: 20px;
}

.order-confirmation-content table.item-list {
  width: 100%;
}

.order-confirmation-content .order-confirmation-list-header {
  color: #737373;
  border-bottom: solid 1px #cccccc;
}

.order-confirmation-content .order-confirmation-item {
  border-bottom: solid 1px #cccccc;
}

.order-confirmation-content .order-confirmation-list-header td {
  padding: 5px 20px 5px 0;
}

.order-confirmation-content .order-confirmation-item td {
  padding: 8px 20px 8px 0;
}

.order-confirmation-content .order-confirmation-list-footer td {
  text-align: left;
  padding: 8px 20px 60px 0;
  font-weight: 500;
}

.order-confirmation-content .contact {
  padding: 20px 0;
}

  .order-confirmation-content .contact h2 {
    color: #363636;
    margin-bottom: 10px;
    padding-left: 0;
    font-size: 1.625em;
    text-transform: none;
  }

@media only screen and (max-width: 991px) {
  .order-confirmation-page a.print-link {
    display: none;
  }

  .order-confirmation-item .image,
  .order-confirmation-item .details {
    float: none;
    width: auto;
    margin-bottom: 30px;
  }
}

@media only screen and (max-width: 640px) {
  .order-confirmation-content .btn {
    display: block;
    float: none;
    width: 100%;
    padding: 1em 0;
  }
}


/********************************************************************
* timeout page
*******************************************************************/

.timeout-content {
  text-align: center;
  margin-top: 140px;
}


/********************************************************************
* disaster page
*******************************************************************/
.auth .disaster-page.thumbnail-page {
  margin-top: 50px;
}

.disaster-list {
  background: transparent;
  margin-bottom: 80px;
}

  .disaster-list > .container {
    margin-top: 0px;
  }

.disaster-heading img {
  width: 100%;
  margin-bottom: 30px;
}

.disaster-heading h2 {
  font-size: 1.75em;
  font-weight: 500;
}

#maui h2,
#morocco h2 {
  font-size: 1.75em;
  font-weight: 700;
}

.disaster-list h2 + p {
  font-weight: 500;
  font-size: 1.5rem;
}

.disaster-list .internal-page-nav {
  text-align: center;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.disaster-list .internal-page-nav .btn {
  margin-left: 1rem;
  margin-right: 1rem;
}

.disaster-list hr {
  width: 66%;
  border-color: #cccccc;
  margin-bottom: 4rem;
}

.disaster-list .charity-content {
  display: flex;
  flex-direction: row;
  margin-top: 36px;
}

.disaster-list .logo-wrap a {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.disaster-list .logo-wrap a:hover,
.disaster-list .logo-wrap a:active,
.disaster-list .logo-wrap a:focus {
  text-decoration: none;
}

.disaster-list .charity-content p {
  font-size: 1.5em;
  align-self: center;
  padding-left: 24px;
}

  .disaster-list .charity-content .logo-wrap img {
    max-width: 201px;
    margin-bottom: 24px;
  }

@media only screen and (max-width: 830px) {
  .disaster-list .charity-content .banner img.mobile {
    display: block;
  }

  .disaster-list .charity-content .banner img.desktop {
    display: none;
  }

  .disaster-list .charity-content {
    flex-direction: column;
  }

    .disaster-list .charity-content p {
      margin-top: 24px;
    }
}

@media only screen and (max-width: 768px) {
  .disaster-list .charity-content h2 {
    font-size: 3em;
  }
}

@media only screen and (max-width: 480px) {
  .disaster-list .charity-content h2 {
    font-size: 2em;
  }
}


/********************************************************************
* print styles
*******************************************************************/

@media only screen {
  .print-only {
    display: none !important;
  }
}

@media print {
  html,
  body {
    height: auto;
    margin: 0px 0px 0px 0px;
  }

  .site-header,
  .site-footer,
  .no-print {
    display: none !important;
  }
}
