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

#fukugyo img {
  height: auto;
  max-width: 100%;
}

/*-------------------
フォント設定
---------------------*/
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;
}*/

@media (min-width: 768px) {
  .fukugyoContainer {
    margin: 0 auto;
    padding-left: 15px;
    padding-right: 15px;
    position: relative;
    max-width: 980px;
  }
}

/* .fukugyoJumbotron */
.fukugyoJumbotron {
  background-image: url(../img/jumbotron-bg.jpg);
  background-position: center top;
  background-size: cover;
  padding-bottom: 60px;
  padding-top: 30px;
}

@media (min-width: 768px) {
  .fukugyoJumbotron {
    padding-bottom: 0;
    padding-top: 0;
    height: 558px;
  }
}

.fukugyoJumbotronTitle {
  padding-left: 15px;
}

@media (min-width: 768px) {
  .fukugyoJumbotronTitle {
    padding-bottom: 0;
    padding-left: 55px;
    padding-top: 60px;
  }
}

.fukugyoJumbotronTitle img {
  width: 200px;
}

@media (min-width: 768px) {
  .fukugyoJumbotronTitle img {
    width: auto;
  }
}

/* .fukugyoHeaderTitle */
.fukugyoHeaderTitle {
  text-align: center;
}

/* .fukugyoTime */
.fukugyoTime {
  padding-bottom: 20px;
  padding-top: 8px;
}

@media (min-width: 768px) {
  .fukugyoTime {
    padding-bottom: 65px;
    padding-top: 40px;
  }
}

.fukugyoTimeTitle {
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoTimeTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoTimeTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoTimeTitle span {
    font-size: 16px;
  }
}

.fukugyoTimeList {
  display: flex;
  justify-content: space-between;
  padding-left: 10px;
  padding-right: 10px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoTimeList {
    padding-left: 0;
    padding-right: 0;
  }
}

.fukugyoTimeList li {
  padding-left: 3px;
  padding-right: 3px;
  text-align: center;
  width: calc(100% / 3 - 1%);
}

@media (min-width: 768px) {
  .fukugyoTimeList li {
    text-align: center;
    width: calc(100% / 3 - 1%);
  }
}

.fukugyoTimeList li a {
  display: block;
}

.fukugyoTimeList li img {
  width: 60%;
}

@media (min-width: 768px) {
  .fukugyoTimeList li img {
    width: auto;
  }
}

@media (min-width: 768px) {
  .fukugyoTimeList li img:hover {
    opacity: .8;
  }
}

.fukugyoTimeList li a div {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 16px;
  height: 50px;
  justify-content: center;
  position: relative;
}

@media (min-width: 768px) {
  .fukugyoTimeList li a div {
    font-size: 18px;
  }
}

@media (min-width: 768px) {
  .fukugyoTimeList li a div {
    align-items: center;
    color: #fff;
    display: flex;
    font-size: 18px;
    height: 50px;
    justify-content: center;
    position: relative;
  }
}

.fukugyoTimeMorning {
  background-color: #EF7C23;
}

.fukugyoTimeDaytime {
  background-color: #E8A84B;
}

.fukugyoTimeNight {
  background-color: #75BFB5;
}

#merit{
  padding: 40px 10px 0 10px;
  box-sizing: border-box;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 1.3;
}

@media (min-width: 768px) {
  #merit{
    max-width: 980px;
    margin: 0 auto;
  }
}

#merit h2{
  background: #f2f2f2;
  font-size: 14px;
  text-align: center;
  padding: 10px 0;
  margin: 0 0 20px 0;
}

@media (min-width: 768px) {
  #merit h2{
    background: #f2f2f2;
    font-size: 20px;
    text-align: center;
    padding: 10px 0;
    margin: 0 0 20px 0;
  }
}

@media (min-width: 768px) {
  .fukugyoTimeMeritWrap {
    display: flex;
    justify-content: space-between;
  }
}

