@charset "UTF-8";
@import url("../css/default.css");
body {
  width: 100%;
  min-width: 12.1rem;
  color: #333;
  font-size: .16rem;
  font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "游ゴシック", YuGothic, "Yu Gothic", "メイリオ", Meiryo, sans-serif;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  background-color: #fff;
}

@media screen and (max-width: 767px) {
  body {
    min-width: 320px;
    font-size: .13rem;
  }
  body.fixed {
    position: fixed !important;
    top: 0;
    left: 0;
    overflow: hidden;
  }
}

/* Avoid Chrome to see Safari hack */
@supports (-webkit-touch-callout: none) {
  body {
    /* The hack for Safari */
    min-height: -webkit-fill-available;
  }
}

.wrapper {
  overflow: hidden;
}

.container {
  width: 10.28rem;
  margin: 0 auto;
  margin-bottom: 1.5rem;/*230801add*/
}

@media screen and (max-width: 767px) {
  .container {
    width: calc(100% - .3rem);
    margin-bottom: 0.6rem;
  }
}

a {
  color: #333;
}

@media screen and (max-width: 767px) {
  img {
    width: 100%;
  }
}

.img_switch {
  visibility: hidden;
}

@media screen and (max-width: 767px) {
  .pconly {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .sponly {
    display: none;
  }
}

/* header
--------------------------------------------------------------*/
.cmn_header {
  width: 100%;
  min-width: 12.1rem;
  height: 1.6rem;
  padding: .2rem 0 0;
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  /* globalNav ---------- */
}

@media screen and (min-width: 768px) {
  .cmn_header {
    -webkit-box-shadow: 0.06rem 0.06rem 0.06rem rgba(170, 170, 170, 0.2);
            box-shadow: 0.06rem 0.06rem 0.06rem rgba(170, 170, 170, 0.2);
    background: center bottom/auto 0.8rem #fff repeat-x url(../img/cmn/nav_bg_pc.png);
  }
}

.cmn_header_wrap {
  max-width: 12.1rem;
  margin: 0 auto;
  position: relative;
}

.cmn_header_logo {
  margin: 0 0 .2rem .2rem;
}

.cmn_header_logo a {
  display: block;
}

@media screen and (min-width: 768px) {
  .cmn_header_logo a {
    -webkit-transition: .4s;
    transition: .4s;
  }
  .cmn_header_logo a:hover {
    opacity: .7;
  }
}

.cmn_header_logo .logo1 {
  width: 2.08rem;
  margin-right: .25rem;
}

.cmn_header_logo .logo2 {
  width: 2.66rem;
}
.cmn_header_logo .logo {
  width: 5rem;
}

@media screen and (min-width: 768px) {
  .cmn_header_nav .hamburger {
    display: none;
  }
}

.cmn_header_nav .global li.apply a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
}

.cmn_header_nav .global li.apply a .icon {
  display: inline-block;
  padding-right: .3rem;
  position: relative;
}

.cmn_header_nav .global li.apply a .icon::after {
  content: "";
  width: .2rem;
  height: .2rem;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center;
  position: absolute;
  top: calc(50% - .1rem);
  right: 0;
}

