#freeter *, #freeter *:after, #freeter *:before {
  box-sizing: border-box;
}

#freeter img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

@media (min-width: 768px) {
  #freeter .inner {
    max-width: 980px;
    margin: 0 auto;
    padding-left: 15px;
    padding-right: 15px;
  }
}

/*-------------------
フォント設定
---------------------*/
html {
  font-size: 13px;
	scroll-behavior: smooth;
}
body {
  line-height: 1.3;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: lighter;
}
/*:root {
  --px8: 0.6153rem;
  --px10: 0.769rem;
  --px11: 0.846rem;
  --px12: 0.923rem;
  --px13: 1rem;
  --px14: 1.077rem;
  --px15: 1.154rem;
  --px16: 1.231rem;
  --px17: 1.308rem;
  --px18: 1.385rem;
  --px19: 1.462rem;
  --px20: 1.538rem;
  --px21: 1.615rem;
  --px22: 1.692rem;
  --px23: 1.769rem;
  --px24: 1.846rem;
  --px25: 1.923rem;
  --px26: 2rem;
  --px27: 2.077rem;
  --px28: 2.154rem;
  --px29: 2.231rem;
  --px30: 2.308rem;
  --px31: 2.385rem;
  --px32: 2.462rem;
  --px33: 2.583rem;
  --px34: 2.615rem;
}*/

/* .Jumbotron */
@media (min-width: 768px) {
  .Jumbotron {
    background: url(../img/img_top.jpg) no-repeat center top;
  }
}

@media (min-width: 768px) {
  .Jumbotron {
    height:635px;
    text-align: center;
  }
}

@media (min-width: 768px) {
  .Jumbotron img {
    padding: 308px 0 0 0;
    text-align: center;
  }
}

/* #mainImg */
#mainImg {
  text-align:center;
}

#mainImg img {
  width: 100%;
}

/* .area */
.area section {
  background: url(../img/bg_searchbox_01.gif) repeat;
  padding-bottom: 3%;
  padding-top: 4.5%;
}

.area h3 {
  font-weight: 700;
  text-align: center;
  padding: 25px 0 20px 0;
  font-size: 20px;
}

@media (min-width: 768px) {
  .area h3 {
    font-size: 30px;
  }
}

/* #bigContentsWrapper */
#bigContentsWrapper {
  padding: 0;
  background: url(../img/bg_contents.gif) repeat;
}

@media (min-width: 768px) {
  #bigContentsWrapper {
    padding: 0 0 50px 0;
  }
}

/* #experienceBox */
#experienceBox p {
  background-color: #fff;
  padding: 1% 10%;
  font-size: 12px;
  line-height: 1.5;
}

#experienceBox h3{
  font-weight: 700;
  text-align: center;
  padding: 25px 0 20px 0px;
  font-size: 20px;
}

#experienceBox img {
  width: 100%;
}

@media (min-width: 768px) {
  #experienceBox {
  }

  #experienceBox #experienceBG {
    position: relative;
  }

  #experienceBox h3{
    font-size: 30px;
    padding: 25px 0 20px 0;
  }

/*
  #experienceBox .box_01{
    height: 445px;
    position: relative;
  }

  #experienceBox .box_02{
    height: 450px;
    position: relative;
  }

  #experienceBox .box_03{
    height: 335px;
    position: relative;
  }
*/

  #experienceBox .box_01 dl{
    width: 43%;
    position: absolute;
    right: 4%;
    top: 7%;
  }

  #experienceBox .box_01 dt{
    padding: 0 0 10px 0;
  }

  #experienceBox .box_02 dl{
    width: 43%;
    position: absolute;
    left: 6.5%;
    top: 41.5%;
  }

  #experienceBox .box_02 dt{
    padding: 0 0 10px 0;
  }

  #experienceBox .box_03 dl{
    width: 43%;
    position: absolute;
    right: 4%;
    top: 75%;
  }

  #experienceBox .box_03 dt{
    padding: 0 0 10px 0;
  }

  #experienceBox dd p{
    background-color: transparent;
    font-size: 16px;
    line-height: 1.5;
  }

  #experienceBox .box_01 dd p{
    padding: 0;
  }

  #experienceBox .box_02 dd p{
    padding: 0;
  }

  #experienceBox .box_03 dd p{
    padding: 0;
  }

  #experienceBox .box_01 .btnBox{
    /* position: absolute; */
    left: 3%;
    top: 25%;
  }

  #experienceBox .box_02 .btnBox{
    /* position: absolute; */
    right: 3%;
    top: 58%;
  }

  #experienceBox .box_03 .btnBox{
    /* position: absolute; */
    left: 3%;
    top: 90%;
  }

  #experienceBox .btnBox a:hover{
    opacity: 0.8;
  }
}

