/*reset css
---------------------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;800&display=swap');
@import url(//use.fontawesome.com/releases/v5.13.0/css/all.css);

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}

html {
  scroll-behavior: smooth;
  overflow-y: scroll;
  font-size: 62.5%;
}

body {
  font-family: Avenir, "Open Sans", "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-feature-settings: "palt";
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1;
  color: #333;
  background: #f5f5f5;
  overflow: hidden;
}

body#aboutus {
  background: #fff;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-style: normal;
  font-weight: normal;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

input,
textarea {
  margin: 0;
  padding: 0;
}

ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption,
th {
  text-align: left;
}

a:focus {
  outline: none;
}

a,
a:hover {
  text-decoration: none;
}

/*a,
a::before,
a::after {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
}*/
a:hover img {
  opacity: 0.9;
  filter: alpha(opacity=90);
  -ms-filter: "alpha(opacity=90)";
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
}

.clear {
  clear: both;
  margin: 0;
  padding: 0
}

img {
  vertical-align: bottom;
}

img.img_responsive {
  max-width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}


/* 画面サイズが641px以上の場合に適用 */
@media only screen and (min-width: 641px) {
  .pc-none {
    display: block;
  }

  .sp-none {
    display: none;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .pc-none {
    display: none;
  }

  .sp-none {
    display: block;
  }
}

/* css
---------------------------------------------------*/
.btn01 {
  text-align: center;
}

.btn01 a {
  display: inline-block;
  padding: 10px;
  font-family: "Montserrat";
  font-size: 2rem;
  color: #66beff;
  border: 1px solid #66beff;
  border-radius: 25px;
  /* CSS3草案 */
  -webkit-border-radius: 25px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 25px;
  /* Firefox用 */
  width: 140px;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.btn01 a:hover {
  background: #66beff;
  color: #fff;
}

/* 画面サイズが767px以下の場合に適用 */
@media only screen and (max-width: 767px) {
  .btn01 a {
    font-size: 1.4rem;
    padding: 5px;
  }
}

.thanks_page .btn01 a {
  margin-top: 80px;
  background: #4d4d4d;
  border: 1px solid #4d4d4d;
  color: #fff;
}

.thanks_page .btn01 a:hover {
  color: #4d4d4d;
  background: #fff;
}

.btn02 a {
  padding: 8px;
  text-align: center;
  border: 1px solid #66beff;
  display: inline-block;
  width: 290px;
  margin-left: auto;
  margin-right: auto;
  color: #66beff;
  font-weight: bold;
  border-radius: 50px;
  /* CSS3草案 */
  -webkit-border-radius: 50px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 50px;
  /* Firefox用 */
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  margin: 5px;
}

.btn02 a:hover {
  background: #66beff;
  color: #fff;
}

.in {
  width: 100%;
  max-width: 1000px;
  margin: 0px auto;
}

.in80 {
  width: 80%;
  margin: 0px auto;
}

.in70 {
  width: 70%;
  margin: 0px auto;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .in {
    padding: 0px 15px;
  }

  .in70,
  .in80 {
    width: 100%;
  }
}

#contents {
  min-height: 55vh;
}

#contents section {
  padding: 4em 0px;
  margin-bottom: 2em;
}

#contents section:last-child {
  margin-bottom: 0px;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  #contents {
    margin-top: 65px;
  }

  #contents section {
    padding: 2em 0px;
    margin-bottom: 1em;
  }
}

.title01 {
  margin-bottom: 1.5em;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 4.8rem;
  color: #3e3a39;
}

.title01 span.jp {
  font-family: Avenir, "Open Sans", "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  letter-spacing: 8px;
  font-size: 2.7rem;
  font-weight: bold;
  border-bottom: 2px solid #333;
  padding: 15px 0px 5px 0px;
  display: block;
}

.title02 {
  margin-bottom: .4em;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 170px;
  color: #f5f5f5;
  line-height: 125px;
  position: relative;
  text-align: center;
  letter-spacing: 6px;
}

.title02 span {
  width: 100%;
  position: absolute;
  top: 0;
  height: 125px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 3.4rem;
  color: #333;
  font-weight: bold;
}

.title03:after {
  content: " 】";
}

.title03:before {
  content: "【 ";
}

.title03 {
  font-size: 3.9rem;
  text-align: center;
  letter-spacing: 3px;
  margin-bottom: 2em;
}

.titlebox01 {
  background: url("images/feature_bg.png") center center / cover no-repeat;
  padding: 20px;
  color: #fff;
  line-height: 1.6;
}

.titlebox01 .point_txt {
  background: #fff;
  letter-spacing: 5px;
  display: inline-block;
  padding: 5px 0px 5px 10px;
  line-height: 1;
  font-size: 2.1rem;
  font-weight: bold;
  color: #2778bd;
}

.titlebox01 .ttl_txt {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 2.8rem;
  letter-spacing: 2px;
  margin-bottom: .5em;
}

.titlebox01 .logo {
  text-align: center;
  margin-bottom: 1.5em;
}

.titlebox01 .txtbox:before {
  content: '';
  /*何も入れない*/
  display: inline-block;
  /*忘れずに！*/
  width: 215px;
  /*画像の幅*/
  height: 19px;
  background-image: url(images/top_waku.png);
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}

.titlebox01 .txtbox:after {
  content: '';
  /*何も入れない*/
  display: inline-block;
  /*忘れずに！*/
  width: 215px;
  /*画像の幅*/
  height: 19px;
  background-image: url(images/bottom_waku.png);
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}

.titlebox01 .txtbox p {
  padding: 0px 10px;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .title01 {
    font-size: 3.6rem;
  }

  .title01 span.jp {
    font-size: 1.8rem;
  }

  .title02 {
    font-size: 100px;
    margin-bottom: .8em;
  }

  .title02 span {
    font-size: 1.8rem;
    height: auto;
    letter-spacing: 3px;
  }

  .title03 {
    font-size: 2.4rem;
    font-weight: bold;
  }

  .titlebox01 {
    line-height: 1.4;
    font-size: 1.4rem;
    background: none;
    padding: 0px;
    margin-bottom: 3em;
    border-bottom: 2px solid #2778bd;
  }

  .titlebox01 .ttl_txt {
    font-size: 3rem;
    color: #2778bd;
    margin-bottom: 0px;
  }

  .titlebox01 .txtbox {
    display: none;
  }

  .titlebox01 .logo {
    display: none;
  }

  .titlebox01 .point_txt {
    color: #fff;
    background: url("images/feature_bg.png") center center / cover no-repeat;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .title02 {
    font-size: 50px;
    line-height: 1;
    position: inherit;
  }

  .title02 span {
    position: inherit;
    line-height: 1;
    margin-top: 10px;
  }

  .titlebox01 .point_txt {
    font-size: 1.6rem;
  }
}

.header .in {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
  -webkit-align-items: baseline;
  /* Safari */
  align-items: baseline;
  padding: 80px 0px 40px 0px;
}

.header_nav ul.dropdwn {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}

.header_nav ul.dropdwn>li {
  padding: 0px 15px;
  font-weight: bold;
}

.header_nav ul.dropdwn>li a {
  color: #333;
  font-weight: bold;
}

.dropdwn_menu {
  display: none;
  position: absolute;
  padding: 5px;
  background: #fff;
  min-width: 100px;
  text-align: center;
  background: -moz-linear-gradient(top, #fff, #e8f0fc);
  background: -webkit-linear-gradient(top, #fff, #e8f0fc);
  background: linear-gradient(to bottom, #fff, #e8f0fc);
  z-index: 10;
}

.dropdwn_menu li {
  width: 100%;
  border-bottom: 1px dotted #fff;
}

.dropdwn_menu li a {
  padding: 5px;
  display: block;
}

.sp_nav {
  display: none;
}

.search {
  position: relative;
}

.search>div {
  position: absolute;
  right: 0;
  top: -10px;
}

.search form {
  position: relative;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all 1s;
  width: 38px;
  height: 38px;
  box-sizing: border-box;
  border-radius: 25px;
  cursor: pointer;
}

.search input {
  position: absolute;
  top: 0px;
  left: 0;
  width: 100%;
  height: 39px;
  line-height: 30px;
  outline: 0;
  border: 0;
  font-size: 1em;
  border-radius: 20px;
  background: #bbcce9;
}

.search img {
  box-sizing: border-box;
  position: absolute;
  top: 0;
  right: 0;
}

.search form.clicked {
  width: 250px;
}

.search form.clicked input {
  display: block;
  padding: 0 20px;
}

.search form #s-btn-area {
  width: 38px;
  /*検索ボタンの横幅*/
  height: 39px;
  /*検索ボタンの縦幅*/
  position: absolute;
  /*検索ボタンの絶対位置*/
  right: 0px;
  /*検索ボタンの位置調整*/
  top: 0;
  border-radius: 20px;
  /*検索ボタンの角を丸める*/
  background: #7fbfff;
  /*検索ボタンの背景カラー*/
  border: none;
  /*検索ボタンの枠線を消す*/
  color: #fff;
  /*検索ボタンのテキストカラー*/
  font-weight: bold;
  /*検索ボタンのテキスト太字*/
  font-size: 14px;
  /*検索ボタンのフォントサイズ*/
  transition: all 1s;
}

.search form.clicked #s-btn-area {
  border-radius: 0px 20px 20px 0px;
  /*検索ボタンの角を丸める*/
  width: 80px;
  /*検索ボタンの横幅*/
  position: absolute;
  /*検索ボタンの絶対位置*/
  right: 0px;
  /*検索ボタンの位置調整*/
  padding-right: 40px;

}

.sp_nav {
  display: none;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .header .in {
    background: #f5f5f5;
    padding: 10px;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
  }

  .header .in .logo img {
    height: 45px;
    width: auto;
  }

  .search {
    display: none;
  }

  .header_nav {
    display: none;
  }

  .sp_nav {
    position: inherit;
    display: block;
    z-index: 9999;
  }

  /*menu*/
  .menu {
    height: 20px;
    position: fixed;
    right: 20px;
    top: 20px;
    width: 30px;
    z-index: 9999;
  }

  .menu__line {
    background: #2778bd;
    display: block;
    height: 2px;
    position: absolute;
    transition: transform .3s;
    width: 100%;
  }

  .menu__line--center {
    top: 9px;
  }

  .menu__line--bottom {
    bottom: 0;
  }

  .menu__txt {
    font-size: 1rem;
    color: #2778bd;
    font-weight: bold;
    position: absolute;
    bottom: -15px;
    transition: transform .3s;
  }

  .menu__line--top.active {
    top: 8px;
    transform: rotate(45deg);
  }

  .menu__line--center.active {
    transform: scaleX(0);
  }

  .menu__line--bottom.active {
    bottom: 10px;
    transform: rotate(135deg);
  }

  /*gnav*/
  .gnav {
    background: #fff;
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 9998;
  }

  .gnav__wrap {
    /*align-items:center;*/
    display: flex;
    height: 100%;
    justify-content: center;
    position: absolute;
    width: 100%;
  }

  .gnav__menu__item {
    border-bottom: 1px solid #bbcce9;
    text-align: center;
  }

  .gnav__menu__item a,
  .gnav__menu__item span {
    display: block;
    color: #2778bd;
    font-size: 1.5rem;
    padding: 10px;
    text-decoration: none;
    transition: .5s;
  }

  .gnav__menu__item2 {
    padding-bottom: 1px;
  }

  .gnav__menu__item2 a {
    display: block;
    background: #bbcce9;
    color: #2778bd;
    font-size: 1.4rem;
    text-align: center;
    padding: 5px;
  }

  .gnav__menu__item a:hover,
  .gnav__menu__item2 a:hover {
    color: #fff;
    background: #a2b3db;
  }

  .gnav__menu__item>a:hover:before {
    color: #fff;
  }
}

.footer {
  background: #000;
  color: #fff;
  padding: 3em 0px;
  text-align: center;
}

.f_link {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  margin-bottom: 2em;
}

.f_link a {
  padding: 10px;
  color: #fff;
}

.f_share {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  margin-right: 20px;
  padding-right: 20px;
  border-right: 2px solid #fff;
}

.f_logo {
  margin-bottom: 2em;
}

.copy {
  font-size: 1.2rem;
}


/*common
-----------------------------------------------------*/
.category_icon {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  margin-top: 8px;
  margin-bottom: 5px;
}

.category_icon p {
  display: inline-block;
  background: #2778bd;
  color: #fff;
  padding: 3px 5px;
  font-size: 1.2rem;
  line-height: 1;
  margin-right: 5px;
}

.main_list>.sidebar {
  margin-bottom: 50px;
}

/* 画面サイズが1001px以上の場合に適用 */
@media only screen and (min-width: 1001px) {
  .main_list>.sidebar {
    margin-top: -4em;
  }
}


/* side
---------------------------------------------------*/
/*リセット*/
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  cursor: pointer;
}

.side_serch {
  padding: 1em;
  background: rgba(255, 255, 255, 0.8);
  margin-top: 15px;
}

.search_side {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}

.search_side dt {
  width: 75%;
}

.search_side dt input {
  width: 100%;
  height: 40px;
  padding: 5px;
}

.search_side dd {
  width: 22%;
  text-align: left;
}

.sidebar .side_tag {
  padding: 1em;
  background: rgba(255, 255, 255, 0.8);
}

.sidebar .ttl {
  font-weight: bold;
  font-size: 16px;
  padding: 5px;
  border-bottom: 2px solid #007cba;
  margin-bottom: 15px;
  text-align: left;
}

.sidebar .taglist {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: flex-start;
  /* Safari */
  justify-content: flex-start;
  gap: 10px 0;
}

.sidebar .taglist li {
  padding: 5px;
}

.sidebar .taglist li a {
  font-weight: bold;
  font-size: 12px;
  background: #eee;
  border-radius: 15px;
  /* CSS3草案 */
  -webkit-border-radius: 15px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 15px;
  /* Firefox用 */
  padding: 5px 10px;
  color: #333;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.sidebar .taglist li a:hover {
  background: #333;
  color: #fff;
}


/*search一覧ページ
-------------------------------*/
.search_ttl {
  font-weight: bold;
  font-size: 18px;
  line-height: 1.4;
  letter-spacing: 2px;
  margin-bottom: 30px;
}

.search_ttl span {
  font-weight: bold;
  font-size: 1.4em;
  color: #2778bd;
  margin-right: 5px;
}

.search_notfound {
  font-weight: bold;
  line-height: 1.4;
}

/*tag一覧ページ
-------------------------------*/
.tag_name {
  font-weight: bold;
  font-size: 18px;
  line-height: 1.4;
  margin-bottom: 30px;
  letter-spacing: 2px;
}

.tag_name span {
  font-weight: bold;
  font-size: 1.4em;
  color: #2778bd;
  margin-right: 5px;
}


/* top
---------------------------------------------------*/
.top_fv {
  background: url(images/bg01.png) center center / cover no-repeat;
}

#main_img {
  text-align: center;
  padding: 0px 2em;
}