@media screen and (min-width: 768px) {
  .cmn_header_nav .global {
    display: -webkit-box !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .cmn_header_nav .global li {
    height: .8rem;
  }
  .cmn_header_nav .global li.contact {
    -webkit-box-shadow: 0.06rem 0 0.06rem -0.06rem rgba(170, 170, 170, 0.2);
            box-shadow: 0.06rem 0 0.06rem -0.06rem rgba(170, 170, 170, 0.2);
  }
  .cmn_header_nav .global li:not(.apply) a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    height: 100%;
    padding: .1rem .23rem 0;
    letter-spacing: .08em;
    -webkit-box-shadow: -0.06rem 0 0.06rem -0.06rem rgba(170, 170, 170, 0.2);
            box-shadow: -0.06rem 0 0.06rem -0.06rem rgba(170, 170, 170, 0.2);
    text-align: center;
  }
  .cmn_header_nav .global li:not(.apply) a .big {
    color: #666;
    font-size: .18rem;
    font-weight: 600;
    -webkit-transition: color .4s;
    transition: color .4s;
  }
  .cmn_header_nav .global li:not(.apply) a .en {
    margin: .07rem 0 0;
    color: #7cb9b7;
    font-size: 0.08rem;
    font-weight: 400;
  }
  .cmn_header_nav .global li:not(.apply) a.current .big {
    color: #e7380d;
  }
  .cmn_header_nav .global li:not(.apply) a:hover .big {
    color: #00938f;
  }
  .cmn_header_nav .global li:not(.apply) a.current {
    pointer-events: none;
  }
  .cmn_header_nav .global li.apply {
    width: 1.7rem;
    height: .5rem;
    position: absolute;
    top: 0;
  }
  .cmn_header_nav .global li.apply a {
    padding-left: .35rem;
    font-size: .18rem;
    font-weight: 700;
    letter-spacing: .04em;
    border-radius: .04rem;
    border: 2px solid #00938f;
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .cmn_header_nav .global li.apply a {
    -webkit-transition: color .4s, background-color .4s;
    transition: color .4s, background-color .4s;
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .cmn_header_nav .global li.apply a .icon::after {
    -webkit-transition: background-image .4s;
    transition: background-image .4s;
  }
}

@media screen and (min-width: 768px) {
  .cmn_header_nav .global li.apply.item1 {
    right: 2rem;
  }
  .cmn_header_nav .global li.apply.item1 a {
    color: #fff;
    background-color: #00938f;
  }
  .cmn_header_nav .global li.apply.item1 a .icon::after {
    background-image: url(../img/cmn/apply_icon_white.png);
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .cmn_header_nav .global li.apply.item1 a:hover {
    color: #00938f;
    background-color: #fff;
  }
  .cmn_header_nav .global li.apply.item1 a:hover .icon::after {
    background-image: url(../img/cmn/apply_icon_green.png);
  }
}

/* == 202502 ==== */
@media screen and (min-width: 768px) {
  .cmn_header_nav .global li.apply span.icon span {
    font-size: 0.12rem;
    display: block;
    text-align: center;
  }
  .cmn_header_nav .global li.apply.item3 {
    right: 3.8rem;
  }
  .cmn_header_nav .global li.apply.item3 a {
    color: #fff;
    background-color: #00938f;
  }
  .cmn_header_nav .global li.apply.item3 a .icon::after {
    background-image: url(../img/cmn/apply_icon_white.png);
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .cmn_header_nav .global li.apply.item3 a:hover {
    color: #00938f;
    background-color: #fff;
  }
  .cmn_header_nav .global li.apply.item3 a:hover .icon::after {
    background-image: url(../img/cmn/apply_icon_green.png);
  }
}
/* == 202502 ==== */

@media screen and (min-width: 768px) {
  .cmn_header_nav .global li.apply.item2 {
    right: .2rem;
  }
  .cmn_header_nav .global li.apply.item2 a {
    color: #00938f;
    background-color: #fff;
  }
  .cmn_header_nav .global li.apply.item2 a .icon::after {
    background-image: url(../img/cmn/apply_icon_green.png);
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .cmn_header_nav .global li.apply.item2 a:hover {
    color: #fff;
    background-color: #00938f;
  }
  .cmn_header_nav .global li.apply.item2 a:hover .icon::after {
    background-image: url(../img/cmn/apply_icon_white.png);
  }
}


@media screen and (max-width: 767px) {
  .cmn_header {
    min-width: 100%;
    height: .51rem;
    padding: .12rem 0 0;
    /* globalNav ---------- */
  }
  .cmn_header_wrap {
    max-width: 100%;
  }
  .cmn_header_logo {
    margin: 0 0 .12rem .15rem;
  }
  .cmn_header_logo .logo1 {
    width: 1.15rem;
    margin-right: .15rem;
  }
  .cmn_header_logo .logo2 {
    width: 1.5rem;
  }
  .cmn_header_logo .logo {
    width: 70vw;
  }
  .cmn_header_nav .hamburger {
    display: block;
    width: .5rem;
    position: absolute;
    top: -.12rem;
    right: 0;
    z-index: 99;
  }
  .cmn_header_nav .global {
    display: none;
    width: 100%;
    height: auto;
    padding: .7rem 0 .3rem;
    background-color: rgba(6, 75, 73, 0.9);
    position: absolute;
    top: -.32rem;
  }
  .cmn_header_nav .global li a {
    display: block;
    font-size: .18rem;
  }
  .cmn_header_nav .global li:not(.apply) a {
    padding: .17rem .3rem;
    color: #fff;
    font-weight: 400;
    letter-spacing: .1em;
    text-align: left;
    background-color: rgba(6, 75, 73, 0.8);
    border-bottom: 1px solid #fff;
  }
  .cmn_header_nav .global li.contact {
    margin: 0 0 .4rem;
  }
  .cmn_header_nav .global li.apply {
    width: 3.15rem;
    height: .6rem;
    margin: 0 auto .2rem;
  }
  .cmn_header_nav .global li.apply a {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #064b49;
    font-weight: 700;
    border-radius: .02rem;
    background-color: #fff;
  }
  .cmn_header_nav .global li.apply a .icon {
    display: inline-block;
    position: relative;
  }
  .cmn_header_nav .global li.apply a .icon::after {
    background-image: url(../img/cmn/apply_icon_green_sp.png);
    top: calc(50% - 0.12rem);
  }
  .cmn_header_nav .global li.apply a .icon span {
	  margin-right: 10px;
  }
}

.mod_main {
  margin: 1.6rem 0 0;
}

@media screen and (max-width: 767px) {
  .mod_main {
    margin: .51rem 0 0;
  }
}

/* footer
--------------------------------------------------------------*/
.cmn_footer {
  padding: .4rem 0 .2rem;
  color: #fff;
  text-align: center;
  background: #064b49;
}

.cmn_footer a {
  display: block;
  color: #fff;
}

.cmn_footer_link {
  margin: 0 0 .3rem;
}

.cmn_footer_link li {
  margin: 0 .04rem;
}

.cmn_footer_link li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 4rem;
  height: 1rem;
  color: #064b49;
  font-size: .28rem;
  font-weight: 700;
  letter-spacing: .06em;
  border: 2px solid #fff;
  border-radius: .04rem;
  background-color: #fff;
}

.cmn_footer_link li a .icon span {
  font-size: .18rem;
  display: block;
}

.cmn_footer_link li a .icon {
  display: inline-block;
  padding-right: .5rem;
  position: relative;
}

.cmn_footer_link li a .icon::after {
  content: "";
  width: .3rem;
  height: .3rem;
  background: center/100% auto no-repeat url(../img/cmn/footer_link_icon.png);
  position: absolute;
  top: calc(50% - .15rem);
  right: 0;
}
@media screen and (min-width:769px) {
	.mod_flex_center.cmn_footer_link {
		flex-wrap: nowrap;
	}
}
@media screen and (min-width: 768px) {
  .cmn_footer_link li a .icon::after {
    -webkit-transition: background-image .4s;
    transition: background-image .4s;
  }
}

@media screen and (min-width: 768px) {
  .cmn_footer_link li a {
    -webkit-transition: background-color .4s, color .4s;
    transition: background-color .4s, color .4s;
  }
  .cmn_footer_link li a:hover {
    color: #fff;
    background-color: #064b49;
  }
  .cmn_footer_link li a:hover .icon::after {
    background-image: url(../img/cmn/apply_icon_white.png);
  }
}

.cmn_footer_navi li {
  margin: 0 .08rem;
}

.cmn_footer_navi li a {
  display: block;
  padding: .1rem;
  letter-spacing: .06em;
}

@media screen and (min-width: 768px) {
  .cmn_footer_navi li a {
    -webkit-transition: color .4s;
    transition: color .4s;
  }
  .cmn_footer_navi li a:hover {
    color: #e8342f;
  }
}

.cmn_footer_name {
  margin: .25rem 0 .1rem;
  font-size: .14rem;
}

.cmn_footer_copyright small {
  font-size: .14rem;
  letter-spacing: .06em;
}

@media screen and (max-width: 767px) {
  .cmn_footer {
    padding: .3rem .3rem .1rem;
  }
  .cmn_footer_link {
    margin: 0 0 .1rem;
  }
  .cmn_footer_link li {
    margin: 0 auto .2rem;
  }
  .cmn_footer_link li a {
    width: 3.15rem;
    height: .6rem;
    font-size: .18rem;
    border-radius: .02rem;
  }
  .cmn_footer_link li a .icon {
    padding-right: .3rem;
  }
  .cmn_footer_link li a .icon span {
    font-size: .14rem;
    display: inline;
    padding-right: 0.1rem;
  }
  .cmn_footer_link li a .icon::after {
    width: .2rem;
    height: .2rem;
    top: calc(50% - .12rem);
  }
  .cmn_footer_navi li {
    width: 50%;
    margin: 0;
  }
  .cmn_footer_navi li a {
    padding: .1rem 0;
    font-size: .12rem;
    text-align: left;
  }
  .cmn_footer_navi li.about1 {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
  }
  .cmn_footer_navi li.about2 {
    -webkit-box-ordinal-group: 5;
    -webkit-order: 4;
        -ms-flex-order: 4;
            order: 4;
  }
  .cmn_footer_navi li.flow {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .cmn_footer_navi li.faq {
    -webkit-box-ordinal-group: 4;
    -webkit-order: 3;
        -ms-flex-order: 3;
            order: 3;
  }
  .cmn_footer_navi li.privacy {
    -webkit-box-ordinal-group: 6;
    -webkit-order: 5;
        -ms-flex-order: 5;
            order: 5;
  }
  .cmn_footer_name {
    margin: .15rem 0 .05rem;
    font-size: .09rem;
  }
  .cmn_footer_copyright small {
    font-size: .09rem;
  }
}

/* pagetop ---------- */
/* --------------------------------------------------------------
   下層_共通
-------------------------------------------------------------- */
/* 01 BreadCrumb ---------- */
.breadcrumb ol {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.breadcrumb ol li {
  display: inline;
  font-size: 13px;
}

.breadcrumb ol li a {
  color: #333;
  -webkit-transition: .4s;
  transition: .4s;
}

.breadcrumb ol li a:hover {
  opacity: .7;
}

.breadcrumb ol li a::after {
  content: "/";
  margin-left: 3px;
}

/* 02 BreadCrumb ---------- */
.breadcrumb .breadcrumb_inner {
  width: 100%;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.breadcrumb .breadcrumb_inner > span {
  display: inline;
  font-size: 13px;
}

.breadcrumb .breadcrumb_inner > span a {
  color: #333;
  -webkit-transition: .4s;
  transition: .4s;
}

.breadcrumb .breadcrumb_inner > span a:hover {
  opacity: .7;
}

.breadcrumb .breadcrumb_inner > span a::after {
  content: "/";
  margin-left: 3px;
}

/* page title ---------- */
/* template ---------- */
/* ページャー ---------- */
/* SP時、横スクロール */
.cmn_yoko_scroll {
  width: 100%;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
  overflow-x: scroll;
  white-space: nowrap;
  /*-webkit-overflow-scrolling: touch;safari未対応のため削除する*/
}

.cmn_yoko_scroll .inner {
  min-width: 18.4rem;
}

.cmn_yoko_scroll::-webkit-scrollbar {
  height: 10px;
}

.cmn_yoko_scroll::-webkit-scrollbar-track {
  margin: 0 2px;
  background: #ccc;
  border-radius: 5px;
}

.cmn_yoko_scroll::-webkit-scrollbar-thumb {
  border-radius: 5px;
  background: #666;
}

/* SP時のみタップしたら画像拡大 */
.sponly {
  position: relative;
}

.sponly a {
  pointer-events: none;
}

.sponly a::before {
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  z-index: 10;
}

/* 中心 ----------- */
/* --------------------------------------------------------------
   Module_Element
-------------------------------------------------------------- */
/* Flex ---------- */
.mod_flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}

.mod_flex.align-center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.mod_flex_center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.mod_flex_center.align-center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.mod_flex_between {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  /* 3列4列の場合の調整 */
  /* // 3列4列の場合の調整 */
}

.mod_flex_between.align-center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.mod_flex_between.col3::after, .mod_flex_between.col4::before, .mod_flex_between.col4::after {
  content: "";
  display: block;
  height: 0;
}

.mod_flex_between.col4::before {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
}

.mod_flex_around {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
}

.mod_flex_around.align-center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

/* mod_layout ---------- */
.mod_layout1 {
  padding: .9rem 0 1.4rem;
}

@media screen and (max-width: 767px) {
  .mod_layout1 {
    padding: .5rem 0 .7rem;
  }
}

.mod_layout2 {
  padding: 1.2rem 0 1.4rem;
}

@media screen and (max-width: 767px) {
  .mod_layout2 {
    padding: .7rem 0;
  }
  ul.cmn_footer_navi.mod_flex_center {
	  justify-content: flex-start;
  }
}

/* mod_tit ---------- */
.mod_tit1 {
  font-size: .42rem;
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 1.6;
  text-align: center;
}

.mod_tit1 .deco {
  display: inline-block;
  padding: 0 0 .15rem;
  position: relative;
}

.mod_tit1 .deco::after {
  content: "";
  width: .8rem;
  height: .04rem;
  background-color: #00938f;
  position: absolute;
  left: calc(50% - .4rem);
  bottom: 0;
}

@media screen and (max-width: 767px) {
  .mod_tit1 {
    font-size: .21rem;
  }
  .mod_tit1 .deco::after {
    width: .4rem;
    height: 2px;
    left: calc(50% - .2rem);
  }
}

.mod_tit2 {
  padding-left: .25rem;
  font-size: .32rem;
  font-weight: 700;
  letter-spacing: .1em;
  border-left: .04rem solid;
}

.mod_tit2.color1 {
  color: #00938f;
  border-left-color: #00938f;
}

.mod_tit2.color2 {
  color: #2cab4d;
  border-left-color: #2cab4d;
}

.mod_tit2 .en {
  display: block;
  margin: .12rem 0 0;
  color: #95cbca;
  font-size: .12rem;
  font-weight: 500;
  letter-spacing: .06em;
}

@media screen and (max-width: 767px) {
  .mod_tit2 {
    padding-left: .12rem;
    font-size: .18rem;
    border-left: .025rem solid;
  }
  .mod_tit2 .en {
    margin: .06rem 0 0;
    font-size: .09rem;
  }
}

/*▽230801 add*/

.mod_tit3 {
  padding-left: .25rem;
  font-size: .25rem;
  font-weight: 500;
  letter-spacing: .1em;
  border-left: .04rem solid;
  margin-bottom: 0.5rem;
  margin-top: 0.5rem;
}

.mod_tit3.color1 {
  color: #00938f;
  border-left-color: #00938f;
}

.mod_tit3.color2 {
  color: #2cab4d;
  border-left-color: #2cab4d;
}

.mod_tit5 {
  font-size: .25rem;
  font-weight: 600;
  letter-spacing: .1em;
  margin-bottom: -0.5rem;
  margin-top: 0.8rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .mod_tit3 {
    padding-left: .12rem;
    font-size: .18rem;
    border-left: .025rem solid;
  }
  .mod_tit5 {
	font-size: .21rem;
    margin-bottom: -0.1rem;
    line-height: 1.4;
  }
}

/*▲230801 add*/



/* mod_btn ---------- */
.mod_btn1 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 1.9rem;
  height: .4rem;
  color: #fff;
  font-size: .14rem;
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: .04rem;
  border: 2px solid #00938f;
  background-color: #00938f;
}

@media screen and (min-width: 768px) {
  .mod_btn1 {
    -webkit-transition: color .4s, background-color .4s;
    transition: color .4s, background-color .4s;
  }
  .mod_btn1:hover {
    color: #00938f;
    background-color: #fff;
  }
}

@media screen and (max-width: 767px) {
  .mod_btn1 {
    width: 3.15rem;
    height: .45rem;
    margin: 0 auto;
    letter-spacing: .14em;
    border-radius: .02rem;
  }
}

/* mod_text ---------- */
.mod_text1 {
  font-weight: 400;
  line-height: 1.625;
  letter-spacing: .1em;
  text-align: justify;
}

@media screen and (max-width: 767px) {
  .mod_text1 {
    line-height: 1.53;
  }
}

.mod_text2 {
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: .1em;
}

.mod_text3 {
  font-weight: 400;
  line-height: 2;
  letter-spacing: .06em;
}

.mod_text4 {
  font-size: .14rem;
  font-weight: 400;
  line-height: 1.57;
  letter-spacing: .1em;
}

@media screen and (max-width: 767px) {
  .mod_text4 {
    font-size: .11rem;
    line-height: 1.54;
  }
}

/* number ---------- */
.mod_num {
  counter-reset: number 0;
}

.mod_num .num {
  position: relative;
}

.mod_num .num::before {
  counter-increment: number 1;
  content: counter(number) ".";
  position: absolute;
}

/* TOP
--------------------------------------------------------------*/
.fixedBtn {
  position: fixed;
  right: 10px;
  bottom: 10px;
  background: #FFF;
  color: #00938f;
  padding: 1em;
  border-radius: 5px;
  border: 2px solid #00938f;
  transition: all 0.5s;
  z-index: 10;
}
.fixedBtn:hover {
  color: #FFF;
  background: #00938f;
}

.top_mv_head {
  margin: 0 0 .35rem;
}
.top_mv_head img {
  height: .74rem;
}
.top_mv .mod_text1 {
  max-width: 4.38rem;
}

.top_mv_btn {
  margin: .25rem 0 0;
}
.top_mv .box {
  width: 80%;
}
.top_mv .btn {
  color: #FFF;
  background: #00938f;
  padding: 0.15rem 0.3rem;
  margin: 0.1rem 0;
  border-radius: 5px;
  box-sizing: border-box;
}

.top_mv .swiper-slide {
  height: 6rem;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.top_mv .swiper-slide .container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
}
/* main visual ----------- */
@media screen and (min-width: 768px) { 
  .top_mv {
    max-width: 1600px;
  }
  .swiper-wrapper {
    display: flex;
  }
  /* 2つのブロックを半々に配置 */
  .top_mv .swiper-slide {
    width: 50%;  /* 変更：元は60%だった */
    margin-bottom: 0.5rem;
  }
  .top_mv .swiper-slide .container {
    display: flex;
    flex-direction: column;
  }
  /* item1の.fv_pcの幅は118%に統一 */
  .top_mv .swiper-slide.item1 .container .fv_pc {
    width: 118%;
  }
  .top_mv .swiper-slide .container .fv_pc {
    position: absolute;
    top: 0;
    left: 0;
    height: 3.1rem;
    overflow: hidden;
  }
  /* 画像にトランジションを追加 */
  .top_mv .swiper-slide .container .fv_pc img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s;
  }
  .top_mv .swiper-slide.item1 {
    background-image: none;
  }
  .top_mv .swiper-slide.item2 {
    background-image: none;
  }
  .top_mv .swiper-slide.item1 .container {
    width: 80%;
    margin: 0 0 0 auto;
    justify-content: flex-end;
  }
  .top_mv .swiper-slide.item2 .container {
    width: 76%;
    margin: auto;
    justify-content: flex-end;
  }
  .top_mv .swiper-slide.item1 .fv_pc {
    clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
    transition: 0.5s;
  }
  .top_mv .swiper-slide.item2 .fv_pc {
    clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
    transition: 0.5s;
    width: 100%;
  }
  /* ホバー時：clip-pathを四角形に変更＆画像拡大 */
  .top_mv .swiper-slide.item1:hover .fv_pc,
  .top_mv .swiper-slide.item2:hover .fv_pc {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    overflow: visible;
    z-index: 1;
  }
  .top_mv .swiper-slide.item1:hover .fv_pc img,
  .top_mv .swiper-slide.item2:hover .fv_pc img {
    transform: scale(1.2);
  }
}
/* 
@media screen and (max-width: 767px) { 
  .top_mv .swiper-slide.item1 {
    background-image: url(../img/top/mv1@2x.jpg);
  }
  
  .top_mv .swiper-slide.item2 {
    background-image: url(../img/top/mv2@2x.jpg);
  }
} */


.top_mv .swiper-pagination {
  bottom: .3rem;
}

.top_mv .swiper-pagination .swiper-pagination-bullet {
  width: .1rem;
  height: .1rem;
  background: #064b49;
  opacity: 1;
}

.top_mv .swiper-pagination .swiper-pagination-bullet-active {
  width: .62rem;
  border-radius: .05rem;
}

@media screen and (max-width: 767px) {
  .top_mv_head {
    margin: 0 0 .15rem;
  }
  .top_mv_head img {
    width: auto;
    height: .41rem;
  }
  .top_mv .mod_text1 {
    max-width: 100%;
  }
  .top_mv_btn {
    margin: .15rem 0 0;
  }
  .top_mv .swiper-slide {
    height: 4.05rem;
    padding: .2rem .15rem 2.08rem;
  }
  .top_mv .swiper-slide .container {
    display: block;
  }
  .top_mv .swiper-slide.item1 {
    background-image: url(../img/top/mv1_sp.png);
  }
  .top_mv .swiper-slide.item1 .mod_text1 {
    letter-spacing: .06em;
  }
  .top_mv .swiper-slide.item2 {
    background-image: url(../img/top/mv2_sp.png);
  }
  .top_mv .swiper-pagination {
    bottom: .15rem;
  }
  .top_mv .swiper-pagination .swiper-pagination-bullet {
    width: .05rem;
    height: .05rem;
  }
  .top_mv .swiper-pagination .swiper-pagination-bullet-active {
    width: .31rem;
    border-radius: .025rem;
  }
  .top_mv .flex {
    flex-wrap: wrap;
  }
}

/* news ----------- */
.top_news {
  padding: .4rem 0 .6rem;
  background: #e0efeb;
}

.top_news_head {
  padding: 0 .28rem .1rem;
  border-bottom: 1px solid #00938f;
}

.top_news_head .ja {
  font-size: .22rem;
  font-weight: 700;
  letter-spacing: .1em;
}

.top_news_head .en {
  display: inline-block;
  margin-left: .06rem;
  color: #00938f;
  font-size: .12rem;
  letter-spacing: .06em;
}

.top_news_lists .item a,
.top_news_lists .item>div {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: .5rem;
  padding: .05rem .1rem .05rem .28rem;
  border-bottom: 1px solid #00938f;
}

.top_news_lists .item a .data,
.top_news_lists .item>div .data {
  width: 1.75rem;
  color: #999;
  font-weight: 600;
  letter-spacing: .1em;
}

@media screen and (min-width: 768px) {
  .top_news_lists .item a .data,
  .top_news_lists .item>div .data {
    -webkit-transition: color .4s;
    transition: color .4s;
  }
}

.top_news_lists .item a .stit,
.top_news_lists .item>div .stit {
  width: calc(100% - 1.75rem);
  font-weight: 400;
  letter-spacing: .1em;
  line-height: 1.625;
}

@media screen and (min-width: 768px) {
  .top_news_lists .item a .stit,
  .top_news_lists .item>div .stit {
    -webkit-transition: color .4s;
    transition: color .4s;
  }
}

.top_news_lists .item a .stit .icon,
.top_news_lists .item>div .stit .icon {
  display: inline-block;
  padding-right: .3rem;
  position: relative;
}

.top_news_lists .item a .stit .icon::after,
.top_news_lists .item>div .stit .icon::after {
  content: "";
  width: .22rem;
  height: .26rem;
  background: center/100% auto no-repeat url(../img/top/pdf_icon.png);
  position: absolute;
  top: calc(50% - .13rem);
  right: 0;
}

@media screen and (min-width: 768px) {
  .top_news_lists .item a .stit .icon::after,
  .top_news_lists .item>div .stit .icon::after {
    -webkit-transition: background-image .4s;
    transition: background-image .4s;
  }
}

@media screen and (min-width: 768px) {
  .top_news_lists .item a:hover .data {
    color: #00938f;
  }
  .top_news_lists .item a:hover .stit {
    color: #00938f;
  }
}

.top_news_lists .item:nth-child(odd){
  background-color: #fff;
}
/*
.top_news_lists .item:nth-child(odd) a {
  background-color: #fff;
}
*/

@media screen and (max-width: 767px) {
  .top_news {
    padding: .2rem 0 .3rem;
  }
  .top_news_head {
    padding: 0 0 .07rem;
    margin: 0 0 .15rem;
  }
  .top_news_head .ja {
    font-size: .18rem;
  }
  .top_news_head .en {
    margin-left: .03rem;
    font-size: .11rem;
  }
  .top_news_lists .item a,
  .top_news_lists .item>div {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    padding: .05rem .15rem .07rem;
  }
  .top_news_lists .item a .data,
  .top_news_lists .item>div .data {
    width: 100%;
    margin: 0 0 .03rem;
    font-size: .11rem;
  }
  .top_news_lists .item a .stit,
  .top_news_lists .item>div .stit {
    width: 100%;
    font-size: .11rem;
    line-height: 1.45;
  }
  .top_news_lists .item a .stit .icon,
  .top_news_lists .item>div .stit .icon {
    padding-right: .43rem;
  }
  .top_news_lists .item a .stit .icon::after,
  .top_news_lists .item>div .stit .icon::after {
    width: .21rem;
    height: .26rem;
    top: calc(50% - .125rem);
  }
}

/* about ----------- */
.top_about {
  padding: .25rem 0 0.8rem;
}

.top_about .mod_tit1 {
  margin: 0.5rem 0 .8rem;
  padding: .75rem 0 0;
  background: center top/7.37rem auto no-repeat url(../img/top/about_title_deco@2x.jpg);
}

.top_about .mod_tit1 .deco {
  padding: 0 0 .3rem;
}

.top_about_info .item {
  width: 4.35rem;
  position: relative;
}

.top_about_info .item + .item {
  margin: 2.05rem 0 0;
}

.top_about_info .item .title {
  margin: 0 0 .6rem;
}

.top_about_info .item .title img {
  height: .58rem;
}

.top_about_info .item .pic {
  width: 6rem;
  position: absolute;
  top: 0;
}

.top_about_info .item:nth-child(odd) {
  width: 4.85rem;
}

.top_about_info .item:nth-child(odd) .pic {
  right: -6.2rem;
}

.top_about_info .item:nth-child(even) {
  margin-left: 6rem;
}

.top_about_info .item:nth-child(even) .pic {
  left: -6.7rem;
}

.top_about_recom {
  padding: 0 0 .1rem;
  margin: 0 0 .3rem;
  border-bottom: 1px solid #666;
}

.top_about_recom .stit {
  font-weight: 600;
  line-height: 1.75;
  letter-spacing: .1em;
  position: relative;
}

.top_about_recom .stit::before {
  content: "";
  width: 100%;
  height: 1px;
  background: #666;
  position: absolute;
  top: .12rem;
  left: 0;
}

.top_about_recom .stit .bg {
  display: inline-block;
  padding-right: .06rem;
  background: #fff;
  position: relative;
  z-index: 5;
}

.top_about_recom .lists li {
  padding-left: .35rem;
  letter-spacing: .16em;
  background: top 0.05rem left/0.22rem auto no-repeat url(../img/top/check_icon@2x.png);
}

.top_about_btn {
  margin: .55rem 0 0;
}

@media screen and (max-width: 767px) {
  .top_about {
    padding: .35rem 0 0;
  }
  .top_about .mod_tit1 {
    margin: 0 0 .34rem;
    padding: .27rem 0 0;
    background: center top/100% auto no-repeat url(../img/top/about_title_deco_sp.jpg);
  }
  .top_about .mod_tit1 .deco {
    padding: 0 0 .15rem;
  }
  .top_about_info .item {
    width: 100%;
  }
  .top_about_info .item + .item {
    margin: .5rem 0 0;
  }
  .top_about_info .item .title {
    margin: 0 0 .17rem;
  }
  .top_about_info .item .title img {
    width: auto;
    height: .36rem;
  }
  .top_about_info .item .pic {
    width: 100%;
    margin: .32rem 0 0;
    position: static;
  }
  .top_about_info .item .pic.add {
    margin: .32rem 0 .37rem;
  }
  .top_about_info .item:nth-child(odd) {
    width: 100%;
  }
  .top_about_info .item:nth-child(even) {
    margin-left: 0;
  }
  .top_about_recom {
    padding: 0 0 .15rem;
    margin: 0 0 .15rem;
  }
  .top_about_recom .stit {
    margin: 0 0 .05rem;
    font-weight: 600;
    line-height: 1.75;
    letter-spacing: .1em;
    position: relative;
  }
  .top_about_recom .stit::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #666;
    position: absolute;
    top: .1rem;
    left: 0;
  }
  .top_about_recom .lists li {
    padding-left: .4rem;
    letter-spacing: .14em;
    line-height: 1.73;
    background: top 0.03rem left 0.15rem/0.18rem auto no-repeat url(../img/top/check_icon_sp@2x.png);
  }
  .top_about_btn {
    margin: .23rem 0 0;
  }
}

/* voice ----------- */
.top_voice {
  max-width: 1200px;
  padding: 0 0 .4rem;
  margin: 0 auto;
}
.top_voice.pdn {
	padding: 1.4rem 0 0;
}
.top_voice .mod_tit1 {
  margin: 0 0 .8rem;
}

.top_voice_list {
  margin: 0 0 .6rem;
  justify-content: start;
  gap: 0.2rem 0.1rem;
}

.top_voice_list .item {
  width: calc(100%/3 - 0.1rem);
  margin: 0;
  position: relative;
}

.top_voice_list .item .stit {
  margin: 0 0 .3rem;
  color: #fff;
  font-size: .22rem;
  font-weight: 400;
  letter-spacing: .04em;
  line-height: 2.27;
  position: relative;
  z-index: 3;
}

.top_voice_list .item .stit .marker {
  padding: .05rem .1rem;
  display: inline;
}

.top_voice_list .item .text_wrap {
  height: 100%;
  padding: .1rem .2rem .15rem;
  z-index: 3;
  bottom: 0;
  position: relative;
  border-radius: 4px;
}
.top_voice_list .item .text_wrap:after {
  position: absolute;
  content: "";
  bottom: -0.15rem;
  right: 0.5rem;
  box-sizing: border-box;
  width: 20px;
  height: 12px;
  border: 8px solid transparent;
  border-left: 20px solid rgba(226, 239, 229, 0.95);
  transform: rotate(120deg);
}

.top_voice_list .item .text_wrap .txt {
  font-size: .16rem;
  font-weight: 400;
  letter-spacing: .04em;
  line-height: 1.85;
}

.top_voice_list .item .pic {
  width: 2rem;
  position: absolute;
  top: -.15rem;
  right: 0;
  z-index: 1;
}

.top_voice_list .item:nth-child(odd) .stit .marker {
  background: #2cab4d;
}

.top_voice_list .item:nth-child(odd) .text_wrap {
  background: rgba(226, 239, 229, 0.95);
}


.top_voice_list .item:nth-child(even) .stit .marker {
  background: #00938f;
}

.top_voice_list .item:nth-child(even) .text_wrap {
  background: rgba(225, 240, 239, 0.95);
}
.top_voice_list .item:nth-child(even) .text_wrap:after {
  border-left: 20px solid rgba(225, 240, 239, 0.95);
}


.top_voice_link .btn1 a,
.top_voice_link .btn2 a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 5.72rem;
  height: 1rem;
  margin: 0 auto;
  font-size: .28rem;
  font-weight: 700;
  letter-spacing: .06em;
  border-radius: .04rem;
  border: 0.03rem solid #00938f;
}

.support {
  border: 2px solid #00938f;
  width: 90%;
  max-width: 950px;
  margin: 0 auto 1.4rem;
  padding: .5rem .5rem;
  box-sizing: border-box;
}
.support h3 {
  font-size: 0.3rem;
}
.support p {
  margin: 2em 0 0;
  line-height: 1.8;
}

.about_page .about_overview.about2 {
	margin-top: 0.6rem;
}

@media screen and (min-width: 768px) {
  .top_voice_link .btn1 a,
  .top_voice_link .btn2 a {
    -webkit-transition: color .4s, background-color .4s;
    transition: color .4s, background-color .4s;
  }
}
@media screen and (max-width: 767px) { 
  .support {
    padding: .2rem;
    margin: 0 auto 0.8rem;
  }
  .support h3 {
    font-size: 0.2rem;
    margin-top: 0.1rem;
  }
  
  .top_voice.pdn {
	  padding: 0.8rem 0 0.4rem;
  }
  .about_page .about_overview.about2 .top_voice.pdn .mod_tit1 {
	  margin-top: 0;
  }
}

.top_voice_link .btn1 {
  margin: 0 auto .4rem;
}

.top_voice_link .btn1 a {
  color: #00938f;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .top_voice_link .btn1 a:hover {
    color: #fff;
    background-color: #00938f;
  }
}

.top_voice_link .btn2 a {
  color: #fff;
  background-color: #00938f;
}

.top_voice_link .btn2 a .icon {
  display: inline-block;
  padding-right: .5rem;
  position: relative;
}

.top_voice_link .btn2 a .icon::after {
  content: "";
  width: .3rem;
  height: .3rem;
  background: center/100% auto no-repeat url(../img/cmn/apply_icon_white.png);
  position: absolute;
  top: calc(50% - .15rem);
  right: 0;
}

@media screen and (min-width: 768px) {
  .top_voice_link .btn2 a .icon::after {
    -webkit-transition: background-image .4s;
    transition: background-image .4s;
  }
}

@media screen and (min-width: 768px) {
  .top_voice_link .btn2 a:hover {
    color: #00938f;
    background-color: #fff;
  }
  .top_voice_link .btn2 a:hover .icon::after {
    background-image: url(../img/cmn/apply_icon_green.png);
  }
}

@media screen and (max-width: 767px) {
  .top_voice {
    padding: 0 0 .7rem;
  }
  .top_voice .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .top_voice_list {
    width: calc(100% - .3rem);
    margin: 0 auto .43rem;
  }
  .top_voice_list .item {
    width: 100%;
    margin: 0;
    min-height: auto;
    display: flex;
  }
  .top_voice_list .item + .item {
    margin-top: 0;
  }
  .top_voice_list .item .stit {
    margin: 0 0 .11rem;
    font-size: .18rem;
    line-height: 2;
  }
  .top_voice_list .item .stit .marker {
    padding: .03rem .06rem;
    display: inline;
  }
  .top_voice_list .item .text_wrap {
    width: 2rem;
    padding: .15rem .13rem;
    position: relative;
    height: fit-content;
  }
  .top_voice_list .item .text_wrap .txt {
    font-size: .12rem;
    line-height: 1.66;
    text-align: justify;
  }
  .top_voice_list .item .pic {
    width: 1.35rem;
    top: -.12rem;
    position: relative;
    left: 0;
  }
  .top_voice_list .item:nth-child(odd) {
    flex-direction: row-reverse;
  }
  .top_voice_list .item:nth-child(odd) .pic {
    right: auto;
  }
  .top_voice_link .btn1 a,
  .top_voice_link .btn2 a {
    width: 3.15rem;
    height: .6rem;
    font-size: .18rem;
    border-radius: .02rem;
    border: 0.015rem solid #00938f;
  }
  .top_voice_link .btn1 {
    margin: 0 auto .2rem;
  }
  .top_voice_link .btn2 a .icon {
    padding-right: .3rem;
  }
  .top_voice_link .btn2 a .icon::after {
    width: .2rem;
    height: .2rem;
    top: calc(50% - .12rem);
  }
}

/* faq ----------- */
.top_faq {
  padding: .65rem 0 .7rem;
  background: center/cover no-repeat url(../img/top/faq_bg@2x.jpg);
}

.top_faq .mod_tit1 {
  margin: 0 0 .8rem;
}

.top_faq_link .item {
  width: 4.74rem;
  height: 3rem;
  margin: 0 .14rem;
}

.top_faq_link .item a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  color: #00938f;
  background: #fff;
  border-radius: .08rem;
  -webkit-box-shadow: 0.14rem 0.14rem 0.4rem rgba(0, 147, 143, 0.3);
          box-shadow: 0.14rem 0.14rem 0.4rem rgba(0, 147, 143, 0.3);
}

