.contactHeroBanner-ct		{
	 min-height: 380px;
   background-size: cover;
   background-position: center;
   display: flex;
   align-items: center;
     justify-content: center;
      position: relative;
	 padding: 87px 23px;
}

.contactHeroBanner-ct:before {
  content: "";
    position: absolute;
   top: 0;
  left     :   0;
   right: 0;
   bottom: 0;
  background: rgba(26,48,74,0.82);
}

.heroContactContent {
   position: relative;
    z-index :       2;
	text-align: center;
   max-width: 780px;
}


.contactPageTitle {
    font-weight: 800;
   margin-bottom: 16px;
               color: #ffffff;
    font-size   :        46px;
}

.contactPageSubtitle {

   font-size: 18px;
   color: #e8f1f8;
	line-height: 1.61;
}

.contactMainArea-ct {
  padding: 84px 0;
   background: #ffffff;
}

.contactGridLayout {
   display     :       grid;
  grid-template-columns: 1fr 1.4fr;
   gap: 64px;
  align-items: start;
}

.contactInfoColumn-ct {
   position :   sticky;
    top: 97px;
}

.infoColumnHeading   {
    font-weight: 700;
  color: #1a202c;
  margin-bottom: 18px;
    font-size: 33px;
}

.infoColumnText {
                  font-size: 16px;
  color: #4a5568;
   line-height: 1.73;
  margin-bottom: 38px;
}

.contactMethodsList {
	margin-bottom: 37px;
}

.contactMethodItem {
  display: flex;
   gap: 19px;
  align-items: start;
               margin-bottom: 29px;
	 padding-bottom  :    29px;
   border-bottom: 1px solid #e2e8f0;
}

.contactMethodItem:last-child {
	   border-bottom: none;
       margin-bottom: 0;
    padding-bottom  : 0;

}