#main_img .img {
  margin-bottom: 2em;
}

#main_img .txt {
  line-height: 30px;
  font-weight: bold;
  margin-bottom: 2em;
  font-size: 2rem;
}

#main_img .btn01 a {
  background: #4d4d4d;
  border: 1px solid #4d4d4d;
  color: #fff;
}

#main_img .btn01 a:hover {
  color: #4d4d4d;
  background: #fff;
}

/* 画面サイズが1001px以上の場合に適用 */
@media only screen and (min-width: 1001px) {
  .main_img_box {
    display: -webkit-box;
    /*--- Androidブラウザ用 ---*/
    display: -ms-flexbox;
    /*--- IE10 ---*/
    display: -webkit-flex;
    /* Safari */
    display: flex;
    -ms-flex-wrap: wrap;
    /*--- IE10用 ---*/
    -webkit-flex-wrap: wrap;
    /* Safari */
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    /*--- Androidブラウザ用 ---*/
    -ms-flex-pack: justify;
    /*--- IE10 ---*/
    -webkit-justify-content: space-between;
    /* Safari */
    justify-content: space-between;
    padding: 5em 0px;
  }

  .main_img_box>#main_img {
    width: 75%;
  }

  .main_img_box>.sidebar {
    width: 25%;
  }
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .main_img_box>#main_img {
    padding-top: 100px;
    margin-bottom: 30px;
  }

  .main_img_box>.main_img_box {
    padding: 4em 15px;
  }
}

#pickup .txt {
  padding: 10px 20px 20px 20px;
  background: #fff;
  line-height: 1.8;
}

#pickup .txt p.ttl {
  font-weight: bold;
}

#pickup .txt .date {
  font-size: .8rem;
}

#pickup .bxslider li a {
  display: block;
  color: #333;
}

.name {
  font-weight: bold;
  margin-bottom: 20px;
}

.newlist {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  margin-bottom: 2em;
}

.newlist li {
  width: 33.3%;
  padding: 1%;
  padding-bottom: 1.5em;
  position: relative;
}

.newlist li a {
  display: block;
  color: #333;
}

.newlist .img {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  height: 185px;
  overflow: hidden;
}

.newlist .img img {
  max-width: 100%;
  width: auto;
  object-fit: cover;
  min-width: 320px;
  min-height: 185px;
  max-height: 100%;
}

.newlist li .new_icon {
  position: absolute;
  top: -10px;
  right: -5px;
}

.newlist .txt {
  line-height: 1.6;
}

.newlist .txt .ttl {
  font-weight: bold;
}

.newlist .txt .date {
  font-size: .8rem;
}

.newlist .tagbox {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-direction: row;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-direction: row;
  /*--- IE10用 ---*/
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
}

.newlist .tagbox span {
  display: inline-block;
  font-weight: bold;
  font-size: 12px;
  border-radius: 15px;
  /* CSS3草案 */
  -webkit-border-radius: 15px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 15px;
  /* Firefox用 */
  padding: 2px 10px;
  margin: 0px 2px 2px 0px;
  border: 1px solid #eee;
  color: #333;
  background: #fff;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .newlist li {
    width: 48%;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  .newlist .img {
    text-align: center;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .newlist li {
    width: 100%;
  }
}

.articlebox {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
  margin-bottom: 3em;
}

.articlebox .titlebox01 {
  width: 26%;
}

.articlebox .first_article {
  width: 67%;
}

.first_article a {
  display: block;
  color: #333;
}

.first_article .img {
  background: rgb(77, 144, 200);
  padding-bottom: 17px;
  background: linear-gradient(273deg, rgba(77, 144, 200, 1) 0%, rgba(226, 236, 245, 1) 47%, rgba(101, 45, 145, 1) 100%);
  margin-bottom: 1.5em;
  margin-right: 45px;
}

.first_article .img img {
  margin-top: -20px;
  margin-left: 20px;
}

.first_article .txtbox {
  line-height: 1.4;
}

.first_article .txtbox .txt {
  font-size: 3rem;
  margin-bottom: .5em;
  font-weight: bold;
}

.first_article .txtbox .date {
  font-size: 2rem;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .articlebox .titlebox01 {
    width: 100%;
    order: 1;
  }

  .articlebox .first_article {
    width: 100%;
    order: 2;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .first_article .img {
    padding-bottom: 5px;
  }

  .first_article .img img {
    margin-top: -5px;
    margin-left: 10px;
  }

  .first_article .txtbox .txt {
    font-size: 2.4rem;
  }
}



.article_list {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  margin-bottom: 2em;
}

.article_list li {
  width: 33.3%;
  padding: 1%;
  padding-bottom: 1.5em;
  position: relative;
}

.article_list .img {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  height: 185px;
  overflow: hidden;
}

.article_list .img img {
  max-width: 100%;
  width: auto;
  object-fit: cover;
  min-width: 320px;
  min-height: 185px;
  max-height: 100%;
}

.article_list li a {
  display: block;
  color: #333;
}

.article_list .txt {
  line-height: 1.6;
}

.article_list .txt .ttl {
  font-weight: bold;
}

.article_list .txt .date {
  font-size: .8rem;
}

.article_list .tagbox {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-direction: row;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-direction: row;
  /*--- IE10用 ---*/
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
}

.article_list .tagbox span {
  display: inline-block;
  font-weight: bold;
  font-size: 12px;
  border-radius: 15px;
  /* CSS3草案 */
  -webkit-border-radius: 15px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 15px;
  /* Firefox用 */
  padding: 2px 10px;
  margin: 0px 2px 2px 0px;
  border: 1px solid #eee;
  color: #333;
  background: #fff;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .article_list li {
    width: 48%;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  .article_list .img {
    text-align: center;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .article_list li {
    width: 100%;
  }
}


section.serialization {
  background: url(images/bg01.png) center center / cover no-repeat;
}

.serialization_list {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  margin-bottom: 2em;
}

.serialization_list li {
  width: 33.3%;
  padding: 1%;
  padding-bottom: 1.5em;
  position: relative;
}

.serialization_list li a {
  display: block;
  color: #333;
}

.serialization_list .img {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  height: 185px;
  overflow: hidden;
}

.serialization_list .img img {
  max-width: 100%;
  width: auto;
  object-fit: cover;
  min-width: 320px;
  min-height: 185px;
  max-height: 100%;
}

.serialization_list .txt {
  line-height: 1.6;
}

.serialization_list .txt .ttl {
  font-weight: bold;
}

.serialization_list .txt .date {
  font-size: .8rem;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .serialization_list li {
    width: 48%;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  .serialization_list .img {
    text-align: center;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .serialization_list li {
    width: 100%;
  }
}



/*EVENT**************************************/
.event {
  background: rgb(99, 47, 146);
  background: linear-gradient(0deg, rgba(99, 47, 146, 1) 0%, rgba(54, 129, 193, 1) 100%);
}

.event .btn01 a {
  color: #fff;
  border: 1px solid #fff;
}

.event .btn01 a:hover {
  background: #fff;
  color: #3380c1;
}

.event .title01 {
  color: #fff;
}

.event .title01 span.jp {
  border-bottom: 2px solid #fff;
}

#event {
  margin-bottom: 2em;
}

#event .txt {
  padding: 10px 20px 20px 20px;
  background: #fff;
  line-height: 1.8;
}

#event .txt p.ttl {
  font-weight: bold;
}

#event .txt .date {
  font-size: .8rem;
}

#event .bxslider li a {
  display: block;
  color: #333;
}


/*RELEASE**************************************/
.release_box {
  padding: 80px 20px 60px 20px;
  /* 要素の上下左右の余白を指定 */
  width: 100%;
  /* ボックスの横幅を指定 */
  font-size: 13px;
  /* フォントの大きさを指定 */
  box-shadow: 0px 0px 5px 3px #d1e6f8, 0px 0px 5px 3px #d1e6f8 inset;
  /* ボックスの影を指定 */
  border-radius: 5px;
  /* CSS3草案 */
  -webkit-border-radius: 5px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 5px;
  /* Firefox用 */
  position: relative;
  text-align: center;
}

