/* #region - global */

* {
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
}

body {
    font-family: 'MuseoSans', sans-serif;
    font-size: 1.6rem;
    color: #000;
    background-color: #FAFAFA;
}

body.menu-is-active,
body.filter-is-active {
    overflow: hidden;
}

img {
    max-width: 100%;
    width: auto;
    height: auto;
    display: block;
    pointer-events: none;
}

img[src*=".svg"],
svg {
    width: 100%;
}

.object-fit {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

a {
    color: inherit;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0, 0, 0.2, 1) 0s;
}

a:hover {
    color: #CCC;
    text-decoration: none;
}

/* #endregion */
/* #region - site-header */

.site-header {
    position: fixed;
    left: 50%;
    max-width: 192rem;
    width: 100%;
    z-index: 99;
    transform: translate(-50%, 0);
    pointer-events: none;
}

.header__section {
    width: 100%;
    padding: 4rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: transform .4s ease-in-out, background .2s ease;
}

.site-header.unpinned .header__section,
.filter-is-active .header__section {
    transform: translate(0, -100%);
}

.site-header.add-bg .header__section {
    background-color: #FFF;
}

.header__logo {
    position: relative;
}

.header__logo-link {
    max-width: 12.4rem;
    width: 100%;
    margin-right: 4rem;
    display: block;
    pointer-events: all;
}

.header__nav {
    z-index: 1;
    pointer-events: all;
}

.header__nav-button {
    position: relative;
    width: 2.4rem;
    height: 1.8rem;
    margin-left: auto;
    display: block;
    cursor: pointer;
    transform: rotate(0deg);
    transition: rotate 0.5s ease-in-out;
}

.header__nav-button span,
.header__nav-button span,
.header__nav-button span {
    background-color: #E1251B;
    position: absolute;
    left: 0;
    width: 100%;
    height: .2rem;
    display: block;
    opacity: 1;
    transform: rotate(0deg);
    transition: 0.25s ease-in-out;
}

.header__nav-button span:nth-child(1) {
    top: 0;
}

.header__nav-button span:nth-child(2),
.header__nav-button span:nth-child(3) {
    top: .8rem;
}

.header__nav-button span:nth-child(4) {
    top: 1.6rem;
}

.header__nav-button:hover span {
    background-color: #D46E69;
}

.header__nav-button.active span {
    background-color: #CCC;
}

.header__nav-button.active span:nth-child(1),
.header__nav-button.active span:nth-child(4) {
    top: .8rem;
    left: 50%;
    width: 0;
}

.header__nav-button.active span:nth-child(2) {
    transform: rotate(45deg);
}

.header__nav-button.active span:nth-child(3) {
    transform: rotate(-45deg);
}

.header__nav-container {
    background-color: #FFF;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    max-height: 0;
    z-index: -1;
    overflow: hidden;
    transform: translate3d(0, 0, 0);
    transition: max-height .5s ease-in-out;
    pointer-events: none;
}

.header__nav-button.active+.header__nav-container {
    max-height: 100vh;
    pointer-events: all;
}

.header__menu {
    height: 100vh;
    padding: 4rem;
    overflow: auto;
    display: flex;
}

.header__menu.animating {
    overflow: hidden;
    pointer-events: none;
}

.header__menu ul.primary-menu {
    font-family: 'Museo', serif;
    font-weight: 700;
    line-height: 1;
    text-transform: lowercase;
    color: #E1251B;
    list-style-type: none;
    position: relative;
    width: 100%;
    padding: 0;
    margin: auto;
}

.header__menu ul.primary-menu>li {
    position: relative;
    width: 100%;
    margin: 0 0 2.5rem;
    display: flex;
    justify-content: flex-end;
    opacity: 0;
    transform: translateY(-5rem);
    pointer-events: none;
    transition: transform cubic-bezier(.165, .84, .44, 1) 1s, opacity cubic-bezier(.165, .84, .44, 1) 1s;
}

.header__menu ul.primary-menu>li.show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
}

.header__menu ul.primary-menu>li:last-child {
    margin-bottom: 0;
}

.header__menu ul.primary-menu>li>a {
    color: inherit;
    position: relative;
    display: flex;
    align-items: center;
}

.header__menu ul.primary-menu>li>a:hover {
    color: #CCC;
}

/* #endregion */
/* #region - site-main */

.site {
    background-color: #FFF;
    box-shadow: 0 0 2rem 0.1rem #EAEAEA;
    position: relative;
    max-width: 192rem;
    width: 100%;
    margin: auto;
    overflow: hidden;
}

