
@import url('./icons.css');
@import url('https://fonts.googleapis.com/css2?family=Work+Sans:wght@200;300;400;700:500;&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display&family=Roboto:wght@300,400&display=swap');




* {
    margin: 0;
    padding: 0;
}

:root {
    --blackColor: #000;
    --whiteColor: #fff;
    --primaryColor: #ECEBE7
}

html, body {
    font-family: 'Work Sans', sans-serif;
    height: 100%;
    background-color: var(--whiteColor);
}
.project-card img { width: 100%; filter: grayscale(1); }
.darkMode { position: fixed; bottom: 15px; right: 15px; cursor: pointer; width: 50px; height: 30px; background-color: #fff; color: #000; }

.uk-breadcrumb { margin-top: 15px; }
.uk-breadcrumb>*>* { color: var(--blackColor); }

.colorWhite { color: var(--whiteColor)!important; }
.colorBlack { color: var(--blackColor)!important; }
.uk-nav-divider { background-color: var(--blackColor); }
.uk-offcanvas-bar { background-color: #fff; }
.primary-btn { background-color: #000; line-height: 36px; padding: 0px 10px; border-width: 0; color: var(--whiteColor); display: inline-block; text-decoration: none; position: relative; cursor: pointer; }
.primary-btn:hover { text-decoration: none; color: var(--primaryColor); }
.primary-btn::after { width: 0; transition: all 1.2s ease-in-out; content: ""; height: 2px; background-color: #ff0000; position: absolute; bottom: 0; left: 0; }
.primary-btn:hover::after { content: "";  width: 100%; height: 2px; }
.lang_anchor { color: var(--blackColor); padding-right: 5px; }
.lang_anchor:nth-child(2) { padding-right: 0; }
.titleLine { width: 0; height: 1px; background-color: var(--blackColor); display: block; transition: all 1.5s ease-in-out; }
.titleLine.anim { width: 100%; }
.titleLine.anim1 { width: 100%; margin-left: auto; }
#menu { width: 30px; height: 16px; cursor: pointer; display: inline-block; position: relative; }
#menu .menuLine { background-color: #000; width: 100%; height: 2px; margin-bottom: 5px; transition: all 1s ease-in-out; display: block; }
#menu:hover .menuLine { transform: rotate(45deg); }
#menu:hover .menuLine:nth-child(2) { width: 0px; }
#menu:hover .menuLine:nth-child(3) { transform: rotate(-45deg) translateY((-50%)); }

.constructor { height: 100%; }
.constructor h1 { font-weight: 400; font-size: 40px; line-height: 49px; display: flex; align-items: center; margin-top: 49px; margin-bottom: 0; }
.constructor h1::after { content: ""; width: calc(100% - 7px); height: 1px; background-color: var(--blackColor); display: block; flex: 1; margin-left: 7px; }
.constructor span.title { display: block; font-weight: 400; font-size: 100px; line-height: 120px; text-align: center; color: var(--blackColor); }
.constructor p { font-size: 40px; line-height: 49px; font-weight: 400; color: var(--blackColor); text-align: center; }
.constructor .usmargintop { margin-top: 114px; }
.constructor span.ico { font-size: 40px; font-weight: 300; line-height: 47px; color: var(--blackColor); display: block; }
.constructor a { text-decoration: none; }
.constructor p.subtext{ font-weight: 200; font-size: 25px; line-height: 29px; }

header { background-color: var(--whiteColor); padding: 15px 0; box-shadow: 10px 10px 10px -15px; }
header img { filter: brightness(0) invert(0); }
header ul.menu { display: flex; justify-content: center; list-style-type: none; margin-bottom: 0; }
header ul.menu li { margin-right: 30px; position: relative; }
header ul.menu li::after { content:""; position: absolute; left: 0; bottom: -5px; height: 2px; width: 0; background-color: #ff0000; transition: all 1.2s ease-in-out; }
header ul.menu li.active::after { width: 100%; }
header ul.menu li:hover::after { width: 100%; }
header ul.menu li:last-child { margin-right: 0; }
header ul.menu li a { color: var(--blackColor); line-height: 21px; font-size: 18px; text-decoration: none; font-weight: 400; text-transform: uppercase; }

section.fullSlider div.sliderText h1,
section.fullSlider h1 { font-size: 60px; font-weight: 700; color: var(--blackColor); display: inline-block; margin: 0 auto; }
section:not(.fullSlider) h1,
section:not(.fullSlider) div.sliderText h1,
section h1 { font-size: 60px; font-weight: 400; color: var(--blackColor); display: inline-block; margin: 0 auto; position: relative; text-transform: uppercase; }
section.news h1::after,
section h1::after { position: absolute; left: -30px; right: -30px; bottom: -20px; height: 2px; background-color: #ff0000; content: ""; }

section.news h1::after,
section h1.detail::after { position: absolute; left: 0; right: -30px; bottom: -3px; height: 2px; background-color: #ff0000; content: ""; }

section.fullSlider h1::after { display: none; } 
section.fullSlider { position: relative; margin-top: 15px; }
section.fullSlider { z-index: 9; }
section.fullSlider div.sliderText { position: absolute; right: 0; left: 0; top: 40%; transform: translateY(-50%); }
section.fullSlider div.sliderText div.content { max-width: 568px; margin-left: auto; }
section.fullSlider div.sliderText h1 { font-size: 38px; font-weight: 200; line-height: 50px; margin: 30px 0; color: var(--blackColor); }
section.fullSlider div.sliderText h1 strong { font-weight: 300; }
section.fullSlider div.sliderText p { font-size: 18px; color: var(--blackColor); font-weight: 300; }
section.fullSlider div.sliderText p strong { font-weight: 400; }
section.fullSlider div.sliderText .primary-btn { margin-top: 30px; }

ul.slick-dots { list-style-type: none; display: flex; align-items: center; justify-content: center; padding: 0; margin: 15px 0; z-index: 9; position: relative; }
ul.slick-dots li button { text-indent: -9999px; width: 10px; height: 10px; background-color: var(--blackColor); margin-right: 5px; border: 0; border-radius: 10px; }
ul.slick-dots li.slick-active button { background-color: var(--whiteColor); border: 1px solid var(--blackColor); box-sizing: content-box; }
ul.slick-dots li:last-child button { margin-right: 0; }

/* section.social { position: absolute; left: 0; right: 0; bottom: 0; } */
section.social { margin-top: 30px; }
section.social ul.social-media { display: flex; list-style-type: none; justify-content: flex-end; padding: 0; position: relative; }
section.social ul.social-media li { margin-right: 15px;  margin-bottom: 15px;}

section.about div.about { display: flex; background-color: var(--whiteColor); align-items: center; justify-content: center; }
section.about div.about > div { flex: 1; padding: 50px 15px; }
section.about div.about > div > h3 { font-size: 40px; font-weight: 200; color: var(--blackColor); }
section.about div.about > div > h3 > strong { font-weight: 300; }
section.about div.about > div > p { font-size: 15px; color: var(--blackColor); font-weight: 300; }
section.about div.box-shadow {box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);}

section.services { margin-top: 30px; }
section.services div.services-card { margin-top: 30px; }
section.services div.services-card a { text-decoration: none; color: var(--blackColor); }
section.services h3 { font-size: 30px; font-weight: 400; color: var(--blackColor); }
section.services p { font-size: 15px; font-weight: 300; color: var(--blackColor); }
section.services div.services-card a div.box { background-color: var(--whiteColor); position: relative; padding: 15px; box-shadow: 0 4px 7px 0px rgba(0,0,0,0.4); border: 1px solid black; }
section.services div.item:nth-child(2n+2) div.services-card { margin-right: 90px; }
section.services div.item:nth-child(2n+1) div.services-card { margin-left: 90px; }
section.services div.services-card a div.box div.uk-flex > div { flex :1 0; } 
section.services div.services-card a div.box h4 { color: var(--blackColor); font-size: 18px; font-weight: 700; }
section.services div.services-card a div.box p { color: var(--blackColor); font-size: 16px; min-height: 240px; }
section.services div.services-card img { 
    margin: 15px auto;
    display: block; width: 40%; opacity: .3; position: absolute; right: 20px; bottom: 0; }

section.projects div.project-card a { color: #000; text-decoration: none; }
section.projects div.project-card a div.box { margin-top: 10px; overflow: hidden; }

section.projects div.project-card a h4,
section.projects div.project-card a div.box h4 { color: var(--blackColor); font-size: 16px; font-weight: 700; margin: 0;font-family: 'Roboto', sans-serif; }

section.projects div.project-card a span,
section.projects div.project-card a div.box span { font-size: 12px; font-weight: 300; color: var(--blackColor); margin-left: 5px; display: inline-block; font-style: italic; }
section.projects div.project-card a p,
section.projects div.project-card a div.box p { font-size: 12px; font-weight: 300; margin: 0px 0; color: var(--blackColor); }

section.projects div.project h1 { font-size: 50px; font-weight: 300; margin: 0; line-height: 60px; margin-right: 15px; }
section.projects div.project h1.detail { font-size: 50px; font-weight: 300; margin: 0; line-height: 60px; margin-right: 15px; }
section.projects div.project span.detail-location { font-weight: 200; font-size: 30px; color: var(--blackColor); display: block; text-align: left; }
section.projects div.project p { font-size: 18px; font-weight: 300; color: var(--blackColor); }

section.contact label { font-size: 20px; font-weight: 400; color: var(--blackColor); }
section.contact ul.contact-list { list-style-type: none; padding: 0; margin: 0; }
section.contact ul.contact-list li { margin-top: 15px; }
section.contact ul.contact-list li i { margin-right: 15px; filter: brightness(1) invert(1); }
section.contact ul.contact-list li span { color: var(--blackColor); font-size: 15px; line-height: 17.5px; font-weight: 400; }
section.contact ul.contact-list li a { text-decoration: none; position: relative; }
section.contact ul.contact-list li a::before { transition: all 1.2s ease-in-out; position: absolute; left: 0; bottom: -5px; right: 0; width: 0; height: 2px;  background-color: var(--blackColor); content: ""; }
section.contact ul.contact-list li a:hover::before { width: 100%; }

section.news h1 { font-size: 50px; font-weight: 200; }
section.news h2 { font-size: 29px; font-weight: 600; color: var(--blackColor); } 
section.news p { font-size: 16px; font-size: 300; color: var(--blackColor); }

.gridOutLine { width: 95%; height: 2px; background-color: #ff0000; }


section.projects div.project-card a .frame { width: 100%; min-height: 204px; border: 2px solid var(--blackColor); box-shadow:0 3px 5px rgba(0,0,0,0.5); position: absolute; top: 0; box-sizing: border-box; }  

section.projects div.project-card a .frame .window { width: calc(100% - 35px);
    position: absolute;
    overflow: hidden;
    bottom: 0;
    right: -100%;
    min-height: 1;
    background-color: rgba(255,255,255,.8);
    padding: 5px;
    transition: .2s all ease-in-out;
 }
section.projects div.project-card a:hover .frame .window { right: 0; }
section.projects div.project-card a .frame .window .top { background-color: var(--whiteColor); height: 121.5px; position: relative; top: 0; z-index: 9; transition: all .1s ease-in; } 
section.projects div.project-card a .frame .window .bottom { background-color: var(--whiteColor); height: 121.5px; position: relative; bottom:0; transition: all .1s ease-in;  } 
section.projects div.project-card a .frame .window .top .position { position: absolute; bottom: -120px; right:15px; left: 15px; text-align: right; }

section.projects div.project-card a .frame .window .top .position h4 { font-size: 27px!important; color: var(--blackColor);  }
section.projects div.project-card a.hovered .frame .window .top { top: -135px; }
section.projects div.project-card a.hovered .frame .window .bottom { bottom: -125.5px; }

section.projects div.project-card a div.aBox { width: 0%;
    height: 0;
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    background-color: white;
    z-index: 9999; transition: all .3s ease-in; } 
    
section.projects div.project-card a:hover div.aBox.hovered { width: 100%; height: 100vh; }

@media only screen and (max-width: 1400px) {
    .constructor .usmargintop { margin-top: 50px; }
}

@media only screen and (max-width: 1024px) {
    .constructor h1 { font-size: 35px; }
    .constructor span.title { font-size: 80px; }
    .constructor p { font-size: 30px; }
    .constructor img.res-img { margin-top: 30px; }
}

@media only screen and (max-width: 960px) {
    div.project { margin-top: 15px; }
    section.projects div.project h1 { font-size: 40px; line-height: 42px; }
    section.projects div.project span.detail-location { font-size: 20px; }
    section.projects div.project p { font-size: 16px; }
    div.about { flex-direction: column; }
    section.fullSlider div.sliderText { position: relative; transform: unset; }
    form { margin-top: 15px!important; display: block; }
    section.about div.about > div { padding: 15px 0; }
    
    section:not(.fullSlider) h1, section:not(.fullSlider) div.sliderText h1, section h1 { font-size: 30px; } 
}

@media only screen and (max-width: 640px) {
    .constructor .usmargintop { margin-top: 30px!important; }
    .constructor h1 { font-size: 25px; }
    .constructor span.title { font-size: 40px; line-height: normal; }
    .constructor p { font-size: 20px; margin-top: 5px; margin-bottom: 0; }
    .constructor span.ico { font-size: 25px; }
    .constructor img.res-img { margin-top: 30px; }
    .constructor p.subtext { font-size: 16px; }
}