* {
  margin: 0;
  padding: 0;
  font-size: 16px;
  font-family: 'Montserrat', arial, sans-serif;
}

:focus {
  outline: none;
}

b,i {
  font-size: inherit;
}

a {
  all: unset;
  cursor: pointer;
}

/*
** Cookies message
*/

.cookiesmsg {
  display: none;
  position: fixed;
  z-index: 1;
  bottom: 0px;
  background-color: #000;
  color: #fff;
  padding: 15px 8%;
}
.cookiesmsgtext  {
  float: left;
  width: 95%;
  padding-right: 15px;
  box-sizing: border-box;
}

.cookiesmsgtext,
.cookiesmsgtext a,
.cookiesmsgtext br {
  font-family: 'Montserrat', arial, sans-serif;
  font-size: 0.9em;
  line-height: 130%;
}
.cookiesmsgtext a {
  font-size: 1em;
  color: #ecb1b2;
}
.cookiesmsgtext a:hover {
  text-decoration: underline;
}

.cookiesmsgbutt  {
  float: right;
  width: 5%;
}
.cookiesmsgbutt svg {
  transform: scale(1.4);
  cursor: pointer;
}

@media (max-width: 768px) {
.cookiesmsg {
  padding: 15px 5%;
}
.cookiesmsgtext,
.cookiesmsgtext a {
  font-size: 0.6em;
}
.cookiesmsgtext a {
  font-size: 1em;
}
}

.bggray {
  background-color: #f0f0f0;
}

.psec {
  padding: 50px 15px 40px 15px;
  text-align: center;
  font-size: 38px;
  font-weight: normal;
  text-transform: uppercase;
}
.psec::after {
  content: "";
  display: block;
  width: 170px;
  margin: 0 auto;
  margin-top: 20px;
  border-top: #ecb1b2 solid 3px;
}

@media (max-width: 768px) {
.psec {
  margin-top: 0;
  padding-top: 40px;
  font-size: 24px;
}
.psec br {
  display: none;
}
}

.titleinfo {
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  padding: 0 15% 35px 15%;
  line-height: 32px;
  white-space: pre-line;
}

@media (max-width: 768px) {
.titleinfo {
  font-size: 16px;
  line-height: 20px;
  white-space: normal;
}
}