@media (min-width: 768px) and (max-width: 950px) {
  #experienceBox dd p{
    font-size: 1.5vw;
  }
}

/* #qaBox */
#qaBox {
  padding: 0 0 100px 0;
  background: url(../img/bg_qa.gif) repeat-x bottom #f3f0e8;
}

#qaBox h3 {
  font-size: 20px;
  font-weight: 700;
  padding: 0 0 50px 0;
  text-align: center;
}

@media (min-width: 768px) {
  #qaBox h3 {
    font-size: 30px;
    padding: 50px 0 70px 0;
  }
}

#qaBox h3 span {
  border-bottom: 3px solid #000;
}

@media (min-width: 768px) {
  #qaBox h3 span {
    border-bottom: 5px solid #000;
  }
}

#qaBox dl {
  padding-left: 15px;
  padding-right: 15px;
}

#qaBox dl dt {
  font-size: 16px;
  font-weight: 700;
  padding-bottom: 20px;
  padding-left: 50px;
  position: relative;
}

@media (min-width: 768px) {
  #qaBox dl dt {
    font-size: 20px;
  }
}

#qaBox dl dt::before {
  align-items: center;
  background-color: #000;
  border-radius: 50%;
  color: #fff;
  content: 'Q';
  display: flex;
  height: 40px;
  justify-content: center;
  left: 0;
  position: absolute;
  top: -5px;
  width: 40px;
}

#qaBox dl dd {
  background-color: #fff;
  border: 4px solid #000;
  font-size: 14px;
  line-height: 2;
  padding: 15px;
  padding-left: 60px;
  position: relative;
}

@media (min-width: 768px) {
  #qaBox dl dd {
    font-size: 18px;
  }
}

#qaBox dl dd::before {
  align-items: center;
  background-color: #fff;
  border: 4px solid #000;
  border-radius: 50%;
  content: 'A';
  display: flex;
  font-weight: 700;
  height: 40px;
  justify-content: center;
  left: 10px;
  position: absolute;
  top: 10px;
  width: 40px;
}

#qaBox dl dd + dt {
  margin-top: 50px;
}

/* .areaBand */
.areaBand {
  padding: 0 0 30px 0;
  background: #FFF;
}

.areaBand.bottom {
  border-bottom: 4px solid #3a3834;
}

.areaBand h3 {
  font-weight: 700;
  text-align: center;
  padding: 25px 0 20px 0;
  font-size: 20px;
}

@media (min-width: 768px) {
  .areaBand h3 {
    font-size: 30px;
  }
}

/* エリア検索（都道府県） */
#area section {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-left: 10px;
  padding-right: 10px;
}

@media (min-width: 768px) {
  #area section {
    padding-left: 20px;
    padding-right: 20px;
  }
}

#area section dl {
  align-self: baseline;
  background-color: #fff;
  flex-basis: calc(100% / 2 - 1%);
  margin-bottom: 1.5%;
  max-width: calc(100% / 2 - 1%);
  padding-left: 5px;
  padding-right: 5px;
}