.top_faq_link .item a .stit {
  padding: 2.15rem .5rem 0 0;
  font-size: .32rem;
  font-weight: 700;
  letter-spacing: .06em;
  position: relative;
}

.top_faq_link .item a .stit::before {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center;
  position: absolute;
  top: .65rem;
}

.top_faq_link .item a .stit::after {
  content: ">";
  position: absolute;
  right: 0;
}

.top_faq_link .item a.q1 .stit::before {
  width: .97rem;
  height: 1.13rem;
  background-image: url(../img/top/faq_icon1@2x.png);
  left: calc(50% - .485rem);
}

.top_faq_link .item a.q2 .stit::before {
  width: 1.31rem;
  height: 1.11rem;
  background-image: url(../img/top/faq_icon2@2x.png);
  left: calc(50% - .655rem);
}

@media screen and (min-width: 768px) {
  .top_faq_link .item a {
    -webkit-transition: -webkit-box-shadow .4s;
    transition: -webkit-box-shadow .4s;
    transition: box-shadow .4s;
    transition: box-shadow .4s, -webkit-box-shadow .4s;
  }
  .top_faq_link .item a:hover {
    position: relative;
    bottom: -.03rem;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

@media screen and (max-width: 767px) {
  .top_faq {
    padding: .39rem .3rem .4rem;
    background: center/cover no-repeat url(../img/top/faq_bg_sp.jpg);
  }
  .top_faq .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .top_faq_link .item {
    width: 100%;
    height: 1rem;
    margin: 0;
  }
  .top_faq_link .item + .item {
    margin-top: .2rem;
  }
  .top_faq_link .item a {
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: left;
    -webkit-justify-content: left;
        -ms-flex-pack: left;
            justify-content: left;
    border-radius: .04rem;
    -webkit-box-shadow: 0 0.07rem 0.2rem 0 rgba(0, 147, 143, 0.3);
            box-shadow: 0 0.07rem 0.2rem 0 rgba(0, 147, 143, 0.3);
    position: relative;
  }
  .top_faq_link .item a::after {
    content: ">";
    font-size: .18rem;
    font-weight: 700;
    position: absolute;
    top: calc(50% - .09rem);
    right: .15rem;
  }
  .top_faq_link .item a .stit {
    font-size: .18rem;
  }
  .top_faq_link .item a .stit::after {
    content: none;
  }
  .top_faq_link .item a.q1 {
    padding: 0 0 0 .64rem;
  }
  .top_faq_link .item a.q1 .stit {
    padding: 0 0 0 .58rem;
  }
  .top_faq_link .item a.q1 .stit::before {
    width: .43rem;
    height: .51rem;
    background-image: url(../img/top/faq_icon1@2x.png);
    left: 0;
    top: calc(50% - .255rem);
  }
  .top_faq_link .item a.q2 {
    padding: 0 0 0 .23rem;
  }
  .top_faq_link .item a.q2 .stit {
    padding: 0 0 0 .65rem;
    letter-spacing: 0;
  }
  .top_faq_link .item a.q2 .stit::before {
    width: .53rem;
    height: .45rem;
    background-image: url(../img/top/faq_icon2@2x.png);
    left: 0;
    top: calc(50% - .225rem);
  }
}

/* contact ----------- */
.top_contact {
  padding: 1.3rem 0 1.5rem;
  text-align: center;
}

.top_contact .mod_tit1 {
  margin: 0 0 .7rem;
}

.top_contact_btn {
  margin: .55rem 0 0;
}

.top_contact_btn a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 5.72rem;
  height: 1rem;
  margin: 0 auto;
  color: #fff;
  font-size: .28rem;
  font-weight: 700;
  letter-spacing: .06em;
  border-radius: .04rem;
  border: 2px solid #00938f;
  background-color: #00938f;
}
.contact_cot.mod_layout1 {
	padding: .9rem 0 0rem;
}
.contact_cot p {
	font-weight: 400;
    line-height: 1.625;
    letter-spacing: .1em;
    text-align: justify;
}

@media screen and (min-width: 768px) {
  .top_contact_btn a {
    -webkit-transition: background-color .4s, color .4s;
    transition: background-color .4s, color .4s;
  }
  .top_contact_btn a:hover {
    color: #00938f;
    background-color: #fff;
  }
}

@media screen and (max-width: 767px) {
  .top_contact {
    padding: .7rem 0 1rem;
  }
  .top_contact .mod_tit1 {
    margin: 0 0 .25rem;
  }
  .top_contact_btn {
    margin: .33rem 0 0;
  }
  .top_contact_btn a {
    width: 3.15rem;
    height: .6rem;
    font-size: .18rem;
    border-radius: .02rem;
    border: 1px solid #00938f;
  }
  .contact_cot.mod_layout1 {
	  padding: .5rem 0 0.4rem;
  }
}

/* 食品分析士とは / 食品品質管理士とは
--------------------------------------------------------------*/
/* 共通 ----------- */
.about_page .about_about {
  max-height: 6rem;
  /* min-height: 6.1rem; */
  /* padding: .85rem 0 0;
  background: repeat url(../img/about/bg_repeat.png); */
  overflow-y: hidden;
}
.about_page .about_about .container {
  width: 100%;
  position: relative;
}
.about_page .about_about .mod_tit1 {
  color: #FFF;
  margin-bottom: 0.15rem;
  position: relative;
  padding-left: 0.1rem;
  padding-right: 0.1rem;
}
.about_page .about_about .mod_tit1:before {
  content: "";
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: #00938f;
  animation: move 1s ease-in-out;
}
.about_page .about_about_wrap .text {
  width: 5.1rem;
  height: 100%;
  position: absolute;
  z-index: 2;
  left: 9%;
  right: inherit;
  margin: auto;
}
.about_page .about_about_wrap .text .box {
  padding: 0 0 0;
  display: flex;
  flex-direction: column;
  align-items: baseline;
  justify-content: center;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
}
.about_page .food_ae .about_about_wrap .text {
  right: 0;
  left: 50%;
  margin: 0 auto;
}
.about_page .about_about_wrap .text .stit {
  margin: 0 0 .15rem;
  color: #00938f;
  font-size: .22rem;
  padding: 0.1rem 0.1rem;
  font-weight: 700;
  letter-spacing: .1em;
  position: relative;
  display: inline-block;
  box-sizing: border-box;
}
.about_page .about_about_wrap .text .stit:before {
  position: absolute;
  content: "";
  background: #FFF;
  z-index: -1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  animation: move 1s ease-in-out;
}
.about_page .about_about_wrap .pic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about_page .about_overview .abstract li {
  list-style-type: none;
}
@keyframes move {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
@media screen and (max-width: 768px) { 
  .about_page .about_about_wrap {
    display: flex;
    flex-direction: column;
  }
  .about_page .container .about_about_wrap .text {
    width: 90%;
    margin: auto;
    padding: 0;
    position: relative;
    left: 0;
    right: 0;
  }
  .about_page .container .about_about_wrap .text .box {
    padding-top: 0;
  }
}

/*  ========================
  *********  食品分析士  *********
=============================================  */

.about_page .about_overview .mod_tit1 {
  margin: 0 0 .7rem;
}

.about_page .about_overview_item + .about_overview_item {
  margin-top: .8rem;
}

.about_page .about_overview_item .mod_tit2 {
  margin: 0 0 .2rem;
}

.about_page .about_overview_item .data_li {
  border-top: 1px solid #666;
  border-left: 1px solid #666;
}

.about_page .about_overview_item .data_li dt,
.about_page .about_overview_item .data_li dd {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  border-right: 1px solid #666;
  border-bottom: 1px solid #666;
}

.about_page .about_overview_item .data_li dt {
  width: 3rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: .13rem 0;
  font-size: .22rem;
  font-weight: 400;
  letter-spacing: .06em;
}

.about_page .about_overview_item .data_li dd {
  width: calc(100% - 3rem);
  padding: .17rem .26rem;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}

.about_page .about_overview_item .data_li .mod_text2 .img {
  width: 4.4rem;
  margin: .2rem auto;
}

.about_page .grade3 .about_overview_item .data_li {
  margin-bottom: 0.8rem;
}

.about_page .about_overview_item.item1 .data_li dt {
  background-color: #e1f0ef;
}

.about_page .about_overview_item.item2 .data_li dt {
  background-color: #e2efe5;
}

.about_page .about_overview_btn {
  width: 5.72rem;
  height: 1rem;
  margin: .8rem auto 0;
}

.about_page .about_overview_btn a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  color: #00938f;
  font-weight: 700;
  font-size: .28rem;
  letter-spacing: .06em;
  border-radius: .04rem;
  border: 0.03rem solid #00938f;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .about_page .about_overview_btn a {
    -webkit-transition: background-color .4s, color .4s;
    transition: background-color .4s, color .4s;
  }
  .about_page .about_overview_btn a:hover {
    color: #fff;
    background-color: #00938f;
  }
}

