@import 'form.css';
.background-image-defaults {
  background-size: 100% auto;
  background-repeat: no-repeat;
}
.pill-button {
  display: block;
  padding: 0.2em 0.8em;
  border-radius: 0.3em;
  text-transform: uppercase;
}
.primary-pill-button {
  display: block;
  padding: 0.2em 0.8em;
  border-radius: 0.3em;
  text-transform: uppercase;
  color: #003b56;
  background-color: #71c170;
}
.brownstone {
  font-weight: 400;
  -webkit-font-smoothing: subpixel-antialiased;
}
.brownstone-light {
  font-family: 'Courier New', Courier, Calibri, Arial, Roboto, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: subpixel-antialiased;
}
.brownstone-hole {
  font-family: 'Courier New', Courier, Calibri, Arial, Roboto, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: subpixel-antialiased;
}
.brownstone-thin {
  font-family: 'Courier New', Courier, Calibri, Arial, Roboto, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: subpixel-antialiased;
}
.content-box {
  position: relative;
  background-color: rgba(0, 59, 86, 0.9);
  color: #71c170;
  border: 4px solid #71c170;
  padding: 4em;
}
.content-box .close-button {
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
  line-height: 1em;
  font-size: 2em;
  padding: 0em 0.2em;
  cursor: pointer;
}
.icon-link {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
}
* {
  -webkit-box-sizing: border-box;
  /* using border-box, padding included in width / height */
  box-sizing: border-box;
  -webkit-touch-callout: none;
  /* prevent callout to copy image, etc when tap to hold */
  -webkit-text-size-adjust: none;
  /* prevent webkit from resizing text to fit */
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  /* prevent tap highlight color / shadow */
  -webkit-user-select: text;
  /* prevent copy paste, to allow, change 'none' to 'text' */
}
html,
body {
  width: 1024px;
  height: 768px;
  padding: 0;
  margin: 0;
  overflow: hidden;
  background-color: #003b56;
}
body {
  font-size: 20px;
  font-family: "Helvetica Neue", Helvetica, Arial;
  font-weight: 300;
  -webkit-font-smoothing: subpixel-antialiased;
}
.gallery .content-container {
  background-color: #fff;
}
.gallery .content-container h1 {
  color: #003b56;
  font-family: 'Playfair Display', serif;
  font-weight: 400;
  text-decoration: none;
  font-size: 1.5em;
}
a {
  color: inherit;
  text-decoration: none;
}
h1,
h2 {
  font-size: 1.6em;
}
.thrive-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  background-color: #003b56;
  color: #71c170;
}
.content-container {
  width: 100%;
  height: 692px;
  position: relative;
  padding: 1em 4em;
}
.content-container h1 {
  color: #fff;
  font-weight: normal;
  font-family: 'Playfair Display', serif;
}
.content-container {
  z-index: 1;
}
.masthead,
.footer {
  z-index: 2;
}
.home .thrive-container,
.thanks .thrive-container,
.register .thrive-container {
  background-color: #003b56;
  color: #71c170;
}
.home .content-container,
.thanks .content-container,
.register .content-container {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: top center;
  background-image: url(../img/bg/thrive-text-bg-full.png);
}
.thrive-footer-nav {
  width: 90%;
}
.thrive-footer-nav li {
  display: block;
  width: 20%;
  text-align: center;
  float: left;
  height: 100%;
}
.thrive-footer-nav li a {
  display: block;
  width: 100%;
  height: 100%;
  padding-top: 5.5em;
  font-size: 0.8em;
  background-size: 44% auto;
  background-position: center top;
  letter-spacing: 0.05em;
  font-weight: 100;
  color: #71c170;
}
a[href='/floorplans'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/floorplans.png);
}
a[href='/floorplates'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/floorplates.png);
}
a[href='/viewlines'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/viewlines.png);
}
a[href='/gallery'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/gallery.png);
}
a[href='/siteplan'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/siteplan.png);
}
.masthead-action[href='/floorplans'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/masthead-floorplans.png);
}
.masthead-action[href='/floorplates'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/masthead-floorplates.png);
}
.masthead-action[href='/viewlines'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/masthead-viewlines.png);
}
.masthead-action[href='/gallery'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/masthead-gallery.png);
}
.masthead-action[href='/siteplan'] {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-size: auto;
  display: block;
  overflow: hidden;
  background-image: url(../img/icons/masthead-siteplan.png);
}
.content-modal {
  position: relative;
  background-color: rgba(0, 59, 86, 0.9);
  color: #71c170;
  border: 4px solid #71c170;
  padding: 4em;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 76%;
  height: auto;
  text-align: center;
  opacity: 0;
  margin-left: -38%;
  border: 4px solid #fff;
}
.content-modal .close-button {
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
  line-height: 1em;
  font-size: 2em;
  padding: 0em 0.2em;
  cursor: pointer;
}
.content-modal.modal-visible {
  opacity: 1;
}
.content-modal.modal-anim-in {
  -webkit-animation: kf-modal-in 0.4s ease-out;
}
.content-modal.modal-anim-out {
  -webkit-animation: kf-modal-out 0.3s ease-out;
}
.content-modal p {
  color: #fff;
}
@-webkit-keyframes kf-modal-in {
  0% {
    -webkit-transform: translate3d(0, 20%, 0);
    opacity: 0;
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@-webkit-keyframes kf-modal-out {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translate3d(0, -10%, 0);
    opacity: 0;
  }
}
.masthead {
  width: 100%;
  height: 76px;
  line-height: 76px;
  position: relative;
  background-color: #003b56;
  border-bottom: 1px solid #71c170;
  color: #71c170;
  z-index: 2;
  padding: 0 1em;
}
.masthead-action {
  background-size: 100% auto;
  background-repeat: no-repeat;
  display: block;
  text-align: center;
  cursor: pointer;
  padding: 0 1em;
  height: 76px;
  line-height: 76px;
  width: 3em;
  float: left;
  background-size: 50% auto;
  background-position: center;
  position: relative;
  font-weight: bold;
}
.masthead-action.page-indicator {
  background-size: 60% auto;
}
.masthead-action.close-button {
  background-size: 62% auto;
  background-image: url(../img/icons/close.png);
}
.masthead-action.select-asset {
  background-size: 62% auto;
  background-image: url(../img/icons/add-floorplan.png);
}
.masthead-action.select-asset.inactive {
  opacity: 0.4;
}
.masthead-action.select-asset.selected {
  background-image: url(../img/icons/remove-floorplan.png);
}
.masthead-action.email {
  background-size: 60% auto;
  background-image: url(../img/icons/email.png);
}
.masthead-action.email[data-selected-count]:before {
  content: attr(data-selected-count);
  display: block;
  position: absolute;
  font-size: 0.6em;
  width: 1.4em;
  height: 1.4em;
  line-height: 1.4em;
  border-radius: 1.4em;
  background-color: #fff;
  color: #003b56;
  top: 1.4em;
  right: 0;
}
.masthead-action.register {
  display: block;
  padding: 0.2em 0.8em;
  border-radius: 0.3em;
  text-transform: uppercase;
  color: #003b56;
  background-color: #71c170;
  display: inline-block;
  width: auto;
  height: auto;
  line-height: 1.2em;
  padding: 0.3em 1em ;
  font-size: 0.7em;
  margin: 1.7em 1em 0 0;
  font-family: "HelveticaNeue-ExtraBold", "Helvetica Neue Extra Bold", "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-weight: 400;
  background-color: transparent;
  border: 2px solid #71c170;
  color: #71c170;
}
.masthead-left-actions {
  float: left;
}
.masthead-right-actions {
  float: right;
}
.submenu {
  margin: 0;
  padding: 0;
  list-style-type: none;
  display: block;
  height: 68%;
}
.submenu li,
.submenu li a {
  display: block;
  height: 1.6em;
  line-height: 1.6em;
}
.submenu.first-level-menu li:before {
  background-size: 100% auto;
  background-repeat: no-repeat;
  content: ' ';
  display: block;
  float: left;
  width: 1.2em;
  height: 100%;
  background-image: url(../img/nav-arrow-right-w.png);
  background-size: auto 60%;
  background-position: left center;
}
.submenu.first-level-menu li a {
  margin-left: 1.4em;
}
.submenu.second-level-menu {
  padding-left: 0.6em;
  border-left: 1px solid #003b56;
}
.submenu.second-level-menu li a {
  margin-left: 0.4em;
}
.menu-back-link {
  display: block;
  width: 1.4em;
  float: left;
  height: 68%;
  background-image: url(../img/nav-arrow-left-w.png) !important;
  background-size: 46% auto !important;
  background-position: left 0.4em !important;
  color: transparent;
}
.menu-back-link + .second-level-menu {
  margin-left: 1.4em;
}
.gallery-nav {
  background-size: 100% auto;
  background-repeat: no-repeat;
  position: absolute;
  display: block;
  font-size: 3em;
  top: 0px;
  height: 100%;
  width: 42px;
  overflow: hidden;
  color: transparent;
  background-size: 50% auto;
  background-position: center;
  cursor: pointer;
  z-index: 6;
}
.gallery-nav.next {
  right: 0px;
  background-image: url(../img/nav-arrow-right.png);
}
.gallery-nav.previous {
  left: 0px;
  background-image: url(../img/nav-arrow-left.png);
}
.content-container .swipe-container {
  background-color: #000000;
  position: absolute;
  top: 0;
  left: 0;
  width: 1024px;
  height: 768px;
  overflow: hidden;
  z-index: 4;
  -webkit-backface-visibility: hidden;
}
.content-container .swiper-wrapper {
  height: 100%;
}
.content-container .swiper-slide {
  width: 1024px;
  display: block;
  height: 100%;
  pointer-events: none;
  float: left;
  background-color: #fff;
}
.content-container .slide-img {
  display: block;
  margin: 1% 0 0 1%;
  width: 98%;
  height: auto;
  pointer-events: none;
}
.home .content-container {
  padding-top: 240px;
}
.home .content-container.init-entry {
  background-position: top center;
  background-image: url(../img/bg/thrive-text-bg-trimmed.png);
}
.home .thrive-entry,
.home .flourish-entry {
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 372px;
  height: 226px;
  margin: 0 auto;
  background-position: left top;
  position: relative;
  cursor: pointer;
}
.home .thrive-entry .thrive-entry-button,
.home .flourish-entry .thrive-entry-button {
  position: absolute;
  font-size: 1.9em;
  top: 240px;
  left: 35px;
  color: #71c170;
  background-color: transparent;
  font-family: 'Playfair Display', serif;
  text-transform: none;
}
.home .home-footer {
  position: absolute;
  width: 100%;
  height: 143px;
  bottom: 0px;
  left: 0px;
  background-color: #003b56;
  color: #71c170;
  visibility: hidden;
  z-index: 2;
}
.home .home-footer .thrive-footer-nav {
  width: 90%;
  padding-left: 11%;
}
.home .home-footer.footer-anim-in {
  -webkit-animation: footer-in 0.4s ease-out;
}
.home .home-footer.footer-anim-out {
  -webkit-animation: footer-in 0.4s reverse ease-out;
}
.home .home-footer.visible {
  visibility: visible;
}
.home .thrive-entry-modal {
  border: 4px solid #fff;
}
.home .thrive-entry-modal h1 {
  font-size: 2em;
  margin: 0 auto 0.4em;
}
.home .thrive-entry-modal p {
  font-size: 1.2em;
  width: 16em;
  margin: 0 auto;
}
.home .thrive-entry-modal .icon {
  background-size: 100% auto;
  background-repeat: no-repeat;
  display: inline-block;
  width: 1.2em;
  height: 1.2em;
  margin: 0 0.4em;
  vertical-align: bottom;
}
.home .thrive-entry-modal .add-floorplan-icon {
  background-image: url(../img/icons/add-floorplan.png);
}
.home .thrive-entry-modal .email-icon {
  background-image: url(../img/icons/email.png);
}
.hidetext {
  font-family: 'Playfair Display', serif;
}
@-webkit-keyframes footer-in {
  0% {
    -webkit-transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
    visibility: visible;
  }
}
.gallery .content-container .thumbnail-gallery-container {
  width: 100%;
  height: 606px;
  overflow: scroll;
  position: relative;
  z-index: 1;
  -webkit-overflow-scrolling: touch;
}
.gallery .content-container .thumbnail-gallery-container::-webkit-scrollbar {
  display: none;
}
.gallery .content-container .thumbnail-gallery {
  height: 100%;
  width: 2400px;
}
.gallery .content-container .thumbnail-gallery .thumbnail {
  height: 263px;
  width: 360px;
  margin-right: 40px;
  overflow: hidden;
  float: left;
  cursor: pointer;
}
.gallery .content-container .thumbnail-gallery .thumbnail img {
  display: block;
  height: 223px;
  width: auto;
}
.gallery .content-container .thumbnail-gallery .thumbnail .caption {
  display: block;
  height: 40px;
  line-height: 40px;
  font-size: 0.65em;
}
.gallery .content-container .gallery-type-toggle {
  background-size: 100% auto;
  background-repeat: no-repeat;
  z-index: 999;
  position: absolute;
  top: 1.4em;
  right: 1.4em;
  width: 60px;
  height: 26px;
  cursor: pointer;
}
.gallery .content-container .gallery-type-toggle[data-current='thumb'] {
  background-image: url(../img/icons/gallery-toggle-thumb.png);
}
.gallery .content-container .gallery-type-toggle[data-current='full'] {
  background-image: url(../img/icons/gallery-toggle-full.png);
}
#registration {
  padding: 2em 4em;
  font-size: 0.9em;
  width: 72%;
  top: 64%;
}
#registration h1,
#registration h2 {
  text-align: center;
  font-weight: 400;
  margin: 0 auto;
  margin-bottom: 0.5em;
  font-family: 'Playfair Display', serif;
  color: #fff;
}
#registration h1 small {
  font-size: 0.6em;
  display: block;
  margin-top: 0.2em;
}
#registration h2 {
  font-family: "Helvetica Neue", Helvetica, Arial;
  text-transform: uppercase;
  font-size: 0.9em;
  padding: 0.6em 0;
  margin-top: 0.6em;
  border-top: 1px solid #71c170;
}
#registration > label,
#registration > input:not([type='submit']),
#registration > select {
  font-weight: 400;
  font-size: 0.8em;
  text-transform: none;
}
#registration > input:not([type='submit']),
#registration > select {
  display: block;
  padding: 0.2em 0.8em;
  border-radius: 0.3em;
  text-transform: uppercase;
  text-transform: none;
  color: #00386b;
}
#registration > label {
  color: #fff;
  display: block;
  width: 100%;
  clear: both;
  margin: 0.8em 0 0.2em;
  text-align: left;
}
#registration > input:not([type='submit']) {
  width: 49%;
  margin-bottom: 2%;
}
#registration > input:not([type='submit']):nth-child(2n+1) {
  float: right;
}
#registration > .custom-submit {
  border-radius: 0.2em;
  display: block;
  width: 100%;
  float: none;
  height: 2em;
  line-height: 2em;
  padding: 0;
  background-color: #71c170;
}
.registration-selected-assets {
  font-size: 0.8em;
  margin: 0.4em;
  padding: 0.4em;
  border-top: 1px solid #71c170;
  border-bottom: 1px solid #71c170;
}
.registration-selected-assets a {
  display: inline-block;
  position: relative;
  padding-left: 1.1em;
}
.registration-selected-assets a:not(:first-child) {
  margin-left: 0.8em;
}
.registration-selected-assets a:before {
  background-size: 100% auto;
  background-repeat: no-repeat;
  content: ' ';
  display: block;
  position: absolute;
  width: 0.9em;
  height: 100%;
  top: 0;
  left: 0;
  background-image: url(../img/icons/remove-floorplan.png);
}
.thanks .content-container {
  padding-top: 6em;
}
.registration-thanks {
  position: relative;
  background-color: rgba(0, 59, 86, 0.9);
  color: #71c170;
  border: 4px solid #71c170;
  padding: 4em;
  width: 72%;
  margin: 0 auto;
  text-align: center;
  border-color: #fff;
}
.registration-thanks .close-button {
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
  line-height: 1em;
  font-size: 2em;
  padding: 0em 0.2em;
  cursor: pointer;
}
.registration-thanks h1 {
  font-size: 2.4em;
  margin: 0 auto;
}
.registration-thanks .logotype {
  background-size: 100% auto;
  background-repeat: no-repeat;
  width: 200px;
  height: 80px;
  margin: 0 auto;
  background-image: url(../img/logotype/prosper-logotype-w.png);
}
