/*-------------General Style---------------------------------------*/
html {
    overflow-x:hidden !important;
    height:100%;
}
body {
    margin: 0;
    padding: 0;
    font-family: 'Open Sans', 'Helvetica Neue', sans-serif;
    font-weight: 400;
    font-size: 12px;
    color: #666;
    /*background:#f9f9f9;*/
    height:100%;
    text-align:center;
}
@-o-viewport {width: device-width;}
@-ms-viewport {width: device-width;}
@viewport {width: device-width;}

/*--------------Typography--------------------------------------*/
h1 {
    font-family: 'BauerBodoniBT-Roman', serif;
    color: #444;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 32px;
    -webkit-font-smoothing: antialiased;
    padding:25px 0;
}
h1.large {
    font-size: 50px;
    line-height:1;
}
h2 {
    font-family: 'Raleway', sans-serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 18px;
    font-weight: 400;
}
h2.editorial {
    font-family: 'BauerBodoniBT-Roman', serif;
    color: #444444;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-align: center;
    font-size: 22px;
    -webkit-font-smoothing: antialiased;
    margin-bottom: 10px;
}
h2.editorial.large {
    font-size: 30px;
}
h2.large {
    font-family: 'BauerBodoniBT-Roman', serif;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 50px;
    -webkit-font-smoothing: antialiased;
    padding:25px 0;
}
.post-info h2 {
    font-family: 'BauerBodoniBT-Roman', serif;
    color: #666;
    font-size: 40px;
    -webkit-font-smoothing: antialiased;
    margin-bottom: 10px;
    margin-top: 15px;
}
h3 {
    font-size:24px;
    line-height: 1.3;
    font-weight: 300;
}
h3.editorial {
    font-family: 'BauerBodoniBT-Roman', serif;
    font-size: 26px;
    -webkit-font-smoothing: antialiased;
}
h3.small {
    font-size:14px;
    font-weight: 400;
    text-transform: uppercase;
}
.post-copy h3, .side-bar h3 {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 14px;
    font-weight: 600;
    text-align:left;
    margin-bottom: 15px;
}
.post-copy h4, h4.luxury-collection-item {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 11px;
    padding: 10px 0;
}
h4 {
    font-size: 0.9em;
    font-weight: 200;
}
h4.small {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}
h5 {
    font-size: 0.8em;
    font-weight: 200;
}
h6 {
    font-size: 0.6em;
    font-weight: 200;
}
p {
    text-align:left;
    font-size:14px;
    font-weight:300;
    line-height:24px;
    padding-bottom:10px;
}
p.editorial {
    font-family: 'BauerBodoniBT-Roman', serif;
    font-size:16px;
}
p.large{
    font-size:17px;
}
.fs-15{
    font-size:15px;
}
.fs-35{
    font-size:35px;
}
.fw-300{
    font-weight:300;
}
.fw-500{
    font-weight:500;
}
.ff-editorial{
    font-family: 'BauerBodoniBT-Roman', serif;
}
.test blockquote.large p {
    font-size: 1.5rem;
    font-weight: 300;
    line-height:1.4;
}
blockquote.large p {
    font-size: 1.3rem;
    font-weight: 300;
}
blockquote cite {
    margin-top: 2rem;
    font-size: 60%;
    display: block;
    text-transform: uppercase;
    font-weight: bold;
    font-style: normal;
    letter-spacing: 0.1rem;
}
strong {
    font-weight: 600;
}
.privacy strong{
    font-weight: 400;
    text-transform: uppercase;
}
.font-lightened {
    -webkit-font-smoothing: antialiased;
}
.note-links {
    font-size: 12px;
    color:#aaa;
}
.note-links a {
    text-decoration:underline;
    margin-right:5px;
    color:#aaa;
}
a.underline {
    text-decoration:underline;
}
a.underline-hover:hover {
    text-decoration:underline;
}
.lowercase {
    text-transform:lowercase;
}
.credit {
    font-size: 10px;
    font-weight: normal;
}
.legals {
    font-size: 9px;
    font-weight: normal;
}
.legals a {
    margin-right:10px;
    color:#666;
}
.list {
    list-style-type: square;
    list-style-position: inside;
    text-align:left;
    font-size: 14px;
    font-weight: 300;
    line-height: 24px;
    padding-bottom: 10px;
    padding-left:30px;
}
.list-title {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 12px;
    line-height:1.3;
    font-weight: 200;
    text-align:left;
}
.table > thead > tr > th{
    font-family:inherit;
    font-size:inherit;
}
.table-striped > tbody > tr:nth-of-type(odd) {
    background-color: #fff;
}
.transition {
    -webkit-transition: all 500ms linear;
    -moz-transition: all 500ms linear;
    -o-transition: all 500ms linear;
    -ms-transition: all 500ms linear;
    transition: all 500ms linear;
}
.transition3 {
    -webkit-transition: all 300ms linear;
    -moz-transition: all 300ms linear;
    -o-transition: all 300ms linear;
    -ms-transition: all 300ms linear;
    transition: all 300ms linear;
}
/* ------------ Colors --------------------------*/
.dark-grey {
    color:#3E3536;
}
.medium-grey {
    color:#666;
}
.light-grey {
    color:#888;
}
.lighter-grey {
    color:#999;
}
.white {
    color:white !important;
}
.blk {
    color:black;
}
.gold {
    color:#bfb396;
}
.soft-red {
    color:#fd7470;
}
.green {
    color:#778F79;
}
.bg-white {
    background-color: white;
}
.bg-lightgrey {
    background-color:#f9f9f9;
}
.bg-darkgrey {
    background-color:#232323;
}
.bg-mediumgrey {
    background-color:#efefef;
}
.bkg-none {
    border: 1px solid #000000;
}
.bkg-white {
    background-color: #ffffff;
    border: 1px solid #000000;
}
.bkg-black {
    background-color: #000000;
    border: 1px solid #000000;
}
.bkg-darkgrey {
    background-color: #555;
    border: 1px solid #555;
    font-weight:400;
}
.bkg-red {
    background-color: #fd7470;
    border: 1px solid #fd7470;
}
.bkg-gold, a.bkg-gold, .bkg-gold:link {
    background-color: #d5d0c5;
}
.bkg-white-transparent {
    background-color: rgba(255,255,255,0.8);
}
.bkg-hover-black:hover {
    background-color: #000000;
    border-color: #000000;
    color:white;
}
.bkg-hover-white:hover {
    background-color: #ffffff;
    border-color: #000000;
    color:#000000 !important;
}
.bkg-hover-gold:hover {
    background-color: #b2a584;
    border-color: #b2a584;
    color:white !important;
}
.color-hover-white:hover {
    color: #ffffff;
}
/* ------------ Icons --------------------------*/
.square-icon {
    width: 22px;
    height: 22px;
    line-height: 24px;
    text-align: center;
    display: inline-block;
    padding-top: 4px;
}
.square-icon:hover {
    opacity:0.5;
}
/*-------------Form elements -----------------------------*/
.contact-form-container .form-element,
.contact-form-container textarea,
.comment-form .form-element,
.comment-form textarea {
    margin-bottom: 3rem;
    background-color: white;
    border: none;
    font-size: 12px;
    text-transform: initial;
    color: #999;
}
.appypro .form-element{
    margin-bottom: 30px;
}
.form-element:focus,
textarea:focus {
    background-color: #f4f4f4;
    box-shadow: none;
    color: #000;
}
.form-element.required-field:focus,
textarea.required-field:focus {
    background-color: #f4f4f4;
    box-shadow: none;
    color: #000;
}
.form-element, textarea {
    line-height: 1.4;
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
input, textarea {
    width: 100%;
    padding: 16px 30px;
    margin: 0 0 30px 0;
}
input, textarea, button, a {
    -webkit-transition-property: background, border-color, color, opacity;
    transition-property: background, border-color, color, opacity;
    -webkit-transition-duration: 300ms;
    transition-duration: 300ms;
}
input[type="submit"] {
    width: auto;
    border:0;
}
::-webkit-input-placeholder {
    color: #666;
}
:-moz-placeholder { /* Firefox 18- */
    color: #666;
}
::-moz-placeholder { /* Firefox 19+ */
    color: #666;
}
:-ms-input-placeholder {
    color: #666;
}
label{
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
label.middle-left{
    float: left;
    padding-left: 30px;
    padding-top: 20px;
    padding-right: 5px;
}
.css-input {
  position: relative;
  display: inline-block;
  margin: 2px 0;
  font-weight: 400;
  cursor: pointer;
  text-transform: initial;
  letter-spacing:initial;
}
.css-input input {
  position: absolute;
  opacity: 0;
}
.css-input input:focus + span {
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.25);
}
.css-input input + span {
  position: relative;
  display: inline-block;
  margin-top: -2px;
  margin-right: 3px;
  vertical-align: middle;
}
.css-input input + span:after {
  position: absolute;
  content: "";
}
.css-input-disabled {
  opacity: .5;
  cursor: not-allowed;
}
.css-checkbox {
  margin: 7px 0;
}
.css-checkbox input + span {
  width: 20px;
  height: 20px;
  background-color: #fff;
  border: 1px solid #ddd;
  -moz-transition: background-color 0.2s;
  -o-transition: background-color 0.2s;
  -ms-transition: background-color 0.2s;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.css-checkbox input + span:after {
    content: " ";
      display: block;
      width: 0.4em; /* the short bar of the mark is half as long as the long bar*/
      height: 0.65em;
      border: solid white;
      border-width: 0 0.2em 0.2em 0; 
      position: absolute;
      left: 0.5em;
      top: 35%;
      margin-top: -0.2em;
      -webkit-transform: rotate(45deg); 
      -moz-transform: rotate(45deg);
      -o-transform: rotate(45deg);
      transform: rotate(45deg);
}
.css-checkbox:hover input + span {
  border-color: #ccc;
}
.css-checkbox.css-checkbox-sm {
  margin: 9px 0 8px;
  font-size: 12px;
}
.css-checkbox.css-checkbox-sm input + span {
  width: 16px;
  height: 16px;
}
.css-checkbox.css-checkbox-sm input + span:after {
  font-size: 8px;
  line-height: 15px;
}
.css-checkbox.css-checkbox-lg {
  margin: 3px 0;
}
.css-checkbox.css-checkbox-lg input + span {
  width: 30px;
  height: 30px;
}
.css-checkbox.css-checkbox-lg input + span:after {
  font-size: 12px;
  line-height: 30px;
}
.css-checkbox.css-checkbox-rounded input + span {
  border-radius: 3px;
}
.css-checkbox-default input:checked + span {
  background-color: #222;
  border-color: #222;
}
/* Mailchimp styles */
.phonefield-us .phonearea input, .phonefield-us .phonedetail1 input {
    width: 40px;
}
.phonefield-us input {
    display: inline;
    width: 60px;
    margin: 0 2px;
    letter-spacing: 1px;
    text-align: center;
    padding: 5px 0 2px 0;
}
.nowrap {
    white-space: nowrap;
}
select.appypro{
    display: block;
    margin-top: 30px;
    margin-left: 100px;
}
.form-field-group input.form-element{
    margin-bottom: 10px;
}
.form-field-group{
    margin-bottom: 30px;
    text-align:left;
}
.form-response{
    text-align:left;
    white-space: normal;
    padding-left:30px;
}
/*------- end mailchimp form */
button.medium, .button.medium {
    padding: 13px 25px;
    font-size: 13px;
}
.button, input {
    text-transform: uppercase;
    line-height: 1.4;
}
button, .button {
    font-family: 'Raleway', sans-serif;
    padding: 13px 25px;
    margin: 0 0 1rem 0;
    font-size: 13px;
    letter-spacing:1px;
    line-height: 1.4;
    font-weight: normal;
    vertical-align: top;
    display: inline-block;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/*-------------Layout--------------------------------------*/
#wrapper {
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
}
#header-container {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    height: 70px;
    line-height: 70px;
    width: 100%;
    background: #fff;
    -webkit-transform: translate3d(0,0,0);
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
}
#content_holder {
    height: 100%;
    margin-left: 0;
    vertical-align: top;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    z-index: 3;
    width: 100%;
}
.splash-full-screen{
    height: 100vh;
    width: 100vw;
    background-size: cover;
    background-attachment: scroll;
    background-position: center;
    background-repeat: repeat;
    background-origin: content-box;
    image-rendering: -webkit-optimize-contrast;
}
.splash-full-screen-repeat{
    height: 100vh;
    width: 100vw;
    background-size: 100%;
    background-repeat: repeat;
    image-rendering: -webkit-optimize-contrast;
}
.text-container-centered {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
#left_column, #right_column {
    position:fixed;
    width:50px;
    height:100%;
    background:#fff;
    z-index:1;
    -webkit-transform: translate3d(0,0,0);
}
#left_column {
    left:0;
}
#right_column {
    right:0;
}
#main {
    vertical-align: top;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    z-index: 2;
    height: 100%;
    padding: 50px;
}
#content {
    width: 100%;
    height:100%;
    position: relative;
    z-index: 2;
}
.full-height {
    height:100%;
}
.full-height-wrap {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.height-wrap-85 {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 85%;
}
.height-wrap-15 {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 15%;
}
.height-wrap-90 {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 90%;
}
.height-wrap-10 {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 10%;
}
.half-height-wrap {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 50%;
}
.bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-attachment: scroll;
    background-position: center;
    background-repeat: repeat;
    background-origin: content-box;
}
.section-block-media {
    width: 100%;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    position: relative;
    z-index: 1;
}
.foreground {
    position:relative;
    top:30px;
}
.content-valign {
    height:100%;
}
.content-valign:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}
.content-valign h1 {
    text-align: center;
    display: inline-block;
    vertical-align: middle;
}
.fixed-info-container {
    position: absolute;
    z-index: 2;
    top: 0;
    height: 100%;
    width: 280px;
    background: #666;
    padding: 120px 30px 80px 30px;
    overflow: auto;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    image-rendering: -webkit-optimize-contrast;
}
.min-width{
    min-width:630px;
}
/******* https://css-tricks.com/centering-in-the-unknown/ */
/* This parent can be any width and height */
.block-valign-container {
  text-align: center;

  /* May want to do this if there is risk the container may be narrower than the element inside */
  white-space: nowrap;
  height:100%;
}
/* The ghost, nudged to maintain perfect centering */
.block-valign-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle;
  /* margin-right: -0.25em;  Adjusts for spacing */
}
/* The element to be centered, can also be of any width and height */ 
.centered-valign-content {
  display: inline-block;
  vertical-align: middle;
}
.bottom-valign-content {
  display: inline-block;
  vertical-align: bottom;
}
/* end centering-in-the-unknown/ */