.release_box h2 {
  position: absolute;
  top: -30px;
  left: 0;
  width: 100%;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 4.8rem;
  color: #2670ff;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 5px;
}

.release_box h2 span {
  display: block;
  color: #333;
  font-size: 2rem;
  font-weight: bold;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .release_box h2 {
    font-size: 3.6rem;
  }

  .release_box h2 span {
    font-size: 1.6rem;
  }
}

.release {
  margin-bottom: 3em;
  width: 75%;
  margin-left: auto;
  margin-right: auto;
}

.release dl {
  border-bottom: 2px dotted #333;
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-direction: row;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-direction: row;
  /*--- IE10用 ---*/
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  line-height: 1.6;
}

.release dl dt,
.release dl dd {
  padding: 15px 0px;
  text-align: left;
  font-size: 16px;
}

.release dl dt,
.release dl dd a {
  font-weight: bold;
  color: #333;
}

.release dl dt {
  width: 15%;
}

.release dl dd {
  width: 85%;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .release {
    width: 100%;
  }

  .release dl dt,
  .release dl dd {
    width: 100%;
    padding: 10px 0px;
  }

  .release dl {
    margin-bottom: 25px;
  }
}

/**/
.other_contents {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
  margin-bottom: 2em;
}

.other_contents li {
  width: 31%;
  margin-bottom: 30px;
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .other_contents li {
    width: 100%;
    text-align: center;
  }
}

figure.cp_caption {
  position: relative;
  overflow: hidden;
  width: 100%;
  color: #ffffff;
}

figure.cp_caption * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

figure.cp_caption img {
  width: 100%;
  height: 100%;
}

figure.cp_caption figcaption {
  width: 100%;
  position: absolute;
  z-index: 1;
  top: 50%;
  transition: all 0.3s ease-out;
  transition-delay: 0.1s;
  opacity: 0;
  color: #fff;
  line-height: 20px;
  text-align: center;
  letter-spacing: 0.2em;
  font-size: 18px;
}

figure.cp_caption:after {
  position: absolute;
  top: 0%;
  right: 0%;
  bottom: 0%;
  left: 0%;
  display: inline-block;
  content: '';
  transition: all 0.3s ease-out;
  opacity: 0;
  background: rgba(27, 37, 56, 0.8);
}

figure.cp_caption:hover:after {
  opacity: 0.9;
}

figure.cp_caption:hover figcaption {
  transform: translateY(-50%);
  opacity: 1;
}

/*------------------------------------------------------
  kiji
------------------------------------------------------*/

section.article {
  padding: 0px !important;
  margin-bottom: 6em !important;
}

section.article .in {
  background: #fff;
  padding: 90px 50px;
  text-align: center;
}

section.article img {
  max-width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

/* 画面サイズが1001px以上の場合に適用 */
@media only screen and (min-width: 1001px) {
  section.article .in {
    display: -webkit-box;
    /*--- Androidブラウザ用 ---*/
    display: -ms-flexbox;
    /*--- IE10 ---*/
    display: -webkit-flex;
    /* Safari */
    display: flex;
    -ms-flex-wrap: wrap;
    /*--- IE10用 ---*/
    -webkit-flex-wrap: wrap;
    /* Safari */
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    /*--- Androidブラウザ用 ---*/
    -ms-flex-pack: justify;
    /*--- IE10 ---*/
    -webkit-justify-content: space-between;
    /* Safari */
    justify-content: space-between;
    -webkit-box-direction: reverse;
    /*--- Androidブラウザ用 ---*/
    -ms-flex-direction: reverse;
    /*--- IE10用 ---*/
    -webkit-flex-direction: row-reverse;
    /* Safari */
    flex-direction: row-reverse;
  }

  section.article .main_kiji {
    width: 73%;
  }

  section.article .sidebar {
    width: 25%;
  }
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  section.article .sidebar {
    border: 1px solid #eee;
    margin-bottom: 30px;
  }
}

.kiji_ttl {
  text-align: left;
  line-height: 1.4;
  letter-spacing: 1px;
  margin-bottom: 12px;
}

.kiji_ttl .img {
  margin-bottom: 3em;
  text-align: center;
}

.kiji_ttl h2 {
  font-weight: bold;
  margin-bottom: 1em;
  font-size: 2.5rem;
  letter-spacing: 0.15em;
}

.kiji_ttl .category_icon {
  font-size: 1.7rem;
  margin-bottom: 1em;
}

.kiji_ttl .date {
  font-size: 1.7rem;
}

.kiji_ttl .tagbox {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-direction: row;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-direction: row;
  /*--- IE10用 ---*/
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: flex-end;
  /* Safari */
  justify-content: flex-end;
}

.kiji_ttl .tagbox span {
  padding: 5px;
}

.kiji_ttl .tagbox span a {
  font-weight: bold;
  font-size: 12px;
  border-radius: 15px;
  /* CSS3草案 */
  -webkit-border-radius: 15px;
  /* Safari,Google Chrome用 */
  -moz-border-radius: 15px;
  /* Firefox用 */
  padding: 8px 15px;
  color: #333;
  background: #f1f1f1;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.kiji_ttl .tagbox span a:hover {
  background: #333;
  color: #fff;
}

.kiji_txt01 {
  text-align: left;
  line-height: 1.8;
  font-size: 1.6rem;
  margin-bottom: 2em;
  letter-spacing: 0.15em;
}

.kiji_txt01 iframe {
  width: 680px;
  height: 450px;
}

@media only screen and (max-width: 680px) {
  .kiji_txt01 iframe {
    width: 100%;
    height: 250px;
  }
}

.mb1 {
  margin-bottom: 1.5em;
}

.profile {
  border: solid 2px #2778bd;
  padding: 30px;
  overflow: hidden;
  zoom: 1;
  margin-bottom: 30px;
}

.profile_txt {
  color: #2778bd;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.6;
  margin-bottom: 2em;
}

.profile_txt1 {
  color: #2778bd;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.6;
  margin-bottom: 2em;
  overflow: hidden;
  zoom: 1;
}

.profile_txt2 {
  color: #2778bd;
  text-align: left;
  line-height: 1.6;
  margin-bottom: 2em;
  overflow: hidden;
  zoom: 1;
  letter-spacing: 0.15em;
}

.profile_txt3 {
  color: #2778bd;
  font-size: 1.4rem;
  text-align: left;
  line-height: 1.6;
  overflow: hidden;
  zoom: 1;
  letter-spacing: 0.15em;
}

.profile_img {
  float: left;
  margin-right: 40px;
}

.profile_img2 {
  margin-bottom: 40px;
}

@media only screen and (max-width: 480px) {
  .profile_img {
    float: none;
    margin-right: 0px;
    margin-bottom: 40px;
  }
}

.kiji_box01 {
  margin-bottom: 2em;
}

.kiji_box01 h3 {
  padding: 15px 25px;
  border: 1px solid #2778bd;
  color: #2778bd;
  font-weight: bold;
  font-size: 1.7rem;
  line-height: 1.5;
  text-align: left;
  margin-bottom: 2em;
}

.kiji_img01 {
  margin-bottom: 2em;
}

.kiji_img02 {
  margin-bottom: 2em;
  width: 60%;
  margin: 0 auto;
}

.kiji_txt02 {
  padding-bottom: 2em;
  margin-bottom: 2em;
  border-bottom: 1px dashed #333333;
  text-align: left;
  line-height: 1.6;
  font-size: 1.6rem;
}

.kiji_txt02:last-child {
  padding-bottom: 0px;
  margin-bottom: 0px;
  border-bottom: none;
}

.kiji_txt03 {
  padding-bottom: 2em;
  margin-top: 2em;
  margin-bottom: 2em;
  text-align: left;
  line-height: 1.6;
  font-size: 1.6rem;
}

.kiji_txt03:last-child {
  padding-bottom: 0px;
  margin-bottom: 0px;
  border-bottom: none;
}

.kiji_txt04 {
  text-align: left;
  line-height: 1.8;
  font-size: 1.6rem;
}

.kiji_txt05 {
  text-align: left;
  line-height: 1.8;
  font-size: 1.4rem;
  margin-top: 5px;
  margin-bottom: 2em;
  letter-spacing: 0.2em;
}

.kiji_txt06 {
  text-align: left;
  line-height: 1.8;
  font-size: 1.6rem;
  margin-top: 4em;
  margin-bottom: 2em;
  letter-spacing: 0.15em;
}

.kiji_txt07 {
  padding-bottom: 2em;
  margin-bottom: 2em;
  border-bottom: 1px dashed #333333;
  text-align: left;
  line-height: 1.6;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
}

.kiji_txt08 {
  text-align: left;
  line-height: 1.8;
  font-size: 1.6rem;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
  letter-spacing: 0.15em;
}

.kiji_txt08 iframe {
  width: 680px;
  height: 450px;
}

@media only screen and (max-width: 680px) {
  .kiji_txt08 iframe {
    width: 100%;
    height: 250px;
  }
}

.kiji_hr {
  margin-bottom: 40px;
}

.kiji_strong {
  font-weight: bold;
  margin-top: 40px;
}

.strong1 {
  font-weight: bold;
}

.waku1 {
  border: solid 2px #2778bd;
  padding: 30px;
}

.waku2 {
  border: solid 2px #2778bd;
  padding: 30px;
  margin-bottom: 40px;
}

.waku3 {
  border: solid 2px #2778bd;
  padding: 30px;
  margin-top: 40px;
  margin-bottom: 40px;
}

.name_color {
  color: #2778bd;
  font-weight: bold;
}

.snsbox {
  margin-top: 5em;
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
  padding: 15px;
}

.snsbox p a {
  display: inline-block;
  padding: 0px 25px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 2rem;
  color: #333;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  section.article {
    margin-bottom: 2em !important;
  }

  section.article .in {
    padding: 15px;
    width: 96%;
  }
}

section.staff {
  background: url(images/staff_bg.png) center center / cover no-repeat #fff;
}

.staffbox>div {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  padding: 20px;
}

.staffbox dl {
  padding: 20px;
}

.staffbox dl dt {
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 10px;
}

.staffbox dl dd {
  font-size: 2rem;
  display: table-cell;
  vertical-align: middle;
  line-height: 1.8;
}

.staffbox dl dd a {
  border-bottom: 1px solid #2778bd;
  color: #2778bd;
  padding-bottom: 10px;
}

/*------------------------------------------------------
  kiji_interview
------------------------------------------------------*/
.first_interview {
  width: 100%;
  max-width: 1000px;
  margin: 0px auto;
}



.txtbox01 {
  line-height: 1.8;
  margin-bottom: 3em;
}

.btnbox {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  margin-bottom: 3em;
}

.btnbox .btn02 {
  padding: 0px 5px;
}

.pdfbtn01 {
  text-align: center;
}

.pdfbtn01 img {
  margin-bottom: -6px;
}

.pdfbtn01 a {
  color: #808080;
  font-size: 1.3rem;
  padding-bottom: 5px;
  border-bottom: #808080 1px solid;
}



.omoi {
  background: url(images/abooutus_bg01.png) center center / cover no-repeat;
  padding: 130px 0px !important;
}

.omoi .in80 {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}

.omoi .omoi_txt {
  width: 20%;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  font-weight: bold;
  font-size: 9.6rem;
}

.omoi .txtbox {
  width: 80%;
  letter-spacing: 3px;
}

.omoi .txtbox .txt1 {
  font-size: 3.4rem;
  line-height: 1.5;
  margin-bottom: 1.5em;
}