@media (min-width: 768px) {
  #area section dl {
    align-self: auto;
    flex-basis: calc(100% / 3 - 1%);
    max-width: calc(100% / 3 - 1%);
    padding: 10px;
  }
}

#area section dl:last-child {
  background-color: #666;
  flex-basis: 100%;
  max-width: 100%;
}

@media (min-width: 768px) {
  #area section dl:last-child {
    flex-basis: calc((100% / 3) * 2 - .5%);
    max-width: calc((100% / 3) * 2 - .5%);
  }
}

#area section dl dt {
  color: #000;
  font-size: 14px;
  font-weight: 400;
  padding-bottom: 10px;
  padding-top: 10px;
  text-align: center;
}

@media (min-width: 768px) {
  #area section dl dt {
    font-size: 18px;
  }
}

#area section dl:last-child dt {
  color: #fff;
}

#area section dl dd {
  display: none;
}

@media (min-width: 768px) {
  #area section dl dd {
    display: block !important;
  }
}

#area section dl dd ul {
  display: flex;
  flex-wrap: wrap;
}

#area section dl dd ul li {
  flex-basis: calc(100% / 2 - 2%);
  font-size: 12px;
  font-weight: 400;
  margin-bottom: 1.5%;
  margin-left: 1%;
  margin-right: 1%;
  max-width: calc(100% / 2 - 2%);
}

@media (min-width: 768px) {
  #area section dl dd ul li {
    flex-basis: calc(100% / 3 - 2%);
    font-size: 14px;
    max-width: calc(100% / 3 - 2%);
  }
}

#area section dl dd ul li a {
  align-items: center;
  background-color: #FFF000;
  border-radius: 5px;
  color: #000;
  display: flex;
  height: 38px;
  justify-content: center;
}

/*
#area section dl:last-child dd ul li {
  flex-basis: calc(100% / 4 - 1%);
  max-width: calc(100% / 4 - 1%);
  margin-left: .5%;
  margin-right: .5%;
}
*/

#area section dl:last-child dd ul li a {
  background-color: #E75297;
  color: #fff;
}

/* エリア検索（地方） */
#region section {
  padding-left: 10px;
  padding-right: 10px;
}

@media (min-width: 768px) {
  #region section {
    align-items: baseline;
    display: flex;
    justify-content: space-between;
    padding-left: 20px;
    padding-right: 20px;
  }
}

#region section dl {
  background-color: #3A3834;
  border-radius: 5px;
}

#region section dl + dl{
  margin-top: 5px;
}

@media (min-width: 768px) {
  #region section dl {
    border-radius: 5px;
    flex-basis: calc(100% / 7 - 1%);
    max-width: calc(100% / 7 - 1%);
  }
}

@media (min-width: 768px) {
  #region section dl + dl{
    margin-top: 0;
  }
}

#region section dl dt {
  align-items: center;
  color: #fff;
  cursor: pointer;
  display: flex;
  font-size: 16px;
  font-weight: 400;
  height: 50px;
  justify-content: center;
}

#region section dl dd {
  display: none;
  padding-bottom: 5px;
  padding-left: 5px;
  padding-right: 5px;
}

#region section dl dd ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#region section dl dd ul li {
  flex-basis: calc(50% - 1%);
  font-weight: 400;
  margin-bottom: 1.5%;
  max-width: calc(50% - 1%);
}

#region section dl dd ul li a {
  align-items: center;
  background-color: #fff;
  border-radius: 5px;
  display: flex;
  height: 40px;
  justify-content: center;
}

/* モーダル */
.remodal *, .remodal *:after, .remodal *:before {
  box-sizing: border-box;
}

.remodal img {
  height: auto;
  max-width: 100%;
}

.remodal {
  border: 10px solid #eee;
  border-radius: 0 !important;
  padding: 0 !important;
}

.remodal-close {
  background-image: url(../img/btn_close.png) !important;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover !important;
  height: 30px !important;
  right: 10px !important;
  top: 10px !important;
  width: 30px !important;
}