/*-- Sections -->*/
.sect-scroll {
    position: absolute;
    bottom: 20px;
    left: 50%;
    width: 40px;
    height: 40px;
    line-height: 40px;
    margin-left: -20px;
    z-index: 5;
    font-size: 18px;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}
.sect-scroll:before {
    content: '';
    position: absolute;
    top: -10px;
    left: 50%;
    margin-left: -30px;
    width: 60px;
    background: #fff;
    height: 1px;
    opacity: 0.6;
}
.padding-35 {
    padding:35px;
}
.padding-15 {
    padding:15px;
}
.padding-10 {
    padding:10px;
}
.section-padding {
    padding-top: 40px;
}
.section-padding-40 {
    padding-top: 40px;
}
.section-padding-50 {
    padding-top: 50px !important;
}
.section-padding-20 {
    padding-top: 20px;
}
.section-padding-10 {
    padding-top: 10px;
}
.responsive-padding-2 {
    padding-top: 2%;
}
.responsive-padding li {
    padding-bottom:3vh;
}
.responsive-padding-cover {
    padding-top:4vh;
}
.flush-left{
    padding-left:0;
}
.flush-bottom, div.flush-bottom{
    padding-bottom:0;
}
.push-b-10{
    padding-bottom:10px;
}
.push-l-20{
    padding-left:20px;
}
.push-l-70{
    padding-left:70px;
}
.push-r-20{
    padding-right:20px;
}
.push-b-20{
    padding-bottom:20px;
}
.push-t-20{
    padding-top:20px;
}
.push-t-40{
    padding-top:40px;
}
.row {
    width: 100%;
}
.column {
    -webkit-flex-direction: column;
    flex-direction: column;
}
.media-column {
    height: 100%;
    width:100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
    top: 0;
    left: 0;
    z-index: 0;
    float:left;
}
.multi {
    float:left;
    overflow: hidden;
}
.center {
    text-align:center;
}
.left{
    text-align:left;
}
.text-bottom-left {
    position:absolute;
    bottom:20px;
}
.width-1 {
    width:100%;
}
.width-2 {
    width:50%;
}
.width-3 {
    width:33%;
}
.width-4 {
    width:75%;
}
.width-5 {
    width:25%;
}
.width-6 {
    width:65%;
}
.width-7 {
    width:70%;
}
.width-8 {
    width:37.5%;
}
.clear-line:before {
    content:"";
    display:block;
        width:100%;
        height:10px;
        background-color:yellow;
}
.margintop-10 {
    margin-top:10px;
}
.margintop-20 {
    margin-top:20px;
}
.horizontal-center {
    margin: 0 auto;
}
.section-blog {
    padding-bottom: 50px;
    overflow: hidden;
}
.circle-icons {
    width: 70px;
    height: 70px;
    border: 2px solid #eee;
    border-radius: 50px;
    display: inline-block;
    margin-bottom: 20px;
    padding-top: 25px;
    padding-left: 3px;
}
/*------------ Blog -----------------------------*/
.border-top {
    border-top: 1px solid #000;
}
.post-content {
    margin-right: 50px;
    padding-top: 2rem;
    box-sizing:border-box;
}
.post-info {
    text-align:left;
    padding: 20px 0 40px 0;
}
.post-info h4, .about-content h4 {
    text-transform:uppercase;;
    letter-spacing:1px;
    font-size: 14px;
    font-weight: 600;
}
.post-info h2 {
    padding: 5px 0;
}
.post-copy img {
    width:100%;
}
.post-copy img.initial {
    width:auto;
    width:initial;
}
.pixels img {
    display:inline;
    width: 1px!important;
}
.side-bar {
    padding-top: 2rem;
}
.about-content {
    padding:30px 5px 0 5px;
}
.about-content p {
    font-size: 12px;
    line-height: 24px
}
.about-content > img {
    margin: 10px 0;
}
.about-inner-content img {
    margin: 10px 0;
}
.side-widgets {
    width: 100%;
    margin-bottom: 40px;
    text-align: left;
    border-bottom: 2px solid #eee;
    padding-bottom: 20px;
    margin-top: 10px;
}
.tagcloud li {
    display: inline-block;
    line-height: 35px;
}
.tagcloud li a {
    padding: 6px 10px;
    margin-right: 2px;
    background: #292929;
    border:1px solid #292929;
    color: #fff;
    font-weight: 400;
    font-size: 12px;
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
}
.tagcloud li a:hover {
    background: #fff;
    color: #292929;
}
/*-------------Header--------------------------------------*/