.omoi .txtbox .txt1 span {
  display: inline-block;
  font-weight: bold;
  text-decoration: underline;
}

.omoi .txtbox .txt2 {
  line-height: 2;
  font-size: 2rem;
}

.omoi .txtbox .txt2 p {
  margin-bottom: 1.5em;
  font-weight: bold;
}

.omoi .txtbox .txt2 p:last-child {
  margin-bottom: 0px;
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .omoi .omoi_txt {
    width: 100%;
    order: 1;
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
    color: #8097cd;
    font-size: 5rem;
    margin-bottom: 1em;
    text-align: center;
  }

  .omoi .txtbox {
    width: 100%;
    order: 2;
  }
}


.episode .txtbox01 p {
  margin-bottom: 2em;
}

.episode .txtbox01 p:last-child {
  margin-bottom: 0px;
}

.mvv {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
  -webkit-align-items: center;
  /* Safari */
  align-items: center;
}

.mvv .logo {
  width: 15%;
}

.mvv .txtbox {
  background: url("images/epsode_line.png") no-repeat left center;
  padding: 30px 0px 30px 140px;
  width: 85%;
}

.mvv dl dt {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 3.5rem;
  margin-bottom: .2em;
}

.mvv dl {
  margin-bottom: 2em;
  line-height: 1.8;
}

.mvv dl:last-child {
  margin-bottom: 0px;
}

.mvv dl dd {
  letter-spacing: 3px;
  font-size: 1.5rem;
}

.mvv dl dd p {
  font-size: 1.3rem;
  margin-top: 15px;
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .mvv .logo {
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
  }

  .mvv .logo img {
    width: 80px;
  }

  .mvv .txtbox {
    width: 100%;
    background-image: none;
    padding: 5px;
  }

  .mvv dl {
    padding-top: 20px;
    border-top: 1px dashed #ccc;
    margin-top: 15px;
  }
}

.thought .img {
  text-align: center;
  margin-bottom: 3em;
}

.thought .txt {
  text-align: center;
  line-height: 1.8;
  margin-bottom: 4em;
  letter-spacing: 2px;
}

@media screen and (min-width: 480px) {
  .about_br_pc {
    display: block;
  }

  .about_br_sp {
    display: none;
  }
}

@media screen and (max-width: 480px) {
  .about_br_pc {
    display: none;
  }

  .about_br_sp {
    display: block;
  }
}

.aboutlogo {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}

.aboutlogo .logo {
  width: 25%;
}

.aboutlogo .txtbox {
  width: 70%;
  line-height: 1.8;
  letter-spacing: 2px;
}

.aboutlogo .txtbox .title03 {
  margin-bottom: .5em;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .aboutlogo .logo {
    width: 100%;
    text-align: center;
    padding: 10px;
  }

  .aboutlogo .txtbox {
    width: 100%;
  }
}

.people {
  background: url(images/people_bg.png) center center / cover no-repeat #fff;
  padding: 135px 0px !important;
  margin-bottom: 0px !important;
}

.people h2 {
  margin-bottom: .2em;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 142px;
  text-align: center;
  color: #2678bd;
}

.people_list {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
}

.people_list li {
  text-align: center;
  padding: 20px;
}

.people_list .img {
  margin-bottom: 15px;
}

.people_txt {
  font-size: 18px;
  font-weight: bold;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .people h2 {
    font-size: 100px;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .people h2 {
    font-size: 50px;
  }
}

.nipponmanpower {
  background: url(images/aboutus_bg02.jpg) center center / cover no-repeat;
  padding: 135px 0px !important;
}


.logobox {
  width: 100%;
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
  margin-bottom: 2em;
}

.nipponmanpower .txt1 {
  text-align: center;
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.8;
  margin-bottom: 1em;
}

.nipponmanpower .txt2 {
  text-align: center;
  margin-bottom: 2em;
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .logobox p {
    width: 50%;
    text-align: center;
  }

  .nipponmanpower .txt1 {
    text-align: left;
  }

  .nipponmanpower .txt1 br {
    display: none;
  }
}

a.anchor {
  display: block;
  padding-top: 70px;
  margin-top: -70px;
}

/*////////////////recruit*/
@media screen and (min-width: 480px) {
  .recruit_br_pc {
    display: block;
  }

  .recruit_br_sp {
    display: none;
  }
}

@media screen and (max-width: 480px) {
  .recruit_br_pc {
    display: none;
  }

  .recruit_br_sp {
    display: block;
  }
}

body#recruit {
  background: url("images/recruit_bg.jpg") repeat top center /cover;
}

body#recruit section.bg {
  background: url("images/rec_sec_bg.png") no-repeat center 180px;
  background-attachment: fixed;
  margin-bottom: 0px !important;
}

body#recruit section.bg .in {
  padding: 80px 0px;
}

.message,
.recruit,
.voice,
.partner {
  margin-bottom: 10em !important;
}

.message p.nmplogo {
  text-align: center;
  margin-bottom: 3em;
}

.message .txtbox {
  line-height: 2;
  text-align: center;
  letter-spacing: 3px;
  margin-bottom: 3em;
}

.message .txtbox p {
  margin-bottom: 2em;
  font-weight: bold;
}

.recruit_iframe {
  margin: 0 auto;
  text-align: center;
}

.recruit_iframe iframe {
  width: 640px;
  height: 480px;
}

@media only screen and (max-width: 640px) {
  .recruit_iframe iframe {
    width: 100%;
    height: 350px;
  }
}

.recruit p.txt1 {
  font-weight: bold;
  text-align: center;
  font-size: 3.4rem;
  line-height: 1.7;
  margin-bottom: 1em;
  letter-spacing: 3px;
}

.recruit p.txt2 {
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.7;
  margin-bottom: 2em;
  letter-spacing: 3px;
}

.recruit p.txt22 {
  text-align: left;
  font-size: 1.5rem;
  line-height: 1.7;
  margin-bottom: 2em;
  letter-spacing: 3px;
}

.recruit_btn {
  width: 100%;
  margin-top: 50px;
  margin-bottom: 50px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  display: flex;
  justify-content: center;
}

.recruit_btn_class1 img {
  width: 250px;
  margin: 5px;
}

@media only screen and (max-width:800px) {
  .recruit_btn {
    display: block;
  }

  .recruit_btn_class1 a {
    margin: 0 auto;
    margin-bottom: 15px;
  }

  .recruit_btn_class2 a {
    margin: 0 auto;
    margin-bottom: 15px;
  }

  .recruit_btn_class3 a {
    margin: 0 auto;
    margin-bottom: 15px;
  }
}

.img_link {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}

.img_link a {
  display: inline-block;
  margin-bottom: 10px;
}

.img_link100 {
  text-align: center;
  margin-top: 80px;
  margin-bottom: 80px;
  justify-content: center;
  flex-wrap: wrap;
}

.img_link100 img {
  margin-bottom: 20px;
}

@media only screen and (max-width: 495px) {
  .img_link100 {
    width: 100%;
  }
}

.img_link101 {
  text-align: center;
  justify-content: center;
  flex-wrap: wrap;
}

.img_link101 img {
  margin-bottom: 20px;
}

@media only screen and (max-width: 495px) {
  .img_link101 {
    width: 100%;
  }
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  body#recruit section.bg {
    padding: 0px 10px;
    height: 100vh;
    background: url("images/rec_sec_bg.png") no-repeat center center / cover;
    overflow: scroll;
    -ms-overflow-style: none;
    /* IE, Edge 対応 */
    scrollbar-width: none;
    /* Firefox 対応 */
  }

  body#recruit section.bg::-webkit-scrollbar {
    /* Chrome, Safari 対応 */
    display: none;
  }

  .img_link a {
    width: 49.5%;
  }
}

.other {
  background: rgba(0, 0, 0, 0.05);
}

.recruit_txtbox {
  width: 666px;
  margin: 0 auto;
}

.txt10 {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 3px;
  margin-bottom: 2rem;
  text-align: left;
}

.txt11 {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 3px;
  margin-bottom: 80px;
  text-align: left;
}

.txt11_re {
  font-size: 1.6rem;
  font-weight: bold;
  color: grey;
  line-height: 1.7;
  letter-spacing: 3px;
  margin-bottom: 80px;
  text-align: left;
}

.txt12 {
  font-size: 1.7rem;
  font-weight: bold;
  line-height: 1.7;
  letter-spacing: 3px;
  margin-bottom: 2rem;
  text-align: left;
}

@media only screen and (max-width: 666px) {
  .recruit_txtbox {
    width: 95%;
  }
}

.strong01 {
  text-indent: -0.8em;
  padding-left: 0.8em;
}

.strong02 {
  text-indent: -0.8em;
  padding-left: 0.8em;
}

.strong_recruit01 {
  font-weight: bold;
  color: #2778bd;
}

.strong_recruit02 {
  font-weight: bold;
  color: #f4789a;
}

.strong_recruit03 {
  font-weight: bold;
  color: #47a590;
}

/*----------------------
interview
------------------------*/
.interview {
  font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
}

.interview_box01 {
  text-align: left;
  line-height: 1.8;
  margin-bottom: 5em;
}

.interview_box01 h3 {
  font-size: 3.1rem;
  margin-bottom: .8em;
}

.interview_box02 {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  margin-bottom: 5em;
}

.interview_box02 .color {
  padding: 10px;
}

.interview_box02 dl {
  text-align: left;
  line-height: 1.8;
  padding: 10px;
}

.interview_box02 dl dt {
  letter-spacing: 5px;
  font-size: 2.2rem;
  font-weight: bold;
  margin-bottom: .5em;
}

.interview_box02 dl dd {
  font-size: 1.4rem;
  letter-spacing: 2px;
}

.interview_img01 {
  margin-bottom: 5em;
}

.interview_box03 {
  margin-bottom: 5em;
}

.interview_box03 h3 {
  font-size: 3.1rem;
  margin-bottom: .8em;
}

.interview_box04 {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -ms-flex-wrap: wrap;
  /*--- IE10用 ---*/
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  /*--- Androidブラウザ用 ---*/
  -ms-flex-pack: justify;
  /*--- IE10 ---*/
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
}

.interview_box04 .img {
  padding: 0px 15px;
  width: 40%;
}

.interview_box04 .txt {
  padding: 0px 15px;
  text-align: left;
  line-height: 1.8;
  width: 60%;
}

.interview_box04 .txt h3 {
  font-weight: bold;
  font-size: 1.9rem;
  letter-spacing: 5px;
  margin-bottom: .8em;
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {

  .interview_box04 .img,
  .interview_box04 .txt {
    width: 100%;
    margin-bottom: 20px;
  }
}



.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 40px 0;
  position: relative;
  font-size: 13px;
}

.pagination span,
.pagination a {
  display: block;
  width: auto;
  margin: 4px;
  padding: 8px;
  border: 1px solid #008984;
  background-color: #fff;
  text-decoration: none;
  text-align: center;
  line-height: 16px;
}

/* ページ番号 */
.pagination .pager {
  width: 32px;
}

/* ホバー時 & 現在のページ */
.pagination a:hover,
.pagination .current {
  color: #fff;
  border-color: #008984;
  background-color: #008984;
}

/* 前へ */
.pagination a.prev {
  margin-right: 16px;
}

/* 次へ */
.pagination a.next {
  margin-left: 16px;
}

/* 最初へ */
.pagination a.first {}

/* 最後へ */
.pagination a.last {}

/* Page x / y */
.pagination span.page_num {
  display: none;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 40px 0;
  position: relative;
  font-size: 13px;
}

