/* CSS Document
main #33AF8B rgba(51,175,139, .25)
main for text #239E78
sub #FFFECF
*/

.topkv {
  margin: 0 auto;
  background-color: #D0EAFA;
  text-align: center;
}

.Topcenter {
  margin: 0 auto;
  max-width: 500px;
}

figure {
  text-align: center;
}

.contentArea {
  overflow-y: hidden;
}

.contentArea.jobnavi {
  position: relative;
  overflow-x: hidden;
}

.indexArea,
.marketArea,
.scheduleArea,
.categoryArea,
.knowledgeArea,
.jobvoteArea,
.selectArea,
.interviewArea,
.resumeArea,
.flowArea {
  padding: 0 0.5em;
}

.contentArea.jobnavi>div {
  position: relative;
}

p {
  line-height: 1.5;
}

p span.textweight {
  font-weight: bold;
  color: #333;
}

.aboutArea p {
  padding: 0 1rem;
}

.imgcenter {
  width: min(100%, 334px);
  margin: 0 auto;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-top: 4rem;
  margin-bottom: 4rem;
}

.pLine {
  position: relative;
}

.pLine::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0%;
  height: 7px;
  background: #ffc65c;
  transition: all 2s;
  opacity: 0.5;
}

.pLine.isActive::after {
  width: 100%;
}

.indexmokuji {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px 12px;
  width: min(calc(100% - 3rem), 600px);
  margin: 3rem auto;
}

.indexmokuji a {
  position: relative;
  display: grid;
  align-content: center;
  padding: 1rem;
  height: 100%;
  border: 2px #C9CACA solid;
  border-radius: 0.5rem;
  box-shadow: 0 3px 0 #C9CACA;
  text-align: center;
}

.indexmokuji li.current a{
  background-color: #A4D0ED;
  border: none;
  box-shadow: none;
  font-weight: 700;
}

.indexmokuji li.current a::after {
  content: '';
  background: url('../../../img/page/jobnavi/index_btn_decoright.png') left bottom / contain no-repeat;
  width: 4.5rem;
  height: 4.5rem;
  top: -3rem;
  right: 0;
}

/* .interview{
	padding-top: 2rem!important;
} */
.kv_bottombtn {
  color: #fff;
  font-size: 2rem;
  padding: 0 0 0 1rem;
  width: min(90%, 281px);
  margin: 0 auto;
  font-weight: 700;
  transform: translateY(-1rem);
}

.kv_bottombtn a {
  position: relative;
  display: block;
  background-color: #EF8889;
  padding: 2rem min(20%, 57px) 2rem min(27%, 77px);
  border-radius: 5rem;
  box-shadow: 5px 5px 0px 0 rgb(189, 85, 90);
}

.kv_bottombtn a::before {
  content: '';
  top: 50%;
  left: -1rem;
  background: url('../../../img/page/jobnavi/kv_btn_decoleft.png') center / contain no-repeat;
  width: min(27%, 77px);
  aspect-ratio: 1 / 1;
  transform: translateY(-50%);
}

.kv_bottombtn a::after {
  content: '';
  top: 50%;
  right: 0;
  background: url('../../../img/page/jobnavi/kv_btn_decoright.png') center / contain no-repeat;
  background-size: contain;
  width: min(20%, 57px);
  aspect-ratio: 57 / 63;
  transform: translateY(-50%);
}


/*-----indexMenu-----*/
.contentTtl {
  margin: 0 auto;
  padding: 15px 0;
  text-align: center;
  font-size: 2.2rem;
  line-height: 1.4;
}


.indexMenu {
  background: #fff;
  border: #f58a8a 2px solid;
  border-radius: 3px;
  margin: 1em;
}

.indexMenu p.index {
  background: #f58a8a;
  color: #fff;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0.5em;
}

.indexMenu ul {
  padding: 1em;
  display: grid;
  grid-template-columns: 1fr 1fr;
  text-align: left;
}