#header-container {
    float: left;
    width: 100%;
    padding: 0 50px;
    padding-top: 10px;
    position: relative;
}
.logo {
    position: absolute;
    top: 10px;
    left: 50px;
    height: 50px;
}
.logo img {
    position: relative;
    top: 27%;
}
.logo #logo-icon {
    padding-right: 10px;
}

/*--Nav----------*/
.login {
    float: right;
    position: relative;
}
.login:before {
    content: '';
    position: absolute;
    left: 3px;
    width: 2px;
    height: 30px;
    background: #eee;
    z-index: 1;
}
.login span{
    vertical-align: top;
}
.login .menu {
    margin-top: 20px;
}
.login .menu li a {
    padding: 10px;
}
.login a {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.login li a:last-child{
     padding-right: 0;
}
.login li a i {
    font-size: 13px;
}
ul.menu{
    position: relative;
    float: left;
}
.nav-wrapper {
    float: right;
    position: relative;
}
nav {
    position: relative;
    float: left;
    width: 100%;
    top: 10px;
}
nav li {
    float: left;
    position: relative;
}
nav li a {
    float: left;
    padding: 10px 18px 25px 18px;
    line-height: 1;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #666;
    top: 0;
    position: relative;
    -webkit-transition: all 100ms linear;
    -moz-transition: all 100ms linear;
    -o-transition: all 100ms linear;
    -ms-transition: all 100ms linear;
    transition: all 100ms linear;
}
.sub-menu > li a {
    padding: 10px 22px;
    width: 100%;
    text-align: left;
}
nav li a.active:before {
    content: '';
    position: absolute;
    bottom: 10px;
    left: 0;
    width: 100%;
    height: 80%;
    background: #f5f5f5;
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
    z-index: -1;
}
nav li a.active:hover {
    color:#000;
}
nav li a:hover {
    color:#ccc;
}
nav li a.active:hover:before {
    height:0;
}
/*---Subnav---*/
nav li ul a:before {
    display:none;
}
nav li ul a.active, #footer-menu li ul a.active {
    color:#000;
    font-weight:600;
}
nav li ul, #footer-menu li ul {
    margin: 30px 0 0 0;
    opacity: 0;
    visibility: hidden;
    position: absolute;
    min-width: 150px;
    top: 38px;
    left: 0;
    z-index: 1;
    background: #fff;
    transition: margin .2s ease-in-out;
    white-space:nowrap;
}
nav li:hover > ul, #footer-menu li:hover > ul {
    opacity: 1;
    visibility: visible;
    margin: 0;
}
#footer-menu li:hover > ul {
    position: absolute;
    top: auto;
    left: 0;
    bottom: 100%;
    z-index: 1000;
    float: left;
    text-align: left;
    background-color: #fff;
    -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175);
    box-shadow: 0 6px 12px rgba(0,0,0,.175);
    padding: 10px 0;
}
#footer-menu li ul li a {
    padding: 5px 22px;
    line-height:1.4;
}
#footer-menu li ul li a:hover {
    color:#ccc;;
    text-decoration:none;
}
#footer-menu li ul li {
    padding: 10px 10px;
}
nav li ul li ul {
    top: 0;
    left: -100%;
}
nav li ul li:hover > ul, #footer-menu li ul li:hover > ul {
    opacity: 1;
    visibility: visible;
    right: 100%;
}
nav li ul li, #footer-menu li ul li {
    float: none;
    display: block;
    border: 0;
}
.visible-mobile {
    display: none;
}
/*---Drawer---*/
.nav-drawer {
    float: right;
    border-left: 1px solid rgba(255,255,255,0.4);
    margin: 0 0 0 10px;
    padding-left: 22px;
    display: none;
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
}
.nav-drawer-icon {
    float: right;
    width: 25px;
    height: 24px;
    position: relative;
    margin-top: 9px;
    cursor: pointer;
}
.nav-drawer-icon span {
    float: left;
    width: 100%;
    height: 3px;
    background: #000;
    margin-bottom: 4px;
    position: relative;
}
/*--Sides--*/
.hs {
    position: absolute;
    top: 50%;
    right: -40px;
    width: 30px;
    z-index: 20;
    height: 60px;
    margin-top: -30px;
}
.hs-plain {
    position: fixed;
    top: 50%;
    right: 0px;
    width: 50px;
    z-index: 20;
}
.hs:before, .hs:after {
    content: '';
    position: absolute;
    width: 100%;
    height: 2px;
    background: #eee;
    -webkit-transition: all 200ms linear;
    -moz-transition: all 200ms linear;
    -o-transition: all 200ms linear;
    -ms-transition: all 200ms linear;
    transition: all 200ms linear;
}
.hs:before {
    top: -10px;
    left: 0;
}
.hs:after {
    bottom: -8px;
    right: 0;
}
.hs a {
    position: relative;
    float: left;
    width: 100%;
    height: 30px;
    font-size: 19px;
    margin-bottom: 4px;
}
.hs a.down-arrow {
    margin-top:15px;
}
.ls {
    position: fixed;
    bottom: 0;
    margin-left: -34px;
    cursor: default;
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    -moz-transform-origin: left top;
    -o-transform-origin: left top;
    transform-origin: left top;
    z-index: 12;
}
.photo-credit {
    width: 208px;
}
/*--Swiper--*/
.swiper-container {
    width: 100%;
    height: 100%;
    background-color: white;
}
.swiper-container-quote {
    width: 100%;
    height: 100%;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.swiper-container.resize {
    float: left;
    position: relative;
    padding-left: 310px;
}
.swiper-pagination.resize {
    padding-left: 310px;
}
.fifty-percent-wrap {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 50%;
}
.banner-percent-wrap {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 40%;
}
.swiper-slide {
    text-align: center;
    /* Center slide text vertically */
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.swiper-slide.topalign {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
}
.swiper-slide.bottomalign {
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
}
.slide {
    background-size: cover;
    background-attachment: scroll;
    background-position: center;
    background-repeat: repeat;
    background-origin: content-box;
    image-rendering: -webkit-optimize-contrast;
}
.swiper-pagination {
    position: absolute;
    z-index: 20;
    left: 0;
    width: 100%;
    bottom: 20px;
}
.swiper-pagination-bullet {
    margin-right: 5px;
    margin-left: 7px;
    -webkit-transition: 0.5s 0.2s;
    transition: 0.5s 0.2s;
    width: 7px;
    height: 7px;
    border: 1px solid #666;
}
.swiper-pagination-bullet-active {
    background: #ffffff;
}
.hs-plain .swiper-pagination{
    padding-left:10px;
    padding-right :10px;
}
.hs-plain .swiper-pagination-bullet {
    margin-top: 4px;
    margin-bottom: 4px;
    background: #ffffff;
    opacity:1;
}
.hs-plain .swiper-pagination-bullet-active {
    background: #666;
}
.swiper-button-disabled {
    opacity: 0.2;
}
.pagination-fraction{
    position:absolute;
    bottom:50px;
    left:0;
    right:0;
}

.pagination-current{
    padding-bottom:2px;
}
.pagination-total{
    padding-top:2px;
    border-top:solid white 1px;
    display:inline-block;
}
.swiper-nav-inside { /*for demo page*/
    position: absolute; 
    bottom: 0px; 
    z-index: 20; 
    height: 30px; 
    color: white; 
    font-size: 1.8em;
}
.swiper-nav-inside .swiper-button-disabled {
    display:none;
}
/*--------Isotope Grid-------->*/
.grid-filter-menu ul, .grid-filter-menu li {
    padding: 0;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.grid-filter-menu ul {
    width: 100%;
    margin: 5px 0 10px 0;
}
.grid-filter-menu li {
    display: inline-block;
    line-height: 1;
}
.grid-filter-menu a.current {
    border-bottom: 2px solid #ddd;
}
.grid-filter-menu a.current:before {
    content: "\f00c";
    padding-right: 5px;
    color: #ccc;
    font-family: FontAwesome;
    font-weight: normal;
    font-style: normal;
    display: block;
    margin-bottom: 5px;
}
.grid-filter-menu a {
    padding: 7px 15px;
    display: block;
    position: relative;
    font-size:11px;
    color:#666;
    margin: 10px 0;
}
.section-grid {
    position: relative;
    padding-bottom: 50px;
    max-width:1200px;
    margin:0 auto;
    overflow: hidden;
}
.grid-features{
    min-width: 800px;
}
.grid-gutter {
    width: 5%;
}
.grid-sizer, .grid-item {
    width: 30%;
    height: 360px;
}
.grid-item {
    float: left;
    margin-bottom: 5%;
}
.grid-item--height2 {
    height: 150px;
}
.create {
    border: 1px solid #95989A;
    background-color:white;
}
.create .overlay-info {
    background-color:#eee;
}
.organize {
    background-color:#ece1e1;
}
.organize .overlay-info {
    background-color:#ece1e1;
}
.share {
    background-color:#d5d0c5;
}
.share .overlay-info {
    background-color:#d5d0c5;
}
.grid-subtitle {
    display:none;
}
.item-short-description {
    display:none;
}
.grid-content.editorial p.item-short-description {
    text-transform:initial;
}
/* List view */
.list-view {
    width:965px;
    margin:auto;
}
.list-view .grid-item.grid-subtitle {
    display:block;
    height:90px;
}
.list-view .item-short-description {
    display:block;
}
.list-view .grid-sizer {
    width: 100%;
    height:0;
}
.list-view .grid-item {
    width: 100%;
    height: 50px;
    margin-bottom: 0;
}
.list-view .create, .list-view .organize, .list-view .share {
    background-color:transparent;
    border:none;
    border-bottom:1px solid #ddd;
}
.list-view .caption {
    display:none;
}
.grid-item:before {
    content: '';
    display: inline-block;
    height: 100%; 
    vertical-align: middle;
}
/* List view */
.list-view .grid-item {
    text-align: left;
}
.list-view .grid-content p {
    display:table-cell;
    vertical-align:middle;
    padding-bottom:0;
    margin-right:10px;
    line-height:1.4;
}
.list-view .grid-content.editorial p:first-child {
    padding-bottom: 5px;
}
.list-view .grid-content p i {
    width:40px;
    padding-top: 3px;
}
.list-view .grid-content p span.icon-group {
    letter-spacing:-7px;
    margin-left: -5px;
}
.list-view .grid-content p span.icon-group i:first-child {
    width:19px;
}
.list-view .grid-content p span.icon-group i:last-child {
    width:18px;
    margin-right:8px;
    padding-top: 8px;
}
.list-view .grid-content p:nth-child(2) {
    width:250px;
    text-align:left;
}
.list-view .grid-content p:nth-child(3) {
    width:665px;
    text-align:left;
}
.list-view .grid-content.editorial p {
    font-family: inherit;
    font-size: 15px;
    letter-spacing: normal;
}
.list-view .grid-subtitle .grid-content.editorial p {
    font-family: 'BauerBodoniBT-Roman', serif;
    font-size: 22px;
    padding-top:30px;
}
.list-view .grid-content.editorial .caption {
    display:none;
}
.list-view .grid-content p br {
    display:none;
}
.grid-content {
    text-align: center;
    display: inline-block;
    vertical-align: middle;
}
.grid-content.editorial p {
    font-family: 'BauerBodoniBT-Roman', serif;
    color:#444444;
    text-transform:uppercase;
    letter-spacing: 1px;
    text-align:center;
    font-size: 22px;
    -webkit-font-smoothing: antialiased;
}
.grid-content.editorial .caption {
    font-size: 11px;
    text-transform:initial;
}
.grid-content.editorial p:first-child {
    padding-bottom: 25px;
}
.post-image {
    position:relative;
}
.grid-item .overlay-info, .post-image .overlay-info, .luxury-collection-item .overlay-info {
    width: 101%;
    line-height: 1;
    opacity: 0
}

.grid-item:hover .overlay-info, .post-image:hover .overlay-info, .luxury-collection-item:hover .overlay-info {
    opacity: 1
}
/* List view */
.list-view .grid-item:hover .overlay-info{
    opacity: 0
}

.overlay-info {
    width: 101%;
    height: 101%;
    padding: 0;
    margin: 0;
    opacity: 0;
    position: absolute;
    top: -1px;
    left: -1px;
    z-index: 1;
    -webkit-transition-property: padding, background, color, opacity, box-shadow, -webkit-transform;
    transition-property: padding, background, color, opacity, box-shadow, transform;
    -webkit-transition-duration: 300ms;
    transition-duration: 300ms;
    overflow: hidden;
}
.overlay-info img {
    max-width: 101%;
    height: auto;
    display: inline-block;
    vertical-align: middle;
    border: none;
    outline: none;
    -webkit-transition-property: padding, background, color, opacity, -webkit-transform;
    transition-property: padding, background, color, opacity,transform;
    -webkit-transition-duration: 300ms;
    transition-duration: 300ms;
    width:101%;
}
.overlay-info:hover img {
    -webkit-transform: scale3d(1.2,1.2,1);
    transform: scale3d(1.2,1.2,1);
}
.overlay-info > span {
    width: 100%;
    height: 100%;
    padding: 20px;
    box-sizing:border-box;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    text-align:left;
    font-size:14px;
    font-weight:300;
    line-height:24px;
}
.overlay-info > span > span {
    position: absolute;
    bottom: 20px;
    padding-right: 20px;
}
/*------------- Timeline -------------------------------------*/
.container {
    width:80%;
    margin:0 auto;
    overflow:auto;
    padding:2%;
}
.right-content, .left-content {
    float:left;
    display:block;
    width:50%;
    padding:1% 2%;
}
.left-content {
    border-right:1px solid #efefef;
}
.left-content div {
    margin:150px 0 0;
    text-align:right;
}
/*.left-content div p {
text-align:right;
}*/
.right-content div {
    margin:80px 0 150px;
}
.container p {
    -webkit-transition: all 0.7s ease-in-out;
    -moz-transition: all 0.7 ease-in-out;
    -ms-transition: all 0.7s ease-in-out;
    -o-transition: all 0.7s ease-in-out;
    transition: all 0.7s ease-in-out;	
}
.left-content .more-padding {
    padding-right:100px;
}
.right-content .more-padding {
    padding-left:100px;
}
/*----------Pricing----------------------*/
.pricing-table-header {
    padding: 15px 15px;
}
.pricing-table-header h2 {
    font-size: 15px;
    line-height: 1;
    font-weight: 700;
    text-transform: normal;
    color: #000;
}
.pricing-table-price {
    padding: 15px;
    color: #232323;
}
.pricing-table-price h4 {
    font-size: 38px;
}
.pricing-table-price .currency {
    font-size: 13px;
    top: -15px;
    position: relative;
}
.pricing-table-price .interval {
    font-size: 14px;
    opacity: 0.5;
}
ul.pricing-table-options {
    margin: 0;
    padding: 0 0 2rem 0;
    list-style: none;
    line-height: 1.5;
    font-size: 14px;
}
.pricing-table-options li {
    margin-bottom: 0;
    padding: 5px 15px;
}
.pricing-table-column {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    float: left;
    width:50%;
}
.pricing-table-column.callout {
    margin-left: -1px;
    margin-bottom: -2rem;
    box-shadow: 0rem 0rem 0.8rem rgba(0,0,0,.2);
    position: relative;
    top: -1.5rem;
    z-index: 1;
}
/*----------About----------*/
.circle-image {
    width:60px;
    height:60px;
    border-radius:30px;
}
.testimonials blockquote i{
    font-size:0.5em;
    vertical-align: super;
    margin-right:5px;
    margin-left:5px;
}
/*------  Footer ------------------------------------------------------*/
#footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50px;
    background: #fff;
    z-index: 15;
    padding: 0 50px;
    line-height: 50px;
}
#social-media {
    float:left;
}
#social-media li {
    float: left;
}
#social-media li a {
    padding: 0 8px;
    font-size: 13px;
    color: #666;
}
#social-media li a:hover {
    color: #222;
}
#footer-menu {
    float: left;
    font-size: 10px;
    color: #666;
}
#footer-menu span {
    float: left;
}
#footer-menu ul {
    position: relative;
    float: left;
    margin-left: 15px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