.pagination span,
.pagination a {
  display: block;
  width: auto;
  margin: 4px;
  padding: 8px;
  border: 1px solid #8097cd;
  background-color: #fff;
  text-decoration: none;
  text-align: center;
  line-height: 16px;
}

/* ページ番号 */
.pagination .pager {
  width: 32px;
}

/* ホバー時 & 現在のページ */
.pagination a:hover,
.pagination .current {
  color: #fff;
  border-color: #8097cd;
  background-color: #8097cd;
}

/* 前へ */
.pagination a.prev {
  margin-right: 16px;
}

/* 次へ */
.pagination a.next {
  margin-left: 16px;
}

/* 最初へ */
.pagination a.first {}

/* 最後へ */
.pagination a.last {}

/* Page x / y */
.pagination span.page_num {
  display: none;
}





/* ----------------------- saboxplugin-wrap */
.saboxplugin-wrap {
  margin-top: 2em !important;
  text-align: left;
}






/*----------------------
追加分　company
------------------------*/
/*編集*/
.title05 {
  margin-bottom: .4em;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 170px;
  color: #ffffff;
  line-height: 125px;
  position: relative;
  text-align: center;
  letter-spacing: 6px;
}

.title05 span {
  width: 100%;
  position: absolute;
  top: 0;
  height: 125px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 3.4rem;
  color: #333;
  font-weight: bold;
}

/* 画面サイズが1000px以下の場合に適用 */
@media only screen and (max-width: 1000px) {
  .title05 {
    font-size: 100px;
    margin-bottom: .8em;
  }

  .title05 span {
    font-size: 1.8rem;
    height: auto;
    margin-top: 10px;
    letter-spacing: 3px;
  }
}

/* 画面サイズが640px以下の場合に適用 */
@media only screen and (max-width: 640px) {
  .title05 {
    font-size: 50px;
    position: inherit;
    line-height: 1;
  }

  .title05 span {
    position: inherit;
    line-height: 1;
  }
}

/*編集ここまで*/
@media screen and (min-width: 950px) {
  .pc {
    display: block;
  }

  .sp {
    display: none;
  }

  .company_contents1_txt2 {
    display: block;
  }

  .company_contents1_txt2_sp {
    display: none;
  }
}

@media screen and (max-width: 950px) {
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  .company_contents1_txt2 {
    display: none;
  }

  .company_contents1_txt2_sp {
    display: block;
  }
}

.company_top {
  margin-top: 150px;
  text-align: center;
}

.company_top_img img {
  width: 186px;
}

.company_top_txt {
  text-align: center;
  margin-top: 80px;
  margin-bottom: 200px;
  font-size: 2rem;
  letter-spacing: 0.2em;
  line-height: 40px;
}

@media screen and (max-width: 530px) {
  .company_top_txt {
    margin-top: 50px;
    margin-bottom: 100px;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 35px;
  }
}

.company_contents1 {
  background: url("images/company_bg.jpg")repeat top center /cover;
}

.company_contents1_ttl1 {
  padding-top: 150px;
}

.company_contents1_ttl2 {
  margin-top: 200px;
}

.company_contents1_ttl2 p {
  font-size: 22px;
  font-weight: 900;
  text-align: center;
  letter-spacing: 0.1em;
  color: #666666;
}

.company_contents1_ttl2 p span {
  font-size: 38px;
  font-weight: 900;
  margin-left: 7px;
  color: #666666;
}

.company_contents1_ttl3 {
  margin-top: 50px;
  color: #2778bd;
}

.company_contents1_ttl3 p {
  width: 290px;
  margin: 0 auto;
  text-align: center;
  font-size: 48px;
  font-weight: 600;
  letter-spacing: 0.2em;
  border-bottom: solid 2px #2778bd;
}

@media screen and (max-width: 530px) {
  .company_contents1_ttl3 p {
    width: 210px;
    margin: 0 auto;
    text-align: center;
    font-size: 36px;
    font-weight: 600;
    letter-spacing: 0.2em;
    border-bottom: solid 2px #2778bd;
  }
}

.company_contents1_txt1 {
  text-align: center;
  margin-top: 50px;
  margin-bottom: 80px;
  font-size: 2rem;
  letter-spacing: 0.1em;
  line-height: 40px;
}

.company_contents1_imgs {
  margin: 0 auto;
  margin-top: 50px;
  display: flex;
  justify-content: center;
}

.company_contents1_imgs img {
  width: 471px;
  margin: 4px;
}

@media screen and (max-width: 950px) {
  .company_contents1_imgs {
    display: block;
    text-align: center;
  }
}

.company_contents1_txt2 {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
}

.company_contents1_txt2 p {
  display: inline-block;
  text-align: left;
  letter-spacing: 0.2em;
  line-height: 25px;
}

.company_contents1_txt2_sp {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
}

.company_contents1_txt2_sp p {
  display: inline-block;
  text-align: left;
  letter-spacing: 0.2em;
  line-height: 25px;
}

@media screen and (max-width: 471px) {
  .company_contents1_imgs img {
    width: 95%;
  }

  .company_contents1_txt2_sp p {
    letter-spacing: 0.1em;
    font-size: 14px;
  }
}

.company_contents2 {
  margin-top: 200px;
}

.company_contents2_ttl3 {
  margin-top: 50px;
  color: #2778bd;
}

.company_contents2_ttl3 p {
  width: 330px;
  margin: 0 auto;
  text-align: center;
  font-size: 48px;
  font-weight: 600;
  letter-spacing: 0.2em;
  border-bottom: solid 2px #2778bd;
}

@media screen and (max-width: 530px) {
  .company_contents2_ttl3 p {
    width: 240px;
    font-size: 36px;
  }
}

.company_contents2_cont1 {
  width: 950px;
  text-align: center;
  margin: 0 auto;
  margin-top: 80px;
  background-color: #fff;
  padding-right: 50px;
  padding-left: 50px;
  padding-bottom: 80px;
}

.company_contents2_cont1_ttl p {
  display: inline-block;
  font-size: 28px;
  color: #fff;
  background-color: #666;
  padding: 10px;
  margin-top: -50px;
  letter-spacing: 0.1em;
}

.company_contents2_cont2_1 p {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  color: #2778bd;
  letter-spacing: 0.2em;
  margin-top: 80px;
}

.company_contents2_cont2_1 img {
  width: 450px;
  margin-top: 50px;
  text-align: center;
}

.company_contents2_cont2_2 {
  margin-top: 80px;
}

.company_contents2_cont2_2 p {
  font-size: 28px;
  font-weight: bold;
  color: #2778bd;
  letter-spacing: 0.2em;
  text-align: left;
}

.company_contents2_cont2_3 {
  margin-top: 20px;
}

.company_contents2_cont2_3 p {
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-align: left;
  border-bottom: solid 1px #000;
  padding-bottom: 8px;
}

.company_contents2_cont2_3 span {
  margin-right: 15px;
}

.company_contents2_cont2_3 img {
  width: 50px;
}

.company_contents2_cont2_4 {
  margin-top: 30px;
}

.company_contents2_cont2_4 p {
  text-align: left;
  font-size: 2rem;
  letter-spacing: 0.2em;
  line-height: 30px;
}

.span_pink {
  color: #e3007f;
  font-weight: bold;
}

.span_orange {
  color: #EF8200;
  font-weight: bold;
}

.span_blue {
  color: #0098D8;
  font-weight: bold;
}

.span_green {
  color: #55C882;
  font-weight: bold;
}

@media screen and (max-width: 950px) {
  .company_contents2_cont1 {
    width: 95%;
    padding-right: 30px;
    padding-left: 30px;
  }

  .company_contents2_cont1_ttl p {
    font-size: 22px;
    background-color: #666;
    padding: 8px;
  }

  .company_contents2_cont2_1 p {
    font-size: 22px;
  }

  .company_contents2_cont2_2 p {
    font-size: 24px;
  }

  .company_contents2_cont2_3 p {
    font-size: 18px;
  }

  .company_contents2_cont2_4 p {
    font-size: 18px;
  }
}

@media screen and (max-width: 740px) {
  .company_contents2_cont2_3 p {
    display: flex;
    line-height: 25px;
  }

  .company_contents2_cont2_3 img {
    width: 35px;
  }
}

@media screen and (max-width: 540px) {
  .company_contents2_cont2_1 img {
    width: 300px;
  }
}

.company_contents3_ttl3 {
  margin-top: 50px;
  color: #2778bd;
}

.company_contents3_ttl3 p {
  width: 300px;
  margin: 0 auto;
  text-align: center;
  font-size: 48px;
  font-weight: 600;
  letter-spacing: 0.2em;
  border-bottom: solid 2px #2778bd;
}

@media screen and (max-width: 530px) {
  .company_contents3_ttl3 p {
    width: 220px;
    font-size: 36px;
  }
}

.company_contents3_img {
  margin-top: 80px;
  text-align: center;
}

.company_contents3_img img {
  width: 420px;
}

@media screen and (max-width: 420px) {
  .company_contents3_img img {
    width: 95%;
  }
}

.company_contents3_txt {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
  margin-bottom: 150px;
}

.company_contents3_txt p {
  display: inline-block;
  letter-spacing: 0.2em;
  line-height: 25px;
}

.company_contents4 {
  margin-top: 200px;
  margin-bottom: 200px;
}

