﻿/* Body */
/* Typography */
/* Header*/
/* Buttons */
/* Panels*/
/* Panel Background*/
/* Highlight */
/* Calendar*/
/**forms */
.bi-text-image {
  padding: 30px;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden; }
  .bi-text-image .content {
    position: relative;
    z-index: 3;
    justify-content: space-between; }
    .bi-text-image .content:before {
      content: '';
      display: block;
      height: 100vh;
      max-height: 150px;
      width: 1px;
      background: #fff;
      position: absolute;
      left: 0px;
      top: 85px;
      opacity: 0.2; }
  .bi-text-image .subtitle {
    color: #fff;
    display: block;
    font-family: 'Montserrat';
    text-transform: uppercase;
    font-weight: 300;
    font-size: 12px;
    margin-bottom: 10px; }
  .bi-text-image .title {
    color: #fff;
    display: block;
    font-size: 24px; }
  .bi-text-image.has-hover:before {
    opacity: 0;
    transition: opacity 0.2s ease-in-out; }
  .bi-text-image.has-hover .hover {
    margin-top: 20px; }
    .bi-text-image.has-hover .hover p {
      opacity: 0;
      transition: opacity 0.2s ease-in-out;
      color: #fff !important; }
  .bi-text-image.has-hover .btn-container {
    opacity: 0;
    transition: opacity 0.2s ease-in-out; }
    .bi-text-image.has-hover .btn-container .btn {
      padding: 12px; }
  .bi-text-image.has-hover:hover:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    background: black;
    opacity: 0.75; }
  .bi-text-image.has-hover:hover .hover p {
    opacity: 1;
    padding-left: 10px; }
  .bi-text-image.has-hover:hover .btn-container {
    opacity: 1; }
  @media (min-width: 1200px) {
    .bi-text-image {
      padding: 60px; }
      .bi-text-image .subtitle {
        font-size: 18px;
        margin-bottom: 15px; }
      .bi-text-image .title {
        font-size: 32px; }
      .bi-text-image .content {
        position: relative;
        z-index: 3; }
        .bi-text-image .content:before {
          max-height: 305px;
          top: 145px; }
      .bi-text-image .btn-container .btn {
        padding: 24px 32px !important; } }

.p-text-image {
  width: 100%;
  height: 100%;
  position: relative; }
  .p-text-image .image-wrapper, .p-text-image .image-wrapper-2, .p-text-image .image-wrapper-3 {
    height: 350px; }
  @media (min-width: 1200px) {
    .p-text-image .image-wrapper {
      height: 500px; }
    .p-text-image .image-wrapper-3 {
      height: 650px; } }
  .p-text-image .caption {
    color: #fff;
    display: block;
    font-size: 24px;
    position: absolute;
    z-index: 2;
    bottom: 40px;
    left: 40px;
    font-family: "Playfair Display";
    max-width: 330px; }