.chkbox {
  display: block;
  position: relative;
  padding-left: 24px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.chkbox input {
  position: absolute;
  left: 0;
  top: 14px;
  opacity: 0;
  height: 0;
  width: 0;
}
.chkbox input:checked ~ .chkmark:after {
  display: block;
}
.chkbox .chkmark {
  position: absolute;
  top: 2px;
  left: 0;
  height: 12px;
  width: 12px;
  border: #fff solid 2px;
}
.chkbox .chkmark:after {
  content: "";
  position: absolute;
  display: none;
  left: 3px;
  top: 1px;
  width: 3px;
  height: 6px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.tbutton {
  display: inline-block;
  background-color: #ecb1b2;
  border: 2px solid #ecb1b2;
  color: #000;
  font-weight: 700;
  font-size: 19px;
  height: 38px;
  line-height: 38px;
  padding: 0 35px;
  text-align: center;
  cursor: pointer;
  white-space: nowrap;
  box-sizing: content-box;
}

.topslider.slick-dotted.slick-slider {
  margin-bottom: 0;
}
.topslider .tsitem {
  height: 866px;
  background-color: #7c7873;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff;
  display: flex;
  text-align: center;
  align-items: center;
  padding: 0 15px;
  box-sizing: border-box;
}
.topslider .tsitem h1,
.topslider .tsitem div,
.topslider .tsitem span {
  width: 100%;
  font-size: 45px;
  font-weight: bold;
  text-shadow: 0px 0px 1px #000;
}
.topslider .tsitem span {
  color: #ecb1b2;
}
.topslider .slick-dots {
  display: flex;
  bottom: 20px;
  justify-content: center;
  margin: 0;
  padding: 1rem 0;
  list-style-type: none;
}
.topslider .slick-dots li {
  margin: 0 10px;
}
.topslider .slick-dots button {
  display: block;
  width: 23px;
  height: 23px;
  padding: 0;
  border: none;
  border-radius: 100%;
  background-color: #fff;
  text-indent: -9999px;
}
.topslider .slick-dots li.slick-active button {
  background-color: #ecb1b2;
}

@media (max-width: 1920px) {
.topslider .tsitem {
  height: 45vw;
}
}

@media (max-width: 1000px) {
.topslider .tsitem {
  height: 440px;
}
}

@media (max-width: 768px) {
.topslider .tsitem h1,
.topslider .tsitem div,
.topslider .tsitem span {
  font-size: 27px;
}
}

.imginfo {
  display: flex;
  align-items: center;
}
.imginfo > div {
  box-sizing: border-box;
}
.imginfo > div:first-child {
  align-self: flex-start;
  width: 40%;
  padding-left: 5%;
  text-align: center;
}
.imginfo > div:first-child + div {
  width: 60%;
  padding-right: 15%;
  line-height: 22px;
  font-size: 17px;
}
.imginfo ul {
  padding-left: 20px;
  font-size: inherit;
}
.imginfo li {
  font-size: inherit;
}

@media (max-width: 960px) {
.imginfo > div:first-child {
  padding-left: 0;
}
.imginfo > div:first-child + div {
  padding-right: 5%;
}
.imginfo img {
  width: 250px;
}
}

@media (max-width: 768px) {
.imginfo {
  display: block;
}
.imginfo > div {
  width: 100% !important;
  padding: 0 8% !important;
}
.imginfo > div:first-child + div {
  padding-top: 20px !important;
  font-size: 14px;
}
}

.imginfoswap {
  flex-direction: row-reverse;
}
.imginfoswap > div:first-child {
  width: 40%;
  padding-left: 0;
  padding-right: 5%;
}
.imginfoswap > div:first-child + div {
  width: 60%;
  padding-right: 0;
  padding-left: 11%;
}

.pictinfo {
  margin: 60px auto;
  width: 75%;
  display: flex;
  align-items: center;
  overflow: auto;
}
.pictinfo > div:first-child {
  width: 48%;
  display: flex;
  align-items: center;
  font-size: 22px;
  font-weight: bold;
  white-space: pre-line;
  padding-left: 8%;
  box-sizing: border-box;
}
.pictinfo > div:first-child + div {
  width: 52%;
  line-height: 22px;
  font-size: 17px;
  padding-left: 10px;
  box-sizing: border-box;
}
.pictinfo img {
  width: 135px;
  padding-right: 30px;
  flex-shrink: 0;
}

@media (max-width: 1050px) {
.pictinfo > div:first-child {
  padding-left: 0;
}
}

@media (max-width: 860px) {
.pictinfo {
  margin: 40px auto;
  width: 80%;
  display: block;
}
.pictinfo > div:first-child {
  width: 100%;
  font-size: 16px;
}
.pictinfo > div:first-child + div {
  width: 100%;
  padding-left: 0;
  padding-top: 15px;
  font-size: 14px;
}
.pictinfo img {
  width: 96px;
}
}

.infotiles {
  margin: 0px 8%;
  padding-bottom: 20px;
  overflow: auto;
}

.ptile {
  width: 21.25%;
  height: 220px;
  padding: 30px 0;
  text-align: center;
  float: left;
}
.ptile img {
  width: 135px;
}
.ptile span {
  display: block;
  padding-top: 20px;
  font-size: 18px;
  font-weight: bold;
  line-height: 24px;
  white-space: pre-line;
}

.parr {
  width: 5%;
  height: 136px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px 0;
  float: left;
}
.parr img {
  width: 35px;
}

.pa4 {
  display: none;
}

@media (max-width: 1000px) {
.ptile {
  width: 30%;
}
.pa3 {
  display: none;
}
.pa4 {
  display: flex;
}
}

@media (max-width: 740px) {
.ptile {
  width: 47.5%;
}
.ptile span {
  font-size: 16px;
}
.pa2 {
  display: none !important;
}
.pa3 {
  display: flex;
}
}

@media (max-width: 500px) {
.ptile {
  width: 100% !important;
  padding: 10px 0;
}
.parr {
  display: none;
}
}

.textdesc {
  font-size: 17px;
  line-height: 22px;
  text-align: center;
  padding: 0px 15% 50px 15%;
}
.textdesc a,
.titleinfo a {
  font-weight: bold;
}
.textdesc a:hover,
.titleinfo a:hover {
  text-decoration: underline;
}

@media (max-width: 768px) {
.textdesc {
  font-size: 14px;
  padding: 0 5% 35px 5%;
}
}

.highline {
  line-height: 28px;
}

.ourprojectsbt {
  margin: 60px 0;
  text-align: center;
}

@media (max-width: 768px) {
.ourprojectsbt {
  margin: 50px 0;
}
.ourprojectsbt .tbutton {
  font-size: 15px;
  padding: 0 20px;
}
}

#pfinishsteps > div {
  background-color: #f0f0f0;
  overflow: auto;
  padding-bottom: 30px;
}
#pfinishsteps > div > div {
  margin: 20px auto 40px auto;
  width: 70%;
  display: flex;
  align-items: center;
  overflow: auto;
}
#pfinishsteps > div > div > div:first-child {
  width: 32%;
  text-align: right;
}
#pfinishsteps > div > div > div:first-child + div {
  width: 68%;
  line-height: 25px;
  font-size: 18px;
}
#pfinishsteps img {
  width: 90px;
  padding-right: 45px;
}
#pfinishsteps b {
  font-size: 22px;
  font-weight: bold;
}