.parenthesis {
  position: relative;
  margin: 0 auto;
  margin-top: 150px;
  width: 950px;
  padding: 15px 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.parenthesis::before,
.parenthesis::after {
  position: absolute;
  top: 0;
  content: '';
  width: 20px;
  height: 100%;
  border-top: 3px solid #2778bd;
  border-bottom: 3px solid #2778bd;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.parenthesis::before {
  left: 0;
  border-left: 3px solid #2778bd;
}

.parenthesis::after {
  right: 0;
  border-right: 3px solid #2778bd;
}

.parenthesis_txt1 {
  text-align: center;
  font-size: 30px;
  color: #2778bd;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.parenthesis_txt2 {
  text-align: center;
  font-size: 22px;
  margin-top: 20px;
  color: #2778bd;
  letter-spacing: 0.2em;
}

@media screen and (max-width: 950px) {
  .parenthesis {
    margin-top: 100px;
    width: 95%;
  }

  .parenthesis_txt1 {
    font-size: 24px;
    line-height: 35px;
  }

  .parenthesis_txt2 {
    font-size: 18px;
    line-height: 28px;
  }
}

@media screen and (max-width: 480px) {
  .parenthesis {
    margin-top: 50px;
  }

  .parenthesis_txt1 {
    font-size: 22px;
    line-height: 35px;
  }

  .parenthesis_txt2 {
    font-size: 16px;
    line-height: 28px;
  }
}

.company_contents4_cont1 {
  width: 950px;
  display: flex;
  margin: 0 auto;
  margin-top: 120px;
}

.ccc_t1 {
  width: 200px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.ccc_t2 {
  width: 230px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.company_contents4_cont1_txt2 p {
  margin-top: 45px;
  font-size: 18px;
  letter-spacing: 0.2em;
  line-height: 30px;
}

.company_contents4_cont1_img img {
  width: 317px;
  margin-left: 30px;
}

.ccc_t3 {
  width: 155px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.ccc_t4 {
  width: 250px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.ccc_t5 {
  width: 230px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.ccc_t6 {
  width: 300px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

.ccc_t7 {
  width: 330px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 45px;
  border-bottom: solid 1px #000;
}

@media screen and (max-width: 950px) {
  .company_contents4_cont1 {
    width: 95%;
    display: block;
    text-align: center;
  }

  .ccc_t1 {
    margin: 0 auto;
  }

  .ccc_t2 {
    margin: 0 auto;
  }

  .company_contents4_cont1_img img {
    margin-top: 80px;
    margin-left: auto;
  }

  .ccc_t3 {
    margin: 0 auto;
  }

  .ccc_t4 {
    margin: 0 auto;
  }

  .ccc_t5 {
    margin: 0 auto;
  }

  .ccc_t6 {
    margin: 0 auto;
  }

  .ccc_t7 {
    margin: 0 auto;
  }
}

/* 画面サイズが420px以下の場合に適用 */
@media only screen and (max-width: 420px) {

  .ccc_t1,
  .ccc_t2,
  .ccc_t3,
  .ccc_t4,
  .ccc_t5,
  .ccc_t6,
  .ccc_t7 {
    font-size: 24px;
    min-width: 155px;
    width: auto;
    display: inline-block;
  }
}

/* 中途採用コンタクトフォーム */
/*Contact Form 7カスタマイズ*/
/*スマホContact Form 7カスタマイズ*/
.contact_a {
  width: 960px;
  margin: 0 auto;
  margin-top: 100px;
}

.contact_ttl {
  font-size: 32px;
}

.contact_txt {
  border: 1px solid #2678bd;
  padding: 20px;
  margin-top: 20px;
}

.contact_txt p {
  font-size: 16px;
  letter-spacing: 3px;
  line-height: 1.3;
}

.contact_span {
  font-weight: bold;
  color: #2678bd;
}

.inquiry {
  width: 960px;
  margin: 0 auto;
  margin-top: 80px;
  margin-bottom: 50px;
}

.inquiry input {
  margin: 5px;
  padding: 15px;
  font-size: 14px;
}

.inquiry textarea {
  margin: 5px;
  padding: 15px;
  font-size: 14px;
  width: 99%;
}

/*見出し欄*/
.inquiry th {
  text-align: left;
  font-size: 14px;
  color: #444;
  padding: 25px;
  width: 30%;
  background: #f7f7f7;
  border: solid 1px #d7d7d7;
  vertical-align: middle;
  line-height: 1.8;
}

/*通常欄*/
.inquiry td {
  font-size: 14px;
  border: solid 1px #d7d7d7;
  padding: 10px;
}

.inquiry td label {
  text-align: center;
  vertical-align: middle;
}

/*
  .inquiry td label input{
    width:10% !important;
    }
  */
/*横の行とテーブル全体*/
.entry-content .inquiry tr,
.entry-content table {
  border: solid 1px #d7d7d7;
}

table.table_C {
  margin: 0 0 30px 0;
  border: solid 1px #000;
  border-collapse: collapse;
  width: 100%;
}

table.table_C tr th {
  border: solid 1px #000;
  background-color: #f5ffff;
  padding: 5px;
}

table.table_C tr th.t_head {
  width: 100px;
  padding: 15px;
}

table.table_C tr td {
  border: solid 1px #000;
  padding: 15px;
  text-align: left;
  letter-spacing: 0.1em;
  line-height: 1.6;
}

/*必須の調整*/
.haveto {
  font-size: 12px;
  padding: 5px;
  background: #ff9393;
  color: #fff;
  border-radius: 2px;
  margin-right: 8px;
  position: relative;
  bottom: 1px;
}

/*任意の調整*/
.any {
  font-size: 12px;
  padding: 5px;
  background: #93c9ff;
  color: #fff;
  border-radius: 2px;
  margin-right: 8px;
  position: relative;
  bottom: 1px;
}

/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
  display: block;
}

/*送信ボタンのデザイン変更*/
#formbtn {
  display: block;
  padding: 1em 0;
  margin: 0 auto;
  margin-top: 50px;
  margin-bottom: 50px;
  width: 300px;
  background: #2678bd;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  border-radius: 2px;
  border: none;
}

/*送信ボタンマウスホバー時*/
#formbtn:hover {
  background: #fff;
  color: #2678bd;
}

.spam_txt {
  text-align: center;
  line-height: 1.5;
  width: 100%;
}

@media(max-width:960px) {
  .inquiry {
    width: 95%;
  }

  .contact_a {
    width: 95%;
  }
}

@media(max-width:650px) {

  .inquiry th,
  .inquiry td {
    display: block !important;
    width: 100% !important;
    border-top: none !important;
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
  }

  .inquiry tr:first-child th {
    border-top: 1px solid #d7d7d7 !important;
  }

  /* 必須・任意のサイズ調整 */
  .inquiry .haveto,
  .inquiry .any {
    font-size: 10px;
  }

  .inquiry input {
    width: 95%;
  }
}

/* 中途採用コンタクトフォームここまで */

/* サンクスページ */
.thanks_page {
  width: 100%;
  margin: 0 auto;
  margin-top: 80px;
}

.thanks_page_logo {
  text-align: center;
}

.thanks_page_logo img {
  width: 300px;
}

.thanks_page_txt1 {
  text-align: center;
  font-size: 18px;
  color: #797c80;
  letter-spacing: 2px;
  line-height: 1.6;
  margin-top: 30px;
}

.thanks_page_txt2 {
  text-align: center;
  font-size: 16px;
  color: #797c80;
  letter-spacing: 2px;
  line-height: 1.7;
  margin-top: 20px;
}

/* サイトマップ */
.sitemap {
  width: 100%;
  margin: 0 auto;
  margin-top: 80px;
}

.sitemap_ttl {
  width: 180px;
  margin: 0 auto;
  text-align: center;
  font-size: 28px;
  border-bottom: 1px solid #000;
}

.sitemap_menu {
  margin: 0 auto;
  margin-top: 50px;
  background-color: #eee;
  text-align: center;
  padding: 30px;
  width: 650px;
}

.sitemap_menu ul {
  margin: 0 auto;
  padding: 80px;
  list-style-type: none;
  background-color: #fff;
}

.sitemap_menu li a {
  display: block;
  padding: 20px;
  text-decoration: none;
  color: #000000;
}

.sitemap_menu li {
  padding: 5px;
  text-align: center;
  border-bottom: 1px solid #000;
}

.sitemap_menu li:last-child {
  border-bottom: none;
}

.sitemap_menu li a.active {
  color: #ffffff;
  background-color: #da3c41;
}

.sitemap_menu li a:hover:not(.active) {
  color: #ffffff;
  background-color: #4d4d4d;
}

.sitemap_menu2 {
  margin: 0 auto;
  background-color: #eee;
  text-align: center;
  padding: 30px;
  width: 650px;
}

.sitemap_menu2 ul {
  margin: 0 auto;
  padding: 80px;
  list-style-type: none;
  background-color: #fff;
}

.sitemap_menu2 li a {
  display: block;
  padding: 20px;
  text-decoration: none;
  color: #000000;
}

.sitemap_menu2 li {
  padding: 5px;
  text-align: center;
  border-bottom: 1px solid #000;
}

.sitemap_menu2 li:last-child {
  border-bottom: none;
}

.sitemap_menu2 li a.active {
  color: #ffffff;
  background-color: #da3c41;
}

.sitemap_menu2 li a:hover:not(.active) {
  color: #ffffff;
  background-color: #4d4d4d;
}

.sitemap_menu3 {
  margin: 0 auto;
  margin-bottom: 80px;
  background-color: #eee;
  text-align: center;
  padding: 30px;
  width: 650px;
}

.sitemap_menu3 ul {
  margin: 0 auto;
  padding: 0;
  list-style-type: none;
  background-color: #fff;
}

.sitemap_menu3 li a {
  display: block;
  padding: 20px;
  text-decoration: none;
  color: #000000;
}

.sitemap_menu3 li {
  padding: 5px;
  text-align: center;
  border-bottom: 1px solid #000;
}

.sitemap_menu3 li:last-child {
  border-bottom: none;
}

.sitemap_menu3 li a.active {
  color: #ffffff;
  background-color: #da3c41;
}

.sitemap_menu3 li a:hover:not(.active) {
  color: #ffffff;
  background-color: #4d4d4d;
}

@media(max-width:650px) {
  .sitemap_menu3 {
    width: 95%;
  }

  .sitemap_menu3 ul {
    padding: 50px;
  }
}

@media(max-width:650px) {
  .sitemap_menu2 {
    width: 95%;
  }

  .sitemap_menu2 ul {
    padding: 50px;
  }
}

@media(max-width:650px) {
  .sitemap_menu {
    width: 95%;
  }

  .sitemap_menu ul {
    padding: 50px;
  }
}

.saitemap_bold {
  font-weight: bold;
}

.bb {
  border: solid 2px #000;
  padding: 30px;
  margin-bottom: 30px;
}

.bc1 {
  color: #2778bd;
}

.bc2 {
  color: #2778bd;
  font-size: 1.3rem
}

.span_green_back {
  background-color: #b6dc90;
  padding: 3px;
}

@media screen and (min-width: 680px) {
  .banner_pc {
    display: block;
  }

  .banner_sp {
    display: none;
  }
}

@media screen and (max-width: 680px) {
  .banner_pc {
    display: none;
  }

  .banner_sp {
    display: block;
  }
}

#mm_banner {
  position: fixed;
  right: 10px;
  bottom: 20px;
  z-index: 100;
}

#mm_banner img {
  width: 200px;
}

@media screen and (max-width:680px) {
  #mm_banner img {
    width: 165px;
  }
}

#kiji_unno06_1 {
  display: block;
  padding-top: 40px;
  margin-top: -40px;
}

#kiji_unno06_2 {
  display: block;
  padding-top: 40px;
  margin-top: -40px;
}

#kiji_unno06_3 {
  display: block;
  padding-top: 40px;
  margin-top: -40px;
}

#kiji_unno06_4 {
  display: block;
  padding-top: 40px;
  margin-top: -40px;
}

#kiji_unno06_5 {
  display: block;
  padding-top: 40px;
  margin-top: -40px;
}

@media screen and (max-width:480px) {
  #kiji_unno06_1 {
    display: block;
    padding-top: 90px;
    margin-top: -90px;
  }

  #kiji_unno06_2 {
    display: block;
    padding-top: 90px;
    margin-top: -90px;
  }

  #kiji_unno06_3 {
    display: block;
    padding-top: 90px;
    margin-top: -90px;
  }

  #kiji_unno06_4 {
    display: block;
    padding-top: 90px;
    margin-top: -90px;
  }

  #kiji_unno06_5 {
    display: block;
    padding-top: 90px;
    margin-top: -90px;
  }
}

.shadow_box {
  padding: 1.5em 1.5em;
  margin: 2em 0;
  color: #5d627b;
  background: white;
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}


/*240319 追加*/
.mokuji001 {
        margin-bottom: 50px;
        border: 2px solid #2589d0;
        border-radius: 3px;
        font-size: 1.6rem;
        line-height: 1.8;
        padding-bottom: 10px;
}

.mokuji001 div {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 10px 0;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 1.1em;
}

.mokuji001 div::before {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 5px;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M3.8%2017.2h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.8-.8-.8zm0-15h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8V3c-.1-.4-.4-.8-.8-.8zm0%207.6h-3c-.5%200-.8.3-.8.7v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.7-.8-.7zM23.2%2018h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8zm0-15h-15c-.4%200-.7.3-.7.8v1.5c0%20.4.3.7.7.7h15c.5%200%20.8-.3.8-.8V3.8c0-.5-.3-.8-.8-.8zm0%207.5h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8z%22%2F%3E%3C%2Fsvg%3E');
    content: '';
}