@media screen and (max-width: 767px) {
  .about_page .about_about {
    min-height: 100%;
    padding: .45rem 0 .37rem;
    background-size: .12rem auto;
  }
  .about_page .about_about .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .about_page .about_about_wrap {
    background: url(../img/about/bg.png) repeat;
    padding-top: 0.3rem;
  }
  .about_page .about_about_wrap .text {
    width: 100%;
    padding: 0;
  }
  .about_page .about_about_wrap .text .stit {
    font-size: .18rem;
  }
  .about_page .about_about_wrap .pic {
    width: 100%;
    margin: .25rem 0 0;
  }
  .about_page .about_overview .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .about_page .about_overview.about2 .mod_tit1 {
	  margin-top: 0.4rem;
  }
  .about_page .about_overview_item + .about_overview_item {
    margin-top: .5rem;
  }
  .about_page .grade3 .about_overview_item .data_li {
	  margin-bottom: 0;
  }
  .about_page .about_overview_item .mod_tit2 {
    margin: 0 0 .15rem;
  }
  .about_page .about_overview_item .data_li dt {
    width: .9rem;
    padding: .1rem 0;
    font-size: .13rem;
    line-height: 1.38;
  }
  .about_page .about_overview_item .data_li dd {
    width: calc(100% - .9rem);
    padding: .1rem .15rem;
    font-size: .11rem;
  }
  .about_page .about_overview_item .data_li .mod_text2 .img {
    width: 100%;
    margin: .1rem auto;
  }
  .about_page .about_overview_btn {
    width: 3.15rem;
    height: .6rem;
    margin: .4rem auto 0;
  }
  .about_page .about_overview_btn a {
    font-size: .18rem;
    border-radius: .02rem;
    border: 0.015rem solid #00938f;
  }
  .about_page .about_about {
    padding: 0 0 1rem;
  }
  .about_page .food_ae .about_about_wrap .text {
    right: 0;
  }
  .about_page .food_ae .about_about_wrap .text {
    left: 0;
    right: 0;
  }
  .about_page .container .about_about_wrap .text .box {
    position: relative;
  }
  .about_page .about_about .mod_tit1 {
    margin: 0 0 0;
  }
  .about_page .about_about_wrap .text .stit {
    margin-top: 0.1rem;
    margin-bottom: 0;
  }
  .about_page .about_about .text p.mod_text1 {
    position: absolute;
    top: 82vw;
  }
  .about_page .about_about .pic p.mod_text1 {
    width: 90%;
    margin: 0.3rem auto;
  }
}