.indexMenu li {
  padding: 0.8em 0;
  margin-left: 0.8em;
}

.indexMenu li span {
  position: relative;
  font-weight: bold;
  display: inline-block;
  box-sizing: border-box;
}

.indexMenu li span::before {
  content: '';
  top: 50%;
  left: -1.2em;
  width: 0.7em;
  height: 0.7em;
  border-bottom: solid 2px #333;
  border-right: solid 2px #333;
  transform: translate(0, -50%) rotate(-45deg);
}

.indexMenu a:active {
  text-decoration: underline #ffc65c;
}

@media screen and (max-width: 300px) {
  .indexMenu ul {
    column-count: auto;
  }
}

h2.pageTtl {
  font-size: 2rem;
  font-weight: 700;
  margin-top: 2rem;
  margin: 1em auto;
  position: relative;
  background: linear-gradient(to bottom, transparent 50%, rgba(64, 150, 211, .25) 50%);
  padding-left: 2.5em;
  padding-bottom: 1rem;
  color: #4096D3;
}

h2.pageTtl::before {
  content: "";
  background: url(../../../img/page/jobnavi/h2_decor.png)no-repeat right top;
  width: 2em;
  height: 2.5em;
  left: 0%;
  top: -44%;
  background-size: contain;
}

h2.pageTtl span {
  position: relative;
}

h3.subTtl {
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
  margin: 1em auto;
}


.midasi_yellow {
  background-color: #ffc65c;
  padding: 5px;
  border-radius: 50px;
  margin-bottom: 10px;
  color: #fff;

}

.jobvoteh2 {
  background-color: #4096D3;
  padding: 2rem;
  color: #fff;
  font-size: 1.7rem;
  width: 247px;
  margin: 0 auto;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  padding-top: 3rem;
  position: relative;
  text-align: center;
}

.jobvoteh2::before {
  content: "";
  background: url(../../../img/page/jobnavi/jobvoteh2_decor.png)no-repeat right top;
  width: 4em;
  height: 2em;
  right: 25%;
  top: 6%;
  background-size: contain;
  transform: translate(-50%, 0%);
}

.jobvoteh2::after {
  content: "";
  background: url(../../../img/page/jobnavi/index_btn_decoright.png)no-repeat right top;
  width: 3em;
  height: 2em;
  right: 5%;
  top: -11%;
  background-size: contain;
}

.number {
  background-color: #ffc65c;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  color: #fff;
  font-size: 20px;
  text-align: center;
  line-height: 29px;
  display: inline-grid;
  margin: 0 9px;
}

/*-----search-----*/
.coprSearchForm {
  margin: 0 auto;
  padding: 6rem 1.5rem 9rem;
  background: repeating-linear-gradient(-40deg, rgba(var(--kyo-color-02), 0.25), rgba(var(--kyo-color-02), 0.25) min(200px, 40vw), rgba(var(--kyo-color-02), 0.1) min(200px, 40vw), rgba(var(--kyo-color-02), 0.1) min(400px, 80vw));
}

.coprSearchForm hgroup {
  margin: 0 auto 2rem;
  text-align: center;
  font-weight: bold;
}

.coprSearchForm h3 {
  position: relative;
  margin: 0 auto 1.5rem;
  font-size: 2.2rem;
  line-height: 1.4;
}

.coprSearchForm p {
  font-weight: inherit;
}

.coprSearchForm .topSearchForm {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin: 0 auto;
  width: min(600px, 100%);
  gap: 1.5rem;
}

.coprSearchForm .topSearchForm .rowCol {
  grid-column: 1 / 3;
}

.coprSearchForm .generalBtn {
  margin: 1rem 0 3rem;
}

.coprSearchForm .generalBtn input[type="submit"] {
  display: none;
}

.coprSearchForm .generalBtn label {
  cursor: pointer;
  position: relative;
  display: grid;
  place-content: center;
  margin: 0 auto;
  padding: 5px;
  width: 75%;
  max-width: 400px;
  min-height: 4.5rem;
  background: rgb(var(--kyo-color-04));
  box-shadow: var(--btnSahdow);
  border-radius: 2em;
  color: #fff;
  font-size: 1.8rem;
  line-height: 1.2;
  font-weight: bold;
}