#merit dl{
  margin: 0 0 20px 0;
}

@media (min-width: 768px) {
  #merit dl{
    margin: 0;
    width: calc(100% / 3 - 1%);
  }
}

#merit dl dt{
  padding: 10px 0;
  text-align: center;
  font-weight: bold;
}

#merit dl dt.income{
  position: relative;
  background: #F4D790;
}

#merit dl dt.income:after{
  top: 100%;
  left: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
  border-color: rgba(136, 183, 213, 0);
  border-top-color: #F4D790;
  border-width: 10px;
  margin-left: -10px;
}

#merit dl dt.fun{
  position: relative;
  background: #88b7d5;
}

#merit dl dt.fun:after{
  top: 100%;
  left: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
  border-color: rgba(136, 183, 213, 0);
  border-top-color: #88b7d5;
  border-width: 10px;
  margin-left: -10px;
}

#merit dl dt.skill{
  position: relative;
  background: #F7A6A6;
}

#merit dl dt.skill:after{
  top: 100%;
  left: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
  border-color: rgba(136, 183, 213, 0);
  border-top-color: #F7A6A6;
  border-width: 10px;
  margin-left: -10px;
}

#merit dl dd{
  padding: 20px 0 0 0;
}

/* .fukugyoJob */
.fukugyoJob {
  background-color: #f1efee;
}

.fukugyoJobHeader {
  background-color: #231815;
  height: 60px;
}

.fukugyoJobTitle {
  color: #fff;
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoJobTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoJobTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoJobTitle span {
    font-size: 16px;
  }
}

@media (min-width: 768px) {
  .fukugyoJobContent {
    background-color: #f1efee;
    padding-bottom: 30px;
    padding-top: 50px;
  }
}

@media (min-width: 768px) {
  .fukugyoJobContentBlocks {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

.fukugyoJobContentBlock {
  background-color: #fff;
  margin-bottom: 10px;
  padding-bottom: 30px;
  position: relative;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlock {
    box-shadow: 2px 2px 4px 0 rgba(0,0,0,0.2);
    margin-bottom: 30px;
    padding-bottom: 0;
    width: calc(50% - 2.25%);
  }
}

.fukugyoJobContentBlockTitle {
  align-items: center;
  display: flex;
  font-size: 22px;
  font-weight: normal;
  line-height: 1.3;
  padding: 15px 120px 10px 15px;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlockTitle {
    font-size: 18px;
    line-height: 1;
  }
}

.fukugyoJobContentBlockTitle img {
  width: 52px;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlockTitle img {
    width: 40px;
  }
}

.fukugyoJobContentBlockImg {
  padding-bottom: 15px;
  padding-left: 15px;
  padding-right: 15px;
  text-align: center;
}

.fukugyoJobContentBlockImg img {
  width: 100%;
}

.fukugyoJobContentBlockTxt {
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: 20px;
  padding: 0 20px;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlockTxt {
    font-size: 15px;
    line-height: 1.7;
    padding: 0 15px;
  }
}

.fukugyoJobContentSearchList {
  display: flex;
  flex-wrap: wrap;
  margin-left: 20px;
  margin-right: 20px;
}

@media (min-width: 768px) {
  .fukugyoJobContentSearchList {
    margin-bottom: 20px;
  }
}

.fukugyoJobContentSearchListItem {
  font-size: 13px;
  font-weight: 400;
  flex-basis: calc(50% - 1%);
  max-width: calc(50% - 1%);
  padding-bottom: 5px;
}

@media (min-width: 768px) {
  .fukugyoJobContentSearchListItem {
    flex-basis: auto;
    max-width: auto;
    padding-left: 4px;
    padding-right: 4px;
  }
}

.fukugyoJobContentSearchListItem:nth-child(2n) {
  margin-left: 2%;
}

@media (min-width: 768px) {
  .fukugyoJobContentSearchListItem:nth-child(2n) {
    margin-left: 0;
  }
}

.fukugyoJobContentSearchListItem a {
  background-color: #000;
  align-items: center;
  color: #fff;
  display: flex;
  height: 45px;
  justify-content: center;
}

@media (min-width: 768px) {
  .fukugyoJobContentSearchListItem a {
    width: 95px;
  }
}

.fukugyoJobContentBlockBadge {
  display: flex;
  position: absolute;
  right: 15px;
  top: 0;
  z-index: 99;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlockBadge {
    top: -5px;
  }
}

.fukugyoJobContentBlockBadge li {
  padding-left: 7px;
}

.fukugyoJobContentBlockBadge img {
  width: 33px;
}

@media (min-width: 768px) {
  .fukugyoJobContentBlockBadge img {
    width: 38px;
  }
}

#recommend{
  padding:  20px 10px;
}

@media (min-width: 768px) {
  #recommend{
    max-width: 980px;
    margin: 0 auto;
    padding: 0 15px 20px 15px;
  }
}

