@charset "UTF-8";

/* =====================
   共　通
======================== */


@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 450px) {
}




/* =====================
   group
======================== */
#group {}
#group .wrap {}
#group dl {
  padding: 0;
  margin: 0 auto 160px;
  background-color: #fff;
  width: 46%;
  max-width: 460px;
  text-align: center;
  line-height: 1em;
  position: relative;
}
#group dl::after {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 5px;
  background-color: #A13334;
  position: absolute;
  bottom: -5px;
}
#group dl::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 75px;
  border-left: 2px solid #A13334;
  position: absolute;
  bottom: -80px;
  margin-left: 4px;
}
#group dl dt {
  padding: 5x 0;
  margin: 0;
  border: 2px solid #A13334;
  font-size: min(3.5vw,35px);
}
#group dl dd {
  padding: 20px 0;
  margin: 0;
}
#group dl dd ul {
  font-size: min(2.7vw,27px);
  width: 85%;
  height: 100%;
  min-height: 200px;
  padding: 0;
  margin: 0 auto;
  list-style: none;

  display: flex;
  flex-wrap: wrap;
  align-content: center;
}
#group dl dd ul li {
  padding: 15px 0;
  margin: 0;
  width: 100%;
  text-align: center;
}
#group dl dd ul li a {
}
#group dl dd ul li a:hover {
  opacity: 0.7;
}
#group dl dd ul li img {
  width: 100%;
}
#group dl dd ul li img.w230 {
  max-width: 230px;
}

#group .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  position: relative;
}
#group .flex::before {
  content: '';
  display: inline-block;
  width: 50%;
  height: 1px;
  border-top: 2px solid #A13334;
  position: absolute;
  top: -80px;
  left: 25.5%;
}
#group .flex dl::after {
  bottom: auto;
  top: -5px;
}
#group .flex dl::before {
  bottom: auto;
  top: -80px;
}
#group .flex dl dt {
  padding: 23px 0;
}

#group h3 {
  text-align: center;
}
#group ul.list {
  padding: 0;
  margin: 25px 0 0;
  list-style: none;

  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
#group ul.list li {
  padding: 0;
  margin: 0;
  margin-bottom: 25px;
  width: 46%;
}
#group ul.list li a {
  display: block;
  position: relative;
  /* border: 1px solid #f00; */
}
#group ul.list li a::after {
  content: '';
  display: block;
  width: 20px;
  height: 20px;
  position: absolute;
  right: 3px;
  bottom: 3px;
  background-image: url(../images/common/open_in_new_black_24dp.svg);
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: contain;
}
#group ul.list li picture {
  width: 100%;
  overflow: hidden;
  aspect-ratio: 6/4;
  margin-bottom: 10px;
}
#group ul.list li picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
  #group .flex::before {
    left: 26%;
  }
}
@media screen and (max-width: 600px) {
}
@media screen and (max-width: 450px) {
}



/* =====================
   Profile
======================== */
#Profile {}
#Profile .wrap {}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 600px) {
}
@media screen and (max-width: 450px) {
}




/* =====================
   purpose
======================== */
#purpose {}
#purpose .wrap_f picture {
  width: 300px;
}
#purpose .wrap_f .purpose_txt {
  width: calc(100% - 350px);
  text-align: left;
}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 600px) {
  #purpose .wrap_f picture {
    width: 100%;
    margin-bottom: 22px;
  }
  #purpose .wrap_f .purpose_txt {
    width: 100%;
  }
}
@media screen and (max-width: 450px) {
}




/* =====================
   policy
======================== */
#policy {}
#policy .wrap_f picture {
  width: 270px;
}
#policy .wrap_f .policy_txt {
  width: calc(100% - 320px);
  text-align: left;
}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 600px) {
  #policy .wrap_f picture {
    width: 100%;
    max-width: 270px;
    margin: 22px auto 0;
  }
  #policy .wrap_f .policy_txt {
    width: 100%;
  }
}
@media screen and (max-width: 450px) {
}




/* =====================
   outline
======================== */
#outline {}
#outline p {
  margin-bottom: 12px;
}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 450px) {
}




/* =====================
   logo
======================== */
#logo {}
#logo .wrap_f picture {
  width: 200px;
}
#logo .wrap_f ul {
  width: calc(100% - 280px);
  text-align: left;
}

@media screen and (max-width: 1024px) {
}
@media screen and (max-width: 768px) {
}
@media screen and (max-width: 600px) {
  #logo .wrap_f picture {
    width: 100%;
    max-width: 200px;
    margin: 0 auto 22px;
  }
  #logo .wrap_f ul {
    width: 100%;
  }
}
@media screen and (max-width: 450px) {
}