@media (max-width: 768px) {
#pfinishsteps > div {
  padding-bottom: 20px;
}
#pfinishsteps > div > div {
  width: 90%;
  align-items: start;
  margin: 0 auto 20px auto;
}
#pfinishsteps img {
  width: 50px;
  padding-top: 5px;
  padding-right: 15px;
}
#pfinishsteps > div > div > div:first-child {
  width: 20%;
}
#pfinishsteps > div > div > div:first-child + div {
  width: 80%;
  font-size: 15px;
  line-height: 22px;
}
#pfinishsteps b {
  font-size: 17px;
}
}

.pimginfooffer > div {
  background-color: #000;
  color: #fff;
  padding-bottom: 60px;
}
.pimginfooffer > div span {
  font-size: inherit;
}
.pimginfooffer .ecb {
  color: #ecb1b2;
}

@media (max-width: 768px) {
.pimginfooffer > div {
  padding-bottom: 40px;
}
}

.bgwhite > div {
  background-color: #fff;
  color: #000;
}

.pimgview {
  display: block;
  margin: 20px auto;
  width: 75%;
}

@media (max-width: 768px) {
.pimgview {
  margin: 0 auto;
  width: 90%;
}
}


/*
** SITE TEMPLATE page
*/

/*
** SITE Header section
*/

#pheader > div {
  position: relative;
  margin-top: 35px;
  height: 65px;
}
#pheader > div > div {
  font-size: 15px;
  height: 32px;
  margin-bottom: 30px;
}

.hdlogo {
  float: left;
  width: 33.33%;
  text-align: center;
}
.hdlogo img {
  width: 180px;
}

#hdlogom {
  display: none;
}

#hdlang {
  width: 10%;
  min-width: 65px;
  line-height: 32px;
  float: right;
}
#hdlang br {
  display: none;
}

#hdtel {
  display: flex;
  align-items: center;
  width: 33.33%;
  float: left;
  justify-content: center;
}
#hdtel img {
  height: 28px;
  margin-right: 10px;
}

#hdform {
  width: 23.33%;
  display: flex;
  justify-content: right;
  padding-right: 15px;
  box-sizing: border-box;
  float: right;
}
#hdform .tbutton {
  background-color: #fff;
  color: #ecb1b2;
  height: 28px;
  padding: 0 20px;
  line-height: 28px;
  font-size: inherit;
}

@media (max-width: 820px) {
#hdlang {
  position: absolute;
  float: none;
  right: 0px;
  top: 0px;
}

.hdlogo {
  width: 100%;
}

#hdlogom {
  display: block;
}

#hdlogod {
  display: none;
}

#hdtel {
  margin-top: 15px;
  width: 50%;
}

#hdform {
  margin-top: 15px;
  width: 50%;
  padding-right: 0px;
  justify-content: center;
}
}

@media (max-width: 500px) {
#hdlang {
  width: 40px;
  min-width: 0px;
  line-height: 16px;
  text-align: center;
}
#hdlang br {
  display: inline;
}
#hdlang span {
  display: none;
}
#hdtel {
  width: 100%;
  margin-bottom: 0px !important;
}

#hdform {
  width: 100%;
  margin-bottom: -30px !important;
}
}


/*
** SITE Menu section
*/

#pmenu > div {
  display: flex;
  justify-content: center;
  clear: both;
}
#pmenu #mhom,
#pmenu #mmen+label {
  padding: 8px 25px 16px 25px;
  line-height: 0;
}
#pmenu img {
  height: 28px;
}
#pmenu #mmen + label {
  display: none;
}
#pmenu label,
#pmenu > div > a {
  display: inline-block;
  padding: 14px 25px;
  font-size: 20px;
  position: relative;
  text-transform: uppercase;
}
#pmenu label:hover,
#pmenu > div > a:hover {
  color: #ecb1b2;
}
#pmenu label div {
  display: none;
}
#pmenu input {
  display: none;
}
#pmenu label {
  cursor: pointer;
}
#pmenu input:checked + label {
  background: #000;
  color: #fff;
}
#pmenu label div {
  position: absolute;
  z-index: 10;
  background: #000;
  margin-top: 14px;
  left: 0px;
  padding: 12px 0px;
}
#pmenu label a {
  text-align: left;
  font-size: 13px;
  display: block;
  white-space: nowrap;
  padding: 3px 25px;
  text-transform: none;
}
#pmenu label a:hover {
  color: #ecb1b2;
}
#pmenu input:checked + label div {
  display: block;
}

