header {
  display: flex;
  margin: auto;
  padding-top: 1rem;
  padding-bottom: 12rem;
}
header {
  background: #003f87;
  min-height: 100vh;
  padding: 5rem 5vw 2rem;
  padding-top: 6rem;
  padding-bottom: 10rem;
}

header .header-wrapper {
  display: grid;
  margin: auto;
  grid-template-columns: auto auto 1fr 0.2fr 0.8fr 0.5fr;
  grid-template-rows: auto 0.2fr 0.7fr 1fr;
  grid-gap: 1rem;
  transform: rotate(-15deg);
}
header h1 {
  margin: 0;
  line-height: 1.2em;
}
img {
  width: 100%;
}
header h1:nth-child(1) {
  grid-column: 3 / 6;
  grid-row: 2 / 3;
  text-align: right;
  border-top: 10px solid #ffcc1e;
}

header h1:nth-child(2) {
  font-size: calc(2rem + 1.8vw);
  color: #fb2366;
  writing-mode: vertical-lr;
  grid-column: 4 / 5;
  grid-row: 3 / 5;
  justify-self: end;
  margin-top: -34px;
  letter-spacing: 0px;
  white-space: nowrap;
}
header h1:nth-child(3) {
  font-size: calc(2rem + 1.8vw);
  color: #ffcc1e;
  grid-column: 5 / 7;
  grid-row: 4 / 5;
  justify-self: end;
  margin-top: -34px;
  letter-spacing: 0px;
  white-space: nowrap;
}
header .menu-link {
  grid-column: 4 / 6;
  grid-row: 1 / 2;
  font-weight: 700;
  line-height: 1.2;
  align-self: end;
  font-size: calc(1rem + 1.8vw);
  text-align: right;
  z-index: 3;
}
li {
  list-style: none;
}
header .service-list {
  grid-column: 5 / 7;
  grid-row: 4 / 5;
  font-weight: 700;
  line-height: 1.2;
  align-self: end;
  text-align: left;
  font-size: calc(0.9rem + 1.8vw);
  padding: 15px;
  border: 10px solid #fb2366;
  z-index: 3;
}

.menu-link a:hover {
  color: #ffcc1e;
}

.service-list a:hover {
  color: #fb2366;
}

div.circle {
  width: 500px;
  height: 500px;
  position: fixed;
  top: -36%;
  right: -17%;
  opacity: 0.5;
}
div.top-circle:nth-child(1) {
  height: 100%;
  width: 100%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
}
div.top-circle:nth-child(2) {
  height: 90%;
  width: 90%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 5%;
}
div.top-circle:nth-child(3) {
  height: 80%;
  width: 80%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 10%;
}
div.top-circle:nth-child(4) {
  height: 70%;
  width: 70%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 15%;
}
div.top-circle:nth-child(5) {
  height: 60%;
  width: 60%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 20%;
}
div.top-circle:nth-child(6) {
  height: 50%;
  width: 50%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 25%;
}
div.top-circle:nth-child(7) {
  height: 40%;
  width: 40%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 30%;
}
div.top-circle:nth-child(8) {
  height: 30%;
  width: 30%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 35%;
}
div.top-circle:nth-child(9) {
  height: 20%;
  width: 20%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 40%;
}
div.top-circle:nth-child(10) {
  height: 10%;
  width: 10%;
  border-radius: 90%;
  border: 1px solid #fb2366;
  position: absolute;
  margin: 45%;
}
div.circle-solid {
  width: 180px;
  height: 180px;
  background: #fb236666;
  border-radius: 90%;
  position: fixed;
  right: 160px;
  top: 20px;
}
div.lines {
  width: 280px;
  height: 190px;
  position: fixed;
  left: 0;
  top: 340px;
}
div.line:nth-child(1),
div.line:nth-child(2),
div.line:nth-child(3),
div.line:nth-child(4),
div.line:nth-child(5),
div.line:nth-child(6),
div.line:nth-child(7),
div.line:nth-child(8),
div.line:nth-child(9),
div.line:nth-child(10) {
  border-top: 1px solid #47d6c14d;
  height: 10%;
}
.bottom-circle {
  width: 130px;
  height: 130px;
  background: #ffcc1e1a;
  border-radius: 90%;
  position: fixed;
  left: 190px;
  top: 240px;
}

@media screen and (max-width: 973px) {
  header .header-wrapper {
    transform: none;
  }
}

@media screen and (max-width: 712px) {
  header h1:nth-child(2) {
    grid-column: 5 / 6;
  }
  header .header-wrapper {
    grid-template-columns: auto auto 1fr 0.8fr 0.2fr;
    grid-template-rows: auto 0.2fr 0.7fr 1fr;
  }
  header .service-list {
    grid-column: 3 / 5;
    text-align: right;
  }
}

@media screen and (max-width: 579px) {
}