.site-container {
    backface-visibility: hidden;
    perspective: .1rem;
    transform-origin: 50% 0;
    transition: transform cubic-bezier(.77, 0, .175, 1) .5s;
}

.menu-is-active .site-container {
    transform: translate3d(0, 0, 0) scale(.95);
}

/* #endregion */
/* #region - home */

.home-hero__section {
    max-height:92vh;
    overflow:hidden;
}


.home-hero__slider {
    position: relative;
}

.home-hero__slide-content {
    height: 100vh;
}

.home-works__section {
    background-color: #FFF;
    position: relative;
    padding: .25rem;
}

.home-works__filter {
    height: 8rem;
    padding: 4rem;
    display: flex;
    align-items: center;
    background:#fff;
}

.home-works__filter-group {
    margin-right: 2rem;
}

.home-works__filter-title {
    font-size: 3.2rem;
    color: #CCC;
}

.home-works__filter-group.active .home-works__filter-title {
    color: #E1251B;
}

.home-works__filter-title a:hover {
    color: #E1251B;
}
.home-works__filter .close{
    position:absolute;
    right:0;
    top:-20px;
    font-size:2rem;
    width:30px;
    height:30px;
}
.home-works__filter .close span{
    background-color: #ccc;
    position: absolute;
    left: 0;
    width: 100%;
    height: .2rem;
    display: block;
    opacity: 1;
    transition: 0.25s ease-in-out;
    top: .8rem;
    
}
.home-works__filter .close span:nth-child(1) {
    transform: rotate(-45deg);
}
.home-works__filter .close span:nth-child(2) {
    transform: rotate(45deg);
}
.home-works__filter-taxonomy {
    background-color: rgba(255, 255, 255, 1);
    position: absolute;
    top: 8.45rem;
    left: 0;
    width: 100%;
    height: calc(100% - 8rem);
    max-height: 0;
    z-index: 1;
    overflow: hidden;
    transform: translate3d(0, 0, 0);
    transition: max-height .5s ease-in-out;
    pointer-events: none;
}

.home-works__filter-group.active .home-works__filter-taxonomy {
    max-height: calc(100vh - 8rem);
    pointer-events: all;
}

.home-works__filter-list {
    height: 100%;
    padding: 4rem;
    overflow: auto;
    display: flex;
}

.home-works__filter-list.animating {
    overflow: hidden;
    pointer-events: none;
}

.home-works__filter-list ul {
    font-family: 'Museo', serif;
    font-weight: 700;
    line-height: 1;
    text-transform: lowercase;
    color: #E1251B;
    list-style-type: none;
    position: relative;
    width: 100%;
    padding: 0;
    margin: 0;
}

.home-works__filter-list ul>li {
    position: relative;
    width: 100%;
    margin: 0 0 2.5rem;
    display: flex;
    opacity: 0;
    transform: translateY(-5rem);
    pointer-events: none;
    transition: transform cubic-bezier(.165, .84, .44, 1) 1s, opacity cubic-bezier(.165, .84, .44, 1) 1s;
}

.home-works__filter-list ul>li.show {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
}

.home-works__filter-list ul>li>a {
    color: inherit;
    position: relative;
    display: flex;
    align-items: center;
}

.home-works__filter-list ul>li>a:hover {
    color: #CCC;
}

.home-works__item-container,
.related-works__item-container {
    position: relative;
    padding-top: 100%;
    display: block;
}