@media (max-width: 820px) {
#pmenu > div {
  display: block;
}
#pmenu label div {
  position: static;
  background: #fff;
  margin-top: 0px;
  padding: 10px 0px 0px 0px;
}
#pmenu label a {
  font-size: 13px;
  padding: 8px 25px;
}
#pmenu label,
#pmenu > div > a {
  display: none;
  padding: 8px 25px;
}
#pmenu #mhom,
#pmenu #mmen+label {
  display: inline-block;
  padding: 0px 10px;
  margin-bottom: 20px;
}
#pmenu #mmen+label {
  float:right;
}
#pmenu #mmen:checked ~ a,
#pmenu #mmen:checked ~ label {
  display: block;
}
#pmenu input:checked+label {
  background: #fff;
  color: #000;
}
}


/*
** SITE Contact section
*/

#pcontact > div {
  padding-bottom: 50px;
  background-color: #7c7873;
  background-image: url("/img/bgcont.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff;
}
#pcontact .titleinfo br {
  display: inline;
}
#pcontact form > div {
  margin: 0 auto;
  width: 450px;
  box-sizing: border-box;
  background-color: rgba(0,0,0,0.7);
  text-align: center;
  padding: 0 40px 25px 40px;
}
#pcontact form p {
  font-size: 21px;
  padding: 22px 0;
}
#pcontact #continp {
  margin-bottom: 25px;
}
#pcontact #continp input {
  display: inline-block;
  width: 100%;
  height: 40px;
  border: none;
  margin: 3px 0;
  padding-left: 8px;
  box-sizing: border-box;
}
#pcontact #continp input::placeholder {
  opacity: 1;
  font-size: 14px;
}
#pcontact .formchk {
  width: 100%;
  margin: 12px auto;
  text-align: left;
}
#pcontact .chkbox {
  font-size: 11px;
}
#pcontact .tbutton {
  margin: 0 auto;
}
#pcontact .contstat {
  display: none;
  height: 42px;
  text-align: center;
  font-weight: bold;
  font-size: 18px;
  color: #ecb1b2;
}

@media (max-width: 768px) {
#pcontact form > div {
  width: 100%;
  max-width: 450px;
}
#pcontact form p {
  font-size: 18px;
}
#pcontact .contstat {
  font-size: 16px;
}
}

@media (max-width: 400px) {
#pcontact form > div {
  padding: 0 20px 25px 20px;
}
}


/*
** SITE Footer section
*/

#pfooter > div {
  float: left;
  margin-top: 40px;
  box-sizing: border-box;
}
#pfooter > div > div {
  float: left;
}
#pfooter div {
  font-size: 14px;
  line-height: 23px;
}
#pfooter a:hover {
  color: #ecb1b2;
}

#footadr {
  width: 53%; /***//*43*/
  padding-left: 8%;
}
#footadr > div:first-child {
  margin-right: 10%;
}
#footadr img {
  width: 130px;
  margin-top: 6px;
  margin-bottom: 10px;
}

#footmap {
  width: 47%; /***//*37*/
}
#footmap > div {
  padding-left: 10px;
}
#footmap > div:first-child {
  float: none;
}
#footmap > div:first-child + div {
  width: 55%;
}
#footmap a {
  text-transform: uppercase;
}

#footsoc {
  display: none; /***/
  width: 20%;
  padding-left: 10px;
}
#footsoc a {
  display: flex;
  align-items: center;
  margin: 8px 0;
}
#footsoc img {
  width: 32px;
  margin-right: 8px;
}

#copyright {
  width: 100%;
  text-align: center;
  margin: 25px 0 !important;
}
#copyright br {
  display: none;
}

@media (max-width: 768px) {
#pfooter > div {
  float: none;
  width: 100%;
  padding-left: 30px;
  margin-top: 20px;
}
#pfooter > div > div {
  float: none;
  width: 100% !important;
}

#footmap > div {
  padding-left: 0;
}

#footadr {
  margin-top: 30px !important;
}

#copyright {
  padding-left: 0 !important;
  line-height: 18px !important;
}
#copyright br {
  display: block;
}
}


/*
** MAIN page
*/

/*
** MAIN title section
*/

#pmaintitle .tsitem1 {
  background-image: url("/img/bgmaint1.jpg");
}
#pmaintitle .tsitem2 {
  background-image: url("/img/bgmaint2.jpg");
}
#pmaintitle .tsitem3 {
  background-image: url("/img/bgmaint3.jpg");
}


/*
** MAIN who we are section
*/

#whowearedesc3 {
  overflow: auto;
  overflow-x: hidden;
  margin-top: 40px;
  background-color: #000;
  padding: 60px 8%;
}
#whowearedesc3 > div {
  float: left;
  color: #fff;
  box-sizing: border-box;
  width: 33.33%;
  padding: 0 2%;
  font-size: 17px;
  line-height: 22px;
  
}
#whowearedesc3 > div span {
  font-size: 25px;
  font-weight: bold;
}