#recommend h2{
  background: #231815;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  margin: 0 0 20px 0;
  font-size: 18px;
}

#recommend article{
  background: #fff;
  padding: 20px;
  box-sizing: border-box;
  margin: 0 0 10px 0;
  box-shadow:3px 3px 10px -3px #ccc;
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: justify;
}

#recommend article:last-child{
  margin: 0;
}

#recommend article h3{
	font-size: 18px;
	padding: 0 0 10px 0;
	color: #268CBA;
}

/* .fukugyoZaitaku */
.fukugyoZaitakuHeader {
  background-color: #231815;
  height: 60px;
}

.fukugyoZaitakuTitle {
  color: #fff;
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoZaitakuTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoZaitakuTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoZaitakuTitle span {
    font-size: 16px;
  }
}

.fukugyoZaitakuContent {
  background-image: url(../img/zaitaku-content-bg.jpg);
  background-position: center top;
  background-size: cover;
  padding-bottom: 25px;
  padding-top: 25px;
  position: relative;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContent {
    height: 530px;
    padding-bottom: 0;
    padding-top: 0;
  }
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlock {
    padding-top: 40px;
    max-width: 432px;
  }
}

.fukugyoZaitakuContentBlockTxt {
  background-color: rgba(255, 255, 255, .8);
  margin-bottom: 25px;
  margin-left: 20px;
  padding: 10px;
  width: 70%;
  font-size: 12px;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockTxt {
    background-color: inherit;
    font-size: 16px;
    line-height: 1.6;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
    padding-bottom: 25px;
    padding-left: 6px;
    padding-right: 6px;
    padding-top: 0;
    width: auto;
  }
}

.fukugyoZaitakuContentBlockBadge {
  position: absolute;
  right: 15px;
  top: 0;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockBadge {
    position: absolute;
    right: 50px;
    top: 0;
  }
}

.fukugyoZaitakuContentBlockBadge img {
  width: 33px;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockBadge img {
    width: 38px;
  }
}

.fukugyoZaitakuContentBlockList {
  display: flex;
  flex-wrap: wrap;
  padding-left: 15px;
  padding-right: 15px;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockList {
    padding-left: 0;
    padding-right: 0;
  }
}

.fukugyoZaitakuContentBlockList li {
  flex-basis: calc(50% - 1%);
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 5px;
  max-width: calc(50% - 1%);
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockList li {
    flex-basis: calc(100% / 4 - 1%);
    margin-right: 1%;
    max-width: calc(100% / 4 - 1%);
  }
}

.fukugyoZaitakuContentBlockList li:nth-child(2n) {
  margin-left: 2%;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockList li:nth-child(2n) {
    margin-left: 0;
  }
}

.fukugyoZaitakuContentBlockList li a {
  align-items: center;
  background-color: #000;
  color: #fff;
  display: flex;
  height: 45px;
  justify-content: center;
}