/* 食品分析士とは
--------------------------------------------------------------*/
/* content ----------- */
/* 食品品質管理士とは
--------------------------------------------------------------*/
/* content ----------- */
/* 資格取得までの流れ
--------------------------------------------------------------*/
/* content ----------- */
.flow_page .flow_cot.mod_layout1 {
	padding: .9rem 0 0rem;
}
.flow_page .flow_cot .mod_tit1 {
  margin: 0 0 .85rem;
}

.flow_page .flow_cot_list .item + .item {
  margin-top: .6rem;
}

.flow_page .flow_cot_list .item .stit img {
  height: 1.3rem;
}

.flow_page .flow_cot_list .item .text_wrap {
  margin: -.05rem 0 0;
  padding: .24rem .3rem;
  margin-left: 1.28rem;
  background-repeat: repeat;
  background-size: .12rem auto;
}

.flow_page .flow_cot_list .item .text_wrap a {
  color: #00938f;
  font-weight: 600;
  text-decoration: underline;
}
.flow_page .flow_cot_list .item .text_wrap picture {
  width: 100%;
  margin: 0.3rem auto;
  background-color: #ffffffcf;
  padding: 0.35rem;
  display: block;
}
.flow_page .flow_cot_list .item .text_wrap picture img {
  width: 100%;
}