@media (max-width: 768px) {
#whowearedesc3 {
  padding: 40px 8%;
  padding-bottom: 10px;
}
#whowearedesc3 > div {
  float: none;
  width: 100%;
  padding: 0;
  padding-bottom: 30px;
  font-size: 14px;
}
#whowearedesc3 > div span {
  font-size: 16px;
}
}


/*
** MAIN what makes us different section
*/

#pwhatdiff > div {
  background-color: #7c7873;
  background-image: url("/img/bgwhatdiff.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff;
}

#pwhatdiff .infotiles {
  margin: 0px 20%;
}

#pwhatdiff .ptile {
  width: 33.33%;
}
#pwhatdiff .ptile img {
  filter: brightness(1.15);
}

@media (max-width: 740px) {
#pwhatdiff .ptile {
  width: 50%;
}
}


/*
** MAIN benefits section
*/

#pbenefits > div {
  background-color: #f0f0f0;
}

.pctiles {
  padding-bottom: 40px;
  overflow: auto;
}

.pctile {
  width: 50%;
  padding: 20px 0;
  box-sizing: border-box;
  float: left;
}
.pctile > div {
  width: 370px;
  display: flex;
  align-items: center;
}
.pctile img {
  width: 154px;
  padding-right: 25px;
}
.pctile span {
  font-size: 18px;
  font-weight: bold;
  line-height: 24px;
  white-space: pre-line;
}

.pctl > div {
  float: right;
}

@media (max-width: 768px) {
.pctile {
  width: 100%;
  padding: 8px 0;
}
.pctile > div {
  float: none;
  width: 310px;
  margin: 0 auto;
}
.pctile img {
  width: 110px;
}
.pctile span {
  font-size: 16px;
}
}


/*
** MAIN realizations section
*/

#prealizations > div > div {
  margin: 25px auto;
  width: 85%;
  max-width: 1140px;
  overflow: auto;
}
#prealizations a {
  display: block;
  float: left;
  width: 50%;
  padding: 8px 10px;
  box-sizing: border-box;
}
#prealizations img {
  aspect-ratio: 550/302;
  width: 100%;
}

@media (max-width: 648px) {
#prealizations > div > div {
  margin: 0 auto;
}
#prealizations a {
  width: 100%;
  padding: 5px 0;
}
}


/*
** MAIN finishingdesigns section
*/

.findeslist {
  background-color: #f0f0f0;
  padding: 50px 15%;
}
.findeslist a {
  color: #bc4142;
  font-weight: bold;
}
.findeslist input {
  display: none;
}
.findeslist a:hover {
  text-decoration: underline;
}
.findeslist > div {
  display: flex;
}
.findeslist input + div {
  flex: 0 0 70px;
}
.findeslist input + div > label > img {
  width: 45px;
  cursor: pointer;
}
.findeslist input:checked + div > label > img:first-child {
  display: none;
}
.findeslist input:not(:checked) + div > label > img:first-child + img {
  display: none;
}
.findeslist input + div + div {
  flex: 1 1 auto;
}
.findeslist input + div + div > h2 {
  padding-top: 12px;
  font-size: 20px;
  font-weight: bold;
  display: block;
}
.findeslist input + div + div > h2 + div {
  margin-top: 28px;
  font-size: 17px;
  line-height: 22px;
}
.findeslist input:not(:checked) + div + div > h2 + div {
  display: none;
}
.findeslist .fdhr {
  height: 1px;
  margin: 22px 0 25px 0;
  background-color: #000;
}

@media (max-width: 768px) {
.findeslist {
  padding: 50px 5%;
}
.findeslist input + div {
  flex: 0 0 60px;
}
.findeslist input + div + div > h2 {
  padding-top: 14px;
  font-size: 17px;
}
.findeslist input + div + div > h2 + div {
  font-size: 14px;
}
}


/*
** TURNKEY APARTMENTS page
*/

#pturnkeytitle .tsitem1 {
  background-image: url("/img/bgturnkeyt.jpg");
}

#phowfinwork > div {
  background-color: #000;
  color: #fff;
}
#phowfinwork p {
  margin: 0 10%;
  padding-bottom: 50px;
  text-align: center;
  text-size: 18px;
  font-weight: bold;
  white-space: pre-line;
}
#phowfinwork .infotiles {
  margin: 0px 10%;
}
#phowfinwork .ptile {
  width: 33.33%;
  height: 280px;
}
#phowfinwork .ptile span {
  font-weight: normal;
  padding-right: 10%;
  padding-left: 10%;
}
#phowfinwork .ptile span b {
  font-size: 22px;
}
#phowfinwork .ptile img {
  filter: brightness(1.15);
  width: 90px;
}

@media (max-width: 740px) {
#phowfinwork .ptile {
  width: 50%;
}
}

#ptkadvantages > div {
  background-color: #f0f0f0;
  overflow: auto;
}


/*
** SHOW APARTMENTS page
*/

#pshowapttitle .tsitem1 {
  background-image: url("/img/bgshowaptt.jpg");
}