.home-works__item-wrapper,
.related-works__item-wrapper {
    border: .25rem solid transparent;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.home-works__item-image,
.home-works__item-video,
.related-works__item-image,
.related-works__item-video {
    background-color: #EAEAEA;
    width: 100%;
    height: 100%;
}

.home-works__item-description,
.related-works__item-description {
    font-family: 'MuseoSans', serif;
    text-align: center;
    color: #FFF;
    background-color: rgba(183, 183, 183, .5);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    opacity: 0;
    transition: opacity 0.3s cubic-bezier(0, 0, 0.2, 1) 0s;
}

.home-works__item-description>*,
.related-works__item-description>* {
    width: 100%;
}

a.home-works__item-container:hover .home-works__item-description,
a.related-works__item-container:hover .related-works__item-description {
    opacity: 1;
}

.home-works__item-category,
.related-works__item-category {
    font-size: 1.4rem;
    font-weight: 700;
}

.home-works__item-title,
.related-works__item-title {
    font-size: 4rem;
    font-weight: 700;
    line-height: 1;
    margin: 1rem auto;
}

/* #endregion */
/* #region - footer */

.footer__section {
    border-bottom: 1rem solid #E1251B;
    display: flex;
}

.contact__section {
    max-width: 50%;
    padding: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    flex: 1;
}

.contact__section form {
    max-width: 48rem;
    display: flex;
    flex-wrap: wrap;
}

.contact__section form>div {
    position: relative;
    width: 100%;
}

.contact__section form>.is-half {
    display: flex;
}

.contact__section form>.is-half>* {
    flex: 1;
}

.contact__section form .header {
    margin-bottom: 3rem;
}

.contact__section form span {
    display: block;
}

.contact__section form .h1 {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.2;
    color: #E1251B;
}

.contact__section form label {
    text-transform: uppercase;
    margin: 0;
    display: block;
}

.contact__section form input,
.contact__section form textarea,
.contact__section form select {
    font-weight: 300;
    color: #495057;
    background-color: #FFF;
    border: .1rem solid #C3C3C3;
    width: 100%;
    min-height: 4rem;
    padding: .75rem 1.25rem;
    margin: -.1rem 0 0;
    outline: none;
    display: block;
}

.contact__section form select {
    padding: .75rem;
}

.contact__section form select>option {
    font-weight: 300;
}

.contact__section form select>option:first-child {
    color: #CCC;
}

.contact__section form select.empty {
    color: #CCC;
}

.contact__section form select>option {
    color: #495057;
}

.contact__section form .is-half>div:last-child input,
.contact__section form .is-half>div:last-child textarea,
.contact__section form .is-half>div:last-child select {
    margin-left: -.1rem;
    width: calc(100% + .1rem);
}

.contact__section form input:focus,
.contact__section form textarea:focus,
.contact__section form select:focus {
    border-color: #E1251B;
    position: relative;
    z-index: 1;
}

::-webkit-input-placeholder {
    color: #CCC;
}

:-moz-placeholder {
    color: #CCC;
}

::-moz-placeholder {
    color: #CCC;
}

:-ms-input-placeholder {
    color: #CCC !important;
}

::placeholder {
    color: #CCC;
}

.contact__section form input[type="submit"] {
    color: #FFF;
    background-color: #E1251B;
    border: 0;
    border-radius: 4rem;
    width: auto;
    padding: .8rem 3rem;
    margin: 0 0 0 auto;
    cursor: pointer;
    display: table;
    transition: all 0.4s cubic-bezier(0, 0, 0.2, 1) 0s;
}

.contact__section form input[type="submit"]:hover {
    color: #FFF;
}

.contact__section form .ajax-loader {
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    padding: .8rem;
    margin: -.9rem -.8rem -.8rem;
}

.contact__section form input.wpcf7-not-valid,
.contact__section form textarea.wpcf7-not-valid,
.contact__section form select.wpcf7-not-valid {
    border-color: #E1251B;
    position: relative;
    z-index: 1;
}

.contact__section form .wpcf7-not-valid .wpcf7-list-item-label {
    color: #E1251B;
}

.contact__section form .wpcf7-not-valid-tip {
    font-size: 1.4rem;
    color: #E1251B;
    margin: .5rem 0 0;
    display: none;
}

.contact__section form .wpcf7-response-output {
    font-size: 1.4rem;
    font-weight: 300;
    border: 0;
    width: 100%;
    padding: 0;
    margin: 3rem 0 0 auto;
    /* display: none !important; */
}

.contact__section form .wpcf7-validation-errors,
.contact__section form .wpcf7-acceptance-missing {
    color: #E1251B;
}

.contact__section form .wpcf7-mail-sent-ng,
.contact__section form .wpcf7-aborted {
    color: #E1251B;
}

.contact__section form .footer {
    margin-top: 3rem;
    display: flex;
    align-items: center;
}

.contact__section .copyright {
    font-family: 'Museo', serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: #E1251B;
    max-width: 48rem;
    width: 100%;
    margin-top: 3rem;
}

.file__upload .wpcf7-form-control-wrap {
    position: initial;
}

.file__upload .file__select {
    font-weight: 300;
    color: #CCC;
    text-align: left;
    border: .1rem solid #C3C3C3;
    position: relative;
    height: 4rem;
    margin: -.1rem 0 0;
    overflow: hidden;
    cursor: pointer;
    display: flex;
}


.file__upload .file__select .file__select-button,
.file__upload .file__select .file__select-name {
    padding: 0 1.25rem;
    display: flex;
    align-items: center;
}

.file__upload .file__select .file__select-button {
    border-right: .1rem solid #C3C3C3;
    flex: 0 0 auto;
}

.file__upload .file__select .file__select-name {
    white-space: nowrap;
}

.file__upload .file__select .file__select-input {
    position: absolute;
    height: 100%;
    width: 100%;
    margin: 0;
    top: 0;
    left: 0;
    z-index: 1;
    opacity: 0;
}

.file__upload.active .file__select .file__select-button {
    color: #FFF;
    background: #CCC;
}

.file__upload.active .file__select .file__select-name {
    color: #495057;
}

.file__upload input[type="file"] {
    margin: 0;
    border: 0;
    padding: 0;
}

.map__section {
    flex: 1;
}

.map__section p,
.map__section iframe {
    width: 100%;
    height: 100%;
}

.social {
    display: flex;
}

.social a {
    width: 4rem;
    height: 4rem;
    margin-right: 1rem;
    display: inline-block;
}

/* #endregion */
/* #region - single work */

.sw-hero__section,
.about-hero__section {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

.about-hero__section {
    height: 100vh;
}

.sw-hero__image,
.sw-hero__video,
.about-hero__image,
.about-hero__video {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

.sw-hero__video,
.about-hero__video {
    cursor: pointer;
}

.sw-hero__video:after,
.about-hero__video:after {
    content: '';
    background-image: url('../images/play.svg');
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8rem;
    height: 8rem;
    opacity: 1;
    transform: translate(-50%, -50%);
    transition: all .2s cubic-bezier(0.44, 0.57, 0, 1.01);
    transition-property: transform opacity;
    pointer-events: none;
}

.sw-hero__video.played:after,
.about-hero__video.played:after {
    background-image: url('../images/pause.svg');
    opacity: 0;
}

.sw-hero__video.playing:after,
.about-hero__video.playing:after {
    background-image: url('../images/play.svg');
}

.sw-hero__video.clicked:after,
.about-hero__video.clicked:after {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.2);
}

.sw-details__section {
    padding: 0rem 0;
    display: flex;
    flex-wrap: wrap;
}

.sw-details__section>* {
    padding: 4rem;
    flex: 1;
}

.sw-details__discipline {
    margin-bottom: 4rem;
}

.sw-share {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    flex: auto;
}

.sw-share a {
    width: 4rem;
    height: 4rem;
    margin-left: 1rem;
    display: inline-block;
}

.sw-details__title {
    font-size: 2.1rem;
    font-weight: 700;
    color: #E1251B;
    margin-bottom: 2rem;
}

.sw-details__text {
    font-family: 'AvenirBook';
    font-size: 1.4rem;
    font-weight: 300;
}

.sw-gallery__section {
    padding: .25rem;
}

.sw-gallery__item-container {
    position: relative;
    padding-top: 100%;
    display: block;
}

.sw-gallery__item-wrapper {
    border: .25rem solid transparent;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.sw-gallery__item-image,
.sw-gallery__item-video {
    background-color: #EAEAEA;
    width: 100%;
    height: 100%;
}

.related-works__section {
    padding: .25rem;
}

.related-works__title {
    font-size: 6.4rem;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    color: #C3C3C3;
    padding: 4rem;
}

/* #endregion */
/* #region - about */

.about__section {
    background-color: #E1251B;
    display: flex;
}

.about__content {
    width: 100%;
    min-height: 100vh;
    padding: 10rem 4rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.about__content h2 {
    font-size: 9.6rem;
    line-height: 1.2;
    color: #FFF;
    margin-bottom: 2rem;
}

.about__content p {
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: 1.5rem;
    font-family: 'MuseoSans', sans-serif;
}

.about-gallery__section {
    padding: .25rem;
}

.about-gallery__item-container {
    position: relative;
    padding-top: 100%;
    display: block;
}

.about-gallery__item-wrapper {
    border: .25rem solid transparent;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.about-gallery__item-image,
.about-gallery__item-video {
    background-color: #EAEAEA;
    width: 100%;
    height: 100%;
}

.about-gallery__item-text {
    font-family: 'Museo', serif;
    text-align: center;
    color: #FFF;
    background-color: rgba(183, 183, 183, .5);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    opacity: 0;
    transition: opacity 0.3s cubic-bezier(0, 0, 0.2, 1) 0s;
}

.about-gallery__item-text>* {
    width: 100%;
}

.about-gallery__item-container:hover .about-gallery__item-text {
    opacity: 1;
}

.about-gallery__item-name {
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1;
    margin: 1rem auto;
}

.about-gallery__item-position {
    font-size: 1.8rem;
    font-weight: 700;
    font-family: 'MuseoSans', sans-serif;
}

.about-cta__section {
    text-align: center;
    color: #E1251B;
    display: flex;
}

.about-cta__content {
    width: 100%;
    min-height: 50vh;
    padding: 10rem 4rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background:#E1251B;
    color:#fff;
}

.about-cta__content h2,
.about-cta__content a {
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1.2;
}

.about-cta__content h2 {
    margin-bottom: 2rem;
}

.about-cta__content a {
    text-decoration: underline;
    margin-bottom: 1.5rem;
}

/* #endregion */
/* #region - contact footer */

.page-contact .footer__section>* {
    min-height: calc(100vh - 1rem);
}

.page-contact .contact__section {
    padding: 15rem 4rem;
}
.contactText{
    display:none;
}
.page-contact .contact__section .contactText{
    display:block;
    padding: 10px 0;
}
.page-contact .contact__section form .h1 {
    font-size:5.8rem;
    
}
.page-contact .contact__section .contactText {
    color:#C3C3C3;
    font-size:2.8rem;
    font-weight:500;
}
.page-contact .contact__section .contactText a{
    color:#E1251B;
     font-size:2.8rem;
     display:inline-block;
}

/* #endregion */
/* #region - 404 error */

.error__section {
    font-size: 4rem;
    font-weight: 700;
    color: #E1251B;
    text-align: center;
    height: 60vh;
    padding: 8rem 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.newFooter {
    background:#E1251B;
    display: flex;
    flex-wrap: wrap;
}
.newFooter > div {
    padding: 4rem;
    
    color:#fff;
    flex: 1;
     min-width: 25%;
}
.newFooter > div a{
     color:#fff;
}
.newFooter > div a:hover{
    color: #CCC;
}
.newFooter > div ul li {
    list-style:none;
    font-size:48px !important;
    font-weight:700;
    line-height: 1.4em !important;
}

.newFooter > div ul{
    padding:0;
}
.newFooter > div .footer__logo{
    width:120px;
}
.newFooter > div .address{
    font-size: 33px;
    line-height: 1.8em;
    z-index:99;
    position:relative;
}
.newFooter > div .address h2{
    margin-bottom:30px;
}
.newFooter > div .address p{
    font-size:22px;
    line-height:1em;
}
.newFooter > div.copyright{
    flex:1 0 100%;
    width: 100%;
    padding:0rem 4rem 4rem;
    margin-top:-70px;
    z-index:0;
}
/* #endregion */
/* #region - global grid */

[data-columns="3"] div[class*="item-size"],
[data-columns="3"] [data-grid-size="1x1"],
[data-columns="3"] [data-grid-size="1x2"] {
    width: 33.33%;
}

[data-columns="3"] [data-grid-size="2x1"],
[data-columns="3"] [data-grid-size="2x2"] {
    width: 66.67%;
}

[data-columns="4"] div[class*="item-size"],
[data-columns="4"] [data-grid-size="1x1"],
[data-columns="4"] [data-grid-size="1x2"] {
    width: 25%;
}

[data-columns="4"] [data-grid-size="2x1"],
[data-columns="4"] [data-grid-size="2x2"] {
    width: 50%;
}

[data-columns="5"] div[class*="item-size"],
[data-columns="5"] [data-grid-size="1x1"],
[data-columns="5"] [data-grid-size="1x2"] {
    width: 20%;
}

[data-columns="5"] [data-grid-size="2x1"],
[data-columns="5"] [data-grid-size="2x2"] {
    width: 40%;
}
[data-columns="6"] div[class*="item-size"],
[data-columns="6"] [data-grid-size="1x1"],
[data-columns="6"] [data-grid-size="1x2"] {
    width: 16.666%;
}

[data-columns="6"] [data-grid-size="2x1"],
[data-columns="6"] [data-grid-size="2x2"] {
    width: 33.333%;
}

[data-grid-ratio="1x1"]>* {
    padding-top: 100%;
}

[data-grid-ratio="1x1"][data-grid-size="1x2"]>* {
    padding-top: 200%;
}

[data-grid-ratio="1x1"][data-grid-size="2x1"]>* {
    padding-top: 50%;
}

[data-grid-ratio="3x2"]>* {
    padding-top: 75%;
}

[data-grid-ratio="3x2"][data-grid-size="1x2"]>* {
    padding-top: 150%;
}

[data-grid-ratio="3x2"][data-grid-size="2x1"]>* {
    padding-top: 37.5%;
}

[data-grid-ratio="16x10"]>* {
    padding-top: 62.5%;
}

[data-grid-ratio="16x10"][data-grid-size="1x2"]>* {
    padding-top: 125%;
}

[data-grid-ratio="16x10"][data-grid-size="2x1"]>* {
    padding-top: 31.25%;
}

/* #endregion */
/* #region - update */

.site,
.site-header {
    max-width: none;
}

/* #endregion */