*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  line-height: 1.5;
  color: #1B323E;
}

/* ---- Design System ---- */

h1 {
  font-size: 36px;
  font-weight: 700;
  text-transform: uppercase;
}

h2 {
  font-size: 44px;
  font-weight: 700;
}

.small-heading {
  font-size: 16px;
  font-weight: 400;
}

.small-heading-bold {
  font-size: 16px;
  font-weight: 700;
}

/* Desktop headings */
h1.desktop {
  font-size: 60px;
  font-weight: 700;
  text-transform: uppercase;
}

h2.desktop {
  font-size: 60px;
  font-weight: 700;
}

h3.desktop {
  font-size: 60px;
  font-weight: 700;
}

/* Labels */
.label {
  font-size: 14px;
  font-weight: 600;
  padding: 8px;
  border-radius: 5px;
  color: #FFFFFF;
  display: inline-block;
}

.label-dark {
  background-color: #1B323E;
}

.label-green {
  background-color: #6B7C59;
}

.body-text {
  font-size: 20px;
  font-weight: 400;
}

.quote {
  font-size: 24px;
  font-weight: 600;
  font-style: italic;
}

.subtitle {
  font-size: 28px;
  font-weight: 600;
}

img {
  max-width: 100%;
  display: block;
}

header {
  background-color: #1B323E;
  height: 102px;
}

header nav {
  max-width: 1440px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 143px;
}

.logo svg {
  width: 296px;
  height: 40.38px;
}

/* Hero */
.hero {
  background-color: #8FCFF2;
  height: 381px;
}

.hero-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 40px 143px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}

.hero-content h1 {
  line-height: 1.1;
  max-width: 787px;
}

.hero-content .body-text {
  max-width: 744px;
}

/* Pioneer section */
.pioneer {
  background-color: #EDF9FC;
  height: 161px;
}

.pioneer-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  color: #2F5034;
}

.bar-single {
  width: 72px;
  height: 4px;
  background-color: #9B9E5B;
  margin-bottom: 18px;
}

.bar-triple {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.bar-triple .bar {
  width: 72px;
  height: 4px;
  background-color: #9B9E5B;
}

/* Challenge section */
.challenge {
  height: 1133px;
  background-color: white;
}

.challenge-content {
  max-width: 745px;
  margin: 0 auto;
  padding: 60px 0;
  display: flex;
  flex-direction: column;
}

.challenge-content .small-heading-bold {
  margin-bottom: 12px;
}

.challenge-content h2 {
  line-height: 1.1;
  margin-bottom: 24px;
}

.challenge-content img {
  width: 745px;
  height: 419px;
  margin-bottom: 48px;
}

.challenge-content .body-text {
  margin-bottom: 16px;
}

.bar-blue {
  background-color: #8FCFF2;
  margin-bottom: 18px;
}

/* Proven in Conflict section */
.proven {
  background-color: #1B323E;
  height: 934px;
  color: white;
}

.proven-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  padding-bottom: 94px;
}

.proven-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}

.proven-text {
  flex: 1;
}

.proven-label {
  color: #D5F2A0;
  margin-bottom: 12px;
  padding-top: 165px;
}

.proven-text h3 {
  line-height: 1.1;
  margin-bottom: 53px;
}

.proven-top img {
  width: 552px;
  height: 451px;
  margin-top: 100px;
  object-fit: cover;
  object-position: 60% center;
}

.proven-bottom {
  max-width: 745px;
  margin: 0 auto;
  padding-top: 60px;
}

.proven-quote {
  color: #D5F2A0;
  margin-bottom: 44px;
}

/* Dual Use section */
.dualuse {
  height: 1263px;
  background-color: white;
}

.dualuse-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.dualuse-content img {
  width: 742px;
  height: 281px;
  margin-top: 144px;
  margin-bottom: 70px;
}

.dualuse-content h2 {
  line-height: 1.1;
  margin-bottom: 24px;
  max-width: 745px;
  width: 100%;
}

.dualuse-content > .body-text {
  max-width: 745px;
  width: 100%;
}

.dualuse-boxes {
  width: 1128px;
  height: 342px;
  display: flex;
  margin-top: 48px;
}

.dualuse-box {
  flex: 1;
  padding: 70px 40px 40px 90px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 48px;
}

.dualuse-box-blue {
  background-color: #EDF9FC;
}

.dualuse-box-green {
  background-color: #E7E9CD;
}

