:root {
--color-primary: #a164ff;
--color-secondary: #0f0223;
--logo-color:  #fff;
--btm-text-color:  #202020;
--footer-text-color:  #fff;
--bg-top:  #0f0223 url("../images/main_intro_bg_xl.jpg");
--bg-footer:  #161518 url("../images/main_footer_bg_xl.jpg");
--button-text:  #fff;
--button-bg:  #a164ff;
--form-border: #bdbdbd ;
--form-border-active: #9359ee;
}


/* 
////
//// Easing general purpose
////
--------------------------------------------------------------*/
.easeOut { -webkit-transition-property: all; -webkit-transition-duration: 350ms; -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); -moz-transition-property: all; -moz-transition-duration: 350ms; -moz-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); transition-property: all; transition-duration: 350ms; transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); }
/* 
////
//// Default Font
////
--------------------------------------------------------------*/
html, body { height: 100%; min-height: 100%; }
body { font-family:  "Quicksand",  "Helvetica Neue", Arial, "Nimbus Sans L", FreeSans; font-weight: 400; }
strong { font-weight: 600; }
.genC1 { color: var(--color-primary)!important; }
.genC2 { color: var(--color-secondary)!important; }
#fullWrp { margin: 0 auto; min-height: 100%; background: var(--bg-body); position: relative;  }
svg path,svg shape,svg linearGradient { shape-rendering: geometricPrecision; }

/* Header 
--------------------------------------------------------------*/
#mainHdr {  position: absolute;  left: 0; top: 0; padding: 25px 0; width: 100%; z-index: 10;   }
#mainHdr .FrmCtr { display: flex;  justify-content: space-between; align-items: center;  }
#mainHdr  .mainLogo {  color: var(--logo-color); font-size:  3.2rem; line-height: 1em; font-weight: 800; letter-spacing: -0.04em;  }
#mainHdr  .rgtInfo, #mainHdr  .rgtInfo a {  color: var(--logo-color); }
#mainHdr  .rgtInfo { display: flex; align-items: center; }
#mainHdr  .rgtInfo .ico  { min-width: 5em; max-width: 5em; min-height: 5em; display: flex; align-items: center; justify-content: center; margin-right: 0.4em;  }
#mainHdr  .rgtInfo .ico  img { min-width: 3.9em; max-width: 3.9em; }
#mainHdr  .rgtInfo .ln0 { font-size: 1.6em; font-weight: 700; padding: 0; color: #fff; letter-spacing: -0.02em; }
#mainHdr  .rgtInfo .ln0 a { color: #fff;  }
#mainHdr  .rgtInfo .ln1 { font-size: 1.4em; font-weight: 400; padding: 0.05em 0 0 0; color: #fff; letter-spacing: -0.02em; }

