      .overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        display: flex;
        justify-content: center;
        align-items: center;
        background: rgba(255, 255, 255, 0.8);
        z-index: 9999;
      }
      .spinner {
        width: 64px;
        height: 64px;
        border: 8px solid #ddd;
        border-top-color: #1a8cff; /* accent colour */
        border-radius: 50%;
        animation: spin 1s linear infinite;
      }
      @keyframes spin { 100% { transform: rotate(360deg); } }

      .result-image {
        margin-top: 1rem;
        max-width: 100%;
        height: auto;
        display: block;
      }
 
 
 .form-container {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      background-color: #ffffff;
      border: 2px solid #000000;
      border-radius: 15px;     
 
    }

    button {
      background-color: #00ff90;
      color: #636262;
      border: none;
      padding: 0.75rem 2rem;
      border-radius: 10px;
      cursor: pointer;
      font-weight: bold;
    }


    .outer-container {
        margin-top:  50px;
        padding-top: 80px;
        display: flex;
        justify-content: center;
        flex-direction: column;
        margin: auto;
    }

    .form-group {
      flex: 1 1 140px;
      display: flex;
      flex-direction: column;
    }

    label {
      margin-bottom: 0.5rem;
    }

    input, select {
      padding: 0.5rem;
      border: 2px solid #000000;
      border-radius: 10px;
      background-color: #ffffff;
      color: #1f1f1f;
      transition: border-color 0.3s, box-shadow 0.3s;
    }

    input:focus, select:focus {
      border-color: #00ff90;
      box-shadow: 0 0 10px #00ff90;
      outline: none;
    }

    .form-actions {
      flex: 1 1 100%;
      text-align: center;
      margin-top: 1rem;
    }

    .form-actions input[type="submit"] {
      background-color: #00ff90;
      color: #000;
      border: none;
      padding: 0.75rem 2rem;
      border-radius: 10px;
      cursor: pointer;
      font-weight: bold;
    }

    .form-actions input[type="submit"]:hover {
      background-color: #00cc70;
    }



    /* IOF CSS------------------------------------------------------------------------ */




    * {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
      font-family: "Open Sans", sans-serif;
      color: #555;
  }
  body {
      color: #1a1a1a;
      position: relative;
      min-height: 100vh;
      background-color: #fff;
      /* Add generous horizontal breathing room (≈8 rem each side) */

  }
  .fhg-header {
      line-height: 1.5rem;
      border-bottom: 1px solid #c7cacc;
      margin-bottom: -1px;
      min-height: 12.6rem;
      position: relative;
      }
  .fhg-grid-3-2-1-1 {
      width: 75%;
  }
  .fhg-grid-1-1-1-1 {
       width: 25%;
  }


  .fhg-grid-item {
      display: inline-block;
      vertical-align: top;
  }

  .fhg-header .logo-heading {
  display: inline;
  font-size: 0;
  }

          @media (min-width: 769px) {
            .form-container
            {

                padding: 8rem;
            }
  .fhg-header .section-search {
      float: right;
  }
  }
  .fhg-header .section-search, .fhg-header .row2-1 {
      border-left: 1px solid #c7cacc;
      border-right: 1px solid #c7cacc;
  }
  .fhg-header .section-search, .fhg-header .section-title {
      height: 10rem;
  }

  .logo[src$=".svg"] {
      height: 5rem;
      width: auto;
      max-width: 100%;
  }
   .logo {
      max-height: 5rem;
      max-width: 26rem;
  }
  .section-title {
      padding: 2.5rem;
      padding-top: 2.5rem;
  }
  .fhg-wrapper {
      font-size: 0;
      max-width: 1440px;
      margin: 0 auto;

      overflow: hidden;
      position: relative;
  }

  @media (min-width: 1380px) {
  .fhg-wrapper {

      padding-left: 8rem;
      padding-right: 8rem;
      
  }
}

  @media (min-width: 3440px) {
  .fhg-wrapper {
    padding-left: 8rem;
    padding-right: 8rem;
      max-width: 2880px;
  }
  /* .form-container {
    max-width: 2880px;
  } */
  .outer-container{
    max-width: 2880px;

  }
  }
  .fhg-header .row2 {
  width: 100%;
  }
  .fhg-header .text-site-identifier, .fhg-header .text-site-identifier a {
      font-size: 1.2rem;
      line-height: 1.5rem;
      letter-spacing: .025em;
      color: #555;
      font-weight: 200;
      text-decoration: none;

        font-size: small;
  }
  .fhg-header .section-about {
      float: left;
      padding: 1.5rem 2.5rem;
  }
  .fhg-header .row2-1 {
      text-align: right;
  }
  @media (min-width: 769px) {
  .fhg-header .section-menu-plus {
      padding-left: 0;
  }
  }
  .fhg-header .section-menu-plus {
      font-size: 1.2rem;
      line-height: 1.5rem;
      letter-spacing: .025em;
      padding: 0 1.5rem;
          padding-left: 1.5rem;
  }
  .fhg-header .section-mainlink, .fhg-header .section-menu-plus, .fhg-header .section-menu {
      min-height: 4.3rem;
  }
  ul {
      list-style: none;
  }
  ul >li {
      display: inline-block;
      list-style: none;
      vertical-align: top;
  }
  li {
      font-size: 1.2rem;
      line-height: 1.5rem;
      letter-spacing: .075em;
      cursor: pointer;
      text-transform: uppercase;
      font-weight: 400;
      position: relative;
  }

  .fhg-header .section-menu-plus a {
      text-decoration: none;

      display: block;

  }
  .fhg-header .section-menu-plus a, .fhg-header .section-menu-plus span {
      letter-spacing: .075em;
      display: inline-block;
      color: #1f82c0;
      cursor: pointer;
      padding: 1.5rem 2.5rem 1.5rem;
  }
  a {
      background-color: transparent;
  }
  .fhg-header .section-menu {
      background: #009374;
      padding-bottom: 1px;
  }
  .fhg-header .section-menu {
      background: #009374;
      padding: 0 8rem 0 0;
          padding-bottom: 0px;
      margin-right: -8rem;
      font-size: 1.2rem;
      align-content: center;
      padding-left: 5px;
      color: #fff;
  }
  .fhg-header .section-search, .fhg-header .row2-1 {
      border-left: 1px solid #c7cacc;
      border-right: 1px solid #c7cacc;
      border-top: 1px solid #c7cacc;
  }

  .outer-banner {
      margin-right: -8rem;
  }
  .banner {
      width: 100%;
      height: 30rem;
  }
  .banner-image {
      object-fit: cover;
      width: 100%;
  }

  @media (max-width: 800px) {
      .row2-1{
          display: none;
      }
      .section-search {
          display: none;
      }
      .section-title{
          width: 100%;
          display: flex;
          justify-content: center;
      }
      .section-about {
          display: flex;
          justify-content: center;
          width: 100%;
      }
      .section-nav {
          width: 100%;
      }
      .section-menu {
          width: 100%;

          padding: 0;
          margin-right: 0;
      }
      
  }