.mokuji001 ol {
    list-style-type: decimal;
    margin: 0;
    overflow: hidden;
}

.mokuji001 > ol {
    padding: 1em 1em 1em 3em;
}

.mokuji001 ol ol {
    margin-top: 5px;
    padding-left: 1.1em;
}

.mokuji001 li {
    padding: 5px 0;
    font-weight: bold;
text-align:left;
color:#2589d0;
}

.mokuji001 ol ol li {
    font-weight: 500;
    font-size: .9em;
}

.mokuji001 a {
    color: #333;
    text-decoration: none;
font-weight:bold;
}

.mokuji001 p {
    padding-left: 15px;
}
.mokuji001 p:hover {
    opacity: 0.7;
}
.mokuji001 li {
    padding-left: 15px!important;
}
.mokuji001 li:hover {
    opacity: 0.7;
}
.mokuji001 span{
    margin: 0 10px 0px 15px;
    font-weight:bold;
}

.kouhen{
text-align:left !important;
padding-top: 10px;
}

@media screen and (max-width:480px) {
  .mokuji001{  font-size: 1.4rem!important;}

  .mokuji001 li {
    padding:5px 10px 0px 15px !important
  }
}

.side_banner{
  margin-bottom: 15px;
}

/*レコメンド　PC*/
.r-txt{
  display: flex;
  align-items: center;
  justify-content: center;
  height: 105px;
  color: #007cba;
  text-decoration: none;
  padding: 10px;
  margin: 15px;
  border: solid 1px #007cba;
  line-height: 1.3;
font-weight: 600;}

  /*レコメンド　SP*/
  @media screen and (max-width:480px) {
  .r-txt{
  height: 100px;
  color: #007cba;
  padding: 10px;
  margin: 15px 23%;
  border: none; 
  text-align: center;
  background: #fff;
  }
}

/*241011 追記*/
.recommend_box li{
    display: flex!important;
    align-items: center !important;
	padding: 15px 0px!important;
}
.recommend_box img{
  width: 320px !important;
    margin-right: 30px!important;
}
.recommend_box a{
	color: #000!important;
    line-height: 1.6!important;
    font-weight: bold;
    font-size: 1.7rem!important;
}
  @media screen and (max-width:480px) {
    .recommend_box li{
      display: block!important;
      max-width: 320px!important;
      margin-left: auto!important;
      margin-right: auto!important;
    }
    .recommend_box img{
      width: 100%!important;
      margin-left: 0px!important;
      margin-bottom: 15px!important;
  }
  .recommend_box a{
    font-size: 1.5rem!important;
}

}

.recommend_subtxt{
  font-weight: bold;
  font-size: 16px;
  padding: 5px;
  border-bottom: 2px solid #007cba;
  margin-bottom: 15px;
  text-align: left;
  margin: 0px 15px;
}
.recommend_subbox li{
  margin: 20px 10px 10px!important;
  text-align: left!important;
}
.recommend_subbox img{
  margin-bottom: 10px!important;
  width: 95%!important;
  margin-left: 5px !important;
}

.recommend_subbox a{
  color: #000!important;
  font-size: 1.5rem!important;
  line-height: 1.6!important;
}

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

  .recommend_subbox img{
    width: 100%!important;
    margin-left: 0px !important;
  }
  .recommend_subbox li {
    margin: 20px 25px 10px !important;
}
  
}
@media screen and (max-width:480px) {
.mt60{
  margin-top: 60px!important;
}
}

.kiji-n_desc {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.57;
  letter-spacing: 0.1em;
  text-align: left;
  word-break: break-word;
}

.kiji-n_desc strong {
  font-weight: 700;
}

.kiji-n_container {
  text-align: left;
}

.kiji-n_author {
  margin-bottom: 65px;
  padding: 20px 30px;
  background-color: #f8fdff;
  border: 1px solid #2778bd;
}

@media screen and (max-width: 767px) {
  .kiji-n_author {
    padding: 20px;
  }
}

.kiji-n_author span {
  display: block;
  margin-bottom: 15px;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .kiji-n_author span {
    font-size: 14px;
  }
}

.kiji-n_author p {
  font-size: 1.6rem;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.8em;
  letter-spacing: 0.1em;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .kiji-n_author p {
    font-size: 14px;
  }
}

.kiji-n_author-img {
  position: relative;
  min-width: 150px;
  width: 150px;
  height: 150px;
  aspect-ratio: 1;
  margin: 0 auto 20px;
  border-radius: 50%;
  overflow: hidden;
}

.kiji-n_author-img img {
  position: absolute;
  width: 100%;
  height: 100% !important;
  top: 0;
  left: 0;
  object-fit: cover;
}

.kiji-n_ttl-1 {
  margin-bottom: 40px;
  font-size: 2.5rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.69em;
}

.kiji-n_ttl-2 {
  margin-bottom: 40px;
  font-size: 20px;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  line-height: 1.6;
  color: #2778bd;
  display: flex;
  gap: 11px;
  word-break: break-word;
}

@media screen and (max-width: 767px) {
  .kiji-n_ttl-2 {
    margin-bottom: 20px;
  }
}

.kiji-n_ttl-2 span {
  position: relative;
  display: block;
  height: fit-content;
  padding-left: 20px;
  font-size: 20px;
  font-weight: 700;
  border-left: 3px solid #2778bd;
  word-break: keep-all;
}

.kiji-n_ttl-3 {
  margin-bottom: 40px;
  padding-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.6em;
  letter-spacing: 0.1em;
  border-bottom: 1px solid #2778bd;
  display: flex;
  word-break: break-word;
}

.kiji-n_ttl-3.s2 {
  padding-left: 35px;
}

@media screen and (max-width: 767px) {
  .kiji-n_ttl-3.s2 {
    padding-bottom: 20px;
  }
}

.kiji-n_ttl-3 span {
  padding-right: 10px;
  word-break: keep-all;
}

.kiji-n_ttl-4 {
  width: 100%;
  margin-bottom: 30px;
  padding: 10px 20px;
  font-size: 18px;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.6em;
  letter-spacing: 0.1em;
  background-color: #f6f6f6;
}

.kiji-n_sbtx-hl {
  margin-bottom: 80px;
  font-size: 16px;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.8em;
  letter-spacing: 0.1em;
}

.kiji-n_sbtx-hl strong {
  font-weight: 700;
  line-height: 1.57em;
}

.kiji-n_sbtx-hl img {
  display: block;
  margin: 0 !important;
}

.kiji-n_sbtx-hl img.alignright {
  margin: 0 0 0 auto !important;
}

.kiji-n_sbtx-hl img.aligncenter {
  margin: 0 auto !important;
}

.kiji-n_sbtx-bd {
  margin-bottom: 80px;
  padding: 20px;
  font-size: 1.6rem;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.57em;
  letter-spacing: 0.1em;
  border: 1px solid #ccc;
}

.kiji-n_sbtx-bd strong {
  font-weight: 700;
}