@media (min-width: 768px) {
  .remodal-close {
    height: 50px !important;
    width: 50px !important;
  }
}

.remodal-close:before {
  content: "" !important;
}

.popup {
  padding: 60px 0 30px 0;
  position: relative;
  background: url(../img/bg_searchbox_02.gif);
}

.popup h2 {
  border-bottom: 1px solid #fff;
  color: #fff;
  font-size: 25px;
  margin-bottom: 30px;
  margin-left: 20px;
  margin-right: 20px;
  padding-bottom: 10px;
}

.popup section {
  padding-left: 10px;
  padding-right: 10px;
}

@media (min-width: 768px) {
  .popup section {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.popup section dl {
  align-self: baseline;
  background-color: #fff;
  margin-bottom: 1.5%;
  padding-left: 5px;
  padding-right: 5px;
}

@media (min-width: 768px) {
  .popup section dl {
    align-self: auto;
    flex-basis: calc(100% / 3 - 1%);
    max-width: calc(100% / 3 - 1%);
    padding: 10px;
  }
}

.popup section dl dt {
  color: #000;
  font-size: 14px;
  font-weight: 400;
  padding-bottom: 10px;
  padding-top: 10px;
  text-align: center;
}

@media (min-width: 768px) {
  .popup section dl dt {
    font-size: 18px;
  }
}

.popup section dl dd ul {
  display: flex;
  flex-wrap: wrap;
}

.popup section dl dd ul li {
  flex-basis: calc(100% / 2 - 2%);
  font-size: 12px;
  font-weight: 400;
  margin-bottom: 1.5%;
  margin-left: 1%;
  margin-right: 1%;
  max-width: calc(100% / 2 - 2%);
}

@media (min-width: 768px) {
  .popup section dl dd ul li {
    flex-basis: calc(100% / 3 - 2%);
    font-size: 14px;
    max-width: calc(100% / 3 - 2%);
  }
}

.popup section dl dd ul li a {
  align-items: center;
  background-color: #FFF000;
  border-radius: 5px;
  color: #000;
  display: flex;
  height: 38px;
  justify-content: center;
}

.lpbanner{
    background: #fbfaf8;
    border: 1px solid #d9d3ce;
    border-radius: 5px;
    font-size: 12px;
    margin:0 auto 20px auto;
	width:100%;
}



.lpbanner h3{
	background: #ff4444;
    color: #fff;
    font-size: 18px;
    text-align: center;
    letter-spacing: .06em;
    padding: 10px 0;
    margin: 0 0 15px;
}

.lpbanner p {
    padding: 0 15px 15px;
    box-sizing: border-box;
    letter-spacing: .08em;
    line-height: 1.4;
    font-size: 13px;
    text-align: center;
}

/*/////▼ LPバナー ▼////*/
.adbnr{
	width: 100%;
	margin: 10px 0;
}
	.adbnr h3{
		width: 100%;
		margin: 0 auto 10px auto;
		background: #000;
		padding: 5px 0;
		color: #fff;
		font-size: 14px;
		font-weight: lighter;
		text-align: center;
	}
.adbnr ul{
	width: 100%;
	margin: 0 auto;
}
.adbnr ul li{
	margin: 0 0 10px 0;
}
.adbnr ul li:last-child{
	margin: 0;
}
.adbnr ul li a{
	display: block;
	padding: 5px;
	box-sizing: border-box;
	background: #fff;
	color: #000;
	text-align: center;
	border-bottom: 2px solid #e6e6e6;
	border-radius: 100px;
	font-size: 15px;
}

/*/////▼ LINE OA配信連動企画_バナー設置　▼/////*/
/*.contents_0 {
		width: 800px;
		margin: auto
}
	
.contents_0 img{
       margin: auto;
       padding: 30px 0 30px;
       display: block;
}

@media (max-width: 768px) {
.contents_0 {
	width: 100%;
	padding: 20px 0 20px;
}
.contents_0 img{
    padding: 20px 0px 20px;
}
}*/