.methodIconCircle     {


          width: 54px;
          height: 54px;
    border-radius: 50%;
  background: linear-gradient(135deg, #ebf8ff 0%, #bee3f8 100%);
     display: flex;
   align-items: center;
  justify-content: center;
       flex-shrink: 0;
	} 

.methodIconSvg {
  stroke-width   :    2.2;
	  width: 26px;
	        stroke: #2b6cb0;
	   height: 26px;
	  fill: none;
}

.methodLabel {
                    font-size: 16px;
               font-weight: 600;
  color: #2d3748;
                    margin-bottom: 7px;


}


.methodValue     {
    font-size: 15px;
	color: #4a5568;
                    line-height : 1.68;
   margin :    0 0 4px 0;
}

.methodNote {
  font-size: 13px;
    color: #718096;
  font-style: italic;
    margin:  0;
}



.responseTimeBlock 
 {
     background: linear-gradient(135deg, #ebf8ff 0%, #f7fafc 100%);
 padding   :      23px 21px;
    border-radius: 9px;
    display: flex;
    gap: 17px;
  align-items: start;}

.responseIconBadge {
   width: 47px;
	height: 47px;
  background: #2b6cb0;
   border-radius :     50%;
  display: flex;
    align-items:       center;
	justify-content    :      center;
  flex-shrink: 0; 
	
}

.responseSvgIcon    {

  width: 24px;
    height: 24px;
  stroke    :       #ffffff;
    fill: none;
   stroke-width: 2.3;

}


.responseHeading {
	 font-size: 17px;
    font-weight: 700;
    color: #1a202c;
	 margin-bottom: 6px;


}

.responseDesc {
  font-size: 14px;
       color   :        #4a5568;
	line-height: 1.67;
    margin: 0;
}

.contactFormColumn-ct {
          background: #f7fafc;
   padding: 0;
}

.formWrapper  
  {
   background: #ffffff;
      padding   :44px 39px;
     border-radius     :13px;
       border: 2px solid #e2e8f0; 
	
}

.formMainHeading {
		font-size: 29px;
	 font-weight: 700;
    color: #1a202c;
 margin-bottom: 11px;
}

.formSubtext {
                    font-size: 15px;
  color: #718096;
    margin-bottom: 34px;
}



.formRowGroup {


   margin-bottom: 0;
  gap: 19px;
  display: grid;
  grid-template-columns: 1fr 1fr;

}

.formFieldWrapper 
 {
   margin-bottom: 23px;
}

.fieldLabelTag {
          display: block;
   font-size: 14px;
   font-weight    :   600;
                    color: #2d3748;
                    margin-bottom: 8px;
}

.fieldInputControl,
.fieldSelectControl,
.fieldTextareaControl {
       width: 100%;
   padding :      12px 16px;
	border: 2px solid #e2e8f0;
        border-radius: 7px;
   font-size:   15px;
  color:      #2d3748;
   transition: border-color 0.27s;
       font-family: inherit;
   background: #ffffff;
     }

.fieldInputControl:focus,
.fieldSelectControl:focus,
.fieldTextareaControl:focus {

	   outline: none;
  border-color    :    #2b6cb0;}

.fieldInputControl.error,
.fieldSelectControl.error,
.fieldTextareaControl.error {
	 border-color     : #e53e3e;
}

.fieldTextareaControl    {
   min-height: 120px;
        resize: vertical;
}

.errorMessage    {
    display: block;
    font-size: 13px;
    color: #e53e3e;
    margin-top     :        6px;
 min-height: 18px;
}

.checkboxWrapper 
 {
   margin-bottom: 29px;
}

.checkboxLabel {
        display: flex;
	align-items: start;
  gap: 11px;
   cursor: pointer;
}

.checkboxInput {
   height: 18px;
     flex-shrink: 0;
	cursor: pointer;
   width: 18px;
    margin-top: 2px;
}

.checkboxText {
  font-size: 14px;
    color: #4a5568;
	 line-height: 1.64;
}

.checkboxText a {
   color: #2b6cb0;
  text-decoration: underline;
}

.formSubmitButton {
     width: 100%;
   padding: 15px;
    background   :      #2b6cb0;
   color: #ffffff;
  border: none;
  border-radius: 29px;
   font-size: 17px;
       font-weight:       700;
  cursor: pointer;
   transition: all 0.28s;
        position: relative;

}

.formSubmitButton:hover:not(:disabled) {
    background: #1e4a7a;

	  transform: translateY(-2px);

	  box-shadow: 0 7px 21px rgba(43,108,176,0.37);
} 

.formSubmitButton:disabled {
   opacity: 0.67;
   cursor: not-allowed;
}

.btnLoader {
     display: flex;
   align-items   :  center;
  justify-content: center;
    gap   : 11px;
}

.loaderSpinner		{
   width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.3);
   border-top-color: #ffffff;
  border-radius: 50%;
    animation: spinLoader 0.7s linear infinite;
}@keyframes spinLoader {
    to { transform:rotate(360deg); }
}.whyContactBlock-ct 
 {
  padding: 81px 0;
  background    :#f9fafb;
}

.whyContactHeading {
  font-weight: 700;
   margin-bottom: 51px;
   text-align: center;
					color: #1a202c;
        font-size: 36px;
}

.whyContactGrid   {
	display: grid;
  grid-template-columns: repeat(4, 1fr);
	gap: 31px;
}

.whyContactTile {
  background:     #ffffff;
     padding: 33px 26px;
   border-radius :    9px;
   text-align: center;
    border: 2px solid #e2e8f0;
	 transition: all 0.29s;
}

.whyContactTile:hover {
   border-color: #2b6cb0;
     transform: translateY(-5px);
     box-shadow: 0 11px 28px rgba(43,108,176,0.15);
}

.whyIconHolder {
  width     : 62px;
   -webkit-border-radius: 50%;
    height: 62px;
  background: #ebf8ff;
	-moz-border-radius: 50%;
          border-radius: 50%;
                    display: flex;
    align-items: center;
         justify-content: center;
   margin     :       0 auto 19px;
}

.whyTileSvg {


	 width: 29px;
  height: 29px;
	stroke: #2b6cb0;
         fill: none;
	stroke-width: 2.2;
	}

.whyTileTitle {

  font-size: 18px;
    font-weight     :        600;
    color   : #1a202c;
   margin-bottom: 11px;
}

.whyTileText {
       font-size: 14px; 
   color: #4a5568; 
   line-height: 1.66;

}

.thankYouPopup {


    display: none;
   position: fixed;
   top: 0;
  left    :   0;
  right: 0;
  bottom: 0;
    z-index: 9999;
	}

.thankYouPopup.active {

	  display    : flex;
	 align-items: center;
   justify-content: center;}

.popupOverlay {
  position   :      absolute;
          top: 0;
	left: 0;
   right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.64);


}

.popupContentBox {
  position    :     relative;
   z-index: 10000;
  background: #ffffff;
    max-width: 540px;
  width    :      90%;
        border-radius :        13px;
   animation: popupSlideUp 0.36s ease;
}@keyframes popupSlideUp {
    from {
        opacity:0;
        transform: translateY(40px);
    }
    to {
        opacity:1;
        transform: translateY(0);
    }
}.popupCloseBtn {
                    position: absolute;
  top: 16px;
   right:       16px;
               background: none;
	 border: none;
   font-size: 32px;
    color: #718096;
   cursor: pointer;
  line-height: 1;
  transition: color 0.26s;
}

.popupCloseBtn:hover {


   color: #2b6cb0;
}

.popupInnerContent     {
	 padding: 47px 38px;
   text-align: center;
}

.successIconCircle {
    width: 84px;
  height: 84px;
  background: linear-gradient(135deg, #48bb78 0%, #38a169 100%);
  border-radius: 50%;
   display: flex;
       align-items: center;
    justify-content: center;
     margin: 0 auto 26px;
}

.successCheckSvg {
   width: 42px;
    height: 42px;
  stroke :       #ffffff;
   fill :  none;
   stroke-width: 3;
}

.popupHeading {
  font-size: 27px;
   font-weight: 700;
	color: #1a202c;
	 margin-bottom    :16px;
}

.popupMessage {
  font-size: 16px;

	  color: #4a5568;

		line-height: 1.71;

	  margin-bottom: 31px;
}

.popupOkButton {

	    padding: 13px 47px;
  background: #2b6cb0;
   -webkit-transition: all 0.28s;
  color: #ffffff;
  -moz-border-radius: 27px;
   border: none;
   -moz-transition: all 0.28s;
    border-radius: 27px;
    font-size     :   16px;
    -o-transition: all 0.28s;
  font-weight     :    600;
    cursor: pointer;
   transition  :all 0.28s; 
	

}

.popupOkButton:hover 
 {


    background: #1e4a7a;
  transform: translateY(-2px);
  box-shadow: 0 6px 19px rgba(43,108,176,0.36);

}@media (max-width: 1024px) {
    .contactGridLayout {
        grid-template-columns:1fr;
        gap: 47px;
    }

    .contactInfoColumn-ct {
        position: static;
    }

    .whyContactGrid {
        grid-template-columns:repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .contactPageTitle {
        font-size:34px;
    }

    .formRowGroup {
        grid-template-columns:1fr;
    }

    .whyContactGrid {
        grid-template-columns:1fr;
    }

    .formWrapper {
        padding:32px 26px;
    }
}@media (max-width: 480px) {
    .contactPageTitle {
        font-size:28px;
    }

    .infoColumnHeading {
        font-size:27px;
    }

    .popupInnerContent {
        padding:34px 26px;
    }
}