@media screen and (min-width: 768px) {
  .flow_page .flow_cot_list .item .text_wrap a {
    -webkit-transition: color .4s;
    transition: color .4s;
  }
  .flow_page .flow_cot_list .item .text_wrap a:hover {
    color: #e8342f;
  }
}

.flow_page .flow_cot_list .item .text_wrap .mod_text2 + .mod_text2 {
  margin-top: .15rem;
}

.flow_page .flow_cot_list .item:nth-child(odd) .text_wrap {
  background-image: url(../img/flow/bg1@2x.png);
}

.flow_page .flow_cot_list .item:nth-child(even) .text_wrap {
  background-image: url(../img/flow/bg2@2x.png);
}

.flow_page .flow_cot_list .item:not(:last-child) {
  position: relative;
}

.flow_page .flow_cot_list .item:not(:last-child)::after {
  content: "";
  width: .06rem;
  height: calc(100% + .6rem);
  background-color: #ccc;
  position: absolute;
  top: 0;
  left: .64rem;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .flow_page .flow_cot.mod_layout1 {
  	padding: .5rem 0 0.4rem;
  }
  .flow_page .flow_cot .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .flow_page .flow_cot_list .item + .item {
    margin-top: .3rem;
  }
  .flow_page .flow_cot_list .item .stit img {
    height: auto;
  }
  .flow_page .flow_cot_list .item .text_wrap {
    margin: .15rem 0 0;
    padding: .14rem .2rem;
    margin-left: .7rem;
    background-size: .06rem auto;
  }
  .flow_page .flow_cot_list .item .text_wrap .mod_text2 {
    line-height: 1.54;
  }
  .flow_page .flow_cot_list .item:not(:last-child)::after {
    width: .05rem;
    height: calc(100% + .3rem);
    left: .34rem;
  }
  .flow_page .flow_cot_list .item .text_wrap picture {
    margin: 0.3rem auto 0.1rem;
    padding: 0.15rem;
    z-index: 1;
  }
  /*
  .training .k_flow picture {
	  width: 100%;
  }
  */
  .flow_page .zoomable {
    transition: transform 0.3s ease;
  }
  .flow_page .zoomable.zoomed {
    transform: scale(1.7);
    text-align: center;
    left: -0.3rem;
    position: relative;
  }
}

/* よくあるご質問
--------------------------------------------------------------*/
/* content ----------- */
.faq_page .faq_cot.mod_layout1 {
	padding: .5rem 0 0;
}
.faq_page .faq_cot .mod_tit1 {
  margin: 0 0 .75rem;
}

.faq_page .faq_cot_item + .faq_cot_item {
  margin-top: .8rem;
}

.faq_page .faq_cot_item .mod_tit2 {
  margin: 0 0 .6rem;
}

.faq_page .faq_cot_item .lists dt,
.faq_page .faq_cot_item .lists dd {
  position: relative;
}
.faq_page .faq_cot_item .lists dt:hover{
  cursor:pointer;
}

.faq_page .faq_cot_item .lists dt::before,
.faq_page .faq_cot_item .lists dd::before {
  font-size: .32rem;
  font-weight: 700;
  letter-spacing: .06em;
  position: absolute;
  left: .28rem;
}

.faq_page .faq_cot_item .lists dt {
  padding: 0 .75rem .15rem;
  color: #064b49;
  font-size: .22rem;
  font-weight: 700;
  letter-spacing: .1em;
}

.faq_page .faq_cot_item .lists dt::before {
  content: "Q";
  top: -.08rem;
}

.faq_page .faq_cot_item .lists dd {
  padding: .33rem .32rem .22rem .75rem;
  background: #e1f0ef;
  border-top: 1px dotted #333;
  border-bottom: 1px dotted #333;
}

.faq_page .faq_cot_item .lists dd + dt {
  margin-top: .65rem;
}

.faq_page .faq_cot_item .lists dd::before {
  content: "A";
  color: #e8342f;
  top: .18rem;
}

@media screen and (max-width: 767px) {
  .faq_page .faq_cot .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .faq_page .faq_cot_item + .faq_cot_item {
    margin-top: .4rem;
  }
  .faq_page .faq_cot_item .mod_tit2 {
    margin: 0 0 .25rem;
  }
  .faq_page .faq_cot_item .lists dt::before,
  .faq_page .faq_cot_item .lists dd::before {
    font-size: .23rem;
    left: .15rem;
  }
  .faq_page .faq_cot_item .lists dt {
    padding: 0 .15rem .1rem .48rem;
    font-size: .16rem;
    line-height: 1.4375;
  }
  .faq_page .faq_cot_item .lists dt::before {
    top: -.05rem;
  }
  .faq_page .faq_cot_item .lists dd {
    padding: .16rem .13rem .14rem .48rem;
    font-size: .12rem;
    letter-spacing: .06em;
  }
  .faq_page .faq_cot_item .lists dd + dt {
    margin-top: .26rem;
  }
  .faq_page .faq_cot_item .lists dd::before {
    top: .05rem;
  }
  .faq_page .faq_cot.mod_layout1 {
	  padding: .5rem 0 0.3rem;
  }
}

/* お問い合わせ
--------------------------------------------------------------*/
/* contents ----------- */
.contact_page .contact_cot .mod_tit1 {
  margin: 0 0 .65rem;
}

.contact_page .contact_cot .mod_text3 {
  text-align: center;
}

.contact_page .contact_cot .mod_text3 .note {
  font-size: .14rem;
  letter-spacing: .1em;
}

.contact_page .contact_cot .mod_text3 .note a {
  color: #00938f;
  font-weight: 600;
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .contact_page .contact_cot .mod_text3 .note a {
    -webkit-transition: color .4s;
    transition: color .4s;
  }
  .contact_page .contact_cot .mod_text3 .note a:hover {
    color: #e8342f;
  }
}

.contact_page .contact_cot_inner {
  margin: .7rem 0 0;
}

.contact_page .contact_cot_inner .mod_tit2 {
  margin: 0 0 .75rem;
}

.contact_page .contact_cot_inner .lists {
  width: 100%;
}

.contact_page .contact_cot_inner .lists dt,
.contact_page .contact_cot_inner .lists dd {
  font-size: .22rem;
  font-weight: 400;
  letter-spacing: .06em;
}

.contact_page .contact_cot_inner .lists dt {
  width: 3rem;
  float: left;
  clear: both;
  padding: .15rem 0 0;
}

.contact_page .contact_cot_inner .lists dt .req {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: .44rem;
  height: .24rem;
  float: right;
  color: #fff;
  font-size: .16rem;
  font-weight: 600;
  background-color: #e8342f;
}

.contact_page .contact_cot_inner .lists dd {
  width: calc(100% - 3rem);
  padding: 0 0 .3rem .28rem;
}
/*221213 add　▽*/
.contact_page .contact_cot_inner .lists.formcheck dd {
  width: calc(100% - 3rem);
  padding: 0.15rem 0 0 0.15rem;
}

/*221213 add　▲*/
.contact_page .contact_cot_inner .lists dd input,
.contact_page .contact_cot_inner .lists dd textarea,
.contact_page .contact_cot_inner .lists dd select {
  width: 100%;
  padding: .05rem .17rem;
  font-size: .22rem;
  font-weight: 400;
  letter-spacing: .06em;
  background: #fff;
  border: 1px solid #666;
  outline: none;
}

@media screen and (max-width: 767px) {
  .contact_page .contact_cot_inner .lists dd input,
  .contact_page .contact_cot_inner .lists dd textarea,
  .contact_page .contact_cot_inner .lists dd select {
    font-size: .17rem;
  }
}

.contact_page .contact_cot_inner .lists dd input {
  min-height: .5rem;
}

.contact_page .contact_cot_inner .lists dd select {
  width: 3rem;
  min-height: .5rem;
  cursor: pointer;
}

.contact_page .contact_cot_inner .lists dd textarea {
  height: 3rem;
  resize: none;
}

.contact_page .contact_cot_inner .btn {
  width: 5.72rem;
  margin: .5rem auto 0;
}

.contact_page .contact_cot_inner .btn input {
  display: inline-block;
  width: 100%;
  height: 1rem;
  padding: 0;
  color: #fff;
  font-size: .28rem;
  font-weight: 700;
  letter-spacing: .06em;
  border-radius: .04rem;
  border: 3px solid #00938f;
  background-color: #00938f;
  cursor: pointer;
}

@media screen and (min-width: 768px) {
  .contact_page .contact_cot_inner .btn input {
    opacity: 1;
    -webkit-transition: background-color .4s, color .4s;
    transition: background-color .4s, color .4s;
  }
  .contact_page .contact_cot_inner .btn input:hover {
    color: #00938f;
    background-color: #fff;
  }
}