#psameetteam > div,
#psainfooffer2 > div {
  background-color: #f0f0f0;
  color: #000;
}

#psainfooffer > div {
  background-color: #000;
  color: #fff;
}

#psabenefitsrv .pictinfo {
  align-items: flex-start;
}


/*
** SALES OFFICES page
*/

#pofficestitle .tsitem1 {
  background-image: url("/img/bgofficest.jpg");
}

#pbscoopdet > div {
  background-color: #f0f0f0;
  color: #000;
}

#pbsidoffice .psec {
  padding-top: 0px;
}
#pbsidoffice .textdesc {
  background-color: #000;
  color: #fff;
}

#pbsfunc > div {
  background-color: #ecb1b2;
}
#pbsfunc .psec::after {
  border-top-color: #fff;
}


/*
** APARTMENT DESIGN page
*/

#paptdesigntitle .tsitem1 {
  background-image: url("/img/bgaptdesign.jpg");
}

#padtitle .pimgview,
[id^=padtip] .pimgview {
  margin-top: 0;
  margin-bottom: 50px;
}
[id^=padtip] .titleinfo {
  padding-top: 35px;
}
[id^=padtip] .imginfo {
  padding-bottom: 50px;
}

#padtip1 > div,
#padtip5 > div {
  background-color: #f0f0f0;
}

#padtip3 > div {
  background-color: #000;
  color: #fff;
}

@media (max-width: 768px) {
#padtitle .pimgview,
[id^=padtip] .pimgview {
  margin-bottom: 35px;
}
[id^=padtip] .imginfo {
  padding-bottom: 35px;
}
}


/*
** REALIZATIONS page
*/

#prealtitle .tsitem1 {
  background-image: url("/img/bgrealt.jpg");
}

#prealshow {
  text-align: center;
}

#prealshow h2 {
  text-transform: uppercase;
}

#prealshow .locname {
  font-size: 18px;
  text-transform: none;
  display: inline-block;
}

.catpictlist {
  margin: 25px auto;
  width: 75%;
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.catpictlist a {
  max-width: 600px;
  display: inline-block;
  width: 50%;
  padding: 10px;
  box-sizing: border-box;
  flex-shrink: 0;
}
.catpictlist a:hover span {
  color: #ecb1b2;
}
.catpictlist a:hover img {
  transform: scale(1.1);
}
.catpictlist div {
  overflow: hidden;
}
.catpictlist img {
  display: block;
  aspect-ratio: 550/302;
  width: 100%;
  transform: scale(1);
  transition: transform .3s;
  transition-timing-function: cubic-bezier(.4,.8,.8,.9);
}
.catpictlist span {
  display: block;
  background-color: #000;
  color: #fff;
  line-height: 75px;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  white-space: nowrap;
}

@media (max-width: 1100px) {
.catpictlist span {
  font-size: 18px;
  line-height: 60px;
}
}

@media (max-width: 930px) {
.catpictlist {
  width: 90%;
}
.catpictlist a {
  min-width: 350px;
  padding: 8px;
}
.catpictlist span {
  font-size: 16px;
  line-height: 50px;
}
}

.catlist {
  margin: 30px 0 50px 0;
  white-space: pre-line;
  text-align: center;
}
.catlist a {
  text-transform: uppercase;
  font-size: 20px;
  line-height: 36px;
}

@media (max-width: 768px) {
.catlist {
  margin: 0px 0 40px 0;
}
.catlist a {
  font-size: 15px;
}
}

.locpictlist {
  margin: 25px auto;
  width: 75%;
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  max-width: 1500px;
}
.locpictlist div {
  display: inline-block;
  width: 25%;
  padding: 6px;
  box-sizing: border-box;
  flex-shrink: 0;
  overflow: hidden;
  cursor: pointer;
}
.locpictlist div:hover img {
  transform: scale(1.1);
}
.locpictlist img {
  display: block;
  aspect-ratio: 350/255;
  width: 100%;
  transform: scale(1);
  transition: transform .3s;
  transition-timing-function: cubic-bezier(.4,.8,.8,.9);
}
.locpictlist p {
  width: 100%;
  margin: 20px 0px 10px 5px;
  font-size: 18px;
}

@media (max-width: 1500px) {
.locpictlist div {
  width: 33.33%;
}
}

@media (max-width: 930px) {
.locpictlist {
  width: 90%;
}
}

@media (max-width: 768px) {
.locpictlist div {
  width: 50%;
}
}

@media (max-width: 500px) {
.locpictlist div {
  width: 100%;
}
.locpictlist p {
  font-size: 16px;
}
}


/*
** BLOG pages
*/

#pblogtitle .tsitem1 {
  background-image: url("/img/bgblogt.jpg");
}

#pbloglisthead > div {
  padding-bottom: 15px;
}

