/*
* Template Name: New Construction
*/
#ai-modern-contact {
    position: relative;
    margin: 0 0 90px;
}

#ai-modern-contact .ai-modern-contact-entry {
    position: relative;
    display: block;
    overflow: hidden;
    padding-bottom: 50px;
}

#ai-modern-contact .ai-modern-contact-entry-inner {
    position: relative;
    display: flex;
}

#ai-modern-contact .ai-modern-contact-photo {
    position: relative;
    display: block;
    width: 41.66666667%;
}

#ai-modern-contact .ai-modern-contact-photo span {
    position: relative;
    display: block;
    margin-left: calc(((100vw - 1140px) / -2) + 58px);
}

#ai-modern-contact .ai-modern-contact-photo span:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 130px;
    left: 0;
    width: 46%;
    height: 100vh;
    background: #202020;
}

#ai-modern-contact .ai-modern-contact-photo canvas {
    display: block;
    width: calc(100% - 50px);
    max-width: 619px;
    margin-left: auto;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
}

#ai-modern-contact .ai-modern-contact-main {
    position: relative;
    display: block;
    margin: auto 0;
    padding: 50px 65px 50px 85px;
    flex-grow: 1;
    width: 65%;
}

#ai-modern-contact .ai-modern-contact-title {
    position: relative;
    display: block;
    margin: 0;
    font-family: var(--font-family-title);
    text-transform: uppercase;
}

#ai-modern-contact .ai-modern-contact-title:after {
    content: "";
    display: block;
    width: 133px;
    max-width: 100%;
    height: 1px;
    margin-top: 36px;
    background: var(--primary);
}

#ai-modern-contact .ai-modern-contact-title span {
    display: block;
    font-size: 30px;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: var(--primary);
    line-height: 1;
}

#ai-modern-contact .ai-modern-contact-title strong {
    display: block;
    font-size: 75px;
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1;
    color: var(--font-color-title);
    margin: 4px 0 0;
}

#ai-modern-contact .ai-modern-contact-info {
    position: relative;
    display: block;
    margin: 30px 0 0;
    padding: 0;
}

#ai-modern-contact .ai-modern-contact-info li {
    position: relative;
    display: flex;
}

#ai-modern-contact .ai-modern-contact-info li>span {
    width: 18px;
    font-size: 14px;
    color: var(--primary);
    display: inline-block;
    margin: 7px 15px 0 0;
}

#ai-modern-contact .ai-modern-contact-info li>span.envelope {
    font-size: 11px;
}

#ai-modern-contact .ai-modern-contact-info li>span.pin {
    font-size: 17px;
    margin-top: 5px;
}

#ai-modern-contact .ai-modern-contact-info li a,
#ai-modern-contact .ai-modern-contact-info li p {
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0.05em;
    color: #444444;
    transition: all 0.4s ease-in-out;
}

#ai-modern-contact .ai-modern-contact-info li a:hover {
    color: var(--primary);
}

#ai-modern-contact .ai-modern-contact-info li p {
    display: block;
    margin: 0;
}

#ai-modern-contact .ai-modern-contact-form {
    position: relative;
    display: block;
    margin-top: 42px;
}

#ai-modern-contact .ai-modern-contact-form-title {
    position: relative;
    display: block;
    margin: 0;
    text-transform: uppercase;
    line-height: 1;
    color: var(--font-color-title);
}

#ai-modern-contact .ai-modern-contact-form-title strong {
    display: block;
    font-size: 40px;
    font-weight: 500;
}

#ai-modern-contact .ai-modern-contact-form-title span {
    display: block;
    font-size: 15px;
    font-weight: 300;
    letter-spacing: 0.025em;
    color: var(--font-color-default);
    margin-top: 20px;
}

#ai-modern-contact .ai-modern-contact-form-container {
    position: relative;
    display: block;
    margin-top: 28px;
}

#ai-modern-contact .ai-modern-contact-form-container form {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    margin: 0 -5px;
}

#ai-modern-contact .ai-modern-contact-form-field {
    position: relative;
    width: 50%;
    padding: 20px 5px;
}

#ai-modern-contact .ai-modern-contact-form-field.lg {
    width: 100%;
}

#ai-modern-contact .ai-modern-contact-form-label {
    position: relative;
    display: block;
    color: #000;
    font-size: 14px;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 0;
}

#ai-modern-contact .ai-modern-contact-form-control {
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    border: none;
    background: transparent;
    display: block;
    padding: 0;
    width: 100%;
    height: 26px;
    color: var(--font-color-default);
    font-size: 14px;
    font-weight: 300;
    text-transform: uppercase;
    border-bottom: 1px solid var(--font-color-default);
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