@media (min-width: 768px) {
  .fukugyoZaitakuContentBlockList li a {
    height: 60px;
  }
}

/* .fukugyoVoice */
.fukugyoVoice {
  background-color: #f1efee;
}

.fukugyoVoiceHeader {
  background-color: #231815;
  height: 60px;
}

.fukugyoVoiceTitle {
  color: #fff;
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoVoiceTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoVoiceTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoVoiceTitle span {
    font-size: 16px;
  }
}

@media (min-width: 768px) {
  .fukugyoVoiceContent {
    background-color: #f1efee;
    padding-bottom: 60px;
    padding-top: 50px;
  }
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlocks {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

.fukugyoVoiceContentBlock {
  background-color: #fff;
  margin-bottom: 10px;
  padding-bottom: 30px;
  position: relative;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlock {
    box-shadow: 2px 2px 4px 0 rgba(0,0,0,0.2);
    flex-basis: calc(100% / 3 - 1%);
    margin-bottom: 0;
    max-width: calc(100% / 3 - 1%);
    padding-bottom: 240px;
  }
}

.fukugyoVoiceContentBlockTitle {
  font-size: 18px;
  font-weight: normal;
  line-height: 1.3;
  padding: 15px 15px 10px 15px;
}

.fukugyoVoiceContentBlockImg {
  padding-bottom: 15px;
  padding-left: 15px;
  padding-right: 15px;
  text-align: center;
}

.fukugyoVoiceContentBlockTxt {
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: 20px;
  padding: 0 20px;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlockTxt {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: 0;
    padding: 0 15px;
  }
}

.fukugyoVoiceContentBlockList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-left: 10px;
  padding-right: 10px;
  width: 100%;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlockList {
    bottom: 20px;
    position: absolute;
  }
}

.fukugyoVoiceContentBlockList li {
  font-size: 14px;
  font-weight: 400;
  flex-basis: calc(50% - 1%);
  max-width: calc(50% - 1%);
  padding-bottom: 5px;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlockList li {
    font-size: 16px;
  }
}

.fukugyoVoiceContentBlockList li a {
  background-color: #000;
  align-items: center;
  color: #fff;
  display: flex;
  height: 45px;
  line-height: 1;
  justify-content: center;
}

.fukugyoVoiceContentBlockBadge {
  position: absolute;
  right: 15px;
  top: 0;
  z-index: 99;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlockBadge {
    top: -5px;
  }
}

.fukugyoVoiceContentBlockBadge img {
  width: 33px;
}

@media (min-width: 768px) {
  .fukugyoVoiceContentBlockBadge img {
    width: 38px;
  }
}

/* .fukugyoPointTitle */
.fukugyoPoint {
  background-color: #f1efee;
}

.fukugyoPointHeader {
  background-color: #231815;
  height: 60px;
}

.fukugyoPointTitle {
  color: #fff;
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoPointTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoPointTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoPointTitle span {
    font-size: 16px;
  }
}

.fukugyoPointContent {
  background-image: url(../img/point-content-bg-sp.png);
  background-size: cover;
  padding-bottom: 25px;
}

@media (min-width: 768px) {
  .fukugyoPointContent {
    background-image: url(../img/point-content-bg.jpg);
    background-position: center top;
    background-size: cover;
    min-height: 530px;
  }
}

.fukugyoPointContentImg {
  text-align: center;
}

.fukugyoPointContentBlock {
  background-color: rgba(255, 255, 255, .8);
  border-radius: 3px;
  margin-left: 25px;
  margin-right: 25px;
  margin-top: -50px;
  padding: 15px;
  position: relative;
}

@media (min-width: 768px) {
  .fukugyoPointContentBlock {
    margin-left: 0;
    margin-right: 0;
    margin-top: 0;
    position: absolute;
    right: 0;
    top: 58px;
    max-width: 587px;
    padding: 0;
  }
}

.fukugyoPointContentBlock:before {
  content: "";
  background-image: url(../img/point-content-block-bg.png);
  background-size: 24px auto;
  height: 44px;
  opacity: .8;
  position: absolute;
  right: 30px;
  top: -43px;
  width: 23px;
}

@media (min-width: 768px) {
  .fukugyoPointContentBlock:before {
    background-image: none;
    top: 15%;
    left: -50px;
    border: solid transparent;
    height: 0;
    width: 0;
    opacity: 1;
    pointer-events: none;
    border-color: none;
    border-right-color: rgba(255, 255, 255, .8);
    border-bottom-width: 10px;
    border-left-width: 25px;
    border-right-width: 25px;
    border-top-width: 10px;
  }
}

.fukugyoPointContentBlockTxt {
  font-size: 12px;
  line-height: 1.6;
}

@media (min-width: 768px) {
  .fukugyoPointContentBlockTxt {
    font-size: 16px;
    line-height: 1.8;
    padding: 25px;
  }
}

/* #qa */
#qa{
  font-size: 14px;
  background: #f2f2f2;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
}