#pbloglist > div {
  overflow: auto;
  padding: 50px 0;
  background-color: #f0f0f0;
}

.bloglist {
  margin: 25px auto;
  width: 75%;
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  max-width: 1500px;
}
.bloglist > div {
  display: inline-block;
  width: 25%;
  padding: 6px;
  box-sizing: border-box;
  flex-shrink: 0;
  overflow: hidden;
}
.bloglist > div > div:first-child {
  aspect-ratio: 35/48;
  width: 100%;
  background-color: #fff;
  overflow: hidden;
}
.bloglist > div > div:first-child + div {
  background-color: #fff;
  text-align: center;
  padding: 15px 0;
}
.bloglist > div p {
  padding-top: 8px;
}
.bloglist .blinf {
  padding: 5px 15px 0 15px;
}
.bloglist .blhd {
  font-size: 17px;
  text-transform: uppercase;
}
.bloglist .bldt {
  font-size: 14px;
  font-weight: bold;
  color: #ecb1b2;
  filter: brightness(0.9);
}
.bloglist .bltx {
  font-size: 14px;
  line-height: 19px;
}
.bloglist .tbutton {
  background-color: #000;
  border-color: #000;
  color: #fff;
}
.bloglist img {
  display: block;
  aspect-ratio: 350/255;
  width: 100%;
}

@media (max-width: 1500px) {
.bloglist > div {
  width: 33.33%;
}
}

@media (max-width: 1000px) {
.bloglist {
  width: 90%;
}
}

@media (max-width: 850px) {
.bloglist > div {
  width: 50%;
}
}

@media (max-width: 550px) {
#pbloglist > div {
  padding: 30px 0;
}
.bloglist > div {
  width: 100%;
}
}

#pbloghead .titleinfo {
  color: #ecb1b2;
  filter: brightness(0.95);
}
#pbloghead .psec {
  white-space: pre-line;
}

#pblogcontent > div {
  margin: 60px 20%;
}
#pblogcontent > div > p {
  font-size: 17px;
  line-height: 22px;
  margin: 20px 0;
}
#pblogcontent > div > h2 {
  font-size: 22px;
  font-weight: bold;
}
#pblogcontent > div > h3,
#pblogcontent > div > .h3 {
  font-size: 17px;
  font-weight: bold;
}
#pblogcontent > div > ul {
  padding-left: 20px;
  list-style-position: outside;
  line-height: 22px;
}
#pblogcontent > div li {
  font-size: 17px;
}
#pblogcontent > div a {
  color: #bc4142;
}
#pblogcontent > div a:hover {
  text-decoration: underline;
}
#pblogcontent .locpictlist {
  width: 100%;
}

#pblogbackbutt > div {
  text-align: center;
  margin-bottom: 60px;
}
#pblogbackbutt .tbutton {
  background-color: #000;
  border-color: #000;
  color: #fff;
}

#pblogrelated > div {
  overflow: auto;
  padding-bottom: 10px;
  margin-bottom: 60px;
  background-color: #f0f0f0;
}

#pblogrelated .bloglist > p {
  width: 100%;
  padding: 0px 0px 15px 5px;
  text-transform: uppercase;
  font-size: 20px;
}

@media (max-width: 768px) {
#pblogcontent > div {
  margin: 40px 5%;
}
#pblogcontent > div > p {
  font-size: 15px;
  line-height: 20px;
}
#pblogcontent > div > h2 {
  font-size: 18px;
}
#pblogcontent > div > h3,
#pblogcontent > div > .h3 {
  font-size: 15px;
}
#pblogcontent > div li {
  font-size: 15px;
}

#pblogbackbutt > div {
  margin-bottom: 45px;
}

#pblogrelated > div {
  margin-bottom: 45px;
}
}


/*
** CAREER page
*/

#ppartnerstitle .tsitem1,
#pcareertitle .tsitem1,
#pteamtitle .tsitem1 {
  background-image: url("/img/bgjoinust.jpg");
}

.bggrey > div {
  background-color: #f0f0f0;
}

.careervacancy > div {
  overflow: auto;
  padding: 0 10px 30px 10px;
  text-align: center;
}
.careervacancy h3 {
  font-size: 22px;
  line-height: 70px;
}
.careervacancy ul {
  margin-bottom: 30px;
}
.careervacancy li {
  font-size: 17px;
  line-height: 28px;
  list-style-position: inside;
}

#careerbutton > div {
  margin-top: 0px;
}

@media (max-width: 768px) {
.careervacancy > div {
  padding-bottom: 20px;
}
.careervacancy h3 {
  font-size: 18px;
  line-height: 35px;
}
.careervacancy ul {
  margin-bottom: 25px;
}
.careervacancy li {
  font-size: 14px;
  line-height: 22px;
}
}


/*
** TEAM page
*/