.label-blue {
  background-color: #8FCFF2;
  color: #1B323E;
}

.label-olive {
  background-color: #9B9E5B;
  color: #1B323E;
}

/* Operational Design section */
.operational {
  background-color: #8FCFF2;
  height: 827px;
}

.operational-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}

.operational-content .small-heading-bold {
  margin-bottom: 4px;
}

.operational-content h2 {
  line-height: 1.1;
  margin-bottom: 56px;
}

.operational-columns {
  display: flex;
  gap: 40px;
  margin-bottom: 61px;
}

.operational-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}

.operational-col .bar-single {
  margin-top: 16px;
}

.operational-col .subtitle {
  margin-top: 8px;
}

.label-light {
  background-color: #EDF9FC;
  color: #1B323E;
}

.bar-darkblue {
  background-color: #75AAD3;
}

.operational-content > .body-text {
  max-width: 790px;
}

/* Container image section */
.container-image {
  position: relative;
  height: 668px;
}

.container-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.spacer {
  height: 88px;
  background-color: white;
}

/* System section */
.system {
  height: 973px;
  background-color: white;
  overflow: hidden;
}

.system-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
}

.system-content .small-heading-bold {
  padding-top: 12px;
  margin-bottom: 16px;
}

.system-content h2 {
  line-height: 1.1;
  margin-bottom: 60px;
}

.system-lines {
  max-width: 742px;
  margin-bottom: 100px;
}

.system-lines .bar-olive {
  background-color: #9B9E5B;
  margin-bottom: 18px;
}

.system-lines .bar-triple {
  margin-top: 18px;
}

.bar-olive-bar {
  background-color: #9B9E5B;
}

.system-boxes {
  display: flex;
  height: 512px;
  margin-left: -143px;
  margin-right: -143px;
}

.system-box {
  flex: 1;
  padding: 70px 143px 40px 143px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.system-box .label {
  margin-bottom: 41px;
}

.system-box .subtitle {
  margin-bottom: 24px;
}

.system-box-blue {
  background-color: #EDF9FC;
}

.system-box-green {
  background-color: #D5F2A0;
}

/* Together section */
.together {
  background-color: #1B323E;
  height: 199px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
}

.together .body-text {
  max-width: 741px;
}

/* Quality Assurance section */
.quality {
  height: 1562px;
  background-color: white;
}

.quality-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.quality-content .small-heading-bold {
  align-self: flex-start;
  padding-top: 100px;
  margin-bottom: 12px;
}

.quality-content h2 {
  align-self: flex-start;
  line-height: 1.1;
  margin-bottom: 24px;
}

.quality-content img {
  width: 1128px;
  height: 819px;
  margin-bottom: 61px;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

.quality-content .body-text {
  max-width: 744px;
  margin-bottom: 16px;
}

/* Next Frontier section */
.frontier {
  height: 1335px;
  background-color: #1B323E;
  color: white;
}

.frontier-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
}

.frontier-label {
  color: #9B9E5B;
  padding-top: 100px;
  margin-bottom: 16px;
}

.frontier-content h2 {
  line-height: 1.1;
  margin-bottom: 41px;
}

.frontier-content .bar-single {
  margin-bottom: 18px;
}

.frontier-content .body-text {
  max-width: 744px;
  margin-bottom: 61px;
}

.frontier img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Track Record section */
.trackrecord {
  background-color: white;
}

.trackrecord-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
}

.trackrecord-content .small-heading-bold {
  padding-top: 140px;
  margin-bottom: 20px;
}

.trackrecord-content h2 {
  line-height: 1.1;
  margin-bottom: 56px;
}

.trackrecord-grid {
  display: grid;
  grid-template-columns: 361px 361px;
  gap: 20px;
  justify-content: center;
  padding-bottom: 100px;
}

.trackrecord-item {
  display: flex;
  flex-direction: column;
}

.trackrecord-box {
  width: 361px;
  height: 314px;
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.trackrecord-title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 16px;
}

.trackrecord-line {
  width: 100%;
  height: 8px;
  margin-top: 6px;
}

/* Recover section */
.recover {
  background-color: #8FCFF2;
  height: 830px;
}