#qa h2{
  background: #231815;
  color: #fff;
  text-align: center;
  padding: 20px 0;
  margin: 0 0 20px 0;
  font-size: 18px;
}

#qa section{
  padding: 20px 0 60px 0;
}

@media (min-width: 768px) {
  #qa section {
    margin-left: auto;
    margin-right: auto;
    max-width: 960px;
  }
}

#qa section dl{
  border:5px solid #231815;
  padding: 20px;
  box-sizing: border-box;
  margin: 0 0 10px 0;
}

#qa section dl dt{
  font-size: 18px;
  padding: 0 0 10px 0;
  border-bottom:1px solid #231815;
  margin: 0 0 10px 0;
}

/* .fukugyoArea */
.fukugyoArea {
  padding-bottom: 30px;
  padding-top: 30px;
}

.fukugyoAreaTitle {
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoAreaTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoAreaTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoAreaTitle span {
    font-size: 16px;
  }
}

/* .fukugyoRegion */
.fukugyoRegion {
  padding-bottom: 30px;
  padding-top: 30px;
}

.fukugyoRegionTitle {
  font-size: 18px;
  padding-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .fukugyoRegionTitle {
    font-size: 22px;
    padding-bottom: 10px;
  }
}

.fukugyoRegionTitle span {
  color: #777;
  font-size: 14px;
}

@media (min-width: 768px) {
  .fukugyoRegionTitle span {
    font-size: 16px;
  }
}

/* エリア検索（都道府県） */
#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: #f1efee;
  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: #fff;
  border: 2px solid #000;
  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: #000;
}

#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: #000;
  border-radius: 5px;
  color: #fff;
  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: #000;
  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: #000;
  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-weight: 400;
  font-size: 16px;
  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-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: 20px !important;
  top: 20px !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;
}

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

.popupMorning {
  color: #EF7C23;
}

.popupDaytime {
  color: #E8A84B;
}

.popupNight {
  color: #75BFB5;
}


.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: #f1efee;
  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: #000;
  border-radius: 5px;
  color: #fff;
  display: flex;
  height: 38px;
  justify-content: center;
}

/*/////▼ LPバナー ▼////*/


.adbnr{
  background: #fbfaf8;
  border: 1px solid #d9d3ce;
  border-radius: 5px;
  font-size: 12px;
  margin: 20px auto 20px auto;
  width: 100%;
}
.adbnr ul{
  padding: 0 15px 15px;
      box-sizing: border-box;
      letter-spacing: .08em;
      line-height: 1.4;
      font-size: 13px;
      text-align: center;}
.adbnr ul li a{
	display: block;
	color: #000;
	text-align: center;
}
.adbnr h3{
  background: #444;
  color: #fff;
  font-size: 18px;
  text-align: center;
  letter-spacing: .06em;
  padding: 10px 0!important;
  margin: 0 0 15px;
}