#pteamhead .imginfo {
  padding: 40px 0;
  background-color: #f0f0f0;
}
#pteamhead .imginfo span {
  font-size: 25px;
  font-weight: bold;
}

#pteampeople > div {
  background-color: #000;
  color: #fff;
  padding-bottom: 25px;
}
#pteampeople .textdesc {
  white-space: pre-line;
}

.teamphoto {
  text-align: center;
  margin: 30px 0;
}
.teamphoto img {
  width: 200px;
  margin-top: 20px;
  margin-bottom: 14px;
}
.teamphoto b {
  font-size: 26px;
}
.teamphoto i {
  font-size: 20px;
  line-height: 35px;
}

.tpdbl {
  display: flex;
}
.tpdbl > div {
  width: 50%;
}

@media (max-width: 768px) {
.teamphoto {
  margin: 15px 0;
}
.teamphoto b {
  font-size: 22px;
}
.teamphoto i {
  font-size: 16px;
  line-height: 25px;
}
.tpdbl {
  display: block;
}
.tpdbl > div {
  width: 100%;
}
}


/*
** PARTNERS page
*/

#ppartnerslist > div {
  margin: 0 13% 60px 13%;
}
#ppartnerslist > div > div {
  display: flex;
}
#ppartnerslist > div > div > img:first-child + img {
  width: 30%;
}
#ppartnerslist img {
  width: 35%;
  padding: 40px;
  box-sizing: border-box;
  object-fit: contain;
}

@media (max-width: 768px) {
#ppartnerslist img {
  padding: 20px;
}
}

@media (max-width: 500px) {
#ppartnerslist > div {
  margin: 0 0 40px 0;
}
#ppartnerslist > div > div {
  display: block;
  text-align: center;
}
#ppartnerslist > div > div > img:first-child + img {
  width: 48%;
}
#ppartnerslist img {
  width: 56%;
}
}


/*
** CONTACT page
*/

#pcontactpgtitle .tsitem1 {
  background-image: url("/img/bgmaint2.jpg");
}
#pcontactpgtitle ~ #pcontact h2 {
  display: none;
}
#pcontactpgtitle ~ #pcontact .titleinfo {
  padding-top: 15px;
}

#pcontactpghead > div {
  text-align: center;
}
#pcontactpghead img {
  padding: 10px 0 30px 0;
  width: 135px;
}

#contcall {
  font-size: 19px;
  font-weight: bold;
}

#contphonenumber {
  display: inline-block;
  padding: 10px 0 40px 0;
  font-size: 38px;
}

#pcontactpgaddr > div {
  padding: 60px 5% 50px 5%;
  text-align: center;
  background-color: #000;
}
#pcontactpgaddr img {
  width: 180px;
}
#pcontactpgaddr p {
  white-space: pre-line;
  color: #fff;
  font-size: 20px;
  line-height: 32px;
}

@media (max-width: 768px) {
#contphonenumber {
  font-size: 30px;
}

#pcontactpgaddr p {
  font-size: 16px;
  line-height: 28px;
}
}

#pcontactpgmap #locmap {
  height: 45vw; 
}
#pcontactpgmap iframe {
  width: 100%;
  height: 100%;
  filter: grayscale(100%); 
}

@media (max-width: 1000px) {
#pcontactpgmap iframe {
  height: 600px;
}
}

#photoviewer #pvcont {
  display: none;
  background-color: rgba(0,0,0,0.7);
  position: fixed;
  z-index: 90;
  top: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
#photoviewer .pvitem {
  height: 100vh;
  padding: 10px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
}
#photoviewer img {
  max-width: 100%;
  max-height: 100%;
  border: #fff solid 10px;
  border-radius: 10px;
  box-sizing: border-box;
}
#photoviewer #pvclose {
  display: none;
  position: fixed;
  width: 40px;
  height: 40px;
  top: 10px;
  right: 10px;
  border: 7px solid #000;
  border-radius: 10px;
  z-index: 95;
  cursor: pointer;
  background:
    linear-gradient(45deg, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 43%,#fff 45%,#fff 55%,rgba(0,0,0,0) 57%,rgba(0,0,0,0) 100%),
    linear-gradient(135deg, #000 0%,#000 43%,#fff 45%,#fff 55%,#000 57%,#000 100%);
}

.arrowx {
  position: fixed;
  width: 54px;
  height: 54px;
  margin-top: -27px;
  top: 50%;
  background: #000;
  border: 0px;
  border-radius: 10px;
  z-index: 94;
  cursor: pointer;
}
.arrowx div {
  width: 30px;
  height: 30px;
  border: solid #fff;
  border-radius: 5px;
  border-width: 6px 6px 0 0;
  margin: 12px 12px 6px 6px;
  box-sizing: border-box;
  transform: rotate(45deg);
}

.rightx {
  right: 10px;
}

.leftx {
  left: 10px;
  transform: scaleX(-1);
}
