* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

:root {
  --default-font-color: #524d49;
  --highlight-color: #f56500;
  --highlight-color1: #461704;
}

@font-face {
  font-family: "heading";
  src: url("../assets/fonts/LibreBaskerville-Regular.ttf");
}

@font-face {
  font-family: "para";
  src: url("../assets/fonts/Lato-Regular.ttf");
}

html {
  height: 100vh;
  overflow: auto;
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  width: 99vw;
  height: 100vh;
  padding: 0;
  margin: 0;
  font-family: "para", sans-serif;
  color: var(--default-font-color);
}

.maincontainer {
  height: 100%;
  width: 100%;
}

/* MARK: Common styles */
.heading {
  font-family: "heading", sans-serif;
}

.bodyfont {
  font-family: "para", sans-serif;
}

.bodyfonttitle {
  color: var(--highlight-color);
  font-size: 1.25rem;
  font-weight: 600;
}

.buttoncta {
  background: var(--highlight-color);
  padding: 14px 20px;
  border: none;
  color: #fff;
  border-radius: 0.75rem;
  cursor: pointer;
  font-weight: 600;
  margin-top: auto;
}

/* Login Section */
.login_outer {
  left: 0;
  top: 0;
  z-index: 100;
  height: 90vh;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.login_div {
  background-color: #fff;
  padding: 2rem;
  border-radius: 1rem;
  width: 35%;
}

.login_div h3 {
  font-size: 1.5rem;
  color: #2d3760;
}

.login_div p {
  color: var(--default-font-color);
  margin-top: 0.8rem;
}

.login_form {
  display: flex;
  flex-direction: column;
  margin-top: 40px;
  gap: 1rem;
}

.login_form label {
  color: #150b04;
  font-weight: 500;
  margin-bottom: 12px;
}

.login_form input {
  padding: 16px 10px;
  border-radius: 12px;
  border: 1px solid #cfd2dd;
}

.login_form .login_field {
  display: flex;
  flex-direction: column;
}

.login_form button {
  width: 100%;
}

.login_btn {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.login_btn p:hover {
  color: var(--highlight-color);
  cursor: pointer;
}

.passwordinput {
  position: relative;
  width: 100%;
}
.passwordinput input {
  width: 100%;
  padding-right: 10%;
}

.pswdeye {
  position: absolute;
  right: 10px;
  top: 12px;
  cursor: pointer;
}

/* MARK: header section */
.headermain {
  width: 100%;
  height: fit-content;
  padding: 1rem 5rem;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #e0ddda;
}
.logosection {
  width: clamp(124px, 17.153vw, 247px);
}

.logosection img {
  width: 100%;
  height: 100%;
}

.menusection {
  display: flex;
  gap: 2rem;
  align-items: center;
}

.loginsection {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.loginsection img {
  height: 28px;
  width: 28px;
}
.menu2 {
  padding-right: 2rem;
}
.menu2 a {
  text-decoration: none;
  color: #302c27;
}
.menu2 a:hover {
  color: var(--highlight-color);
}
.logintxt {
  font-weight: bold;
  color: #302c27;
  background: none;
  border: none;
  cursor: pointer;
}

.logintxt:hover {
  color: var(--highlight-color);
}
/* MARK: Mainbody section */
.mainbody {
  width: 100%;
}
.herosection {
  width: 100%;
  height: 717px;
  display: flex;
  justify-content: center;
  padding-top: 7.5rem;
  background: url("../assets/images/herobg.jpg");
  background-size: cover;
}
.herocontent {
  width: 80%;
  height: fit-content;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 2.5rem;
  color: #fff;
}
.herocontent h1 {
  display: flex;
  justify-content: center;
  text-align: center;
  font-weight: bold;
  font-size: 3.2rem;
}
.herocontent p {
  width: 60%;
  text-align: center;
  font-size: 1.25rem;
}

.herocontent a {
  text-decoration: none;
}

.missionsection {
  padding: 6.4rem 5rem;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

.missionmain,
.planmain {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}
.missionmain h2,
.planpricing h2 {
  font-size: 2.5rem;
  color: var(--highlight-color1);
  text-align: center;
}

.missionmain p {
  font-size: 1.125rem;
  width: 55%;
  text-align: center;
}

.clientandmission {
  display: flex;
  gap: 1.5rem;
}
.client-head{
width:50%;
}

.client-img{
width: 100%; 
margin-top: 1.5rem;
}


.mission {
  width: 50%;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  border-radius: 1rem;
  box-shadow: 0px 0px 16px rgba(142, 144, 152, 0.25);
}

.client h4,
.mission h4 {
  font-size: 1.875rem;
  color: #150b04;
}

.missiondesc {
  line-height: 1.625rem;
}

.misisionlist {
  display: flex;
  gap: 1.5rem;
}

.num {
  /* padding: 14px 10px;
   */
  height: 2.5rem;
  width: 2.5rem;
  background-color: #ffdda5;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  color: #a13a0b;
  border-radius: 100%;
}

.list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.list h3 {
  font-size: 1.25rem;
  color: #a13a0b;
}

.planpricing {
  background-color: #f5f5f5;
  padding: 5rem;
  text-align: center;
  gap: 4rem;
  display: flex;
  flex-direction: column;
}

.pricingouter {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  text-align: left;
  gap: 1.5rem;
}

.priceind {
  padding: 2rem;
  background: #fff;
  border-radius: 1rem;
  width: 100%;
}

.priceind h5 {
  font-size: 1.25rem;
  color: #150b04;
}

.featureformobile {
  display: none;
}

.priceind p {
  padding-top: 1.125rem;
}
.priceind h3 {
  font-size: 4.5rem;
  color: var(--highlight-color1);
  margin-top: 3.5rem;
}

.priceind button {
  width: 100%;
  margin-top: 3.5rem;
}

.pricingtable {
  width: 100%;
}

.pricingtable table {
  background: #fff;
  width: 100%;
  border-radius: 1rem;
}

tbody tr td:first-child {
  text-align: left;
  font-size: 1.125rem;
  color: #150b04;
}

thead tr th:first-child {
  text-align: left;
  font-size: 1rem;
  color: var(--highlight-color1);
}

thead tr th {
  color: var(--highlight-color1);
}

th,
td {
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

th,
td {
  border-bottom: 1px solid #e0ddda;
}

/*MARK: Footer element */

.footerouter {
  height: fit-content;
  width: 100%;
  background-color: #f5f5f5;
  margin-top: 7.5rem;
  padding: 30px 80px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #333;
}
 
.footerouter p {
  font-family: "heading";
  font-size: 0.875rem;
  color: #fff;
}
 
.getintouch {
  display: flex;
  gap: 12px;
  align-items: center;
}
 
.icon {
  stroke: #fff; /* default stroke color */
  transition: stroke 0.3s ease; /* smooth transition */
}
 
.icon:hover {
  stroke: var(--highlight-color); /* Facebook blue on hover */
}
 
.footer_contact {
  display: flex;
  align-items: center;
  gap: 10px;
}
.foot1{
    display:flex;
gap: 12px;
  align-items: center;
}
 
.social_logo {
  display: flex;
  gap: 20px;
}

/* MARK: file upload section */

.fileupload_outer {
  width: 100%;
  padding: 80px;
}
.fileuploadinner {
  padding: 1.5rem;
  background-color: #f5f5f5;
  border-radius: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.upload_section {
  display: flex;
  gap: 1.5rem;
}
.fileupload {
  padding: 2rem;
  background-color: #fff;
  width: 60%;
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.fileupload h3 {
  font-size: 1.5rem;
  color: #150b04;
}

.uploadarea {
  padding: 33px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 1px dashed var(--highlight-color);
  border-radius: 12px;
  gap: 1rem;
}

.uploadarea button {
  padding: 8px 20px;
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  border: 1px solid var(--highlight-color);
  border-radius: 8px;
  color: var(--highlight-color);
  cursor: pointer;
}

.personal {
  padding: 2rem;
  width: 40%;
  background-color: #fff;
  border-radius: 1rem;
}

.personal .heading {
  font-size: 1.5rem;
  color: #150b04;
}

.field {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-top: 1rem;
  gap: 0.85rem;
}

.field input {
  padding: 1.125rem;
  border-radius: 12px;
  border: 1px solid #c8cde2;
}

.consent {
  display: flex;
  gap: 1rem;
  width: 50%;
}

.submitbtn {
  width: 20%;
}
.submitbtn button {
  width: 100%;
}
/* Hide arrows for Chrome, Safari, Edge */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Hide arrows for Firefox */
input[type="number"] {
  -moz-appearance: textfield;
}

.uploadarea.dragover {
  background-color: #f0f8ff;
  border: 2px dashed #0056b3;
  border-radius: 8px;
  transition: background-color 0.3s, border-color 0.3s;
}
.error-message {
  color: red;
  font-size: 13px;
  margin-top: 4px;
}

.client {
    width: 100%;
    height: fit-content;
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    border-radius: 1rem;
    box-shadow: 0px 0px 16px rgba(142, 144, 152, 0.25);
}

/* Media query */

@media (max-width: 900px) {
  html {
    font-size: 14px;
  }
  .headermain {
    padding: 1rem 1.5rem;
  }
  .loginsection img {
    height: 18px;
    width: 18px;
  }
  .menu2 {
    padding-right: 1rem;
  }
  .herosection {
    height: 490px;
    background: url("../assets/images/herobannermb.jpg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
  }
  .herocontent {
    width: 90%;
  }

  .herocontent h1 {
    font-size: 2rem;
  }
  .herocontent p {
    width: 80%;
    font-size: 1rem;
  }

  .missionsection {
    padding: 5.5rem 1.5rem;
  }
  .missionmain,
  .planmain {
    gap: 1.5rem;
  }
  .missionmain h2,
  .planpricing h2 {
    font-size: 1.75rem;
  }
  .missionmain p {
    width: 80%;
    font-size: 1rem;
  }
  .clientandmission {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  .client,
  .mission {
    width: 100%;
    padding: 1.14rem;
  }
  .client h4,
  .mission h4 {
    font-size: 1.5rem;
  }

  .client p,
  .mission p {
    font-size: 1rem;
  }

  .planpricing {
    padding: 1.75rem;
    gap: 3rem;
  }
  .pricingouter {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .priceind {
    padding: 1rem;
  }

  .priceind p {
    padding-top: 0;
  }

  .featureformobile {
    display: flex;
    flex-direction: column;
    margin-top: 32px;
    gap: 1rem;
  }

  .pricingtable {
    display: none;
  }

  .featurelistmb {
    display: flex;
    align-items: center;
    gap: 12px;
  }

  .featurelistmb div {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .footerouter {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
  }

  .fileupload_outer {
    padding: 40px 20px;
  }

  .fileuploadinner {
    padding: 1rem;
    border-radius: 1rem;
  }

  .upload_section {
    flex-direction: column;
  }

  .fileupload {
    width: 100%;
  }
  .fileupload h3 {
    font-size: 1.25rem;
  }

  .personal {
    width: 100%;
  }

  .personal .heading {
    font-size: 1.25rem;
    color: #150b04;
  }

  .consent {
    width: 100%;
  }

  .submitbtn {
    width: 70%;
  }

  .login_div {
    width: 80%;
  }
  .login_div h3 {
    font-size: 1.25rem;
    color: #2d3760;
  }
  .login_div p {
    font-size: 0.85rem;
  }
  .client-head{
width:100%
}
.client-img{
width: 100%;
}

}

@media (max-width: 600px) {
.getintouch{
    flex-direction:column;
    margin-top:10px;
}
.getintouch hr{
    display:none;
    gap:20px;
}
.foot1{
    flex-direction:column;
    gap:20px;
}
}