/* Top 
--------------------------------------------------------------*/
#mainTop { overflow: hidden; background: var(--bg-top) no-repeat center center; background-size: cover; }
#mainTop .bg { padding: 20rem 0;  display: flex; justify-content: center; align-items: center; margin-bottom: -1px; position: relative; }
#mainTop .FrmCtr { display: flex; justify-content: center; }
#mainTop  .ctr .ln1 { font-size: 5rem; padding-bottom: 0; font-weight: 800; line-height: 1em; color: #fff; letter-spacing:  -0.02em; padding: 0.3em 0.5em; text-transform: uppercase; border: solid 1px rgba(255,255,255,0.5); }
@media all and (max-width: 1240px) {
#mainTop  .ctr  { font-size: 0.8vw; }
}
@media all and (max-width: 992px) {
#mainTop .bg { padding: 16rem 0; }
}
@media all and (max-width: 768px) {
#mainTop  .ctr   { font-size: 1.1vw;}
#mainTop  .ctr .ln1 { font-size:5rem; }
}
/* Mid Bg
--------------------------------------------------------------*/
#mainMidBg {  background:  url("../images/main_mid_bg_xl.jpg") no-repeat center center; background-size: cover; height: 26.66vw; min-height: 256px; } 
/* Mid
--------------------------------------------------------------*/
#mainInfo { background: #fff center center; text-align: center; padding: 15rem 0 0 0; }
#fullWrp .altInfo { padding: 15rem 0; }
#mainInfo .FrmCtr { display: flex; justify-content: space-between; align-items: center; max-width: 869px; }
#mainInfo .ln2 { font-size: 4em; padding-bottom: 2.6em; text-align: center; font-weight: 700; max-width: 11em; margin: 0 auto; line-height: 1.1em; }
#mainInfo .FrmCtr .itm { border: solid 1px #9359ee; width: calc(33.33% - 21.33px); min-width: calc(33.33% - 21.33px); border-radius: 1.3rem;   padding: 0  0 6em 0; background: #9359ee; align-self: stretch; }
#mainInfo .FrmCtr .itm .ico { width: 8em; height: 8em; display: flex; margin: 0 auto; color: #fff; background: var(--color-primary); position: relative;  top: -4em;  margin-bottom: -4em; box-shadow: 0 0.6em 0.6em -0.2em rgba(0,0,0,0.35); }
#mainInfo .FrmCtr .itm .ico svg { width: 4em; margin: 0 auto; }
#mainInfo .FrmCtr .itm .ico svg.env { width: 4em;}
#mainInfo .FrmCtr .itm .title { font-size: 2.1em; padding: 1.4em 0 0.8em 0; color: #fff;}
#mainInfo .FrmCtr .itm p { font-size: 1.6em; line-height: 1.6em; height: 3.2em;  color: #fff; padding: 0; font-weight: 500; display: block; position: relative; width: 100%;  }
#mainInfo .FrmCtr .itm a { color: #fff!important; }
#mainInfo .FrmCtr .itm p:after { content: ''; display: block; height:2px; background: #fff; width: 4.2em; margin: 0 auto 0 -2.1em; position: absolute; left: 50%;  bottom: -1.4em; }
@media (max-width: 1080px) {
#mainInfo .FrmCtr .itm { width: calc(33.33% - 13.33px); min-width: calc(33.33% - 13.33px); }
}
@media (max-width: 992px) {
#mainInfo { padding: 6rem 0 0 0; }
#mainInfo .ln2 { font-size: 3.8em; padding-bottom: 1.6em; }
#fullWrp .altInfo { padding: 6rem 0; }
#mainInfo .FrmCtr .itm { font-size: 1vw; }
}
@media (max-width: 640px) {
#mainInfo .FrmCtr { flex-direction: column; }
#mainInfo .FrmCtr .itm { width: 100%; min-width: 100%; margin-top: 2rem; font-size: 1rem; }
#mainInfo .FrmCtr .itm:first-child { margin-top: 0; }
}
/* Btm
--------------------------------------------------------------*/
#mainBtm { background: #ffffff   no-repeat left center; background-size: auto 100%!important;  } 
#mainBtm .bg { background:  no-repeat right center ; background-size: auto 100%!important; padding:  10rem 0; }
#mainBtm .FrmCtr { max-width: 1110px; }
#mainBtm .contactFrm { display: flex; justify-content: center; align-items: stretch; padding: 0; }
#mainBtm .tmb { background: no-repeat center center; background-size: cover!important;     flex-grow: 1;  }
#mainBtm .rgtForm { flex-grow: 1; max-width:  1110px;  }
#mainBtm .formWrp { padding: 0; }
#mainBtm .ln1 { font-size: 1.6em; padding-bottom: 0.4em; display: block;  text-align: center; color: var(--color-primary); font-weight: 600; }
#mainBtm .ln2 { font-size: 4em; padding-bottom: 1.0em; text-align: center; font-weight: 700; max-width: 11em; margin: 0 auto; line-height: 1.1em; }
#mainBtm .formWrp p .ico { position: absolute;  padding-left: 12px; left: 0;  top: 0; height: 58px;  width: 24px;  display: flex; justify-content: center; align-items: center;   font-size: 16px; min-width: 24px; }
#mainBtm .formWrp p.HfRlg  .ico { left: 0.75rem; }
#mainBtm .formWrp p .ico svg { width: 16px; }

#mainBtm textarea  { padding-top: 1.1em; padding-bottom: 1.1em; }
#mainBtm .btnWrp { padding-top: 2rem; clear: both;  } 
#mainBtm .genBtn1 .ico { background: var(--color-primary); min-width: 3.25em; min-height: 3.25em; padding: 0; display: flex; justify-content: center; align-items: center; margin-left: 1em; }
#mainBtm  .btnConfirm { display: flex; justify-content: flex-start; }
 
#mainBtm .conf { color: #000; font-size: 16px; padding: 0.4em  0; text-align: center;  }
@media (max-width: 992px) {
#mainBtm .bg { padding:  6rem 0; }
#mainBtm .ln2 { font-size: 3.8em; }
}
@media (max-width: 942px) {
#mainBtm .rgtForm {max-width:  574px;  }
#mainBtm .formWrp { padding: 0 0em; }
}
@media (max-width: 825px) {
#mainBtm .contactFrm { flex-direction: column; align-items: center;   }
#mainBtm .rgtForm { max-width:  100%;  }
#mainBtm .formWrp {  padding: 0 0em; }
#mainBtm .tmb { padding-top: 19em; width: 19em; border-radius: 100em; background-position: center top!important;  }
}
@media (max-width: 639px) {
#mainBtm .formWrp p.HfRlg  .ico { left: 0 }
}

/* Footer
--------------------------------------------------------------*/
#mainFtr { background: var(--bg-footer); box-shadow: inset 0 -155px 40px -120px #161518, 0 4000px 0 4000px #161518; color: var(--footer-text-color);  padding: 12rem 0; font-weight: 500;  }
#mainFtr p {  font-size: 16px;  padding: 0;   }
@media all and (max-width: 992px) {
#mainFtr { padding: 6rem 0; }
}
@media all and (max-width: 572px) {
#mainFtr { padding:  6rem 0;  }
#mainFtr p  { font-size: 2rem; }
}