@media screen and (max-width: 767px) {
  .contact_page .contact_cot .mod_tit1 {
    margin: 0 0 .25rem;
  }
  .contact_page .contact_cot .mod_text3 {
    text-align: left;
  }
  .contact_page .contact_cot .mod_text3 .note {
    font-size: .08rem;
  }
  .contact_page .contact_cot .mod_text3 .note a {
    font-weight: 400;
  }
  .contact_page .contact_cot_inner {
    margin: .38rem 0 0;
  }
  .contact_page .contact_cot_inner .mod_tit2 {
    margin: 0 0 .3rem;
  }
  .contact_page .contact_cot_inner .lists {
    width: 100%;
  }
  .contact_page .contact_cot_inner .lists dt,
  .contact_page .contact_cot_inner .lists dd {
    font-size: .18rem;
  }
  .contact_page .contact_cot_inner .lists dt {
    width: 100%;
    float: none;
    padding: 0 0 .1rem;
  }
  .contact_page .contact_cot_inner .lists dt .req {
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    width: .27rem;
    height: .15rem;
    margin: 0 0 0 .1rem;
    float: none;
    font-size: .1rem;
    letter-spacing: .12em;
    vertical-align: middle;
  }
  .contact_page .contact_cot_inner .lists.formcheck dd {
	  padding: 0.1rem 0 0.35rem 0;
  }
  .contact_page .contact_cot_inner .lists.formcheck dd,
  .contact_page .contact_cot_inner .lists dd {
    width: 100%;
    padding: 0 0 .3rem;
  }
  .contact_page .contact_cot_inner .lists dd input,
  .contact_page .contact_cot_inner .lists dd textarea,
  .contact_page .contact_cot_inner .lists dd select {
    width: 100%;
    padding: .05rem .15rem;
    font-size: .17rem;
  }
  .contact_page .contact_cot_inner .lists dd input {
    min-height: .37rem;
  }
  .contact_page .contact_cot_inner .lists dd select {
    width: 100%;
    min-height: .37rem;
  }
  .contact_page .contact_cot_inner .lists dd textarea {
    height: 1.5rem;
  }
  .contact_page .contact_cot_inner .btn {
    width: 3.15rem;
    margin: .2rem auto 0;
  }
  .contact_page .contact_cot_inner .btn input {
    height: .6rem;
    margin: 0 auto;
    font-size: .18rem;
    border-radius: .02rem;
  }
}

/* form ----------- */
input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
  color: #333;
}
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
  color: #333;
}
input::-ms-input-placeholder,
textarea::-ms-input-placeholder {
  color: #333;
}
input::placeholder,
textarea::placeholder {
  color: #333;
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
  color: #333;
}

input::-ms-input-placeholder,
textarea:-ms-input-placeholder {
  color: #333;
}

input::-ms-input-placeholder,
textarea::-ms-input-placeholder {
  color: #333;
}

input::-ms-input-placeholder,
textarea::placeholder {
  color: #333;
}

/* プライバシーポリシー
--------------------------------------------------------------*/
/* contents ----------- */
.privacy_page .privacy_cot .mod_tit1 {
  margin: 0 0 .75rem;
}

.privacy_page .privacy_cot_item + .privacy_cot_item {
  margin-top: .8rem;
}

.privacy_page .privacy_cot_item .mod_tit2 {
  margin: 0 0 .55rem;
}

.privacy_page .privacy_cot_item .lists {
  margin: .3rem 0 0;
}

.privacy_page .privacy_cot_item .lists a {
  color: #f00;
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .privacy_page .privacy_cot_item .lists a {
    -webkit-transition: .4s;
    transition: .4s;
  }
  .privacy_page .privacy_cot_item .lists a:hover {
    opacity: .7;
  }
}

.privacy_page .privacy_cot_item.q1 .lists {
  padding: 0 0 0 .3rem;
}

.privacy_page .privacy_cot_item.q1 .lists li + li {
  margin-top: .25rem;
}

.privacy_page .privacy_cot_item.q1 .lists li .stit {
  color: #064b49;
  font-size: .14rem;
  font-weight: 400;
  letter-spacing: .14em;
  line-height: 1.57;
}

.privacy_page .privacy_cot_item.q1 .lists li .stit::before {
  left: -.3rem;
}

.privacy_page .privacy_cot_item.q2 .lists dt {
  padding: 0 0 .03rem;
  margin: 0 0 .15rem;
  color: #00938f;
  border-bottom: 1px solid #00938f;
}

.privacy_page .privacy_cot_item.q2 .lists dd + dt {
  margin-top: .2rem;
}

@media screen and (max-width: 767px) {
  .privacy_page .privacy_cot .mod_tit1 {
    margin: 0 0 .3rem;
  }
  .privacy_page .privacy_cot_item + .privacy_cot_item {
    margin-top: .35rem;
  }
  .privacy_page .privacy_cot_item .mod_tit2 {
    margin: 0 0 .25rem;
  }
  .privacy_page .privacy_cot_item .lists {
    margin: .3rem 0 0;
  }
  .privacy_page .privacy_cot_item.q1 .lists {
    padding: 0 0 0 .15rem;
  }
  .privacy_page .privacy_cot_item.q1 .lists li .stit {
    font-size: .11rem;
    letter-spacing: .1em;
  }
  .privacy_page .privacy_cot_item.q1 .lists li .stit::before {
    left: -.15rem;
  }
  .privacy_page .privacy_cot_item.q2 .lists dt {
    margin: 0 0 .1rem;
  }
  .privacy_page .privacy_cot_item.q2 .lists dd + dt {
    margin-top: .25rem;
  }
}
/*# sourceMappingURL=style.css.map */


/*230529 追加*/
.abstract {
  margin-top: 0.18rem;
  border: 3px solid #00938f;
  width: 90%;
  margin: 0.3rem auto 0.4rem auto;
}
.abstract h4 {
  font-size: 0.2rem;
  padding: 0.2rem 0.35rem;
  margin-bottom: 0.18rem;
  font-weight: bold;
  background: #00938f;
  color: #FFF;
  position: relative;
  letter-spacing: 0.02rem;
}
.abstract ul {
  padding: 0.1rem 0.16rem;
}
.abstract li {
  margin-bottom: 0.18rem;
  margin-left: 0.2rem;
  list-style-type:disc;
  position: relative;
  padding-left: 0.25rem;
}
.abstract li:before {
  position: absolute;
  content: "";
  width: 14px;
  height: 14px;
  background: #00938f;
  border-radius: 5px;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.abstract li:after {
  position: absolute;
  content: "";
  width: 4px;
  height: 4px;
  background: #FFF;
  border-radius: 1px;
  left: 5px;
  top: 0;
  bottom: 0;
  margin: auto;
}
.abstract p {
  padding: 0.1rem 0.35rem 0.3rem;
}

.info {
  font-size: 0.14rem;
  margin-top: 0.2rem;
  margin-bottom: 0.2rem;
}
.info li {
  margin-left: 0.25rem;
  list-style-type: circle;
}
.table_h5 {
  font-size: .18rem;
  font-weight: bold;
  color:#00938f ;
  margin-bottom: 0.18rem;
  margin-top: 0.18rem;
}

.mvBtn {
  display: block;
  text-align: center;
  background-color: #00938f;
  border: 2px solid #00938f;
  border-radius: 3px;
  color: #fff;
  transition: 0.5s;
  width: 80%;
  margin: 0.18rem auto;
  padding: 0.1rem;
}
.mvBtn:hover {
  background-color: #fff;
  color: #00938f;;
}
.license {
  display: flex;
  width: 45%;
  gap: 0 0.1rem;
}
.areaMv{
  margin-top: 0.1rem;
}
@media screen and (max-width: 767px) {
  .abstract{
    margin-top: 0.15rem;
    padding: 0.15rem;
    width: 96%;
  }
  .abstract li{
    margin-bottom: 0.15rem;
    list-style-type:disc;
    margin-left: 0.15rem;
  }
  .abstract p {
    line-height: 1.6;
    padding: 0rem 0.16rem 0.2rem;
    font-weight: 400;
  }
  .info{
    font-size: 0.12rem;
    margin-top: 0.2rem;
  }
  .info li{
    margin-left: 0.15rem;
  }
  .table_h5{
    font-size: .15rem;
    margin-bottom: 0.15rem;
    line-height: 1.5;
  }
  .areaMv{
  	margin-top: 0;
  }
  
  .mvBtn{
    display: block;
    width: 100%;
    margin: 0.18rem auto;
    padding: 0.05rem;
  }
}

.name_s{
  font-size: 80%;
}

.err_message{
  color: #c00;
  padding: .25rem;
  border: 1px solid #c00;
}

.btn a {
  display: block;
  background: #ccc;
  color: #333;
  border:1px solid #333;
  text-align: center;
  padding: .25rem;
  font-size: .25rem;
}

/*  ========================
  *********  食品分析士とは  *********
=============================================  */
.about_page .about_about.food_ae {
  padding-top: 0;
}


/*  ========================
  *********  training 202502  *********
=============================================  */
.mod_layout2.training_notice {
  padding-top: 0;
}

.about_page .training .about_about {
  margin-bottom: 1.4rem;
}
.about_page .training .text:before {
  background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(249,253,253,1) 78%, rgba(246,252,252,1) 100%);
  clip-path: polygon(0 0%, 100% 0, 80% 100%, 0% 100%);
  width: 53vw;
}
.about_page .training .about_about .mod_tit1:before {
  content: none;
}
.about_page .training .about_about .mod_tit1 {
  text-align: left;
  padding: 0;
}
.about_page .training .about_about .mod_tit1 span {
  position: relative;
  display: inline-block;
  margin-bottom: 0.2rem;
  padding: 0 0.4rem;
}
.about_page .training .about_about .mod_tit1 span:before {
  content: "";
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  animation: move 1s ease-in-out;
  background: #00938f;
}
.about_page .training .about_about_wrap .text {
  width: 4.6rem;
}

.reason {
  display: flex;
  justify-content: space-around;
  align-items: flex-end;
  margin-bottom: 1rem;
  text-align: center;
  line-height: 1.6;
}
.reason h5 {
  font-size: min(4.68vw,0.23rem);
  color: #00a6a2;
  margin: .3rem 0 .2rem;
  font-weight: 600;
}
.reason p {
  color: #333;
}
.balloon {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: 600;
}
.balloon .bal {
  font-size: min(3.3vw,0.23rem);
  padding: 0.1rem 0.2rem;
  display: inline-block;
  width: fit-content;
}
.balloon .bal.bal01,
.balloon .bal.bal03 {
  background: #00a6a2;
  color: #FFF;
  margin: 1em 0rem 0;
}
.balloon .bal.bal02,
.balloon .bal.bal04 {
  border: 2px solid #00a6a2;
  color: #00a6a2;
  margin: 1em 0 0 2rem;
}
.center {
  text-align: center;
  margin: .5rem auto 1rem;
}
.bottom_arrow {
  width: 172px;
  height: 60px;
  background: #00a6a2;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  margin: 0.3rem auto 0.3rem;
}