.coprSearchForm .generalBtn label span {
  padding-left: 1.25em;
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 49.71 54.42"><path fill="rgba(255,255,255,1)" fill-rule="evenodd" d="M1.56,53.4a4.35,4.35,0,0,0,6.14-.54l9.81-11.74a21.86,21.86,0,0,0,24.41-36A21.85,21.85,0,0,0,10.83,35.5L1,47.23A4.39,4.39,0,0,0,1.56,53.4ZM15.15,11.27l2.59-2.51a16.36,16.36,0,0,1,3-1.84l3.35-1.19A16.49,16.49,0,0,1,38.56,9.14a16.61,16.61,0,1,1-23.41,2.13Z" /></svg>') left center / 1em auto no-repeat;
}

.topSearchForm .select {
  position: relative;
  width: 100%;
  min-height: 4rem;
  background: #fff;
  border-radius: 0.5rem;
  font-size: 1.5rem;
}

.topSearchForm .select::before {
  content: '';
  top: 50%;
  right: 0.5em;
  width: 0.5em;
  height: 0.5em;
  border-right: solid 1px #333;
  border-bottom: solid 1px #333;
  transform: translateY(-50%) rotate(45deg);
}

.topSearchForm .select select {
  padding: 0.8em 1.25em 0.8em 0.5em;
  width: 100%;
  font-size: 1.5rem;
}

.topSearchForm .searchInput input[type="text"] {
  padding: 0.8em 1.25em 0.8em 0.5em;
  width: 100%;
  min-height: 4rem;
  background: url('../../../img/page/jobnavi/index_btn_decoright.png') calc(100% - 0.25em) center / 1.5em auto no-repeat, #fff;
  border-radius: 0.5rem;
  font-size: 1.5rem;
}

.coprSearchForm .textLinks {
  text-align: center;
  font-size: 1.4rem;
}

.coprSearchForm .textLinks a {
  position: relative;
}

.coprSearchForm .textLinks a::after {
  content: '';
  top: 50%;
  right: -8px;
  width: 0.5em;
  height: 0.5em;
  border-bottom: solid 1px #333;
  border-right: solid 1px #333;
  transform: translate(0, -50%) rotate(-45deg);
}

.subTtl {
  background-color: #fff;
  box-shadow: 0 0px 15px 2px rgba(0, 0, 0, 0.2);
  padding: 1.5rem;
  width: 277px;
  border-radius: 50px;
}

.checkPointBlue {
  margin: 5rem auto;
  padding: 3rem;
  width: min(90%, 800px);
  background: #4096D3;
  position: relative;
}

.checkPointBlue::before {
  content: '';
  display: block;
  position: absolute;
  top: -1.5rem;
  left: 50%;
  width: 106px;
  height: 66px;
  background: url('../../../img/page/jobnavi/last_point_clip.png') left top / contain no-repeat;
  transform: translate(-50%, 0%);
  z-index: 10;
}

.checkPointBlue::after {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  bottom: -1rem;
  width: min(20vw, 223px);
  aspect-ratio: 148 / 149;
  background: url('../../../img/page/jobnavi/importantGirl.png') right bottom / contain no-repeat;
  z-index: 10;
}

.checkPoint {
  background: #fff;
  padding: 1.5em;
  padding-bottom: 5em;
}

h5.checkTtl {
  position: relative;
}

h5.checkTtl span {
  background: #ffe9e9;
  color: #f58a8a;
  font-size: 1.5rem;
  font-weight: bold;
  padding-right: 0.5em;
  position: relative;
  z-index: 2;
}

h5.checkTtl::after {
  content: "";
  width: 50%;
  height: 2px;
  right: 0;
  background: #f58a8a;
  top: 50%;
  z-index: 1;
}