#ai-modern-contact .ai-modern-contact-form-control.textarea {
    resize: none;
    height: 70px;
    padding-right: 43px;
    white-space: normal;
    text-overflow: clip;
}

#ai-modern-contact .wpcf7 form .wpcf7-response-output {
    width: 100%;
}

#ai-modern-contact .ai-modern-contact-form-submit {
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    border: none;
    background: transparent;
    margin: 0;
    padding: 0;
    position: absolute;
    right: 13px;
    bottom: 33px;
    font-size: 29px;
    color: var(--font-color-default);
    transition: all 0.4s ease-in-out;
}

#ai-modern-contact .ai-modern-contact-form-submit:hover {
    color: var(--primary);
}

#ai-modern-contact .ai-modern-contact-form-container .wpcf7-not-valid-tip {
    position: absolute;
    top: 50%;
    right: 0;
    left: auto;
    transform: translateY(-50%);
    width: auto;
    font-size: 14px;
}

#ai-modern-contact .ai-modern-contact-form-container .wpcf7-response-output {
    margin: 0 !important;
    padding: 10px !important;
    font-size: 14px;
    text-align: center;
}

#ai-modern-contact .ai-modern-contact-map {
    position: relative;
    display: block;
    margin: 100px 0 0;
    padding: 0 50px;
}

#ai-modern-contact .ai-modern-contact-map:before {
    content: "";
    position: absolute;
    top: -50px;
    bottom: 60px;
    right: 50px;
    width: 706px;
    background: var(--primary);
}

#ai-modern-contact .ai-modern-contact-map iframe {
    position: relative;
    display: block;
    width: calc(100% - 50px);
    filter: grayscale(1);
}


.new-const-img img {
    width: calc(100% + 8vw);
    position: relative;
    left: -8vw;
    padding-left: 40px;
}

.new-const-img:after {
    content: '';
    min-width: 1600px;
    height: 100%;
    position: absolute;
    top: 50px;
    left: calc(-1600px - -20vw);
    background: #022349;
    display: block;
    width: 100%;
    z-index: -1;
}

.new-const-content {
    padding-left: 50px;
}

#content-full #content {
    width: 100%;
    max-width: 1170px;
    margin: 160px auto 0;
}

.hp-fp {
    padding: 90px 15px;
}

.hp-fp .section-title .sub-title {
    font-size: 18px;
    margin-top: 15px;
}

.nc-fp-list {
    margin: 45px -10px 0;
}

.hp-fp-item {
    padding: 0 10px;
    width: 33.33%;
}

.hp-fp-item a {
    display: block;
    position: relative;
}

.hp-fp-item a .canvas-img {
    background: var(--primary);
}

.hp-fp-item a:hover .canvas-img img,
.hp-fp-item a:focus .canvas-img img {
    opacity: .24;
}

.hp-fp-stat {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 18px;
    letter-spacing: .075em;
    color: var(--white-text);
    font-style: italic;
    padding: 10px 20px;
    background: var(--primary);
    z-index: 5;
}

.hp-fp-info {
    margin-top: 25px;
    color: var(--primary);
}

.hp-fp-info>span {
    display: block;
}

.hp-fp-price {
    font-size: 22px;
    letter-spacing: .1em;
}

.hp-fp-address {
    font-size: 18px;
    letter-spacing: .025em;
    line-height: 1;
    padding: 10px 0 15px;
    font-style: italic;
    color: #999;
}

.hp-fp-beds {
    display: flex;
    padding-top: 12px;
    font-size: 12px;
    letter-spacing: .05em;
    position: relative;
}

.hp-fp-beds:before {
    position: absolute;
    content: '';
    left: 0;
    top: 0;
    width: 100%;
    height: 1px;
    background: #dee3e7;
    max-width: 365px;
}

.hp-fp-beds>span {
    padding: 5px min(1.125vw, 18px);
    border-left: 1px solid #dee3e7;
}

.hp-fp-beds>span:first-of-type {
    padding-left: 0;
    border: 0;
}

.hp-fp-beds>span:last-of-type {
    padding-right: 0;
}

.hp-fp-beds span span {
    color: #999;
}


@media only screen and (min-width: 992px) {
	
}
@media only screen and (max-width: 1199px) {
	
}

@media only screen and (max-width: 991px) {
	
}
@media only screen and (max-width: 767px) {
	
}
@media only screen and (max-width: 567px) {
	
}
@media only screen and (max-width: 480px) {
	
}