.emp {
  font-size: min(5vw,0.36rem);
  color: #00a6a2;
  line-height: 1.6;
  font-weight: 700;
}
.emp span {
  font-size: min(6vw,0.6rem);
  background: linear-gradient(transparent 80%, #ffd9ff 10%);
}
.emp02 {
  position: relative;
  padding: 0.1em 1em;
  line-height: 1.2;
  display: inline-block;
  margin-top: 0.4em;
  margin-bottom: 0.3em;
  margin-left: 4em;
}
.emp02::before,
.emp02::after {
    position: absolute;
    top: -3px;
    width: 10px;
    height: 100%;
    content: '';
    border-top: solid 1px;
    border-bottom: solid 1px;
}

.emp02::before {
    border-left: solid 1px;
    left: 0;
}

.emp02::after {
    border-right: solid 1px;
    right: 0;
}
.data_li p span.emp02 small  {
  text-indent: initial;
  margin-left: 0;
}
/*
.data_li p small {
  display: block;
  margin-bottom: 0.5em;
  text-indent: 5em;
}
*/
.data_li p small {
	display: block;
    margin-bottom: 0.5em;
}
.data_li p.indent02 small {
  margin-left: 4em;
  text-indent: initial;
}
.data_li p.indent03 small {
  margin-left: 5em;
  text-indent: initial;
}
.training p.note {
  font-size: min(2.6vw,0.16rem);
  margin-top: 0.2rem;
}
.btnArea {
  display: flex;
  gap: 0 0.25rem;
  justify-content: center;
  font-weight: 700;
}
.btnArea div {
  width: calc(100%/2);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.btnArea div p {
  font-size: .36rem;
}
.nmlBtn {
  color: #00a6a2;
  background: #FFF;
  border: 2px solid #00a6a2;
  width: 100%;
  height: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: .28rem;
  margin: .3rem 0 .5rem;
  border-radius: .04rem;
}
.nmlBtn .icon::after {
  background-image: url(../img/cmn/apply_icon_green.png);
  content: "";
  width: .2rem;
  height: .2rem;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center;
  position: absolute;
  top: calc(50% - .1rem);
  right: 0;
}
.nmlBtn:hover {
  background: #00a6a2;
  color: #FFF;
}
a.nmlBtn {
  transition: color .4s, background-color .4s;
}
a.nmlBtn .icon {
  display: inline-block;
  padding-right: .3rem;
  position: relative;
}

.btnArea.btnArea02 {
  width: 100%;
}
.btnArea.btnArea02 div {
  width: 100%;
  text-align: center;
  font-size: .24rem;
}
.btnArea.btnArea02 .text_red {
  color: #c00;
  font-size: .24rem;
}
.btnArea.btnArea02 .nmlBtn {
  max-width: 600px;
}
.sp_srollpop {
  display: none;
}
@media screen and (min-width:769px) {
	.training .container {
		margin-bottom: 1rem;
	}
}
@media screen and (max-width: 768px) { 
  .reason {
    gap: 0.2rem;
    flex-wrap: wrap;
    margin-bottom: 5.2vw;
  }
  .reason div {
    width: 80%;
    margin-bottom: 0.2rem;
  }
  .reason div img {
    width: 30%;
  }
  .balloon .bal.bal01, .balloon .bal.bal03 {
    margin: .05rem 0.4rem .05rem 0;
  }
  .balloon .bal.bal02, .balloon .bal.bal04 {
    margin: .05rem 0 .05rem 0.4rem;
  }
  .center {
    margin-top: 0.2rem;
    margin-bottom: 0.2rem;
  }
  .btnArea {
    flex-wrap: wrap;
  }
  .btnArea div {
    width: 100%;
  }
  .btnArea div p {
    font-size: 5vw;
    margin: .2rem 0;
  }
  .nmlBtn {
    font-size: 5vw;
    margin: 0 0 5.2vw;
    height: 15.6vw;
  }
  .btnArea.btnArea02 {
    margin-top: 0.2rem;
    line-height: 1.4;
  }
  .btnArea.btnArea02 .text_red {
    font-size: 5vw;
    margin-top: 0;
  }
  .sp_ov {
    overflow-x: scroll;
    padding: 0.2rem 0;
    position: relative;
  }
  .sp_ov figure {
    width: 550px;
  }
  .sp_srollpop {
    display: block;
    color: #00938f;
    margin-top: 10px;
    border-radius: 50px;
    font-size: 12px;
    text-align: right;
    animation: flash 2s infinite;
  }
  .about_page .training .container {
	  margin-bottom: 0.65rem;
  }
  .about_page .training .about_about {
    min-height: 115.88vw;
    padding: 0;
    overflow: hidden;
    margin-bottom: 0.6rem;
  }
  .about_page .training .about_about_wrap {
    padding-top: 0!important;
  }
  .about_page .training .training_fv {
    margin-bottom: 0;
  }
  .about_page .training .about_about_wrap .text {
    position: absolute;
    top: 5%;
    left: 0%;
    width: 85%;
  }
  .about_page .training .about_about_wrap .pic {
    margin-top: 0;
  }
  .about_page .training .about_about_wrap h2 {
    display: flex;
    flex-direction: column;
  }
  .about_page .training .about_about .mod_tit1 span {
    width: fit-content;
    padding: 0 0.2rem;
    margin-bottom: 0.1rem;
  }
  .about_page .training .about_about .text p.mod_text1 {
    top: 25vw;
  }
}
@keyframes flash {
  0% {
    opacity: 1;
  }
  60% {
    opacity: 1;
  }
  80% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
  
}

/*  ========================
  *********  case 202502  *********
=============================================  */
.case .caseBox {
  border: 1px solid #666666;
  padding: 0 0.25rem 0.25rem;
  line-height: 1.8;
  margin-bottom: 1rem;
}

@media screen and (min-width:769px) {
  .case > div:nth-child(5) {
	margin-bottom: 1.5rem;
  }
}
.case .caseBox .tag {
  background: #00a6a2;
  text-align: right;
  display: flex;
  justify-content: right;
  width: fit-content;
  margin-left: auto;
  margin-bottom: 0.25rem;
  padding: 0.2rem;
}
.case .caseBox h3 {
  color: #00a6a2;
  font-size: 0.36rem;
  font-weight: 600;
  line-height: 1.4;
}
.case .caseBox h4 {
  color: #00a6a2;
  padding-bottom: 0.1rem;
  margin-bottom: 0.2rem;
  border-bottom: 3px dashed #00a6a2;
  font-size: 0.26rem;
  font-weight: 600;
}
.sub_company {
  font-size: 0.2rem;
  margin: 0.15rem 0 0.35rem;
}
.case .caseBox .flex {
  display: flex;
  gap: 0 0.25rem;
}
.case .caseBox .flex.flex02 div {
  width: calc(100%/2);
}
.case .caseBox .flex p {
  margin-bottom: 0.4rem;
  font-weight: 400;
}
.case .caseBox figure {
  max-width: 370px;
  width: 100%;
  flex-shrink: 0;
  margin-bottom: 0.45rem;
}
.case .subBox {
  background: #fbeceb;
  border: 1px solid #ffb7b7;
  padding: 0.25rem;
  border-radius: 5px;
  margin-bottom: 0.35rem;
}
.case .caseBox .subBox .ttl {
  margin-bottom: 0.15rem;
  font-size: 0.2rem;
  font-weight: 600;
}
.case .caseBox .subBox figure {
  max-width: 180px;
  margin-bottom: 0;
}
.case .caseBox .subBox .flex p {
  margin-bottom: 0;
}

.companyBox {
  border: 1px solid #999;
  padding: 0.25rem 0.3rem;
}
.companyBox p.sub_company {
  margin: 0 0 0.15rem;
  font-weight: 600;
}
.companyBox p {
  font-weight: 400;
}
.comment {
  background: #f9efde;
  padding-bottom: 0.25rem;
  margin: 0.5rem 0 0.3rem;
}
.comment .ttl {
  background: #e8cca2;
  color: #FFF;
  padding: 0.1rem 0;
  text-align: center;
  font-size: 0.2rem;
  font-weight: 600;
}
.comment p {
  font-weight: 400;
  padding: 0.3rem 0.25rem 0;
}

@media screen and (max-width: 768px) { 
  .case .caseBox {
    padding: 0 4vw 4vw;
  }
  .case .caseBox .tag {
    width: 50%;
    padding: 0.15rem 0.1rem;
  }
  .case .caseBox h3 {
    font-size: 5.7vw;
  }
  .sub_company {
    font-size: 3.5vw;
    margin: 0.05rem 0 0.25rem;
  }
  .case .caseBox .flex {
    flex-wrap: wrap;
  }
  .case .caseBox h4 {
    font-size: 4.3vw;
  }
  .case .caseBox figure {
    margin-bottom: .3rem;
  }
  .case .caseBox .flex.flex02 div {
    width: 100%;
  }
  .case .companyBox {
    padding: 4vw;
  }
  .comment {
    margin-bottom: 0;
  }
  .comment .ttl {
    font-size: 4.3vw;
  }
  .comment p {
    padding: 4vw 4vw 0;
  }
  .case .subBox {
    padding: 0.15rem;
  }
  .case .caseBox .subBox .ttl {
    font-size: 3.5vw;
  }
  .case .caseBox .subBox figure {
    margin: 0 auto 0.15rem;
  }
}

/*  ========================
  *********  about 202502  *********
=============================================  */

.tab {
  display: flex;
  gap: 0 0.1rem;
  text-align: center;
  flex-wrap: wrap;
  box-sizing: border-box;
  margin-bottom: 0.5rem;
  margin-top: 0.4rem;
}
.tab li {
  border: 2px solid #00938f;
  color: #00938f;
  width: calc(100%/4 - 0.15rem);
  padding: 0.15rem;
  margin-bottom: 0.15rem;
  border-radius: 4px;
  transition: all .5s;
  cursor: pointer;
}
.tab li.active {
  background: #00938f;
  color: #FFF;
}
.tabArea .tabBox {
  display: none;
}
.tabArea .tabBox.active {
  display: block;
}
.mb1 {
	margin-bottom: 0.1rem;
}

@media screen and (max-width: 768px) { 
  .abstract {
    padding: 0;
  }
  .abstract h4 {
    text-align: center;
    padding: 0.2rem 0.1rem;
    font-size: .16rem;
  }
  .abstract li {
    margin-left: 0;
    line-height: 1.4;
    font-size: .13rem;
    font-weight: 400;
  }
  .tab {
    margin-top: 0;
    margin-bottom: 0.4rem;
  }
  .tab li {
    width: calc(100%/2 - 0.05rem);
    font-size: .16rem;
    border-radius: .04rem;
  }
}