#footer-menu ul:before {
    content: '';
    position: absolute;
    top: 16px;
    left: -2px;
    background: #eee;
    width: 2px;
    height: 20px;
}
#footer-menu ul li {
    float: left;
}
#footer-menu ul li a {
    padding: 0 10px;
    color: #666;
}
#footer-menu ul li a:hover {
    text-decoration: underline;
    cursor:pointer;
}
#footer-links p{
    font-size: 12px;
    line-height: 20px;
}
#footer-links .button {
    padding: 10px 25px;
    font-size: 10px;
}
#footer-links .disclaimer .legals{
    line-height: 1.5;
}
#text-hidden{
    padding-top: 5px;
    height: 0;
    overflow: hidden;
}
#text-hidden.open{
    height: auto;
}
.button-footer{
    margin-bottom: 0;
    margin-top: 5px;
    /*float:right;*/
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing: grayscale;
    /*font-weight:700;*/
}
.button-footer i{
    vertical-align:bottom;
    font-size:1.5em;
    margin-left:5px;
    margin-right: -5px;
}
/*------Responsive------------------------------------------------------*/
@media only screen and (max-width: 1036px) {
    .visible-mobile {
        display: inline;
    }
    .nav-drawer {
        display: block;
    }
    .nav-drawer-icon {
        margin-top: 19px;
    }
    .nav-wrapper {
        position: absolute;
        top: 60px;
        right: -285px;
        bottom: 0;
        display: block;
        float: left;
        width: 100%;
        max-width: 284px;
        height: 100%;
        -moz-transition: all 300ms;
        -webkit-transition: all 300ms;
        transition: all 300ms;
    }
    nav ul li , nav ul li ul li , nav li ul li > ul {
        float:left;
        width:100%;
        margin-bottom:10px;
        text-align:left;
        left:0;
        opacity:1;
        right: 0;
    }
    nav li ul {
        margin: 0;
        padding-left:20px;
        opacity: 1;
        visibility: visible;
        position: relative;
        width:100%;
        display:block;
        top:0;
        left: 0;
        z-index: 1;
        border-bottom:none;
    }
    .login {
        float: none;
    }
    .login:before {
        background: transparent;
    }
    ul.login:after {
        content: '';
        display:block;
        overflow:hidden;
        width: 100%;
        height: 2px;
        background: #fff;
        z-index: 1;
    }
    ul.menu{
        padding-top: 20px;
    }
    #wrapper.menu-active {
        right: 250px;
    }
    #wrapper.menu-active header {
        right: 250px;
    }
    #wrapper.menu-active #header-container {
        background: linear-gradient(90deg, #ffffff 93%, #f5f5f5 7%);
    }
    
    /*---- hp slider ----*/
    .fixed-info-container {
        display: none;
    }
    .swiper-container.resize, .swiper-pagination.resize {
        padding-left: 0;
    }
    .min-width{
        min-width: 100%;
    }
    .reset-xs{
        width: 100%;
        float: none;
        padding-right:0;
        padding-left: 0;
    }
}
/*-----------------Luxury-----------------*/
.luxury h1 {
}
.luxury h2 {
    text-transform:uppercase;
    letter-spacing:1px;
    font-size: 13px;
    font-weight:normal;
    padding:20px 0 10px 0;
    color:#000;
}
.luxury h4 {
    text-transform:uppercase;
    letter-spacing:1px;
    font-size: 11px;
    font-weight:normal;
    padding:20px 0 10px 0;
    color:#000;
}
.luxury-thumbnails {
    margin:10px 0;
}
.luxury-thumbnails a {
    margin-right:2px;
}
.luxury-thumbnails a.active {
    opacity:0.2;
}
@media only screen and (max-width: 979px) {
    /*@media (min-width: 768px) and (max-width: 979px){*/
        /*#main {
            padding: 70px 0 50px 0;
            }
            #left_column, #right_column, .hs{
            display:none;
            }*/
            /*------isotope grid --------*/
            .section-grid {
               /* width:90%;*/
                margin:0 auto;
            }
            .row.section-grid{
                margin-right: -15px;
                margin-left: -15px;
            }
            .grid-content p{
                /*font-size: 18px; ----- only for iPad *----------*/
            }
            .section-grid .overlay-info > span {
                padding:10px;
                font-size:13px;
                line-height:18px;
            }
            .section-grid .overlay-info > span > span {
                bottom: 10px;
                padding-right: 10px;
            }
            .grid-sizer, .grid-item {
                height: 285px;
            }
            .grid-item--height2{
                height: 125px;
            }
            .fifty-percent-wrap {
                height: 40%;
            }
            .content-inner {
                width:100%;
                padding-left: 50px;
                padding-right: 50px;
            }
            .width-2.width-responsive{
                width:100%;
            }
        }
        @media (min-width: 768px) and (max-width: 979px) and (orientation:portrait) { /*--- should be only tablets */
            .full-height-wrap {
                height:85%;
            }
            .half-height-wrap {
                height:30%;
            }
            .container {
                width: 100%;
            }
            
            #wrapper.menu-active #header-container .nav-drawer {
                margin-right:50px;
            }
            #wrapper .login a, #wrapper nav li a{
                font-size:13px;
            }
    
        }
        @media only screen and (max-device-width: 480px) {
            #main {
                padding: 70px 0 50px 0;
            }
            #left_column, #right_column, .hs {
                display:none;
            }
        }
        