.checkPoint div {
  margin: 1em auto 1em 2em;
}

.checkPoint p.mark {
  position: relative;
  font-weight: bold;
  text-decoration: 2px #f58a8a underline;
  text-underline-offset: 0.3em;
  line-height: 2;
  font-size: 19px;
}

.checkPoint p.mark::after {
  content: '';
  display: block;
  position: absolute;
  top: -0.0em;
  left: -2em;
  width: 58px;
  height: 31px;
  background: url(../../../img/page/jobnavi/last_point.png)no-repeat left top;
  background-size: contain;
}

.backbulue {
  background-color: #EDF7FD;
  padding-bottom: 1rem;
  padding-top: 3rem;
}

.kyuujinpoint {
	background-color: #EDF7FD;
	margin: 0 auto 3rem;
	padding: 1rem 0;
	width: 100%;
}

.kyuujinpoint dl dt {
	margin: 1rem;
	margin-left: 0;
	font-weight: 700;
	font-size: 1.7rem;
}
.pointBg {
	margin: 0 auto 1rem;
	width: min(calc(100% - 3rem), 900px);
	background-color: #fff;
	padding: 1rem;
}

.pointBg dd {
	margin-left: 10px;
	margin-bottom: 20px;
	line-height: 1.5;
}

/*  ---------- PC_css ----------  */
@media screen and (min-width: 769px) {
  .topkv {
    max-height: 284px;
  }

  .Topcenter {
    max-width: 1300px;
  }

  .forSp {
    display: none;
  }

  .forPc {
    display: block;
  }

  .contentArea {
    max-width: 1300px;
    margin: 0 auto;
  }

  p {
    font-size: 1.25rem;
    line-height: 2;
  }

  /* mokuji */
  .indexmokuji a {
    padding: 2rem;
  }

  .kv_bottombtn {
    width: min(100%, 400px);
  }

  .kv_bottombtn a {
    padding: 2rem min(20%, 57px) 2rem min(27%, 110px);
  }

  .kv_bottombtn a::before {
    width: min(27%, 110px);
  }

  /*-----indexMenu-----*/
  .contentTtl {
    font-size: 3rem;
  }

  .indexMenu {
    width: 80%;
    margin: 3em auto;
  }

  .indexMenu ul {
    margin: 0 auto;
    column-count: 3;
    padding: 1em 1em 1em 3em;
  }

  .jobvoteh2 {
    width: 292px;
    padding-top: 3rem;
    padding-bottom: 1rem;
    padding-left: 0;
    padding-right: 0;
    font-size: 1.5rem;
    text-align: center;
  }

  .indexArea,
  .marketArea,
  .scheduleArea,
  .categoryArea,
  .knowledgeArea,
  .jobvoteArea,
  .selectArea,
  .interviewArea,
  .resumeArea,
  .flowArea {
    padding: 0;
  }

  .Pcaida {
    margin-top: 3rem;
  }

  .checkPointBlue::after {
    right: -10%;
    bottom: -6rem;
  }

  .checkPoint {
    margin: 0 auto;
    padding: 3rem;
  }

  .checkPointBlue {
    margin: 7rem auto;
  }

  .coprSearchForm hgroup {
    margin-bottom: 3rem;
  }

  .topSearchForm .select,
  .topSearchForm .select select,
  .topSearchForm .searchInput input[type="text"] {
    font-size: 1.3rem;
    min-height: auto;
  }

  .coprSearchForm .generalBtn {
    margin: 3rem 0 2rem;
  }

  .kyuujinPcimg{
		max-width: 70%;
    margin: 0 auto;
	}
  
	.kyuujinpoint.top {
		margin-bottom: 0;
		padding-bottom: 0;
	}
	.kyuujinpoint.bottom {
		padding-top: 0;
		padding-bottom: 6rem;
	}
  
	.pointBg{
		margin-bottom: 0;
	}

	.pointBg dd {
		width: 100%;
		font-size: 15px;
	}
}