.recover-content {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 143px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.recover-content h2 {
  line-height: 1.1;
  padding-top: 97px;
  margin-bottom: 77px;
  max-width: 700px;
}

.recover-row {
  display: flex;
  align-items: center;
  gap: 130px;
  margin-bottom: 124px;
}

.recover-row .body-text {
  max-width: 365px;
}

/* Footer */
footer {
  background-color: #1B323E;
  height: 610px;
  color: white;
}

.footer-content {
  max-width: 600px;
  margin: 0 auto;
  padding: 48px 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.footer-content .logo {
  margin-bottom: 40px;
}

.footer-text {
  font-size: 16px;
  margin-bottom: 24px;
}

.footer-office {
  font-size: 16px;
  font-weight: 600;
  color: #D5F2A0;
  margin-bottom: 8px;
}

.footer-address {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 24px;
}

.footer-email {
  font-size: 16px;
  text-transform: none;
  letter-spacing: normal;
  margin-bottom: 60px;
}

.footer-bottom {
  margin-top: auto;
}

.footer-linkedin {
  display: inline-block;
  margin-bottom: 16px;
}

.footer-copyright {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.6);
}

.container-btn {
  position: absolute;
  top: 60px;
  left: 143px;
}

.btn-get-in-touch {
  background-color: #D5F2A0;
  color: #1B323E;
  text-decoration: none;
  padding: 12px 24px;
  font-weight: 600;
  font-size: 20px;
  border-radius: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ======================== */
/* Tablet Styles            */
/* ======================== */
@media (max-width: 1200px) and (min-width: 769px) {

  /* Reduce padding globally */
  header nav,
  .hero-content,
  .pioneer-content,
  .proven-content,
  .dualuse-content,
  .operational-content,
  .system-content,
  .quality-content,
  .frontier-content,
  .trackrecord-content,
  .recover-content {
    padding-left: 60px;
    padding-right: 60px;
  }

  /* Hero */
  .hero {
    height: auto;
    min-height: 300px;
  }

  .hero-content h1 {
    font-size: 44px;
  }

  /* Challenge */
  .challenge {
    height: auto;
  }

  .challenge-content {
    max-width: 100%;
    padding: 40px 60px;
  }

  .challenge-content img {
    width: 100%;
    height: auto;
  }

  /* Proven */
  .proven {
    height: auto;
  }

  .proven-top img {
    width: 350px;
    height: 300px;
  }

  .proven-text h3 {
    font-size: 44px;
  }

  /* Dual Use */
  .dualuse {
    height: auto;
  }

  .dualuse-content img {
    width: 100%;
    height: auto;
  }

  .dualuse-boxes {
    width: 100%;
  }

  .dualuse-box {
    padding: 40px 40px;
  }

  /* Operational */
  .operational {
    height: auto;
    padding: 40px 0;
  }

  /* System */
  .system {
    height: auto;
    overflow: visible;
  }

  .system-boxes {
    margin-left: -60px;
    margin-right: -60px;
    height: auto;
  }

  .system-box {
    padding: 40px 60px;
  }

  /* Quality */
  .quality {
    height: auto;
  }

  .quality-content img,
  .quality-content picture img {
    width: 100%;
    height: auto;
  }

  /* Frontier */
  .frontier {
    height: auto;
  }

  /* Track Record */
  .trackrecord-grid {
    grid-template-columns: 1fr 1fr;
  }

  .trackrecord-box {
    width: 100%;
  }

  /* Recover */
  .recover {
    height: auto;
    padding: 40px 0;
  }

  .recover-content h2 {
    font-size: 44px;
  }

  /* Footer */
  .footer-content {
    padding: 40px 60px;
  }
}

/* ======================== */
/* Mobile Styles            */
/* ======================== */
@media (max-width: 768px) {

  /* Header */
  header {
    height: 213px;
  }

  header nav {
    flex-direction: column;
    justify-content: center;
    gap: 24px;
    padding: 0 20px;
  }

  /* Hero */
  .hero {
    height: 361px;
  }

  .hero-content {
    padding: 24px 24px;
  }

  .hero-content .small-heading {
    margin-bottom: 16px;
  }

  .hero-content h1 {
    font-size: 36px;
    max-width: 100%;
    margin-bottom: 16px;
  }

  .hero-content .body-text {
    max-width: 100%;
    font-size: 18px;
  }

  /* Pioneer */
  .pioneer {
    height: 178px;
  }

  .pioneer-content {
    padding: 0 24px;
  }

  /* Challenge */
  .challenge {
    height: 1021px;
  }

  .challenge-content {
    padding: 24px 24px;
    max-width: 100%;
  }

  .challenge-content h2 {
    font-size: 36px;
  }

  .challenge-content img {
    width: 100vw;
    max-width: none;
    margin-left: -24px;
    height: auto;
  }

  .challenge-content .body-text {
    max-width: 100%;
  }

  /* Proven */
  .proven {
    height: auto;
  }

  .proven-content {
    padding: 0 24px;
    padding-bottom: 40px;
  }

  .proven-top {
    flex-direction: column;
    gap: 24px;
  }

  .proven-label {
    padding-top: 24px;
  }

  .proven-text h3 {
    font-size: 36px;
    margin-bottom: 16px;
  }

  .proven-top img {
    width: 100%;
    height: auto;
    margin-top: 0;
  }

  .proven-bottom {
    max-width: 100%;
    padding-top: 24px;
  }

  /* Dual Use */
  .dualuse {
    height: auto;
  }

  .dualuse-content {
    padding: 24px 24px;
  }

  .dualuse-content img {
    width: 100%;
    height: auto;
    margin-top: 24px;
    margin-bottom: 40px;
  }

  .dualuse-content h2 {
    font-size: 36px;
    max-width: 100%;
  }

  .dualuse-content > .body-text {
    max-width: 100%;
  }

  .dualuse-boxes {
    width: 100%;
    height: auto;
    flex-direction: column;
    margin-top: 32px;
  }

  .dualuse-box {
    padding: 32px 24px;
  }

  /* Operational */
  .operational {
    height: auto;
  }

  .operational-content {
    padding: 24px 24px;
  }

  .operational-content h2 {
    font-size: 36px;
    margin-bottom: 32px;
  }

  .operational-columns {
    flex-direction: column;
    gap: 32px;
  }

  .operational-content > .body-text {
    max-width: 100%;
  }

  /* Container image */
  .container-image {
    height: 400px;
  }

  .container-btn {
    left: 24px;
    top: 40px;
  }

  /* Spacer */
  .spacer {
    height: 0;
  }

  /* System */
  .system {
    height: auto;
    overflow: visible;
  }

  .system-content {
    padding: 24px 24px;
  }

  .system-content h2 {
    font-size: 36px;
  }

  .system-lines {
    max-width: 100%;
  }

  .system-boxes {
    flex-direction: column;
    height: auto;
    margin-left: -24px;
    margin-right: -24px;
  }

  .system-box {
    padding: 40px 24px;
  }

  /* Together */
  .together {
    height: auto;
    padding: 40px 24px;
  }

  .together .body-text {
    max-width: 300px;
    font-size: 16px;
    text-align: center;
  }

  /* Quality */
  .quality {
    height: auto;
  }

  .quality-content {
    padding: 24px 24px;
  }

  .quality-content .small-heading-bold {
    padding-top: 24px;
  }

  .quality-content h2 {
    font-size: 36px;
  }

  .quality-content img,
  .quality-content picture img {
    width: 100%;
    height: auto;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  }

  .quality-content .body-text {
    max-width: 100%;
  }

  /* Frontier */
  .frontier {
    height: 907px;
  }

  .frontier-content {
    padding: 24px 24px;
  }

  .frontier-label {
    padding-top: 24px;
  }

  .frontier-content h2 {
    font-size: 36px;
  }

  .frontier-content .body-text {
    max-width: 100%;
  }

  .frontier img {
    width: 100%;
    object-fit: cover;
  }

  /* Track Record */
  .trackrecord-content {
    padding: 24px 24px;
  }

  .trackrecord-content .small-heading-bold {
    padding-top: 24px;
  }

  .trackrecord-content h2 {
    font-size: 36px;
  }

  .trackrecord-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .trackrecord-box {
    width: 100%;
    height: 260px;
  }

  .trackrecord-line {
    height: 8px;
  }

  /* Recover */
  .recover {
    height: 940px;
  }

  .recover-content {
    padding: 40px 24px;
    align-items: center;
  }

  .recover-content h2 {
    font-size: 36px;
    max-width: 100%;
    padding-top: 0;
  }

  .recover-row {
    flex-direction: column;
    gap: 40px;
    margin-bottom: 60px;
  }

  .recover-row .body-text {
    max-width: 100%;
  }

  /* Footer */
  footer {
    height: auto;
  }

  .footer-content {
    max-width: 100%;
    padding: 40px 24px;
  }

  .footer-email {
    margin-bottom: 40px;
  }

}