.kiji-n_convo {
  margin-bottom: 80px;
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.kiji-n_convo-mg {
  display: flex;
  gap: 23px;
}

.kiji-n_convo-mg:nth-child(even) {
  flex-direction: row-reverse;
}

.kiji-n_convo-mg:nth-child(even) .kiji-n_convo-msg::before {
  left: unset;
  right: -30px;
  transform: scaleX(-1);
}

.kiji-n_convo-imgtxt {
  width: 60px;
  min-width: 60px;
}

.kiji-n_convo-imgtxt span {
  display: block;
  margin-top: 11px;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  text-align: center;
}

.kiji-n_convo-img {
  position: relative;
  width: 100%;
  height: 60px;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
}

.kiji-n_convo-img img {
  position: absolute;
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  left: 0;
  top: 0;
}

.kiji-n_convo-msg {
  position: relative;
  padding: 20px;
  width: calc(100% - 60px);
  font-size: 1.6rem;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.57em;
  letter-spacing: 0.1em;
  border-radius: 5px;
  background-color: #f2f1f0;
}

.kiji-n_convo-msg:before {
  content: '';
  position: absolute;
  border-width: 12px 15px;
  border-color: transparent #f2f1f0 transparent transparent;
  border-style: solid;
  top: 20px;
  left: -30px;
}

.kiji-n_convo-msg.id2 {
  background-color: #e6f1f4;
}

.kiji-n_convo-msg.id2:before {
  border-color: transparent #e6f1f4 transparent transparent;
}

.kiji-n_convo-msg.id3 {
  background-color: #e9eef4;
}

.kiji-n_convo-msg.id3:before {
  border-color: transparent #e9eef4 transparent transparent;
}

.kiji-n_convo-msg.id4 {
  background-color: #e2f2e8;
}

.kiji-n_convo-msg.id4:before {
  border-color: transparent #e2f2e8 transparent transparent;
}

.kiji-n_btn {
  position: relative;
  width: 100%;
  max-width: 450px;
  margin: 0 auto 100px;
  padding: 20px;
  color: #fff;
  background-color: #feb200;
  border: 1.5px solid #feb200;
  border-radius: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  transition: 0.3s ease;
}

@media screen and (max-width: 767px) {
  .kiji-n_btn {
    padding: 10px;
    border-radius: 24px;
  }
}

.kiji-n_btn:after {
  content: '';
  position: absolute;
  width: 9.5px;
  height: 19px;
  background: url('./images/acp/kiji-carret-white.svg') center / contain no-repeat;
  right: 31px;
  top: 50%;
  transform: translateY(-50%) scale(1.1);
  transition: 0.3s ease;
}

@media screen and (max-width: 767px) {
  .kiji-n_btn:after {
    width: 8.8px;
    height: 11px;
    right: 20px;
  }
}

.kiji-n_btn:hover {
  color: #feb200;
  background-color: #fff;
}

.kiji-n_btn:hover img {
  filter: brightness(0) saturate(100%) invert(58%) sepia(92%) saturate(828%) hue-rotate(1deg) brightness(95%) contrast(105%);
}

.kiji-n_btn:hover:after {
  filter: brightness(0) saturate(100%) invert(58%) sepia(92%) saturate(828%) hue-rotate(1deg) brightness(95%) contrast(105%);
}

.kiji-n_btn img {
  width: 20.6px;
  height: 26.9px;
  margin: 0 !important;
  transition: 0.3s ease;
}

.kiji-n_btn span {
  font-size: 2rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 767px) {
  .kiji-n_btn span {
    font-size: 16px;
  }
}

.kiji-n_download {
  width: 100%;
  margin-bottom: 80px;
  padding: 30px;
  border: 2px solid #2e89d4;
  display: flex;
  align-items: center;
  gap: 20px;
}

@media screen and (max-width: 767px) {
  .kiji-n_download {
    flex-direction: column-reverse;
  }
}

.kiji-n_dl-ls {
  width: calc(100% - 220px);
}

@media screen and (max-width: 767px) {
  .kiji-n_dl-ls {
    width: 100%;
  }
}

.kiji-n_dl-ttl {
  display: block;
  margin-bottom: 20px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  line-height: 1.73em;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 767px) {
  .kiji-n_dl-ttl {
    font-size: 18px;
    text-align: center;
  }
}

.kiji-n_dl-btn {
  position: relative;
  display: block;
  width: 100%;
  max-width: 350px;
  padding: 20px;
  font-size: 2rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
  border-radius: 10px;
  background-color: #feb200;
  border: 1.5px solid #feb200;
  transition: 0.3s ease;
}

@media screen and (max-width: 767px) {
  .kiji-n_dl-btn {
    font-size: 16px;
    padding: 10px;
  }
}

.kiji-n_dl-btn::after {
  content: '';
  position: absolute;
  width: 9.5px;
  height: 19px;
  right: 15px;
  background: url('./images/acp/kiji-carret-white.svg') center / contain no-repeat;
  top: 50%;
  transform: translateY(-50%) scale(1.1);
  transition: 0.3s ease;
}

@media screen and (max-width: 767px) {
  .kiji-n_dl-btn::after {
    width: 8.8px;
    height: 11px;
  }
}

.kiji-n_dl-btn:hover {
  color: #feb200;
  background-color: #fff;
}

.kiji-n_dl-btn:hover:after {
  filter: brightness(0) saturate(100%) invert(58%) sepia(92%) saturate(828%) hue-rotate(1deg) brightness(95%) contrast(105%);
}

.kiji-n_dl-img {
  width: 200px;
  height: 140px;
}

@media screen and (max-width: 767px) {
  .kiji-n_dl-img {
    margin: 0 auto 20px;
  }
}

.kiji-n_indexes {
  width: 100%;
  margin: 50px 0 60px;
  text-align: left;
  border: 2px solid #2589d0;
}

.kiji-n_indexes.s2 {
  margin: 0 0 60px;
  background-color: #f6f6f6;
  border: none;
}

.kiji-n_indexes.s2 .kiji-n_indexes-content {
  padding: 15px 30px 20px 15px;
}

.kiji-n_indexes.s2 .kiji-n_indexes-subheading,
.kiji-n_indexes.s2 .kiji-n_indexes-t2 span,
.kiji-n_indexes.s2 .kiji-n_indexes-t2 p,
.kiji-n_indexes.s2 .kiji-n_indexes-t3,
.kiji-n_indexes.s2 .kiji-n_indexes-t3:before,
.kiji-n_indexes.s2 .kiji-n_indexes-t4 {
  color: #666666;
}

.kiji-n_indexes.s2 .kiji-n_indexes-t4:before {
  background-color: #666666;
  border-color: #666666;
}

.kiji-n_indexes-title {
  display: block;
  width: 100%;
  padding: 12px;
  font-size: 1.8rem;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
  background-color: #2589d0;
}

.kiji-n_indexes-content {
  padding: 15px 30px 20px 15px;
}

.kiji-n_indexes-content a {
  transition: 0.3s ease;
}

.kiji-n_indexes-content a:hover {
  opacity: 0.75;
}

.kiji-n_indexes-subheading {
  display: block;
  margin-bottom: 20px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  color: #2589d0
}

.kiji-n_indexes-t2 {
  margin-bottom: 20px;
  display: flex;
  gap: 15px;
}

.kiji-n_indexes-t2 span {
  padding-top: 3px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  color: #2589d0
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t2 span {
    font-size: 18px;
  }
}

.kiji-n_indexes-t2 p {
  font-size: 1.8rem;
  font-weight: 700;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  line-height: normal;
  color: #1f1715;
  word-break: break-word;
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t2 p {
    font-size: 14px;
  }
}

.kiji-n_indexes-t3 {
  position: relative;
  margin-bottom: 1.6rem;
  padding-left: 20px;
  font-size: 16px;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  line-height: normal;
  color: #1f1715;
  display: flex;
}

.kiji-n_indexes-t3:before {
  content: '・';
  margin-top: -5px;
  padding-right: 10px;
  font-size: 2.2rem;
  color: #2589d0
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t3:before {
    margin-top: -7px;
  }
}

.kiji-n_indexes-t3:last-child {
  margin-bottom: 0;
}

.kiji-n_indexes-t3 p {
  font-weight: 700;
  margin-left: 25px;
  word-break: break-word;
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t3 p {
    font-size: 12px;
  }
}

.kiji-n_indexes-t3 p.s2 {
  text-indent: 0;
}

.kiji-n_indexes-t3 span {
  position: absolute;
  font-weight: 700;
  margin-left: 15px;
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t3 span {
    font-size: 12px;
  }
}

.kiji-n_indexes-t4 {
  position: relative;
  margin: 0 0 0 40px;
  padding-left: 25px;
  font-size: 1.6rem;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  line-height: 1.5em;
  color: #1f1715;
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t4 {
    font-size: 12px;
  }
}

.kiji-n_indexes-t4:before {
  content: '';
  position: absolute;
  width: 12px;
  border-top: 2px solid #2589d0;
  top: 10px;
  left: 0;
  background-color: #2589d0;
}

@media screen and (max-width: 767px) {
  .kiji-n_indexes-t4:before {
    width: 8px;
    top: 7px;
    left: 4px;
    border-width: 1px;
  }
}

.kiji-n_indexes-t4-container {
  display: block;
  margin-bottom: 20px;
}

.kiji-n_indexes-t4-container:last-child {
  margin-bottom: 0;
}

.kiji-n_indexes-subindttl {
  margin-bottom: 25px;
  font-size: 1.6rem;
  font-weight: 500;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', sans-serif;
  letter-spacing: 0.1em;
  text-align: left;
}

.kiji-n_interview {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px 4%;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .kiji-n_interview {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.kiji-n_interview--rev {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .kiji-n_interview--rev {
    flex-direction: column-reverse;
  }
}
.kiji-n_interview-wrap {
  width: 48%;
}
.kiji-n_interview-img {
  width: 100%;
  height: 300px;
  margin-bottom: 20px;
}
.kiji-n_interview-img img {
  width: 100%;
  height: 100% !important;
  object-fit: cover !important;
  -o-object-fit: cover !important;
  object-position: center !important;
  -o-object-position: center !important;
}
.kiji-n_interview-text {
  display: block;
  text-align: center;
  font-size: 12px;
  line-height: 1.5em;
}
.kiji-n_interview-content {
  width: 48%;
  transform: translateY(-5px);
  font-size: 14px;
  line-height: 2em;
}
@media screen and (max-width: 767px) {
  .kiji-n_interview-content {
    width: 100%;
    transform: translateY(0);
  }
}

.kiji-n_intex {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .kiji-n_intex {
    margin-bottom: 30px;
    flex-direction: column;
    gap: 35px;
  }
}
.kiji-n_intex-gr {
  width: calc(50% - 10px);
}
@media screen and (max-width: 767px) {
  .kiji-n_intex-gr {
    width: 100%;
  }
}
.kiji-n_intex-img {
  width: 100%;
  height: 300px;
} 
.kiji-n_intex-img img {
  width: 100%;
  height: 100% !important;
  object-fit: cover !important;
  -o-object-fit: cover !important;
  object-position: center !important;
  -o-object-position: center !important;
}
.kiji-n_intex-txt {
  display: block;
  margin-top: 20px;
  font-size: 12px;
  line-height: 2em;
  text-align: center;
}

.action {
  text-align: center;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .action {
    padding-inline: 4%;
  }
}
.action__desc, .action__btn, .action__btn-num, .action__btn-label, .action__btn-text {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.action__desc {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.8888888889em;
}
@media screen and (max-width: 767px) {
  .action__desc {
    font-size: 16px;
  }
}
.action__desc > span {
  border-bottom: 1px solid #afafaf;
}
.action__desc-01 {
  font-weight: 700;
}
.action__desc-01.is-active {
  color: #2e89d4;
  border-color: #2e89d4;
}
.action__btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 25px;
  gap: 10px 80px;
}
@media screen and (max-width: 767px) {
  .action__btns {
    gap: 10px;
  }
}
.action__btn {
  width: 117px;
  height: 100px;
  background-color: transparent;
  border-radius: 0;
  border: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  padding: 7px 2px;
  cursor: pointer;
}
.action__btn.is-active .action__btn-num,
.action__btn.is-active .action__btn-text {
  color: #2e89d4;
}
.action__btn.is-active .action__btn-num {
  border-color: #2e89d4;
}
button.action__btn:nth-child(1) .action__btn-label {
  width: 103px;
  height: 54px;
}
button.action__btn:nth-child(1).is-active .action__btn-label {
  content: url("./images/acp/suggestive_label_active.svg");
}
button.action__btn:nth-child(2) .action__btn-num {
  right: 25px;
}
button.action__btn:nth-child(2) .action__btn-label {
  width: 102px;
  height: 58px;
}
button.action__btn:nth-child(2).is-active .action__btn-label {
  content: url("./images/acp/comprehensible_label_active.svg");
}
button.action__btn:nth-child(3) {
  width: 130px;
}
button.action__btn:nth-child(3) .action__btn-num {
  right: 15px;
}
@media screen and (max-width: 767px) {
  button.action__btn:nth-child(3) .action__btn-num {
    right: 5px;
  }
}
button.action__btn:nth-child(3) .action__btn-label {
  width: 68px;
  height: 66px;
}
@media screen and (max-width: 767px) {
  button.action__btn:nth-child(3) .action__btn-label {
    width: 58px;
    height: 57px;
    transform: translateY(-4px);
  }
}
button.action__btn:nth-child(3).is-active .action__btn-label {
  content: url("./images/acp/empathetic_label_active.svg");
}
.action__btn:hover {
  background-color: #f7f7f7;
}
.action__btn-num {
  font-size: 14px;
  font-weight: 300;
  color: #afafaf;
  min-width: 30px;
  height: 30px;
  background-color: #fff;
  border: 2px solid #afafaf;
  border-radius: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-inline: 5px;
  position: absolute;
  top: 10px;
  right: 15px;
}
@media screen and (max-width: 767px) {
  .action__btn-num {
    font-size: 12px;
  }
}
.action__btn-text {
  font-size: 16px;
  font-weight: 700;
  color: #afafaf;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .action__btn-text {
    font-size: 12px;
  }
}
.action__sns {
  width: 100%;
  max-width: 657px;
  height: 94px;
  background-color: #f4f4f4;
  display: inline-block;
  margin: 20px auto 0;
  padding: 19px 10px 10px;
}
.action__sns-title {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  display: block;
}

.action__sns-btn .wp_social_bookmarking_light {
  display: flex;
  justify-content: center;
}

.block__container {
  margin-block: 100px;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .block__container {
    margin-block: 55px;
  }
}
.block__ttl {
  font-size: 18px;
  font-weight: 700;
  display: block;
  margin-bottom: 20px;
}
.block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 25px;
  margin-block: 0 50px;
}
@media screen and (max-width: 767px) {
  .block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
            align-items: center;
  }
}
.block__img {
  width: 300px;
  height: 180px;
  overflow: hidden;
}
.block__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.block__content {
  width: 100%;
  max-width: 320px;
  padding-top: 25px;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .block__content {
    text-align: center;
  }
}
.block__content h2 {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.625em;
  letter-spacing: 0.05em;
}
.block__btn {
  font-size: 14px;
  color: #2589d0;
  text-align: center;
  min-width: 150px;
  min-height: 30px;
  display: inline-block;
  border: 1px solid #2589d0;
  border-radius: 15px;
  margin-top: 25px;
  position: relative;
  padding: 7px 10px 5px;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
.block__btn::after {
  content: "";
  width: 5px;
  height: 10px;
  background: url("./images/acp/arrow.svg") center/cover no-repeat;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.block__btn:hover {
  color: #fff;
  background-color: #2589d0;
}
.block__btn:hover::after {
  background: url("./images/acp/arrow-white.svg") center/cover no-repeat;
}

.image {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.image--100 {
  height: 100%;
}
.image--auto {
  width: auto;
}
.image--contain {
  -o-object-fit: contain;
     object-fit: contain;
}

.overflow {
  overflow: hidden;
}

.pc {
  display: block;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
}
