@charset "UTF-8";
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0;
  outline: 0;
  background: 0 0
}

body {
  line-height: 1;
  -webkit-text-size-adjust: 100%
}

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

ol, ul {
  list-style: none
}

blockquote, q {
  quotes: none
}

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

a {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  text-decoration: none;
  color: inherit;
  background: 0 0
}

ins {
  text-decoration: none;
  color: #000;
  background-color: #ff9
}

mark {
  font-weight: 700;
  font-style: italic;
  color: #000;
  background-color: #ff9
}

del {
  text-decoration: line-through
}

abbr[title], dfn[title] {
  cursor: help;
  border-bottom: 1px dotted
}

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

hr {
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
  border: 0;
  border-top: 1px solid #ccc
}

button, input, textarea {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: 0;
  background: 0 0
}

input::-ms-clear {
  visibility: hidden
}

select::-ms-value {
  color: #333;
  background: 0 0
}

input[type=button], input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration, input[type=submit] {
  -webkit-appearance: none
}

* {
  box-sizing: border-box
}

:after, :before {
  box-sizing: inherit
}

html {
  width: 100%
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

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

html {
  font-size: 62.5%
}

body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
  color: #333
}

body.noscroll {
  overflow: hidden
}

body .scroll.open {
  overflow: scroll
}

body a[href] {
  -webkit-transition: all 0.2s;
  transition: all 0.2s
}

body a[href] img {
  -webkit-transition: all 0.2s;
  transition: all 0.2s
}

body a[href] img:hover {
  opacity: 0.5
}

body a[href^="tel:"] {
  cursor: default
}

body a [class*=" outlink_"]:after, body a [class^=outlink_]:after {
  display: inline-block;
  margin-left: 10px;
  content: "";
  background-size: contain
}

body a .outlink_g:after {
  width: 16px;
  height: 13px;
  background: url(../images/icon_outlink_gray.png) no-repeat
}

body a .outlink_w:after {
  width: 12px;
  height: 10px;
  background: url(../images/icon_outlink_w.png) no-repeat
}

body a [class*=" icon_"]:after, body a [class^=icon_]:after {
  position: relative;
  top: 5px;
  display: inline-block;
  width: 20px;
  height: 25px;
  margin-right: 5px;
  margin-left: 10px;
  content: "";
  background-size: contain
}

body a [class*=" icon_"]:before, body a [class^=icon_]:before {
  display: none
}

body a .icon_pdf:after, body a .icon_pdf:before {
  background-image: url(../images/icon_pdf.png);
  background-repeat: no-repeat
}

body a .icon_xls:after, body a .icon_xls:before {
  background-image: url(../images/icon_xls.png);
  background-repeat: no-repeat
}

body a .icon_doc:after, body a .icon_doc:before {
  background-image: url(../images/icon_doc.png);
  background-repeat: no-repeat
}

body a .icon_ppt:after, body a .icon_ppt:before {
  background-image: url(../images/icon_ppt.png);
  background-repeat: no-repeat
}

body a .icon_zip:after, body a .icon_zip:before {
  background-image: url(../images/icon_zip.png);
  background-repeat: no-repeat
}

body a .icon_other:after, body a .icon_other:before {
  background-image: url(../images/icon_other.png);
  background-repeat: no-repeat
}

body img {
  width: 100%;
  height: auto;
  vertical-align: bottom
}

.footer {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  font-weight: 300;
  width: calc(100% - 180px);
  margin-top: 60px;
  margin-left: 180px
}

.footer .pagetop {
  font-family: Roboto;
  width: 100%;
  color: #fff
}

.footer .pagetop a {
  line-height: 80px;
  display: block;
  text-align: center;
  background-color: #198a3b
}

.footer .pagetop a:hover {
  opacity: 0.5
}

.footer .pagetop a img {
  width: 17px;
  margin: 0 18px;
  vertical-align: middle
}

.footer .pagetop a img:hover {
  opacity: 1
}

.footer_nav {
  background-color: #eee
}

.footer_nav_inner {
  max-width: 1060px;
  margin: 0 auto
}

.footer_nav_top {
  display: -webkit-box;
  display: flex;
  padding: 40px 0 23px;
  border-bottom: 1px solid #ccc;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

.footer_nav_top .footer_logo img {
  width: 150px
}

.footer_nav_top ul {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center
}

.footer_nav_top ul li {
  margin: 0 24px
}

.footer_nav_top ul li :last-child {
  margin-right: 0
}

.footer_nav_top ul li a:hover {
  text-decoration: underline
}

.footer_nav_menu {
  font-weight: 400;
  display: -webkit-box;
  display: flex;
  padding: 50px 14%;
  color: #198a3b;
  border-bottom: 1px solid #ccc;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

.footer_nav_menu a:hover {
  text-decoration: underline
}

.footer_nav_sub {
  display: -webkit-box;
  display: flex;
  padding: 30px 0;
  -webkit-box-align: center;
  align-items: center
}

.footer_nav_sub li {
  margin-right: 56px
}

.footer_nav_sub li:last-child {
  margin-right: 0
}

.footer_nav_sub li a:hover {
  text-decoration: underline
}

.footer .copyright {
  padding: 20px 0;
  text-align: center
}

.footer .copyright strong {
  font-weight: 500;
  color: #198a3b
}

.header_pc {
  font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  position: relative;
  z-index: 30;
  display: -webkit-box;
  display: flex;
  width: 100%;
  height: 60px;
  border-bottom: 1px solid #ddd;
  background-color: #fff;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: end;
  justify-content: flex-end
}

.header_pc_headlink {
  display: -webkit-box;
  display: flex;
  padding-right: 6.42%;
  -webkit-box-align: center;
  align-items: center
}

.header_pc_headlink li {
  margin-right: 50px;
  white-space: nowrap
}

.header_pc_headlink li a:hover {
  text-decoration: underline
}

.header_pc_search_wrap {
  position: absolute;
  z-index: 10;
  top: 10px;
  right: 10px;
  width: 80px;
  height: 80px;
  background-color: #fff
}

.header_pc_search {
  font-size: 1.4rem;
  width: 100%;
  height: 100%;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  text-align: center;
  color: #fff;
  background-color: #333
}

.header_pc_search:hover {
  opacity: 0.7
}

.header_pc_search_trigger {
  display: block;
  width: 100%;
  height: 100%;
  padding-top: 45px;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  background: url(../images/icon_search.png) no-repeat;
  background-position: top 16px left 30px;
  background-size: 22px 22px
}

.header_pc_search_box {
  position: absolute;
  z-index: 9;
  top: 60px;
  left: 180px;
  display: none;
  width: calc(100% - 180px);
  background-color: #555
}

.header_pc_search_box_inner {
  position: relative;
  padding: 45px 0
}

.header_pc_search_box form {
  text-align: center
}

.header_pc_search_box input[type=text] {
  font-size: 1.8rem;
  width: 427px;
  height: 48px;
  margin-right: 8px;
  padding: 0 1em;
  background-color: #fff
}

.header_pc_search_box input[type=text]:focus {
  outline: 0
}

.header_pc_search_box input[type=text]:focus::-webkit-input-placeholder {
  color: transparent
}

.header_pc_search_box input[type=text]:focus::-moz-placeholder {
  color: transparent
}

.header_pc_search_box input[type=text]:focus:-ms-input-placeholder {
  color: transparent
}

.header_pc_search_box input[type=text]:focus::-ms-input-placeholder {
  color: transparent
}

.header_pc_search_box input[type=text]:focus::placeholder {
  color: transparent
}

.header_pc_search_box input[type=text]:focus::-webkit-input-placeholder {
  color: transparent
}

.header_pc_search_box input[type=submit] {
  font-size: 1.8rem;
  width: 123px;
  height: 48px;
  padding: 0 1em;
  cursor: pointer;
  color: #fff;
  border: none;
  background-color: #32ac57
}

.header_pc_search_box .close_btn {
  position: absolute;
  top: 58px;
  right: 120px;
  display: block;
  width: 22px;
  height: 22px;
  cursor: pointer
}

.header_pc_search_box .close_btn:before {
  position: absolute;
  top: 50%;
  display: block;
  width: 22px;
  height: 1px;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #fff
}

.header_pc_search_box .close_btn:after {
  position: absolute;
  top: 50%;
  display: block;
  width: 22px;
  height: 1px;
  content: "";
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  background-color: #fff
}

.header_side {
  font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  position: fixed;
  z-index: 9999;
  top: 0;
  width: 180px;
  height: 100%;
  color: #fff;
  background-color: #f0f0f0;
  box-shadow: 2px 0 4px 0 rgba(0, 0, 0, 0.2)
}

.header_side_logo {
  position: absolute;
  width: 100%;
  height: 180px;
  background-color: #fff
}

.header_side_logo a {
  display: block;
  width: 100%;
  height: 100%
}

.header_side_logo img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 150px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}

.header_side_gnav {
  position: absolute;
  top: 180px;
  width: 100%
}

.header_side_gnav li {
  position: relative;
  display: -webkit-box;
  display: flex;
  height: 94px;
  cursor: pointer;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2)
}

.header_side_gnav li::after{
    content: "";
    width: 0.7rem;
    height: 0.7rem;
    position: absolute;
    border-top: solid 0.2rem #fff;
    border-right: solid 0.2rem #fff;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}

.header_side_gnav li:first-child {
  background: #198a3b
}

.header_side_gnav li:first-child.current {
  background: #1f7b3b
}

.header_side_gnav li:first-child.current.on {
  background: #eee
}

.header_side_gnav li:nth-child(2) {
  background: #209342
}

.header_side_gnav li:nth-child(2).current {
  background: #1b7736
}

.header_side_gnav li:nth-child(2).current.on {
  background: #eee
}

.header_side_gnav li:nth-child(3) {
  background: #249a47
}

.header_side_gnav li:nth-child(3).current {
  background: #20803c
}

.header_side_gnav li:nth-child(3).current.on {
  background: #eee
}

.header_side_gnav li:nth-child(4) {
  background: #2ba34f
}

.header_side_gnav li:nth-child(4).current {
  background: #198a3b
}

.header_side_gnav li:nth-child(4).current.on {
  background: #eee
}

.header_side_gnav li:nth-child(5) {
  background: #2ea752
}

.header_side_gnav li:nth-child(5).current {
  background: #209342
}

.header_side_gnav li:nth-child(5).current.on {
  background: #eee
}

.header_side_gnav li p {
  display: -webkit-box;
  display: flex;
  width: 100%;
  -webkit-box-align: center;
  align-items: center;
  flex-direction: column;
  justify-content: center;
}

.header_side_gnav li p .off {
  width: 28px;
  margin-bottom: 10px;
}

.header_side_gnav li p .on {
  display: none
}

.header_side_gnav li p img:hover {
  opacity: 1
}

.header_side_gnav li:hover {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  opacity: 0.6;
}

.header_side_gnav li.on {
  color: #333;
  background-color: #eee
}
.header_side_gnav li.on::after {
    border-color: #333;
}

.header_side_gnav li.on p .off {
  display: none;
}

.header_side_gnav li.on p .on {
  display: block;
  width: 28px;
  margin-bottom: 10px;
}

.header_side_gnav li:nth-child(4) p img.off,
.header_side_gnav li:nth-child(4) p img.on {
    margin-bottom: 5px;
}

.header_side:after {
  display: block;
  width: 100vw;
  height: 100%;
  content: "";
  -webkit-transform: translate(-100%);
  transform: translate(-100%);
  background-color: #fff
}

.header_menu {
  font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  position: fixed;
  z-index: 20;
  top: 0;
  overflow-y: scroll;
  width: calc(100% - 180px);
  height: 100vh;
  margin-left: 180px;
  padding-top: 60px;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-transform: translate(-100%);
  transform: translate(-100%);
  background-color: #eee
}

.header_menu.open {
  -webkit-transform: translate(0);
  transform: translate(0)
}

.header_menu_inner {
  display: none;
  padding: 35px 80px
}

.header_menu_inner.open {
  display: block
}

.header_menu_inner p {
  margin-top: 20px
}

.header_menu_ttl {
  font-size: 2.4rem;
  position: relative;
  padding-bottom: 20px;
  border-bottom: 1px solid #333
}

.header_menu_inner:nth-of-type(4) .header_menu_ttl {
  padding-bottom: 15px;
}

.header_menu_ttl a[href] {
  display: -webkit-box;
  display: flex;
  -webkit-transition: none;
  transition: none;
  -webkit-box-align: center;
  align-items: center
}

.header_menu_ttl a[href] img {
  width: 37px;
  margin-right: 13px;
  vertical-align: middle
}

.header_menu_ttl a[href] img:hover {
  opacity: 1
}

.header_menu_ttl a[href] img:last-of-type {
  display: none
}

.header_menu_ttl a:hover {
  color: #32ac57
}

.header_menu_ttl a:hover img:first-of-type {
  display: none
}

.header_menu_ttl a:hover img:last-of-type {
  display: inline
}

.header_menu_ttl .close_btn {
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 30px;
  height: 30px;
  cursor: pointer;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.header_menu_ttl .close_btn:before {
  position: absolute;
  top: 50%;
  display: block;
  width: 30px;
  height: 1px;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #333
}

.header_menu_ttl .close_btn:after {
  position: absolute;
  top: 50%;
  display: block;
  width: 30px;
  height: 1px;
  content: "";
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  background-color: #333
}

.header_menu_ttl.-arw span:not(.close_btn) {
  position: relative;
  padding-right: 40px
}

.header_menu_ttl.-arw span:not(.close_btn):after {
  position: absolute;
  top: 10px;
  right: 0;
  width: 24px;
  height: 24px;
  content: "";
  background: url(../images/icon_arw.png) no-repeat;
  background-size: contain
}

.header_menu_items {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

.header_menu_item {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  width: 33.3%;
  padding: 20px 25px 0 0
}

.header_menu_item_ttl {
  font-size: 1.6rem;
  font-weight: 500;
  display: -webkit-box;
  display: flex;
  min-height: 24px;
  margin-top: 40px;
  margin-bottom: 10px;
  color: #32ac57;
  -webkit-box-align: center;
  align-items: center
}

.header_menu_item_ttl:first-child {
  margin-top: 0
}

.header_menu_item_ttl.sub_category a {
  position: relative;
  padding-right: 35px
}

.header_menu_item_ttl.sub_category a:hover {
  opacity: 0.5
}

.header_menu_item_ttl.sub_category a:after {
  position: absolute;
  top: 5px;
  right: 0;
  width: 24px;
  height: 24px;
  content: "";
  background: url(../images/icon_arw.png) no-repeat;
  background-size: contain
}

.header_menu_item figure {
  border: 2px solid #198a3b
}

.header_menu_item .list_line.special {
  margin-bottom: 5px
}

.header_menu_item .list_line li {
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  margin-bottom: 13px
}

.header_menu_item .list_line li:before {
  display: block;
  margin-right: 10px;
  content: "-";
  -webkit-box-flex: 0;
  flex: 0 0 4px
}

.header_menu_item .list_line li a:hover {
  text-decoration: underline
}

.header_sp {
  display: none
}

.header_sp_gnav-overlay {
  display: none
}

.heading_btn {
  display: none
}

.localnav.-slide {
  display: block
}

.localnav_back {
  display: none
}

.sublnav {
  position: relative;
  display: none;
  padding: 6px 3.16% 14px;
  border-bottom: 1px solid #ccc
}

.sublnav.no-border {
  border-bottom: none
}

.sublnav.hidden {
  display: none
}

.sublnav_ttl {
  display: none
}

.sublnav_lists {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

.sublnav_lists_item {
  font-size: 1.4rem;
  position: relative;
  margin-top: 8px;
  padding: 0 1.53%
}

.sublnav_lists_item:first-child {
  display: none
}

.sublnav_lists_item:last-child {
  border-right: none
}

.sublnav_lists_item>a {
  line-height: 1.6;
  display: -webkit-box;
  display: flex;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

.sublnav_lists_item>a[href="javascript:void(0);"] {
  font-weight: 500;
  opacity: 1;
  border-bottom: 1px solid #333
}

.sublnav_lists_item>a:hover {
  border-bottom: 2px solid #32ac57
}

.sublnav_lists_item>a:before {
  display: block;
  width: 12px;
  height: 2px;
  margin-right: 12px;
  content: "";
  background: #32ac57
}

.sublnav_lists_item .a_current {
  font-weight: 500;
  border-bottom: 2px solid #32ac57
}

.sublnav_lists_item.sublnav_arw>a:before {
  width: 8px;
  height: 8px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  border-right: 2px solid #32ac57;
  border-bottom: 2px solid #32ac57;
  background: inherit
}

.sublnav_lists_item.sublnav_arw>a.active:before {
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg)
}

.sublnav_lists_item.sublnav_arw.active:before {
  position: absolute;
  z-index: 3;
  bottom: -25px;
  left: 50%;
  display: block;
  width: 0;
  height: 0;
  content: "";
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-width: 25px 25px 0 25px;
  border-style: solid;
  border-color: #fff transparent transparent transparent
}

.sublnav_sub {
  position: absolute;
  z-index: 10;
  top: 34px;
  right: 0;
  left: 0;
  display: none;
  width: calc(100vw - 180px);
  background: rgba(0, 0, 0, 0.3)
}

.sublnav_sub_inner {
  position: relative;
  display: -webkit-box;
  display: flex;
  overflow: hidden;
  margin: 40px;
  padding: 40px 0;
  background: #fff;
  flex-wrap: wrap
}

.sublnav_sub_lists {
  width: 50%;
  margin-top: 80px;
  padding: 0 40px
}

.sublnav_sub_lists .sublnav_sub_top {
  font-size: 2rem;
  position: absolute;
  top: 40px;
  display: -webkit-box;
  display: flex;
  color: #32ac57;
  -webkit-box-align: center;
  align-items: center
}

.sublnav_sub_lists .sublnav_sub_top:hover {
  border-bottom: 1px solid #32ac57
}

.sublnav_sub_lists .sublnav_sub_top a:after {
  content: none
}

.sublnav_sub_lists .sublnav_sub_top a.a_current:hover {
  border-bottom: none
}

.sublnav_sub_lists .sublnav_sub_top>a:not(.a_current) {
  border-bottom: none
}

.sublnav_sub_lists .sublnav_sub_top>a:not(.a_current):hover {
  border-bottom: none
}

.sublnav_sub_lists .sublnav_sub_top:before {
  display: block;
  width: 24px;
  height: 24px;
  margin-right: 14px;
  content: "";
  background: url(../images/icon_arw.png) no-repeat;
  background-size: contain;
  -webkit-box-flex: 0;
  flex: 0 0 24px
}

.sublnav_sub_lists.-left li:nth-child(2) {
  margin-top: 0
}

.sublnav_sub_lists.-right {
  border-left: 1px solid #ccc
}

.sublnav_sub_lists li {
  font-size: 1.6rem;
  margin-top: 24px
}

.sublnav_sub_lists li:first-child {
  margin-top: 0
}

.sublnav_sub_lists li>a {
  border-bottom: 2px solid transparent
}

.sublnav_sub_lists li>a:hover {
  border-bottom: 2px solid #32ac57
}

.sublnav_sub_lists li a {
  position: relative;
  display: -webkit-box;
  display: flex;
  padding-right: 10px;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

.sublnav_sub_lists li a:after {
  position: absolute;
  top: calc(50% - 4px);
  right: 0;
  display: block;
  width: 8px;
  height: 8px;
  content: "";
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  border-right: 2px solid #32ac57;
  border-bottom: 2px solid #32ac57
}

.sublnav_sub_close {
  position: absolute;
  top: 0;
  right: 0;
  display: -webkit-box;
  display: flex;
  width: 50px;
  height: 50px;
  background: #eee;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center
}

.sublnav_sub_close span {
  position: relative;
  display: block;
  width: 16px;
  height: 16px
}

.sublnav_sub_close span:before {
  position: absolute;
  left: 0;
  display: block;
  width: 23px;
  height: 2px;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  background: #555
}

.sublnav_sub_close span:after {
  position: absolute;
  right: 0;
  display: block;
  width: 23px;
  height: 2px;
  content: "";
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
  background: #555
}

.sublnav>.sublnav_lists>.sublnav_lists_item>.sublnav_sub>.sublnav_sub_inner>.sublnav_sub_lists>.sublnav_lists_item>a:before {
  content: none
}

main {
  display: block;
  width: calc(100% - 180px);
  margin-left: 180px
}

main .container {
  position: relative;
  max-width: 1060px;
  margin: 0 auto;
  margin-top: 45px
}

main .ir_heading {
  font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  display: -webkit-box;
  display: flex;
  padding: 0 4.6%;
  color: #fff;
  background-color: #32ac57;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .ir_heading .heading, main .ir_heading h1 {
  font-weight: 400;
  display: -webkit-box;
  display: flex;
  padding: 0;
  letter-spacing: 2px;
  -webkit-box-align: center;
  align-items: center;
  flex-wrap: wrap
}

main .ir_heading .heading span, main .ir_heading h1 span {
  font-size: 1.6rem
}

main .ir_heading .heading .heading_main, main .ir_heading h1 .heading_main {
  font-size: 2.8rem;
  line-height: 1.2;
  padding-top: 8px;
  padding-bottom: 8px
}

main .ir_heading .heading .heading_sub, main .ir_heading h1 .heading_sub {
  display: none
}

main .ir_heading_inner {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  display: -webkit-box;
  display: flex;
  padding: 20px 2.83%;
  letter-spacing: 2px;
  background-color: #198a3b;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: end;
  justify-content: flex-end
}

main .ir_heading_inner .code {
  display: block;
  margin-right: 30px;
  white-space: nowrap
}

main .ir_heading_inner .stock {
  display: inline-block;
  padding: 2px 12px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  white-space: nowrap;
  border: 1px solid #fff
}

main .ir_heading_inner .stock:nth-of-type(2) {
  margin-left: 16px
}

main .ir_heading_inner .stock:hover {
  opacity: 0.5
}

main .ir_heading_inner .stock:after {
  width: 12px;
  height: 10px;
  margin-left: 7px
}

main .ir_heading_inner.-product {
  padding: 20px 22px
}

main .ir_heading_inner.-product .stock {
  padding: 2px 10px;
  letter-spacing: 0
}

main .ir_heading_inner.-product .stock.-icon:before {
  display: inline-block;
  width: 17px;
  height: 12px;
  margin-right: 6px;
  margin-bottom: -1px;
  content: "";
  background: url(../images/icon_contact_w.png) no-repeat;
  background-size: contain
}

main .ir_heading.fixed {
  position: fixed;
  z-index: 10;
  top: 50px;
  right: 0;
  left: 0
}

main .breadcrumbs {
  font-size: 1.2rem;
  margin-right: 90px;
  padding: 14px 20px;
  color: #555
}

main .breadcrumbs ul {
  display: block
}

main .breadcrumbs ul:after {
  display: block;
  clear: both;
  content: ""
}

main .breadcrumbs ul li {
  float: left;
  width: auto
}

main .breadcrumbs ul li a {
  color: #198a3b
}

main .breadcrumbs ul li a:hover {
  text-decoration: underline
}

main .breadcrumbs ul li:after {
  display: inline-block;
  width: 3px;
  height: 3px;
  margin: 2px 10px;
  content: "";
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  border-right: 2px solid #ccc;
  border-bottom: 2px solid #ccc
}

main .breadcrumbs ul li:last-child:after {
  content: none
}

main .heading {
  font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 2.8rem;
  font-weight: 400;
  padding: 10px 4.6%;
  letter-spacing: 2px;
  color: #fff;
  background-color: #32ac57
}

main .container.error {
  padding: 60px 0 27px
}

main .container.calendar {
  padding: 0 0 30px
}

main .localnav {
  padding: 0 2.87% 15px;
  background: #eee
}

main .localnav ul {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .localnav ul li {
  margin-top: 15px;
  padding: 0 1.82%;
  border-right: 1px solid #999
}

main .localnav ul li:last-child {
  border-right: none
}

main .localnav ul li a {
  line-height: 1.6;
  display: block;
  white-space: nowrap;
  border-bottom: 2px solid transparent
}

main .localnav ul li a[href="javascript:void(0);"] {
  font-weight: 500;
  border-bottom: 1px solid #333
}

main .localnav ul li a:hover {
  border-bottom: 2px solid #32ac57
}

main .localnav ul li .a_current {
  font-weight: 500;
  border-bottom: 2px solid #32ac57
}

main .subnav {
  padding: 6px 3.16% 14px;
  border-bottom: 1px solid #ccc
}

main .subnav ul {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .subnav ul li {
  font-size: 1.4rem;
  margin-top: 10px;
  padding: 0 1.53%;
  border-right: 1px solid #b4b4b4
}

main .subnav ul li:last-child {
  border-right: none
}

main .subnav ul li a {
  line-height: 1.6;
  display: block;
  white-space: nowrap;
  border-bottom: 2px solid transparent
}

main .subnav ul li a[href="javascript:void(0);"] {
  font-weight: 500;
  opacity: 1;
  border-bottom: 1px solid #333
}

main .subnav ul li a:hover {
  border-bottom: 2px solid #32ac57
}

main .subnav ul li .a_current {
  font-weight: 500;
  border-bottom: 2px solid #32ac57
}

main .standard_txt {
  margin-bottom: 25px;
  color: #555
}

main .standard_txt.left {
  text-align: left
}

main .standard_txt.center {
  text-align: center
}

main .standard_txt.right {
  text-align: right
}

main .standard_txt a {
  font-weight: 500;
  text-decoration: underline
}

main .standard_txt a:hover {
  opacity: 0.7
}

main .standard_txt .red {
  font-weight: 500;
  color: #da5442
}

main .annotation {
  margin-bottom: 30px;
  padding: 15px 20px 1px;
  color: #555;
  background: #f5f5f5
}

main .annotation.back-white {
  background: #fff
}

main .annotation.pd-0 {
  padding: 0
}

main .annotation .annotation_txt {
  line-height: 1.7;
  margin-bottom: 15px
}

main .annotation .annotation_list {
  line-height: 1.7;
  margin-bottom: 15px
}

main .annotation .annotation_list.decimal {
  padding-left: 20px
}

main .annotation .annotation_list.decimal>li {
  display: list-item;
  padding-left: 10px;
  list-style: decimal
}

main .annotation .annotation_list.decimal>li:before {
  display: none
}

main .annotation .annotation_list>li {
  display: table
}

main .annotation .annotation_list>li:not(:last-child) {
  margin-bottom: 20px
}

main .annotation .annotation_list>li:before {
  display: table-cell;
  width: 1.9em;
  padding-right: 5px;
  content: "・"
}

main .standard_list {
  color: #555
}

main .standard_list.-center {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column;
  -webkit-box-align: center;
  align-items: center
}

main .standard_list>ul {
  margin-bottom: 25px;
  padding-left: 1.7em
}

main .standard_list>ul li:not(:last-child) {
  margin-bottom: 10px
}

main .standard_list>ul li .red {
  font-weight: 500;
  color: #da5442
}

main .standard_list>ul.datelist>li {
  display: table
}

main .standard_list>ul.datelist>li .date {
  font-weight: 500;
  display: table-cell;
  width: 165px;
  padding-right: 2em
}

main .standard_list>ul.none.marb-20 {
  margin-bottom: 20px
}

main .standard_list>ul.none>li {
  padding-left: 0.5em;
  list-style: none
}

main .standard_list>ul.disc {
  padding-left: 0
}

main .standard_list>ul.disc.marb-20 {
  margin-bottom: 20px
}

main .standard_list>ul.disc>li {
  line-height: 1.5;
  display: table
}

main .standard_list>ul.disc>li:before {
  font-size: 1.2rem;
  display: table-cell;
  width: 2em;
  content: "●"
}

main .standard_list>ul.decimal>li {
  padding-left: 0.5em;
  list-style: decimal
}

main .standard_list>ul.-free {
  padding-left: 0
}

main .standard_list>ul.-free>li {
  display: table
}

main .standard_list>ul.-free>li:before {
  display: table-cell;
  padding-right: 5px;
  content: attr(data-text);
  white-space: nowrap
}

main .standard_list>ul.column2 {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .standard_list>ul.column2 li {
  width: calc(50% - 20px)
}

main .standard_list>ul.column3 {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .standard_list>ul.column3 li {
  width: calc(33.3333333333% - 20px)
}

main .standard_list>ul.column3:after {
  display: block;
  box-sizing: border-box;
  width: calc(33.3333333333% - 20px);
  content: ""
}

main .standard_list>ul a {
  font-weight: 500;
  text-decoration: underline;
  color: #333
}

main .standard_list>ul a:hover {
  opacity: 0.7
}

main .back_txt .standard_list>ul {
  margin-bottom: 0
}

main .innerlist {
  margin-top: 20px
}

main .innerlist li {
  display: table
}

main .innerlist li:before {
  display: table-cell;
  padding-right: 5px;
  content: "∟"
}

main .innerlist.-free>li:before {
  content: attr(data-text);
  white-space: nowrap
}

main .arw_list .link_menu {
  font-size: 1.6rem;
  margin-bottom: 50px
}

main .arw_list .link_menu li {
  display: -webkit-box;
  display: flex;
  margin-bottom: 10px;
  -webkit-box-align: baseline;
  align-items: baseline
}

main .arw_list .link_menu li:last-child {
  margin-bottom: 0
}

main .arw_list .link_menu li:before {
  position: relative;
  display: block;
  width: 26px;
  height: 16px;
  margin-right: 12px;
  content: "";
  background-image: url(../images/icon_arw.png);
  background-repeat: no-repeat;
  background-position: top;
  background-size: contain;
  -webkit-box-flex: 0;
  flex: 0 0 24px
}

main .arw_list .link_menu li a {
  font-weight: 500
}

main .arw_list .link_menu li a:hover {
  text-decoration: underline
}

main .arw_list .link_menu li {
  margin-bottom: 20px
}

main .arw_list .link_menu li:before {
  top: 2px
}

main .arw_list .link_menu.column2 {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .arw_list .link_menu.column2 li {
  width: calc(50% - 20px)
}

main .arw_list .link_menu.column3 {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .arw_list .link_menu.column3 li {
  width: calc(33.3333333333% - 20px)
}

main .arw_list .link_menu.column3:after {
  display: block;
  box-sizing: border-box;
  width: calc(33.3333333333% - 20px);
  content: ""
}

main .note_list {
  font-size: 1.4rem;
  margin-bottom: 25px
}

main .note_list>li {
  line-height: 1.5;
  display: table
}

main .note_list>li:before {
  display: table-cell;
  content: attr(data-text);
  white-space: nowrap
}

main .note_list>li .note_list {
  margin-top: 0
}

main .note_list>li .red {
  font-weight: 500;
  color: #da5442
}

main .note_list>li a {
  font-weight: 500;
  text-decoration: underline
}

main .note_list>li a:hover {
  opacity: 0.7
}

main .note_list.right>li {
  margin-left: auto
}

main .strong_list .decimal {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  padding-left: 0;
  list-style-type: none;
  counter-reset: num;
  flex-wrap: wrap
}

main .strong_list .decimal li {
  font-size: 1.4rem;
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  width: 100%;
  min-height: 68px;
  margin-top: 14px;
  border: 1px solid #476eaa;
  -webkit-box-align: center;
  align-items: center
}

main .strong_list .decimal li:first-of-type {
  margin-top: 0
}

main .strong_list .decimal li:before {
  font-family: Roboto, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 3.2rem;
  font-weight: 400;
  display: -webkit-box;
  display: flex;
  width: 52px;
  height: 100%;
  content: counter(num);
  counter-increment: num;
  color: #476eaa;
  background: #f2f4f7;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}

main .strong_list .decimal li>span {
  display: block;
  width: calc(100% - 52px);
  padding: 12px 20px 12px 10px
}

main .strong_list .decimal li>a {
  display: -webkit-box;
  display: flex;
  width: calc(100% - 52px);
  height: 100%;
  padding: 12px 20px 12px 10px;
  text-decoration: underline;
  -webkit-box-align: center;
  align-items: center
}

main .strong_list .decimal li>a:hover {
  opacity: 0.7
}

main .strong_list .decimal li .red {
  font-weight: 500;
  color: #da5442
}

main .strong_list .decimal.column2 li {
  width: calc((100% - 14px) / 2);
  margin-right: 14px
}

main .strong_list .decimal.column2 li:nth-of-type(2n) {
  margin-right: 0
}

main .strong_list .decimal.column2 li:nth-of-type(-n+2) {
  margin-top: 0
}

main .strong_list .decimal.column3 li {
  width: calc((100% - 29px) / 3);
  margin-right: 14px
}

main .strong_list .decimal.column3 li:nth-of-type(3n) {
  margin-right: 0
}

main .strong_list .decimal.column3 li:nth-of-type(-n+3) {
  margin-top: 0
}

main .txt_img .txt .note_list {
  margin-top: 25px
}

main .txt_img .txt .note_list>li .note_list {
  margin-top: 0
}

main .img_big {
  width: 100%;
  max-width: 800px;
  margin: 0 auto 25px
}

main .img_big.left {
  margin-left: 0
}

main .img_big.left .img_big_box figure p img {
  margin: 0
}

main .img_big.left .img_big_box figure.-border p {
  outline: 1px solid #ccc
}

main .img_big .img_big_box figure {
  margin-bottom: 25px
}

main .img_big .img_big_box figure p {
  width: 100%
}

main .img_big .img_big_box figure p img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: auto
}

main .img_big .img_big_box figure.-border p {
  outline: 1px solid #ccc
}

main .img_big .img_big_box figure p:last-of-type {
  display: none
}

main .img_big .img_big_box figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .img_big .img_big_box figure figcaption.left {
  text-align: left
}

main .img_big a {
  display: block
}

main .img_big a:hover {
  opacity: 0.5
}

main .img_big a img:hover {
  opacity: 1
}

main .img_big.bk figure p {
  background: #d3d0d0
}

main .img_mdm {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .img_mdm .img_mdm_box {
  width: 48.11%;
  margin-top: 25px
}

main .img_mdm .img_mdm_box:nth-of-type(-n+2) {
  margin-top: 0
}

main .img_mdm .img_mdm_box.full-img figure p img {
  width: 100%;
  height: 100%
}

main .img_mdm .img_mdm_box figure {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column
}

main .img_mdm .img_mdm_box figure p {
  position: relative;
  padding-top: 66.6666666667%;
  outline: 1px solid #ccc
}

main .img_mdm .img_mdm_box figure p img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .img_mdm .img_mdm_box figure.no-border p {
  outline: 0
}

main .img_mdm .img_mdm_box figure figcaption {
  font-size: 1.4rem;
  margin-top: auto;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .img_mdm .img_mdm_box figure figcaption.left {
  text-align: left
}

main .img_mdm a {
  display: block
}

main .img_mdm a:hover {
  opacity: 0.5
}

main .img_mdm a img:hover {
  opacity: 1
}

main .img_mdm.left .img_mdm_box:not(:nth-child(2n)) {
  margin-right: 3.77%
}

main .img_mdm.right {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  flex-direction: row-reverse
}

main .img_mdm.right .img_mdm_box:not(:nth-child(2n)) {
  margin-left: 3.77%
}

main .img_mdm.bk figure p {
  background: #d3d0d0
}

main .img_mdm .ttl {
  font-size: 1.8rem;
  line-height: 1.4;
  position: relative;
  padding-bottom: 8px;
  padding-left: 25px
}

main .img_mdm .ttl:before {
  position: absolute;
  top: 8px;
  left: 3px;
  display: block;
  width: 11px;
  height: 11px;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background: #a0b6d7
}

main .img_small {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .img_small.col-4 .img_small_box {
  width: 24%
}

main .img_small.col-4.left .img_small_box:not(:nth-child(3n)) {
  margin-right: inherit
}

main .img_small.col-4.left .img_small_box:not(:nth-child(4n)) {
  margin-right: 1.3%
}

main .img_small .img_small_box {
  width: 32.07%;
  margin-top: 25px
}

main .img_small .img_small_box:nth-of-type(-n+3) {
  margin-top: 0
}

main .img_small .img_small_box figure {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column
}

main .img_small .img_small_box figure p {
  position: relative;
  padding-top: 66.4705882353%;
  outline: 1px solid #ccc
}

main .img_small .img_small_box figure p img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .img_small .img_small_box figure.no-border p {
  outline: 0
}

main .img_small .img_small_box figure figcaption {
  font-size: 1.4rem;
  margin-top: auto;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .img_small .img_small_box figure figcaption.left {
  text-align: left
}

main .img_small.col-4:nth-of-type(-n+4) {
  margin-top: 0
}

main .img_small .ttl {
  font-size: 1.8rem;
  line-height: 1.4;
  position: relative;
  padding-bottom: 8px;
  padding-left: 25px
}

main .img_small .ttl:before {
  position: absolute;
  top: 8px;
  left: 3px;
  display: block;
  width: 11px;
  height: 11px;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  background: #a0b6d7
}

main .img_small a {
  display: block
}

main .img_small a:hover {
  opacity: 0.5
}

main .img_small a img:hover {
  opacity: 1
}

main .img_small.left .img_small_box:not(:nth-child(3n)) {
  margin-right: 1.88%
}

main .img_small.right {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  flex-direction: row-reverse
}

main .img_small.right .img_small_box:not(:nth-child(3n)) {
  margin-left: 1.88%
}

main .img_small.bk figure p {
  background: #d3d0d0
}

main .img_col5 {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .img_col5_box {
  width: 19%;
  margin-top: 25px;
  margin-right: 1.25%
}

main .img_col5_box:nth-child(5n) {
  margin-right: 0
}

main .img_col5_box:nth-of-type(-n+5) {
  margin-top: 0
}

main .img_col5_box figure {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column
}

main .img_col5_box figure p {
  position: relative;
  padding-top: 66.4705882353%;
  outline: 1px solid #ccc
}

main .img_col5_box figure p img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .img_col5_box figure.no-border p {
  outline: 0
}

main .img_col5_box figure figcaption {
  font-size: 1.4rem;
  margin-top: auto;
  padding-top: 10px;
  color: #555
}

main .img_col5 a {
  display: block
}

main .img_col5 a:hover {
  opacity: 0.5
}

main .img_col5 a img:hover {
  opacity: 1
}

main .img_col5.bk figure p {
  background: #d3d0d0
}

main .txt_img {
  margin-bottom: 40px
}

main .txt_img:after {
  display: block;
  clear: both;
  content: ""
}

main .txt_img:after:after {
  display: block;
  clear: both;
  content: ""
}

main .txt_img figure {
  width: 47.16%
}

main .txt_img figure.right {
  float: right;
  margin: 0 0 20px 40px
}

main .txt_img figure.left {
  float: left;
  margin: 0 40px 20px 0
}

main .txt_img figure p {
  position: relative;
  padding-top: 66.6%;
  outline: 1px solid #ccc
}

main .txt_img figure p img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .txt_img figure p.p_lr img {
  width: calc(100% - 20px)
}

main .txt_img figure p.p_tb img {
  height: calc(100% - 20px)
}

main .txt_img figure.no-border p {
  outline: 0
}

main .txt_img figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .txt_img figure figcaption.left {
  text-align: left
}

main .txt_img figure figcaption+p {
  margin-top: 15px
}

main .txt_img .txt {
  color: #555
}

main .txt_img .txt p {
  margin-bottom: 20px
}

main .txt_img .txt img {
  width: auto;
  max-width: calc(52.84% - 40px);
  margin-bottom: 25px
}

main .txt_img .txt .small_ttl {
  display: inline-block;
  width: calc(52.84% - 40px);
  margin-top: 0
}

main .txt_img .txt .blue_bk {
  width: calc(52.84% - 40px);
  padding: 20px 15px;
  background: #f2f4f7
}

main .txt_img .txt .blue_bk .blue_li li {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
  position: relative;
  margin-bottom: 8px;
  padding-left: 24px;
  color: #476eaa
}

main .txt_img .txt .blue_bk .blue_li li:before {
  position: absolute;
  left: 2px;
  content: "●"
}

main .txt_img .txt .feature_list_box {
  width: calc(52.84% - 40px)
}

main .btn_big {
  display: -webkit-box;
  display: flex;
  width: 440px;
  margin: 0 auto;
  margin-bottom: 35px;
  flex-wrap: wrap
}

main .btn_big a {
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  width: 100%;
  min-height: 68px;
  margin-top: 35px;
  padding: 10px 40px 10px 20px;
  text-align: center;
  color: #555;
  border: 2px solid #ddd;
  background: url(../images/icon_arw_green.png) no-repeat right 17px center;
  background-size: 13px 12px;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  justify-content: center
}

main .btn_big a:hover {
  opacity: 0.5
}

main .btn_big a:first-of-type {
  margin-top: 0
}

main .btn_big a span {
  width: 100%
}

main .btn_big a [class*=" icon_"], main .btn_big a [class^=icon_] {
  padding-bottom: 10px
}

main .btn_big a img {
  width: auto;
  max-height: 30px;
  margin-right: 4px;
  vertical-align: middle
}

main .btn_big.blue a {
  position: relative;
  color: #fff;
  border: none;
  background: #7eabd0
}

main .btn_big.blue a:after {
  position: absolute;
  top: 50%;
  right: 20px;
  display: block;
  width: 13px;
  height: 12px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/icon_arw_w.png) no-repeat;
  background-size: contain
}

main .btn_big.left a {
  text-align: left;
  -webkit-box-pack: left;
  justify-content: left
}

main .btn_big .caption {
  line-height: 1.4;
  width: 100%;
  margin-bottom: 7px;
  text-align: center;
  color: #555
}

main .btn_big .caption.left {
  -moz-text-align-last: left;
  text-align-last: left
}

main .btn_mdm {
  display: -webkit-box;
  display: flex;
  width: 81.13%;
  margin: 0 auto;
  margin-bottom: 35px;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .btn_mdm.left {
  margin: 0
}

main .btn_mdm.center {
  -webkit-box-pack: center;
  justify-content: center
}

main .btn_mdm.mar-0 {
  margin: 0
}

main .btn_mdm a {
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  width: 44.18%;
  min-height: 68px;
  margin-top: 35px;
  padding: 10px 40px 10px 20px;
  text-align: left;
  color: #555;
  border: 2px solid #ddd;
  background: url(../images/icon_arw_green.png) no-repeat right 17px center #fff;
  background-size: 13px 12px;
  -webkit-box-align: center;
  align-items: center
}

main .btn_mdm a.mgb-5 {
  margin-bottom: 5px
}

main .btn_mdm a:hover {
  opacity: 0.5
}

main .btn_mdm a:nth-of-type(-n+2) {
  margin-top: 0
}

main .btn_mdm.blue a {
  position: relative;
  color: #fff;
  border: none;
  background: #7eabd0
}

main .btn_mdm.blue a:after {
  position: absolute;
  top: 50%;
  right: 20px;
  display: block;
  width: 13px;
  height: 12px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/icon_arw_w.png) no-repeat;
  background-size: contain
}

main .btn_mdm .caption {
  line-height: 1.4;
  width: 100%;
  margin-bottom: 7px;
  text-align: center;
  color: #555
}

main .btn_mdm .caption.left {
  -moz-text-align-last: left;
  text-align-last: left
}

main .btn_small {
  display: -webkit-box;
  display: flex;
  margin: 0 auto;
  margin-bottom: 20px;
  flex-wrap: wrap
}

main .btn_small a {
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  width: calc((100% - 41px) / 3);
  min-height: 68px;
  margin-top: 20px;
  margin-right: 20px;
  padding: 10px 40px 10px 20px;
  text-align: left;
  color: #555;
  border: 2px solid #ddd;
  background: url(../images/icon_arw_green.png) no-repeat right 17px center #fff;
  background-size: 13px 12px;
  -webkit-box-align: center;
  align-items: center
}

main .btn_small a:hover {
  opacity: 0.5
}

main .btn_small a:nth-of-type(-n+3) {
  margin-top: 0
}

main .btn_small a:nth-of-type(3n) {
  margin-right: 0
}

main .btn_small.blue a {
  position: relative;
  color: #fff;
  border: none;
  background: #7eabd0
}

main .btn_small.blue a:after {
  position: absolute;
  top: 50%;
  right: 20px;
  display: block;
  width: 13px;
  height: 12px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/icon_arw_w.png) no-repeat;
  background-size: contain
}

main .btn_small .caption {
  line-height: 1.4;
  width: 100%;
  margin-bottom: 7px;
  text-align: center;
  color: #555
}

main .btn_small .caption.left {
  -moz-text-align-last: left;
  text-align-last: left
}

main .related_link {
  display: -webkit-box;
  display: flex;
  margin-top: 60px;
  margin-bottom: 60px;
  padding: 10px;
  border: 2px solid #ccc;
  -webkit-box-align: center;
  align-items: center
}

main .related_link p {
  width: 16.9%;
  padding: 10px 20px 10px 10px;
  text-align: center;
  color: #198a3b
}

main .related_link ul {
  font-weight: 500;
  width: 83.1%;
  padding: 10px 10px 10px 10px;
  border-left: 2px solid #ccc
}

main .related_link ul li {
  display: table
}

main .related_link ul li:not(:last-child) {
  margin-bottom: 15px
}

main .related_link ul li a:hover {
  text-decoration: underline
}

main .related_link ul li:before {
  display: table-cell;
  padding-right: 5px;
  content: "・"
}

main .related_link ul li a[href*="/webcatalog_"]:after {
  display: inline-block;
  width: 16px;
  height: 13px;
  margin-left: 10px;
  content: "";
  background: url(../images/icon_outlink_gray.png) no-repeat;
  background-size: contain
}

main .standard_tbl {
  margin-bottom: 10px;
  color: #555
}

main .standard_tbl_wrap {
  font-size: 1.4rem;
  margin-bottom: 25px
}

main .standard_tbl table {
  width: 100%;
  border: 2px solid #eee
}

main .standard_tbl table .red {
  font-weight: 500;
  color: #da5442
}

main .standard_tbl table td, main .standard_tbl table th {
  padding: 10px 13px;
  text-align: left;
  vertical-align: middle;
  border: 2px solid #eee
}

main .standard_tbl table th {
  font-weight: 400;
  background: #f5f5f5
}

main .standard_tbl table a {
  font-weight: 500;
  text-decoration: underline
}

main .standard_tbl table a:hover {
  opacity: 0.7
}

main .standard_tbl table .btn_big {
  width: 270px;
  margin: 0 auto 0 0
}

main .standard_tbl table .btn_big a {
  font-size: 1.3rem;
  min-height: 53px;
  margin: 20px 0;
  padding: 10px 40px 10px 20px
}

main .standard_tbl table sup {
  font-size: 1rem;
  vertical-align: text-top
}

main .fluidImg {
  position: relative;
  width: 75.47%;
  margin: 0 auto 60px
}

main .fluidImg:before {
  display: block;
  padding-top: 56.25%;
  content: ""
}

main .fluidImg iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

main .back_link {
  text-align: center
}

main .back_link a {
  font-size: 1.4rem;
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 8px 40px 8px 20px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  letter-spacing: normal;
  background: #eee
}

main .back_link a:hover {
  opacity: 0.5
}

main .back_link a:after {
  position: absolute;
  top: 50%;
  right: 15px;
  display: block;
  width: 13px;
  height: 12px;
  margin-top: -6px;
  content: "";
  background-image: url(../images/icon_arw_b.png);
  background-repeat: no-repeat;
  background-size: contain
}

main .col4 {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .col4_inner {
  width: calc(25% - 15px);
  margin-right: 19.5px;
  margin-bottom: 20px
}

main .col4_inner>a {
  display: block
}

main .col4_inner>a:hover {
  opacity: 0.5
}

main .col4_inner>a img:hover {
  opacity: 1
}

main .col4_inner:nth-child(4n) {
  margin-right: 0
}

main .banner {
  margin-bottom: 80px
}

main .banner li {
  position: relative
}

main .banner li figcaption {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff
}

.ft-han-sans {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 400
}

br.br_sp {
  display: none!important
}

.show-sp {
  display: none!important
}

.hide_ac_pc {
  display: none
}

.hide_ac_sp {
  display: block
}

.clearfix {
  clear: both
}

.clearfix:after {
  display: block;
  clear: both;
  content: ""
}

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

.center-txt {
  text-align: center
}

.img-auto {
  width: auto!important;
  padding: 0 5px;
  vertical-align: middle
}

hr.dashed {
  margin: 5px 0 0 0;
  padding: 0;
  border-top: 1px dashed #86969b
}

.dotted {
  margin: 12px 0;
  border-top: 1px dotted
}

.bold {
  font-weight: 700
}

body.lb-disable-scrolling {
  overflow: hidden
}

.lightboxOverlay {
  position: absolute;
  z-index: 9999;
  top: 0;
  left: 0;
  display: none;
  opacity: 0.8;
  background-color: #000;
  background-color: rgba(0, 0, 0, 0.5)
}

.lightbox {
  font-weight: 400;
  line-height: 0;
  position: fixed;
  z-index: 10000;
  top: 50%!important;
  left: 0;
  width: 100%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  text-align: center;
  outline: 0
}

.lightbox .lb-image {
  display: block;
  max-width: inherit;
  height: auto
}

.lightbox .lb-image a img {
  border: none
}

.lb-outerContainer {
  width: 250px;
  height: 250px;
  margin: 0 auto;
  background-color: #fff
}

.lb-outerContainer:after {
  display: table;
  clear: both;
  content: ""
}

.lb-container {
  position: relative
}

.lb-loader {
  line-height: 0;
  position: fixed;
  top: 50%;
  left: 0;
  width: 100%;
  height: 25%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  text-align: center
}

.lb-cancel {
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 auto;
  background: url(../images/loading.gif) no-repeat
}

.lb-next, .lb-prev {
  display: block;
  height: 100%;
  cursor: pointer
}

.lb-nav {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.lb-nav a {
  outline: 0;
  background-image: url(data:image/gif;base64,R0lGODlhAQABAPAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==)
}

.lb-nav a.lb-prev {
  left: 0;
  float: left;
  width: 15%;
  -webkit-transition: opacity 0.6s;
  transition: opacity 0.6s;
  background: url(../images/prev.png) left 50% no-repeat
}

.lb-nav a.lb-prev:hover {
  opacity: 1
}

.lb-nav a.lb-next {
  right: 0;
  float: right;
  width: 15%;
  -webkit-transition: opacity 0.6s;
  transition: opacity 0.6s;
  background: url(../images/next.png) right 50% no-repeat
}

.lb-nav a.lb-next:hover {
  opacity: 1
}

.lb-container>.nav {
  left: 0
}

.lb-dataContainer {
  width: 100%;
  margin: 0 auto;
  padding-top: 5px;
  border-bottom-right-radius: 4px;
  border-bottom-left-radius: 4px
}

.lb-dataContainer:after {
  display: table;
  clear: both;
  content: ""
}

.lb-data {
  padding: 0 4px;
  color: #ccc
}

.lb-data .lb-details {
  line-height: 1.1em;
  float: left;
  width: 85%;
  text-align: left
}

.lb-data .lb-caption {
  font-size: 13px;
  font-weight: 700;
  line-height: 1em
}

.lb-data .lb-caption a {
  color: #4ae
}

.lb-data .lb-number {
  font-size: 12px;
  display: block;
  clear: left;
  padding-bottom: 1em;
  color: #fff
}

.lb-closeContainer {
  position: absolute;
  top: -28px;
  right: -27px
}

.lb-close {
  display: block;
  float: right;
  width: 30px;
  height: 30px;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
  text-align: right;
  opacity: 0.7;
  outline: 0;
  background: url(../images/close.png) top right no-repeat
}

.lb-close:hover {
  cursor: pointer;
  opacity: 1
}

main .mg_t20_new {
  margin-top: 20px
}

main .mg_t40_new {
  margin-top: 40px
}

main .mg_t50_new {
  margin-top: 50px
}

main .mg_b0_new {
  margin-bottom: 0!important
}

main .mg_b20_new {
  margin-bottom: 20px!important
}

main .mg_b40_new {
  margin-bottom: 40px
}

main .mg_b50_new {
  margin-bottom: 50px
}

main .mg_b70_new {
  margin-bottom: 70px
}

main .pdlr-15 {
  padding: 0 15px
}

main .txt_img_new {
  margin-bottom: 40px
}

main .txt_img_new:after {
  display: block;
  clear: both;
  content: ""
}

main .txt_img_new:after:after {
  display: block;
  clear: both;
  content: ""
}

main .txt_img_new figure {
  width: 30%
}

main .txt_img_new figure.right {
  float: right;
  margin: 0 0 20px 40px
}

main .txt_img_new figure.left {
  float: left;
  margin: 0 40px 20px 0
}

main .txt_img_new figure p {
  position: relative;
  padding-top: 66.6%;
  outline: 1px solid #ccc
}

main .txt_img_new figure p img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .txt_img_new figure p.p_lr img {
  width: calc(100% - 20px)
}

main .txt_img_new figure p.p_tb img {
  height: calc(100% - 20px)
}

main .txt_img_new figure.no-border p {
  outline: 0
}

main .txt_img_new figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .txt_img_new figure figcaption.left {
  text-align: left
}

main .txt_img_new figure figcaption+p {
  margin-top: 15px
}

main .txt_img_new .txt {
  color: #555
}

main .txt_img_new .txt p {
  margin-bottom: 20px
}

main .txt_img_new .txt img {
  width: auto;
  max-width: calc(70% - 40px);
  margin-bottom: 25px
}

main .txt_img_new .txt .small_ttl {
  display: inline-block;
  width: calc(70% - 40px);
  margin-top: 0
}

main .txt_img_new .txt .blue_bk {
  width: calc(70% - 40px);
  padding: 20px 15px;
  background: #f2f4f7
}

main .txt_img_new .txt .blue_bk .blue_li li {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
  position: relative;
  margin-bottom: 8px;
  padding-left: 24px;
  color: #476eaa
}

main .txt_img_new .txt .blue_bk .blue_li li:before {
  position: absolute;
  left: 2px;
  content: "●"
}

main .txt_img_new .txt .feature_list_box {
  width: calc(70% - 40px)
}

main .txt_img_new.img_fit figure {
  width: auto
}

main .txt_img_new.img_fit figure.right {
  margin: 0 0 10px 40px
}

main .txt_img_new.img_fit figure.left {
  margin: 0 40px 10px 0
}

main .txt_img_new.img_fit figure p {
  padding-top: 0
}

main .txt_img_new.img_fit figure p img {
  position: static
}

main .lede {
  margin-top: 17px;
  text-align: center
}

main .lede p {
  font-size: 1.25rem;
  color: #231815
}

main .lede p span {
  font-size: 2.125rem;
  color: #dc2128
}

main .lede h2 {
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -1px;
  color: #005bac
}

main .standard_tbl_new {
  margin-bottom: 10px;
  color: #555
}

main .standard_tbl_new_wrap {
  font-size: 1.4rem;
  margin-bottom: 25px
}

main .standard_tbl_new table {
  width: 100%;
  border: 2px solid #eee
}

main .standard_tbl_new table .red {
  font-weight: 500;
  color: #da5442
}

main .standard_tbl_new table td, main .standard_tbl_new table th {
  padding: 10px 13px;
  text-align: left;
  vertical-align: middle;
  border: 2px solid #eee
}

main .standard_tbl_new table th {
  font-weight: 400;
  width: 1px;
  white-space: nowrap;
  background: #f5f5f5
}

main .standard_tbl_new table a {
  font-weight: 500;
  text-decoration: underline
}

main .standard_tbl_new table a:hover {
  opacity: 0.7
}

main .standard_tbl_new table .btn_big {
  width: 270px;
  margin: 0 auto 0 0
}

main .standard_tbl_new table .btn_big a {
  font-size: 1.3rem;
  min-height: 53px;
  margin: 20px 0;
  padding: 10px 40px 10px 20px
}

main .standard_tbl_new table sup {
  font-size: 1rem;
  vertical-align: text-top
}

main .drawing.drawing_new {
  margin-bottom: 40px
}

main .drawing.drawing_new .drawing_acc {
  text-align: right
}

main .drawing.drawing_new .drawing_acc button {
  font-size: 1.4rem;
  line-height: 34px;
  position: relative;
  width: 140px;
  height: 34px;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  color: #fff;
  background-color: #32ac57
}

main .drawing.drawing_new .drawing_acc button span {
  font-weight: 500;
  position: absolute;
  top: 50%;
  left: 20px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

main .drawing.drawing_new .drawing_acc button:first-child {
  margin-right: 14px
}

main .drawing.drawing_new .drawing_acc button:first-child:after {
  position: absolute;
  top: 50%;
  right: 18px;
  display: block;
  width: 2px;
  height: 10px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #fff
}

main .drawing.drawing_new .drawing_acc button:before {
  position: absolute;
  top: 50%;
  right: 14px;
  display: block;
  width: 10px;
  height: 2px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-color: #fff
}

main .drawing.drawing_new .drawing_box {
  display: -webkit-box;
  display: flex;
  margin-top: 20px;
  border: 2px solid #ddd;
  flex-wrap: wrap
}

main .drawing.drawing_new .drawing_btn {
  position: relative;
  display: -webkit-box;
  display: flex;
  width: 100%;
  min-height: 80px;
  padding: 10px 18px;
  cursor: pointer;
  background: #eee;
  -webkit-box-align: center;
  align-items: center
}

main .drawing.drawing_new .drawing_btn span {
  display: inline-block;
  width: 30%;
  padding-right: 10px
}

main .drawing.drawing_new .drawing_btn .img-sp-draw {
  display: -webkit-box;
  display: flex;
  width: auto;
  padding-right: 0;
  -webkit-box-align: start;
  align-items: flex-start
}

main .drawing.drawing_new .drawing_btn img {
  width: auto;
  height: 60px;
  margin-left: 4px
}

main .drawing.drawing_new .drawing_btn img:first-of-type {
  margin-left: 0
}

main .drawing.drawing_new .drawing_btn:after {
  position: absolute;
  top: 50%;
  right: 15px;
  display: block;
  width: 24px;
  height: 24px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/ac_close_green.png) no-repeat
}

main .drawing.drawing_new .drawing_btn.on:after {
  content: url(../images/ac_open_green.png)
}

main .drawing.drawing_new .drawing_contents {
  width: 100%;
  padding: 10px 3.87%
}

main .drawing.drawing_new .drawing_contents.col-2 {
  display: -webkit-box;
  display: flex
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents {
  display: -webkit-box;
  display: flex;
  width: 40%;
  padding-right: 40px;
  -webkit-box-align: center;
  align-items: center
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox {
  width: 100%;
  text-align: center
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox img {
  width: auto;
  max-height: 120px
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox:first-of-type a {
  position: relative
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox:first-of-type a:after {
  position: absolute;
  right: 4px;
  bottom: 2px;
  display: block;
  width: 22px;
  height: 22px;
  content: "";
  background: url(../images/search.png) no-repeat;
  background-size: contain
}

main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .img_cnt {
  font-size: 1rem;
  position: absolute;
  bottom: 2px;
  left: 4px;
  padding: 2px 4px;
  color: #fff;
  border-radius: 2px;
  background: rgba(46, 46, 46, 0.6)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents {
  width: 100%;
  padding-top: 0
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl {
  font-size: 1.6rem
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt {
  width: 50%;
  margin-right: 30px;
  padding: 15px 0;
  padding-right: 4.5%;
  border-right: 1px solid #ddd
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link {
  font-size: 0;
  display: block;
  padding: 10px 0 10px
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link p {
  font-size: 1.6rem;
  display: inline-block;
  margin: 0;
  padding: 5px 40px;
  padding-left: 0;
  border: none
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a {
  font-size: 1.4rem;
  display: inline-block;
  margin: 0 10px 10px 0;
  padding: 5px 10px 5px 18px;
  border: 1px solid #ccc
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class*=" icon_"], main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class^=icon_] {
  font-size: 1.2rem;
  display: inline-block;
  min-height: 20px;
  margin-right: 5px;
  margin-left: 15px;
  padding-left: 26px;
  color: #777;
  background-repeat: no-repeat;
  background-size: 16px 20px
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class*=" icon_"]:before, main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class^=icon_]:before {
  display: none
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class*=" icon_"]:after, main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class^=icon_]:after {
  display: none
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_pdf {
  background-image: url(../images/icon_pdf.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_xls {
  background-image: url(../images/icon_xls.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_doc {
  background-image: url(../images/icon_doc.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_ppt {
  background-image: url(../images/icon_ppt.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_zip {
  background-image: url(../images/icon_zip.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a .icon_other {
  background-image: url(../images/icon_other.png)
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a:hover {
  color: #fff;
  background: #777
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a:hover [class*=" icon_"], main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a:hover [class^=icon_] {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  color: #fff
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link {
  padding-right: 3.5%
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a {
  line-height: 1;
  margin: 0;
  margin-right: 10px
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class*=" icon_"], main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link a [class^=icon_] {
  margin-left: 0
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd {
  width: calc(50% - 30px);
  margin-right: 0;
  padding: 15px 0
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link {
  font-size: 0;
  display: block;
  padding: 10px 0 10px;
  padding-right: 0
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link p {
  font-size: 1.6rem;
  display: inline-block;
  margin: 0;
  padding: 5px 40px;
  padding-left: 0;
  border: none
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link a {
  line-height: 1;
  margin: 0;
  margin-right: 10px
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link a [class*=" icon_"], main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link a [class^=icon_] {
  margin-left: 0
}

main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl:first-child {
  margin-bottom: 15px;
  padding-bottom: 15px
}

main .drawing.drawing_new .drawing_contents dl {
  font-size: 1.4rem;
  display: -webkit-box;
  display: flex;
  border-bottom: 1px solid #ddd;
  -webkit-box-align: center;
  align-items: center
}

main .drawing.drawing_new .drawing_contents dl:last-child {
  border-bottom: none
}

main .drawing.drawing_new .drawing_contents dl dt {
  width: 140px;
  padding: 25px 0;
  padding-right: 3.5%
}

main .drawing.drawing_new .drawing_contents dl dd {
  width: calc(100% - 140px);
  padding: 25px 0
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link {
  font-size: 0;
  padding: 25px 0 15px
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link p {
  font-size: 1.4rem;
  display: inline-block;
  margin: 0 10px 10px 0;
  padding: 5px 18px;
  border: 1px solid #ccc
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a {
  font-size: 1.4rem;
  display: inline-block;
  margin: 0 10px 10px 0;
  padding: 5px 10px 5px 18px;
  border: 1px solid #ccc
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class*=" icon_"], main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class^=icon_] {
  font-size: 1.2rem;
  display: inline-block;
  min-height: 20px;
  margin-right: 5px;
  margin-left: 15px;
  padding-left: 26px;
  color: #777;
  background-repeat: no-repeat;
  background-size: 16px 20px
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class*=" icon_"]:before, main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class^=icon_]:before {
  display: none
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class*=" icon_"]:after, main .drawing.drawing_new .drawing_contents dl dd.drawing_link a [class^=icon_]:after {
  display: none
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_pdf {
  background-image: url(../images/icon_pdf.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_xls {
  background-image: url(../images/icon_xls.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_doc {
  background-image: url(../images/icon_doc.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_ppt {
  background-image: url(../images/icon_ppt.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_zip {
  background-image: url(../images/icon_zip.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a .icon_other {
  background-image: url(../images/icon_other.png)
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a:hover {
  color: #fff;
  background: #777
}

main .drawing.drawing_new .drawing_contents dl dd.drawing_link a:hover [class*=" icon_"], main .drawing.drawing_new .drawing_contents dl dd.drawing_link a:hover [class^=icon_] {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  color: #fff
}

main .tb_contents_table {
  margin-bottom: 30px
}

main .tb_contents_table table {
  border-collapse: collapse;
  border: 1px solid #0c0104
}

main .tb_contents_table table th {
  font-weight: 400;
  padding: 5px 10px;
  border-collapse: collapse;
  border: 1px solid #0c0104;
  background: #ccd4c4
}

main .tb_contents_table table td {
  padding: 5px 10px;
  border-collapse: collapse;
  border: 1px solid #0c0104;
  background: #fffef6
}

main .tb_contents_table .center {
  text-align: center
}

main .tb_contents_table .left {
  text-align: left
}

main .laws_table_new table {
  border-collapse: collapse;
  border: 1px #666 solid
}

main .laws_table_new td {
  line-height: 18px;
  padding: 5px;
  border-collapse: collapse;
  border: 1px #666 solid
}

main .progress_table_new th {
  font-size: 14px;
  font-weight: 700;
  height: 34px;
  text-align: center;
  vertical-align: middle;
  color: #fff;
  border: 1px solid #a5cfe1;
  background: url(../images/th_back.jpg) repeat-x
}

main .progress_table_new .table_color_001 {
  padding: 5px;
  border: 1px solid #e3d3a0;
  background: #fff8e3
}

main .progress_table_new .table_color_002 {
  padding: 5px;
  border: 1px solid #aad1e2;
  background: #f6fafc
}

main .progress_table_new .number {
  font-weight: 700;
  text-align: center;
  color: #157ba5
}

main .table_wide_new table {
  border-spacing: 1px 1px;
  border-collapse: separate;
  border: 1px solid #eee
}

main .table_wide_new .table_color_001 {
  width: 35px;
  color: #fff;
  background: #64778f
}

main .table_wide_new .table_color_002 {
  text-align: center;
  background: #f5f5f5
}

main .table_wide_new .table_color_003 {
  text-align: left;
  background: #f5f5f5
}

main .table_wide_new td {
  padding: 10px 13px
}

main .contents_txt_dt {
  margin-bottom: 30px
}

main .contents_txt_dt.pdleft-15 {
  padding-left: 15px
}

main .contents_txt_dt dl {
  margin-bottom: 15px
}

main .contents_txt_dt dt {
  float: left;
  width: 2em
}

main .contents_txt_dt dd {
  margin-left: 2.5em
}

main .contents_txt_dt2 {
  margin-bottom: 30px
}

main .contents_txt_dt2.pdleft-15 {
  padding-left: 15px
}

main .contents_txt_dt2 dl {
  margin-bottom: 15px
}

main .contents_txt_dt2 dt {
  float: left
}

main .contents_txt_dt2 dd {
  margin-left: 1.5em
}

main .contents_txt_dt3 {
  margin-bottom: 30px
}

main .contents_txt_dt3.pdleft-15 {
  padding-left: 15px
}

main .contents_txt_dt3.pdleft-30 {
  padding-left: 30px
}

main .contents_txt_dt3.pdleft-45 {
  padding-left: 45px
}

main .contents_txt_dt3.pdleft-60 {
  padding-left: 60px
}

main .contents_txt_dt3 dl {
  margin-bottom: 15px
}

main .contents_txt_dt3 dt {
  float: left;
  width: 3em
}

main .contents_txt_dt3 dd {
  margin-left: 3.5em
}

main .subsidy {
  display: -webkit-box;
  display: flex;
  margin-bottom: 10px;
  flex-wrap: wrap
}

main .subsidy>dt {
  min-width: 15em;
  padding: 0 20px 0 0
}

main .subsidy dd {
  font-size: 12px;
  line-height: 18px;
  margin-left: 10em
}

main .subsidy>* {
  float: none;
  width: auto;
  margin: 0
}

main .lightbox_contents {
  margin-bottom: 30px
}

main .lightbox_contents table {
  border-collapse: collapse;
  border: 1px solid #428f02
}

main .lightbox_contents th {
  line-height: 18px;
  padding: 10px 0;
  text-align: center;
  color: #fff;
  border: 1px solid #428f02;
  background: #428f02
}

main .lightbox_contents_td_001 {
  line-height: 18px;
  padding: 10px 10px;
  text-align: center;
  border: 1px solid #428f02;
  background: #fff
}

main .lightbox_contents_td_001.bg_color {
  background: #f4dbc1
}

main .lightbox_contents_td_002 {
  line-height: 18px;
  padding: 10px 20px;
  text-align: left;
  border: 1px solid #428f02;
  background: #fff
}

main .lightbox_contents_td_002.bg_color {
  background: #f4dbc1
}

main .lightbox_contents_td_002 dt {
  float: left;
  width: 2em
}

main .lightbox_contents_td_002 dd {
  margin-left: 2em
}

main .tab_box_btn {
  display: -webkit-box;
  display: flex
}

main .tab_box_btn li {
  width: 20%
}

main .tab_box_btn li:last-child a {
  border-right: 1px solid #ccc
}

main .tab_box_btn li a {
  position: relative;
  display: -webkit-box;
  display: flex;
  height: 100%;
  padding: 20px 1em;
  text-align: center;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center
}

main .tab_box_btn li a:hover {
  color: #fff;
  border-color: #32ac57;
  background-color: #32ac57
}

main .tab_box_btn li a.select {
  color: #fff;
  border-color: #32ac57;
  background-color: #32ac57
}

main .tab_box_btn li a.select:after {
  position: absolute;
  bottom: -10px;
  left: 50%;
  display: block;
  content: "";
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-top: 12px solid #32ac57;
  border-right: 12px solid transparent;
  border-left: 12px solid transparent
}

main .info {
  margin-bottom: 50px
}

main .info_lists {
  margin-top: 30px
}

main .info_lists_inner {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .info_lists li {
  border-bottom: 1px solid #ccc
}

main .info_lists li:last-child {
  border-bottom: none
}

main .info_lists li a {
  display: block;
  padding: 22px 20px
}

main .info_lists li a[href]:hover {
  background-color: #eee
}

main .info_lists li a [class*=" icon_"], main .info_lists li a [class^=icon_] {
  font-size: 1.2rem;
  display: -webkit-box;
  display: flex;
  min-width: 95px;
  color: #777;
  -webkit-box-align: center;
  align-items: center
}

main .info_lists li a [class*=" icon_"]:before, main .info_lists li a [class^=icon_]:before {
  display: inline-block;
  width: 25px;
  height: 32px;
  margin-right: 14px;
  content: "";
  background-size: contain
}

main .info_lists li a [class*=" icon_"]:after, main .info_lists li a [class^=icon_]:after {
  display: none
}

main .info_lists .date {
  margin-bottom: 16px
}

main .info_lists .date time {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  display: inline-block;
  width: 125px;
  margin-right: 18px;
  color: #198a3b
}

main .info .tag {
  font-size: 1.2rem;
  font-weight: 300;
  display: inline-block;
  min-width: 112px;
  margin-right: 6px;
  padding: 0 1em;
  text-align: center;
  border: 1px solid #ccc;
  background-color: #fff
}

main .info_list {
  padding-right: 20px
}

main .info_btn {
  text-align: center;
  background-color: #eee
}

main .info_btn a {
  display: block;
  padding: 16px 0
}

main .info_head {
  margin: 20px auto 30px;
  padding: 5px 0.5em;
  text-align: right
}

main .info_head time {
  color: #32ac57
}

main .info_foot {
  margin-bottom: 60px
}

main .ir_info {
  margin-bottom: 60px
}

main .ir_info_inner {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .ir_info_inner.col-3 .ir_center_list {
  display: flex;
  display: -webkit-box;
  display: flex;
  padding-right: 20px
}

main .ir_info li {
  border-bottom: 1px solid #ccc
}

main .ir_info li:last-child {
  border-bottom: none
}

main .ir_info li:hover {
  background-color: #eee
}

main .ir_info li a {
  display: block;
  padding: 22px 20px
}

main .ir_info li a [class*=" icon_"], main .ir_info li a [class^=icon_] {
  font-size: 1.2rem;
  display: -webkit-box;
  display: flex;
  min-width: 95px;
  color: #777;
  -webkit-box-align: center;
  align-items: center
}

main .ir_info li a [class*=" icon_"]:before, main .ir_info li a [class^=icon_]:before {
  display: inline-block;
  width: 25px;
  height: 32px;
  margin-right: 14px;
  content: "";
  background-size: contain
}

main .ir_info li a [class*=" icon_"]:after, main .ir_info li a [class^=icon_]:after {
  display: none
}

main .ir_info li a [class*=" icon_"].right, main .ir_info li a [class^=icon_].right {
  display: block
}

main .ir_info li a [class*=" icon_"].right:before, main .ir_info li a [class^=icon_].right:before {
  float: right;
  margin-right: 0
}

main .ir_info_list {
  display: -webkit-box;
  display: flex;
  padding-right: 20px
}

main .ir_info_list .date {
  width: 170px;
  padding-right: 20px
}

main .ir_info_list .date time {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  color: #32ac57
}

main .img_big_box_new img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: 0 auto
}

main .img_big_box_new_full img {
  width: 100%;
  height: auto
}

main .category_ttl {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.4;
  position: relative;
  margin-top: 45px;
  margin-bottom: 35px;
  padding: 0 14px;
  color: #444
}

main .category_ttl:before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 4px;
  height: 100%;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: -webkit-linear-gradient(top, #1f7b3b 0, #1f7b3b 50%, #3cbc63 50.1%, #3cbc63 100%);
  background: linear-gradient(to bottom, #1f7b3b 0, #1f7b3b 50%, #3cbc63 50.1%, #3cbc63 100%)
}

main .category_ttl img {
  width: auto;
  max-height: 32px;
  margin-top: -4px;
  margin-left: 8px;
  vertical-align: middle
}

main .sec_ttl {
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 60px;
  margin-bottom: 25px;
  padding: 8px 1em 8px 14px;
  color: #fff;
  background: -webkit-linear-gradient(60deg, #16953c 0, #16953c 108px, #3ca95d 108px, #3ca95d 100%);
  background: linear-gradient(30deg, #16953c 0, #16953c 108px, #3ca95d 108px, #3ca95d 100%)
}

main .sec_ttl .dot {
  font-weight: 700;
  position: relative
}

main .sec_ttl .dot:before {
  position: absolute;
  top: -1px;
  left: 50%;
  display: block;
  width: 5px;
  height: 5px;
  content: "";
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-radius: 50%;
  background: #fff
}

main .sec_ttl .sup {
  font-size: 1.4rem;
  vertical-align: super
}

main .small_ttl {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.4;
  position: relative;
  margin-top: 40px;
  margin-bottom: 20px;
  padding: 4px 20px 6px;
  color: #064d1b;
  background: #def4ef
}

main .small_ttl:before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 3px;
  height: 100%;
  margin-right: 10px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: #209342
}

main .small_ttl a {
  display: block
}

main .small_ttl a:after {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-bottom: -1px;
  margin-left: 12px;
  content: "";
  background: url(../images/icon_arw_dg.png) no-repeat;
  background-size: contain
}

main .small_ttl a:hover {
  opacity: 0.7
}

main .small_ttl .red {
  font-weight: 600;
  color: #da5442
}

main .category_ttl_h4 {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.4;
  position: relative;
  margin-top: 30px;
  margin-bottom: 10px;
  padding-left: 26px
}

main .category_ttl_h4:before {
  position: absolute;
  top: 10px;
  left: 0;
  display: block;
  width: 10px;
  height: 10px;
  content: "";
  background: #33ac58
}

main .standard_txt_new {
  font-size: 16px;
  margin-bottom: 25px;
  color: #555
}

main .standard_txt_new .left {
  text-align: left
}

main .standard_txt_new a {
  font-weight: 500;
  text-decoration: underline
}

main .standard_txt_new a:hover {
  opacity: 0.7
}

main .standard_txt_new .red {
  font-weight: 500;
  color: #da5442
}

main .txt_strong {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 25px;
  color: #da5442
}

main .txt_strong.blue {
  color: #42abda
}

main .category_ttl_new_h2 {
  font-size: 20px;
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 40px;
  padding: 13px 20px;
  color: #555;
  background: #f5f5f5
}

main .category_ttl_new_h2 span {
  display: block;
  padding: 0 15px;
  border-left: 3px solid #32ac57
}

main .sec_ttl_new_h3 {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 40px;
  padding-left: 10px;
  color: #555;
  border-left: 3px solid #32ac57
}

main .sub_category_new {
  line-height: 1.7;
  margin-bottom: -28px
}

main .sub_category_new span {
  font-size: 14px;
  font-weight: 300;
  display: inline-block;
  padding: 1px 7px;
  padding: 5px 10px;
  color: #32ac57;
  border: 1px solid #32ac57;
  background: #fff
}

main .sub_category_new .active {
  color: #fff;
  border: 1px solid #32ac57;
  background: #32ac57
}

main .small_ttl_new_h3 {
  font-size: 16px;
  margin-bottom: 45px;
  color: #198a3b
}

main .backgreen_txt {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 40px;
  padding: 18px 17px;
  color: #fff;
  border: 1px solid #32ac57;
  background: #32ac57
}

main .back_txt {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 40px;
  padding: 18px 17px;
  color: #555;
  border: 1px solid #32ac57;
  background: #fff
}

main .back_txt .list_category2_box_new {
  margin-bottom: 0!important
}

main .back_txt.gray {
  padding: 20px 30px;
  border: none;
  background: #f2f4f7
}

main .back_txt.green {
  padding: 20px 30px;
  border: 1px solid #32ac57;
  background: #edf7f5
}

main .back_txt_ttl {
  font-size: 1.6rem;
  font-weight: 700;
  position: relative;
  margin-bottom: 3px;
  padding-left: 12px;
  color: #32ac57
}

main .back_txt_ttl:before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 3px;
  height: calc(100% - 10px);
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: #55c477
}

main .back_txt_ttl:after {
  position: absolute;
  bottom: -4px;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  content: "";
  background: -webkit-linear-gradient(right, #aaa 4px, transparent 2px);
  background: linear-gradient(-90deg, #aaa 4px, transparent 2px);
  background-size: 6px 1px
}

main .back_txt_ttl+p {
  margin-top: 24px
}

main .back_txt_ttl+.standard_list {
  margin-top: 14px
}

main .back_txt .standard_list ol li:last-of-type, main .back_txt .standard_list>ul li:last-of-type {
  margin-bottom: 0
}

main .back_txt .standard_list ol li .red, main .back_txt .standard_list>ul li .red {
  font-weight: 500;
  color: #da5442
}

main .back_txt .standard_list .decimal {
  list-style-type: none;
  counter-reset: num
}

main .back_txt .standard_list .decimal li {
  line-height: 1.5;
  display: table
}

main .back_txt .standard_list .decimal li:before {
  font-size: 1.6rem;
  font-weight: 700;
  display: table-cell;
  width: 1.7em;
  content: counter(num);
  counter-increment: num
}

main .back_txt .standard_list .decimal li:not(:last-child) {
  margin-bottom: 10px
}

main .back_txt .standard_list li .list_ttl {
  font-size: 1.6rem;
  display: block
}

main .back_txt .standard_list li .list_ttl+p {
  font-size: 1.4rem;
  line-height: 1.57
}

main .back_txt .standard_list li .innerlist {
  margin-top: 4px
}

main .back_txt .standard_list li .innerlist li {
  margin-bottom: 4px
}

main .back_txt .standard_list .-free {
  padding-left: 0
}

main .back_txt .standard_list .-free>li {
  display: table
}

main .back_txt .standard_list .-free>li:before {
  display: table-cell;
  padding-right: 5px;
  content: attr(data-text);
  white-space: nowrap
}

main .back_txt p .red {
  font-weight: 500;
  color: #da5442
}

main .back_txt>*+.img_big {
  margin-top: 25px
}

main .back_txt .img_big {
  margin-bottom: 5px
}

main .back_txt .img_big .img_big_box figure {
  margin-bottom: 0
}

main .back_txt .txt_img_new {
  margin-bottom: 0
}

main .back_txt .txt_img_new.img_fit {
  padding: 20px 10px 0
}

main .back_sub_txt_new {
  position: relative;
  margin-top: 40px;
  margin-bottom: 45px;
  border: 1px solid #32ac57
}

main .back_sub_txt_new span {
  font-size: 14px;
  position: absolute;
  z-index: 9;
  top: -23px;
  left: 19px;
  display: inline-block;
  padding: 5px 10px;
  color: #fff;
  background: #32ac57
}

main .back_sub_txt_new p {
  font-size: 16px;
  line-height: 26px;
  padding: 18px 17px;
  color: #555
}

main .img_big_big {
  width: 100%;
  max-width: 980px;
  margin: 0 auto
}

main .img_big_big.left {
  margin: 0
}

main .img_big_big.left .img_big_big_box figure p img {
  margin: 0
}

main .img_big_big .img_big_big_box figure {
  margin-bottom: 25px
}

main .img_big_big .img_big_big_box figure p {
  width: 100%
}

main .img_big_big .img_big_big_box figure p img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: auto
}

main .img_big_big .img_big_big_box figure.-border p {
  outline: 1px solid #ccc
}

main .img_big_big .img_big_big_box figure p:last-of-type {
  display: none
}

main .img_big_big .img_big_big_box figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .img_big_big .img_big_big_box figure figcaption.left {
  text-align: left
}

main .img_big_big a {
  display: block
}

main .img_big_big a:hover {
  opacity: 0.5
}

main .img_big_big a img:hover {
  opacity: 1
}

main .img_big_big.bk figure p {
  background: #d3d0d0
}

main .img_wide {
  width: 100%;
  margin: 0 auto
}

main .img_wide .img_wide_box figure {
  margin-bottom: 25px
}

main .img_wide .img_wide_box figure p {
  width: 100%
}

main .img_wide .img_wide_box figure p img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: auto
}

main .img_wide .img_wide_box figure.-border p {
  outline: 1px solid #ccc
}

main .img_wide .img_wide_box figure p:last-of-type {
  display: none
}

main .img_wide .img_wide_box figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .img_wide a {
  display: block
}

main .img_wide a:hover {
  opacity: 0.5
}

main .img_wide a img:hover {
  opacity: 1
}

main .img_wide.bk figure p {
  background: #d3d0d0
}

main .page_link {
  display: -webkit-box;
  display: flex;
  margin-bottom: 50px;
  padding: 20px 20px 6px;
  background: #f4f4f4;
  flex-wrap: wrap
}

main .page_link li {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-right: 14px;
  margin-bottom: 14px
}

main .page_link li a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 10px 50px 10px 20px;
  background: #fff
}

main .page_link li a:hover {
  text-decoration: underline
}

main .page_link li a:after {
  position: absolute;
  top: 50%;
  right: 20px;
  display: block;
  width: 17px;
  height: 10px;
  margin-left: 14px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/icon_arw_down.png) no-repeat;
  background-size: contain
}

main .faq_ttl {
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 60px;
  padding: 7px 20px;
  color: #fff;
  background-color: #32ac57
}

main .faq li {
  margin-bottom: 25px;
  border-bottom: 1px solid #ccc
}

main .faq li:last-child {
  border-bottom: none
}

main .faq_btn a {
  font-size: 1.4rem;
  position: relative;
  display: inline-block;
  margin: 20px 0 0 0;
  padding: 8px 40px 8px 20px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  letter-spacing: normal;
  background: #eee
}

main .faq_btn a:hover {
  opacity: 0.5
}

main .faq_btn a:after {
  position: absolute;
  top: 50%;
  right: 15px;
  display: block;
  width: 13px;
  height: 12px;
  margin-top: -6px;
  content: "";
  background-image: url(../images/icon_arw_w.png);
  background-repeat: no-repeat;
  background-size: contain
}

main .faq_btn a {
  display: block;
  width: 300px;
  text-align: center;
  color: #fff;
  background-color: #32ac57
}

main .faq .a, main .faq .q {
  display: table;
  width: 100%;
  padding-bottom: 25px;
  table-layout: fixed
}

main .faq .a:before, main .faq .q:before {
  font-size: 1.8rem;
  display: table-cell;
  width: 34px;
  padding-right: 20px;
  content: "Q";
  text-align: center;
  color: #32ac57
}

main .faq .q_txt {
  font-size: 1.8rem;
  font-weight: 700;
  display: table-cell
}

main .faq .a:before {
  content: "A"
}

main .faq .a_txt {
  display: table-cell
}

main .faq .a_txt>a {
  font-weight: 500;
  text-decoration: underline
}

main .faq .a_txt>a:hover {
  opacity: 0.7
}

main .faq .a .btn_small {
  margin-top: 20px
}

main .faq .a .btn_small:last-child {
  margin-bottom: 0
}

main .img_small_new {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .img_small_new .img_small_box_new {
  width: calc((100% - 31px) / 3);
  max-width: 340px;
  margin-top: 15px;
  border: 1px solid #ccc
}

main .img_small_new .img_small_box_new:nth-of-type(-n+3) {
  margin-top: 0
}

main .img_small_new .img_small_box_new a {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column;
  height: 100%
}

main .img_small_new .img_small_box_new a:hover {
  opacity: 0.7
}

main .img_small_new .img_small_box_new:not(:nth-child(3n)) {
  margin-right: 15px
}

main .img_small_new .image_small_new {
  position: relative;
  padding-top: 66.4705882353%
}

main .img_small_new .image_small_new img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto
}

main .img_small_new .image_small_new.p_lr img {
  width: calc(100% - 20px)
}

main .img_small_new .image_small_new.p_tb img {
  height: calc(100% - 20px)
}

main .img_small_new .content_small_new {
  display: -webkit-box;
  display: flex;
  border-top: 1px solid #eee;
  -webkit-box-flex: 1;
  flex-grow: 1;
  -webkit-box-align: center;
  align-items: center
}

main .img_small_new .content_small_new:after {
  display: block;
  width: 13px;
  height: 12px;
  margin-right: 20px;
  content: "";
  background: url(../images/icon_arw_green.png) no-repeat;
  background-size: contain
}

main .img_small_new .content_small_new p {
  line-height: 24px;
  width: calc(100% - 33px);
  padding: 16px 7px 16px 20px;
  text-align: center;
  color: #555
}

main .img_small_new.bk .image_small_new {
  background: #d3d0d0
}

main .list_category_new {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .list_category_new .list_category_box_new {
  width: calc((100% - 20px) / 2);
  margin-top: 20px;
  border: 1px solid #ccc
}

main .list_category_new .list_category_box_new:nth-of-type(-n+2) {
  margin-top: 0
}

main .list_category_new .list_category_box_new a {
  display: block
}

main .list_category_new .list_category_box_new a:hover {
  opacity: 0.5
}

main .list_category_new .list_category_box_new .ttl_list_category_box_new {
  font-size: 1.8rem;
  line-height: 1.5;
  color: #fff;
  background: #4cb86d
}

main .list_category_new .list_category_box_new .ttl_list_category_box_new span {
  display: -webkit-box;
  display: flex;
  padding: 7px 45px 7px 20px;
  background: url(../images/icon_arw_white.png) no-repeat right 17px center;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .list_category_new .list_category_box_new .cont_list_category_box_new {
  display: -webkit-box;
  display: flex;
  padding: 15px 20px
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .l_cont_list_category_box_new {
  width: 100%
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .l_cont_list_category_box_new p {
  line-height: 26px;
  color: #555
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .l_cont_list_category_box_new img {
  width: auto;
  outline: 1px solid #ccc
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .l_cont_list_category_box_new.no-border img {
  outline: 0
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .r_cont_list_category_box_new {
  width: 47%;
  padding-left: 20px
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .r_cont_list_category_box_new img {
  margin-top: 5px;
  margin-bottom: 5px;
  outline: 1px solid #ccc
}

main .list_category_new .list_category_box_new .cont_list_category_box_new .r_cont_list_category_box_new.no-border img {
  outline: 0
}

main .list_category_new .list_category_box_new:not(:nth-child(2n)) {
  margin-right: 20px
}

main .ttl_category_box_wrap {
  width: calc((100% - 20px) / 2);
  margin-top: 20px
}

main .ttl_category_box_wrap .ttl_list_category_box_new {
  font-size: 1.8rem;
  line-height: 1.5;
  margin-top: 20px;
  padding: 7px 20px;
  color: #fff;
  background: #4cb86d
}

main .ttl_category_box_wrap .ttl_list_category_box_new:first-of-type {
  margin-top: 0
}

main .ttl_link_new_h3 {
  display: -webkit-box;
  display: flex;
  margin-top: 40px;
  margin-bottom: 20px;
  padding-bottom: 4px;
  border-bottom: 1px solid #ccc;
  -webkit-box-align: baseline;
  align-items: baseline
}

main .ttl_link_new_h3 a:hover {
  -webkit-transition: all 0.2s ease 0s;
  transition: all 0.2s ease 0s;
  opacity: 0.5
}

main .ttl_link_new_h3 span {
  font-size: 18px;
  font-weight: 400;
  color: #333
}

main .ttl_link_new_h3 span:before {
  position: relative;
  top: 3px;
  display: inline-block;
  width: 24px;
  height: 20px;
  margin-right: 12px;
  content: "";
  background-image: url(../images/icon_arw.png);
  background-repeat: no-repeat;
  background-position: top;
  background-size: contain;
  -webkit-box-flex: 0;
  flex: 0 0 20px
}

main .list_thums_new {
  margin-bottom: 30px
}

main .list_thums_new .box_list_thums_new {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: left
}

main .list_thums_new .box_list_thums_new .item_list_thums_new {
  width: calc((100% - 41px) / 3);
  margin-top: 20px
}

main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+3) {
  margin-top: 0
}

main .list_thums_new .box_list_thums_new .item_list_thums_new a {
  display: block
}

main .list_thums_new .box_list_thums_new .item_list_thums_new a:hover {
  opacity: 0.5
}

main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new {
  display: -webkit-box;
  display: flex;
  padding: 7px;
  border: 1px solid #ccc;
  flex-wrap: wrap
}

main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .l_main_item_list_thums_new {
  display: -webkit-box;
  display: flex;
  width: 25.3%;
  margin-right: 12px;
  -webkit-box-align: center;
  align-items: center
}

main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .l_main_item_list_thums_new img {
  width: auto
}

main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .r_main_item_list_thums_new {
  width: 70%
}

main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .r_main_item_list_thums_new p {
  display: -webkit-box;
  display: flex;
  min-height: 82px;
  margin: 0;
  -webkit-box-align: center;
  align-items: center
}

main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(3n)) {
  margin-right: 20px
}

main .back_regulation {
  padding: 40px 0;
  background: #f2f4f7
}

main .box_list_link_back_new {
  display: -webkit-box;
  display: flex;
  margin-bottom: 30px;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: left
}

main .box_list_link_back_new .item_list_link_back_new {
  width: calc(33.3333333333% - 20px);
  margin-bottom: 20px
}

main .box_list_link_back_new .item_list_link_back_new a {
  display: block
}

main .box_list_link_back_new .item_list_link_back_new a:hover {
  opacity: 0.5
}

main .box_list_link_back_new .item_list_link_back_new .main_item_list_link_back_new {
  border: 1px solid #ccc;
  background: #fff
}

main .box_list_link_back_new .item_list_link_back_new .main_item_list_link_back_new span {
  line-height: 27px;
  display: -webkit-box;
  display: flex;
  min-height: 70px;
  padding: 7px 15px;
  padding-left: 45px;
  color: #555;
  background: url(../images/icon_arrow_r_new.png) no-repeat left 24px center;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .box_list_link_back_new .item_list_link_back_new:not(:nth-child(3n)) {
  margin-right: 30px
}

main .list_category2_new {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .list_category2_new .list_category2_box_new {
  width: calc((100% - 20px) / 2);
  margin-top: 20px;
  border: 1px solid #ccc
}

main .list_category2_new .list_category2_box_new:nth-of-type(-n+2) {
  margin-top: 0
}

main .list_category2_new .list_category2_box_new .ttl_list_category2_box_new {
  font-size: 1.8rem;
  line-height: 1.5;
  color: #fff;
  background: #4cb86d
}

main .list_category2_new .list_category2_box_new .ttl_list_category2_box_new a {
  display: -webkit-box;
  display: flex;
  padding: 7px 45px 7px 20px;
  background: url(../images/icon_arw_white.png) no-repeat right 15px center;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .list_category2_new .list_category2_box_new .ttl_list_category2_box_new a:hover {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  background-color: rgba(255, 255, 255, 0.6);
  background-blend-mode: color
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new {
  display: -webkit-box;
  display: flex;
  padding: 15px 15px
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new {
  width: 100%
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new {
  width: 49%
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new a {
  line-height: 27px;
  display: -webkit-box;
  display: flex;
  padding: 7px 15px;
  padding-left: 27px;
  color: #555;
  background: url(../images/icon_arrow_r_new.png) no-repeat left 5px top 15px;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new a:hover {
  text-decoration: underline
}

main .list_category2_new .list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new:not(:nth-child(2n)) {
  margin-right: 1.88%
}

main .list_category2_new .list_category2_box_new:not(:nth-child(2n)) {
  margin-right: 20px
}

main .ttl_category2_box_wrap {
  width: calc((100% - 20px) / 2);
  margin-top: 20px
}

main .ttl_category2_box_wrap .ttl_list_category2_box_new {
  font-size: 1.8rem;
  line-height: 1.5;
  margin-top: 20px;
  color: #fff;
  background: #4cb86d
}

main .ttl_category2_box_wrap .ttl_list_category2_box_new:first-of-type {
  margin-top: 0
}

main .ttl_category2_box_wrap .ttl_list_category2_box_new a {
  display: -webkit-box;
  display: flex;
  padding: 7px 45px 7px 20px;
  background: url(../images/icon_arw_white.png) no-repeat right 15px center;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .ttl_category2_box_wrap .ttl_list_category2_box_new a:hover {
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  background-color: rgba(255, 255, 255, 0.6);
  background-blend-mode: color
}

main .button-arrow-link {
  margin-top: 50px;
  margin-bottom: 50px;
  text-align: center
}

main .button-arrow-link a {
  font-size: 16px;
  font-weight: 300;
  display: inline-block;
  margin: 0 15px;
  padding: 8px 73px;
  color: #555;
  background: #eee;
  background: url(../images/icon_arw_link_r.png) no-repeat right 15px center #eee;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .button-arrow-link a:hover {
  opacity: 0.7
}

main .button-arrow-link span {
  font-size: 16px;
  font-weight: 300;
  display: inline-block;
  margin: 0 15px;
  padding: 8px 73px;
  color: rgba(85, 85, 85, 0.5);
  background: #eee;
  background: url(../images/icon_arw_link_lg_r.png) no-repeat right 15px center #eee;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .button-arrow-link a.left-button-arrow-link {
  padding: 8px 69px;
  padding-left: 76px;
  background: url(../images/icon_arw_link_l.png) no-repeat left 15px center #eee
}

main .button-arrow-link a.right-button-arrow-link {
  padding: 8px 69px;
  padding-right: 76px
}

main .button-arrow-link span.left-button-arrow-link.-disable {
  padding: 8px 69px;
  padding-left: 76px;
  background: url(../images/icon_arw_link_lg_l.png) no-repeat left 15px center #eee
}

main .button-arrow-link span.right-button-arrow-link.-disable {
  padding: 8px 69px;
  padding-right: 76px
}

main .list_cate_link_new {
  margin-bottom: 25px
}

main .list_cate_link_new .box_list_cate_link_new {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new {
  display: -webkit-box;
  display: flex;
  width: 49%;
  margin-top: 20px;
  border: 1px solid #ccc;
  -webkit-box-align: center;
  align-items: center
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:nth-of-type(-n+2) {
  margin-top: 0
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new:hover {
  opacity: 0.7
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new {
  width: 100%
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new a {
  display: block;
  padding: 12px 10px
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .l_main_item_list_cate_link_new {
  position: relative;
  width: 29.756%;
  padding-top: 42.2230432258%
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .l_main_item_list_cate_link_new img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
  max-height: 100%;
  margin: auto;
  outline: 1px solid #ccc
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .l_main_item_list_cate_link_new img:hover {
  opacity: 1
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .l_main_item_list_cate_link_new.no-border img {
  outline: 0
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new {
  position: relative;
  display: -webkit-box;
  display: flex;
  width: 70.24%;
  padding: 0 20px;
  -webkit-box-align: center;
  align-items: center
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new .con_r_main_item_list_cate_link_new {
  display: block;
  width: 100%
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new .con_r_main_item_list_cate_link_new p {
  font-size: 18px;
  font-weight: 500;
  color: #555
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new .con_r_main_item_list_cate_link_new hr {
  width: 60px;
  margin: 7px auto 7px 0;
  border-top: 2px solid #32ac57
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new .con_r_main_item_list_cate_link_new .all_list_cate_link_new span {
  color: #666
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new:after {
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 32px;
  height: 32px;
  content: "";
  background: #ccc;
  background-image: url(../images/icon_arw.png);
  background-repeat: no-repeat;
  background-size: cover
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:not(:nth-child(2n)) {
  margin-right: 1.88%
}

main .list_cate_link_new.column1 {
  margin-bottom: 25px
}

main .list_cate_link_new.column1 .box_list_cate_link_new {
  max-width: 600px;
  margin: 0 auto
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new {
  width: 100%
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new:nth-of-type(-n+2) {
  margin-top: 20px
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new:first-of-type {
  margin-top: 0
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new:not(:nth-child(2n)) {
  margin-right: 0
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new:last-of-type {
  margin-bottom: 0
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .l_main_item_list_cate_link_new {
  width: 26.65%;
  padding-top: 37.55%
}

main .list_cate_link_new.column1 .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new {
  width: 73.3%
}

main .button-arrow-link-single {
  line-height: 1.2;
  position: absolute;
  top: -35px;
  right: 0;
  text-align: left
}

main .button-arrow-link-single.mg_b70_new {
  margin-bottom: 70px
}

main .button-arrow-link-single a {
  font-size: 1.4rem;
  font-weight: 300;
  position: relative;
  display: block;
  padding-left: 24px;
  color: #444;
  -webkit-box-align: center;
  align-items: center
}

main .button-arrow-link-single a:after {
  display: inline-block;
  width: 13px;
  height: 12px;
  margin-left: 10px;
  content: "";
  background: url(../images/icon_arw_green.png) no-repeat;
  background-size: contain
}

main .button-arrow-link-single a:hover {
  opacity: 0.7
}

main .button-arrow-link-single a.left-button-arrow-link-single:before {
  position: absolute;
  top: 3px;
  left: 0;
  display: block;
  width: 13px;
  height: 12px;
  content: "";
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  background: url(../images/icon_arw_green.png) no-repeat;
  background-size: contain
}

main .button-arrow-link-single a.left-button-arrow-link-single:after {
  content: none
}

main .button-arrow-link2 {
  margin-bottom: 50px;
  text-align: center
}

main .button-arrow-link2.mg_b70_new {
  margin-bottom: 70px
}

main .button-arrow-link2 a {
  font-size: 16px;
  font-weight: 300;
  display: inline-block;
  margin: 0 15px;
  padding: 8px 73px;
  color: #555;
  background: #eee;
  background: url(../images/icon_arw_link_r.png) no-repeat right 15px center #eee;
  background-size: auto;
  -webkit-box-align: center;
  align-items: center
}

main .button-arrow-link2 a:hover {
  opacity: 0.7
}

main .button-arrow-link2:after {
  display: block;
  clear: both;
  content: ""
}

main .button-arrow-link2 a.left-button-arrow-link2 {
  float: left;
  margin: 0;
  padding: 8px 25px;
  padding-left: 46px;
  background: url(../images/icon_arw_link_l.png) no-repeat left 15px center #eee
}

main .button-arrow-link2 a.right-button-arrow-link2 {
  float: right;
  margin: 0;
  padding: 8px 25px;
  padding-right: 46px
}

main .blog_new {
  margin-bottom: 50px
}

main .blog_new .main_blog_new {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .blog_new .main_blog_new .l_blog_new {
  width: 49%
}

main .blog_new .main_blog_new .l_blog_new p {
  line-height: 26px;
  color: #555
}

main .blog_new .main_blog_new .l_blog_new:not(:nth-child(2n)) {
  margin-right: 1.88%
}

main .blog_new .main_blog_new .r_blog_new {
  width: 49%
}

main .link_menu_new {
  display: -webkit-box;
  display: flex;
  margin-bottom: 50px;
  flex-wrap: wrap
}

main .link_menu_new.column3 li {
  width: calc((100% - 29px) / 3)
}

main .link_menu_new.column3 li:not(:nth-child(3n)) {
  margin-right: 14px
}

main .link_menu_new li {
  min-height: 74px;
  margin-bottom: 14px;
  border: 1px solid #ccc
}

main .link_menu_new li.active {
  background: #e3f3ea
}

main .link_menu_new li a {
  line-height: 1.68;
  display: -webkit-box;
  display: flex;
  width: 100%;
  height: 100%;
  padding: 10px 20px;
  color: #555;
  -webkit-box-align: center;
  align-items: center
}

main .link_menu_new li a:before {
  display: block;
  width: 16px;
  height: 16px;
  margin-right: 18px;
  content: "";
  background-image: url(../images/icon_arw.png);
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-box-flex: 0;
  flex: 0 0 16px
}

main .link_menu_new li a:hover {
  opacity: 0.7;
  color: #198a3b
}

main .list_video {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap;
  -webkit-box-pack: justify
}

main .list_video.column1 .item_list_video {
  max-width: 600px;
  margin: 25px auto 0
}

main .list_video.column1 .item_list_video:first-of-type {
  margin-top: 0
}

main .list_video.column1 .content_item_list_video:hover {
  opacity: 0.7
}

main .list_video.column2 .item_list_video {
  width: 48.114%;
  margin-top: 25px
}

main .list_video.column2 .item_list_video:nth-of-type(-n+2) {
  margin-top: 0
}

main .list_video.column2 .item_list_video .content_item_list_video:hover {
  opacity: 0.7
}

main .list_video.column2 .item_list_video:not(:nth-child(2n)) {
  margin-right: 40px
}

main .list_video.column3 .item_list_video {
  width: 30.5%;
  margin-top: 25px
}

main .list_video.column3 .item_list_video:nth-of-type(-n+3) {
  margin-top: 0
}

main .list_video.column3 .item_list_video .content_item_list_video:after {
  top: 50%;
  left: 50%;
  width: 75px;
  height: 75px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}

main .list_video.column3 .item_list_video .content_item_list_video:hover {
  opacity: 0.7
}

main .list_video.column3 .item_list_video:not(:nth-child(3n)) {
  margin-right: 1.88%
}

main .list_video .item_list_video .ttl_item_list_video {
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid #32ac57
}

main .list_video .item_list_video .ttl_item_list_video span {
  font-size: 18px;
  line-height: 27px;
  display: -webkit-box;
  display: flex;
  color: #555;
  -webkit-box-align: center;
  align-items: flex-end
}

main .list_video .item_list_video .content_item_list_video {
  position: relative
}

main .list_video .item_list_video .content_item_list_video:after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 88px;
  height: 88px;
  content: "";
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: url(../images/play.png) no-repeat;
  background-size: 100% 100%
}

main .list_video .item_list_video .content_item_list_video:hover {
  cursor: pointer
}

main .list_video .item_list_video .text_item_list_video {
  margin: 10px 0 0
}

main .list_video .item_list_video .text_item_list_video p {
  line-height: 26px;
  color: #555
}

main .content_list_contact {
  margin-bottom: 50px
}

main .content_list_contact .item {
  position: relative;
  position: relative;
  display: -webkit-box;
  display: flex;
  border-right: 2px solid #eee;
  border-bottom: 2px solid #eee;
  border-left: 2px solid #eee;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: flex-end
}

main .content_list_contact .item:first-of-type {
  border-top: 2px solid #eee
}

main .content_list_contact .item .decimal {
  padding-left: 20px
}

main .content_list_contact .item .decimal>li {
  display: list-item;
  padding-left: 10px;
  list-style: decimal
}

main .content_list_contact .item.not-child:last-child>dd {
  border-bottom: 1px solid #eee
}

main .content_list_contact .item.not-child:last-child>dt {
  line-height: 26px;
  width: 25%;
  padding: 20px 10px;
  padding-left: 30px;
  color: #333
}

main .content_list_contact .item>dt {
  line-height: 26px;
  position: absolute;
  top: 50%;
  left: 0;
  display: -webkit-box;
  display: flex;
  width: 25%;
  height: 100%;
  padding: 10px 10px 10px 30px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  color: #333;
  background: #f5f5f5;
  -webkit-box-align: center;
  align-items: center
}

main .content_list_contact .item>dt:not(:first-of-type) {
  display: none
}

main .content_list_contact .item>dd {
  line-height: 26px;
  display: grid;
  width: 75%;
  padding: 10px 10px 10px 30px;
  color: #555;
  border-bottom: 2px solid #eee;
  border-left: 2px solid #eee;
  -webkit-box-align: center;
  align-items: center
}

main .content_list_contact .item>dd:last-child {
  border-bottom: none
}

main .content_list_contact .item>dd .link_contact {
  position: relative;
  display: block;
  margin-top: 4px;
  padding-left: 14px;
  text-decoration: underline
}

main .content_list_contact .item>dd .link_contact.ic_pdf:before {
  top: 10px
}

main .content_list_contact .item>dd .link_contact:before {
  position: absolute;
  top: 6px;
  left: 0;
  display: inline-block;
  width: 12px;
  height: 17px;
  margin-right: 5px;
  content: "";
  background-image: url(../images/icon_arrow_r_new.png);
  background-repeat: no-repeat;
  background-size: contain
}

main .content_list_contact .item>dd .link_contact:hover {
  opacity: 0.7
}

main .list_contact.csr .content_list_contact {
  width: 94.33%;
  margin-left: auto
}

main .list_contact.csr .content_list_contact .item {
  border: none
}

main .list_contact.csr .content_list_contact .item:before {
  position: absolute;
  z-index: 9;
  bottom: 0;
  left: 0;
  width: 25%;
  content: "";
  border-bottom: 1px solid #549567
}

main .list_contact.csr .content_list_contact .item:first-of-type:after {
  position: absolute;
  z-index: 9;
  top: 0;
  left: 0;
  width: 25%;
  content: "";
  border-bottom: 1px solid #549567
}

main .list_contact.csr .content_list_contact .item:first-of-type>dd {
  border-top: 1px solid #ccc
}

main .list_contact.csr .content_list_contact .item>dt {
  height: 100%;
  padding: 10px 10px 10px 30px;
  background: #fafafa
}

main .list_contact.csr .content_list_contact .item>dd {
  min-height: auto;
  padding: 10px 10px 10px 30px;
  border-bottom: 1px solid #ccc;
  border-left: none
}

main .blog2_new {
  margin-bottom: 30px
}

main .catch_copy {
  font-size: 2rem;
  line-height: 1.4
}

main .catch_copy.-large {
  font-size: 3rem;
  font-weight: 500
}

main .catch_copy.-center {
  text-align: center
}

main .catch_copy .red {
  font-weight: 700;
  color: #da5442
}

main .catch_copy_box {
  position: relative;
  margin-top: 50px;
  margin-bottom: 60px
}

main .catch_copy_box:after, main .catch_copy_box:before {
  position: absolute;
  top: 0;
  display: inline-block;
  width: 5.66%;
  height: 100%;
  content: ""
}

main .catch_copy_box:before {
  left: 0;
  border-top: 8px solid #eee;
  border-bottom: 8px solid #eee;
  border-left: 8px solid #eee
}

main .catch_copy_box:after {
  right: 0;
  border-top: 8px solid #eee;
  border-right: 8px solid #eee;
  border-bottom: 8px solid #eee
}

main .catch_copy_box_inner {
  width: 91.5%;
  margin: 0 auto;
  padding: 24px 0
}

main .catch_copy_box .standard_txt_new {
  margin-bottom: 5px
}

main .catch_copy_box .note_list {
  margin-bottom: 0
}

main .catch_copy_box .arw {
  display: block;
  margin: 6px 0;
  text-align: center
}

main .catch_copy_box .arw:after {
  display: inline-block;
  width: 0;
  height: 0;
  content: "";
  border-width: 11px 9px 0 9px;
  border-style: solid;
  border-color: #da5442 transparent transparent transparent
}

main .lineup_box {
  margin-bottom: 60px;
  border: 1px solid #ccc
}

main .lineup_box_inner {
  padding: 40px
}

main .lineup_box_inner .note_list {
  margin-bottom: 0
}

main .lineup_ttl {
  font-size: 2rem;
  line-height: 1.4;
  padding: 10px 25px;
  color: #fff;
  background: -webkit-linear-gradient(135deg, #47a463 25%, #66cf86 25%, #66cf86 50%, #47a463 50%, #47a463 75%, #66cf86 75%, #66cf86);
  background: linear-gradient(-45deg, #47a463 25%, #66cf86 25%, #66cf86 50%, #47a463 50%, #47a463 75%, #66cf86 75%, #66cf86);
  background-size: 5px 5px
}

main .lineup_img_warp {
  width: 100%;
  margin-bottom: 25px;
  text-align: center
}

main .lineup_img_warp img {
  width: auto;
  max-width: 100%
}

main .feature_point_ttl {
  display: -webkit-box;
  display: flex;
  margin-top: 60px;
  margin-bottom: 25px;
  padding: 15px;
  border: 1px solid #999;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .feature_point_ttl_num {
  font-size: 1.6rem;
  line-height: 1;
  width: 120px;
  margin-right: 15px;
  padding: 8px;
  text-align: center;
  color: #fff;
  border-radius: 30px;
  background: #209342
}

main .feature_point_ttl_num span {
  font-size: 2.4rem;
  display: block;
  margin-top: 4px
}

main .feature_point_ttl_txt {
  width: calc(100% - 135px)
}

main .feature_point_ttl_txt .sub {
  font-size: 1.6rem;
  line-height: 1.2;
  color: #209342
}

main .feature_point_ttl_txt .main {
  font-size: 2.8rem;
  line-height: 1.4;
  color: #444
}

main .feature_list {
  margin-bottom: 20px
}

main .feature_list:last-child {
  margin-bottom: 0
}

main .feature_list li {
  font-size: 2rem;
  line-height: 1.5;
  position: relative;
  margin-top: 8px;
  padding-left: 34px;
  color: #476eaa
}

main .feature_list li:before {
  position: absolute;
  top: 10px;
  left: 12px;
  display: block;
  width: 12px;
  height: 12px;
  content: "";
  background: #436aa5
}

main .feature_list li:first-of-type {
  margin-top: 0
}

main .feature_list li p {
  font-size: 1.6rem;
  color: #555
}

main .feature_list li .red {
  font-weight: 700;
  color: #da5442
}

main .feature_list ol {
  padding-left: 0;
  list-style-type: none;
  counter-reset: num
}

main .feature_list ol li:before {
  top: auto;
  width: auto;
  height: auto;
  content: counter(num);
  counter-increment: num;
  background: 0 0
}

main .feature_list>p {
  font-size: 1.6rem;
  line-height: 1.5;
  margin-bottom: 20px;
  padding: 0 5px;
  color: #555
}

main .feature_list>p:last-child {
  margin-bottom: 0
}

main .feature_list.-center {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  flex-direction: column;
  -webkit-box-align: center;
  align-items: center
}

main .feature_list.column2 ol, main .feature_list.column2 ul {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .feature_list.column2 li {
  width: 49%;
  margin-right: 2%
}

main .feature_list.column2 li:nth-of-type(2n) {
  margin-right: 0
}

main .feature_list.column2 li:nth-of-type(-n+2) {
  margin-top: 0
}

main .feature_list.column2 li>p:last-child {
  margin-bottom: 8px
}

main .feature_list.column2 li:nth-last-of-type(-n+2)>p:last-child {
  margin-bottom: 0
}

main .feature_list.column3 ol, main .feature_list.column3 ul {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .feature_list.column3 li {
  width: 32%;
  margin-right: 2%
}

main .feature_list.column3 li:nth-of-type(3n) {
  margin-right: 0
}

main .feature_list.column3 li:nth-of-type(-n+3) {
  margin-top: 0
}

main .feature_list_box {
  margin-bottom: 20px;
  padding: 20px;
  background: #f2f4f7
}

main .feature_list_box>p {
  font-size: 1.6rem;
  line-height: 1.5;
  margin-bottom: 20px;
  padding: 0 5px;
  color: #555
}

main .feature_list_box>p:last-child {
  margin-bottom: 0
}

main .feature_list_ttl {
  display: -webkit-box;
  display: flex;
  margin-bottom: 20px;
  padding: 12px 16px;
  border-bottom: 4px solid #cdd8e8;
  background: #dce4f0;
  -webkit-box-align: center;
  align-items: center;
  flex-wrap: wrap
}

main .feature_list_ttl span {
  font-size: 1.8rem;
  line-height: 1;
  display: inline-block;
  width: 120px;
  margin-right: 25px;
  padding: 9px;
  text-align: center;
  color: #fff;
  border-radius: 17px;
  background: #476eaa
}

main .feature_list_ttl p {
  font-size: 2.8rem;
  line-height: 1.4;
  width: 100%
}

main .feature_list_ttl span+p {
  width: calc(100% - 145px)
}

main .feature_img_list {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between
}

main .feature_img_list .img {
  width: 49%
}

main .feature_img_list .img figure p img {
  margin: 0
}

main .feature_img_list .img figure.-border p {
  outline: 1px solid #ccc
}

main .feature_img_list .img figure figcaption {
  font-size: 1.4rem;
  padding-top: 10px;
  text-align: center;
  color: #555
}

main .feature_img_list .img figure figcaption.left {
  text-align: left
}

main .feature_img_list .list {
  width: 49%
}

main .feature_img_list .list ol {
  padding-left: 0;
  list-style-type: none;
  counter-reset: num
}

main .feature_img_list .list ol li {
  font-size: 2.2rem;
  line-height: 1.4;
  position: relative;
  margin-bottom: 32px;
  padding-left: 62px;
  color: #444
}

main .feature_img_list .list ol li:before {
  font-size: 2.2rem;
  line-height: 40px;
  position: absolute;
  top: 50%;
  left: 0;
  width: 42px;
  height: 42px;
  content: counter(num);
  counter-increment: num;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  text-align: center;
  color: #436aa5;
  border-radius: 21px;
  background: #dce4f0
}

main .feature_img_list .list ol li:last-of-type {
  margin-bottom: 0
}

main .feature_img_list .list ol li span {
  font-size: 1.6rem;
  display: block;
  color: #436aa5
}

main .contact_box {
  width: 94.33%;
  margin-right: auto;
  margin-bottom: 25px;
  margin-left: auto;
  border: 2px solid #32ac57
}

main .contact_box_ttl {
  font-size: 1.8rem;
  line-height: 1.4;
  padding: 7px 16px;
  color: #fff;
  background: #32ac57
}

main .contact_box_inner {
  display: -webkit-box;
  display: flex;
  padding: 24px 40px;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  align-items: flex-start
}

main .contact_box_inner_l {
  width: 57%
}

main .contact_box_inner_r {
  width: 40%
}

main .contact_box_inner .standard_txt_new {
  width: 100%;
  margin-bottom: 20px
}

main .contact_box_inner .standard_list {
  width: 100%
}

main .contact_box_inner .txt_green {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 7px;
  color: #198a3b
}

main .contact_box_inner .txt_small {
  font-size: 1.4rem;
  line-height: 1.4;
  margin-bottom: 7px
}

main .contact_box_inner .tel {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.4;
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

main .contact_box_inner .tel:last-of-type {
  margin-bottom: 10px
}

main .contact_box_inner .tel span {
  display: inline-block;
  margin-right: 30px
}

main .contact_box_inner a[href^="tel:"] {
  pointer-events: none
}

main .contact_box_inner .btn {
  line-height: 1.4;
  position: relative;
  display: inline-block;
  padding: 14px 50px 14px 30px;
  color: #fff;
  background: #32ac57
}

main .contact_box_inner .btn:after {
  position: absolute;
  top: 50%;
  right: 17px;
  display: block;
  width: 15px;
  height: 15px;
  content: "";
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../images/icon_arw_w.png) no-repeat;
  background-size: contain
}

main .contact_box_inner .btn:hover {
  opacity: 0.7
}

main .line {
  width: 100%;
  height: 1px;
  margin-top: 25px;
  margin-bottom: 25px;
  background: #ccc
}

main .topics_box {
  margin-bottom: 25px;
  padding: 20px 30px;
  border: 1px solid #ccc
}

main .topics_heading {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  display: inline-block;
  margin-bottom: 18px;
  padding: 6px 15px;
  color: #fff;
  background: #32ac57
}

main .topics_date {
  display: -webkit-box;
  display: flex;
  margin-bottom: 12px;
  -webkit-box-align: center;
  align-items: center
}

main .topics_date p {
  font-size: 1.6rem;
  line-height: 1
}

main .topics_date span {
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1;
  display: block;
  margin-left: 12px;
  padding: 4px 30px;
  border: 1px solid #ccc
}

main .topics_txt {
  font-size: 1.6rem;
  line-height: 1.56
}

main .block_wrap {
  display: -webkit-box;
  display: flex;
  margin-bottom: 25px;
  flex-wrap: wrap
}

main .block_box {
  width: 48.11%;
  margin-top: 25px
}

main .block_box:nth-of-type(-n+2) {
  margin-top: 0
}

main .block_box:not(:nth-child(2n)) {
  margin-right: 3.77%
}

main .block_box>.small_ttl {
  margin-top: 0
}

main .block_box .standard_list:last-of-type .disc {
  margin-bottom: 0
}

main .lisa_laws_list dt {
  float: left;
  width: 3em
}

main .lisa_laws_list dd {
  margin-bottom: 10px;
  margin-left: 3.5em
}

main .lisa_laws_list.-layer1 dt {
  width: 2em
}

main .lisa_laws_list.-layer1 dd {
  margin-left: 2em
}

main .lisa_laws_list.-layer1.-wide dt {
  width: 3em
}

main .lisa_laws_list.-layer1.-wide dd {
  margin-left: 3em
}

main .lisa_laws_list.-layer2 {
  margin-left: 0.8em
}

main .lisa_laws_list.-layer3 {
  margin-left: 2.8em
}

main .lisa_laws_list.-layer3 dt {
  width: 2em
}

main .lisa_laws_list.-layer3 dd {
  margin-left: 2em
}

main .lisa_laws_list.-layer4 {
  margin-left: 3.8em
}

main .lisa_laws_list.-layer5 {
  margin-left: 5.5em
}

main .lisa_laws_list.-layer5 dt {
  width: 1.5em
}

main .lisa_laws_list.-layer5 dd {
  margin-left: 1.5em
}

main .txt_gray {
  color: #aaa
}

main li.pr_1:before {
  padding-right: 1em!important
}

main li.pr_2:before {
  padding-right: 2em!important
}

main li.pr_3:before {
  padding-right: 3em!important
}

main .search_page ._navs ._page a {
  display: block;
  width: 100%;
  height: 100%
}

main .search_page .pbox-pagenav span._next, main .search_page .pbox-pagenav span._prev {
  position: relative
}

main .search_page .pbox-pagenav span._next a, main .search_page .pbox-pagenav span._prev a {
  display: block;
  width: 100%;
  height: 100%;
  color: transparent
}

main .search_page .pbox-pagenav span._next:before, main .search_page .pbox-pagenav span._prev:before {
  content: none
}

main .search_page .pbox-pagenav span._next a:before, main .search_page .pbox-pagenav span._prev a:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  color: #32ac57;
  background-image: url(../images/next_s.png);
  background-repeat: no-repeat;
  background-position: center center
}

main .search_page .pbox-pagenav span._prev a:before {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg)
}

@-webkit-keyframes modal-video {
  0% {
    opacity: 0
  }
  to {
    opacity: 1
  }
}

@keyframes modal-video {
  0% {
    opacity: 0
  }
  to {
    opacity: 1
  }
}

@-webkit-keyframes modal-video-inner {
  0% {
    -webkit-transform: translate(0, 100px);
    transform: translate(0, 100px)
  }
  to {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
  }
}

@keyframes modal-video-inner {
  0% {
    -webkit-transform: translate(0, 100px);
    transform: translate(0, 100px)
  }
  to {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
  }
}

.modal-video {
  position: fixed;
  z-index: 1000000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  -webkit-animation-name: modal-video;
  animation-name: modal-video;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  opacity: 1;
  background-color: rgba(0, 0, 0, 0.5)
}

.modal-video-close {
  opacity: 0
}

.modal-video-close .modal-video-movie-wrap {
  -webkit-transform: translate(0, 100px);
  transform: translate(0, 100px)
}

.modal-video-body {
  display: table;
  width: 100%;
  max-width: 940px;
  height: 100%;
  margin: 0 auto
}

.modal-video-inner {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle
}

.modal-video-movie-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-animation-name: modal-video-inner;
  animation-name: modal-video-inner;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-color: #333
}

.modal-video-movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.modal-video-close-btn {
  position: absolute;
  z-index: 2;
  top: -35px;
  right: -35px;
  display: inline-block;
  overflow: hidden;
  width: 35px;
  height: 35px;
  border: none;
  background: 0 0
}

.modal-video-close-btn:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.modal-video-close-btn:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.modal-video-close-btn:after, .modal-video-close-btn:before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  margin-top: -1px;
  margin-top: -6px;
  content: "";
  border-radius: 5px;
  background: #fff
}

.modal-video-new {
  position: fixed;
  z-index: 1000000;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100%;
  cursor: pointer;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  -webkit-animation-name: modal-video;
  animation-name: modal-video;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-color: rgba(0, 0, 0, 0.5)
}

.modal-video-close-new {
  opacity: 0
}

.modal-video-close-new .modal-video-movie-wrap-new {
  -webkit-transform: translate(0, 100px);
  transform: translate(0, 100px)
}

.modal-video-body-new {
  display: table;
  width: 100%;
  max-width: 1028px;
  height: 100%;
  margin: 0 auto;
  padding-right: 64px;
  padding-left: 64px
}

.modal-video-inner-new {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle
}

.modal-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 4%;
  background: #fff
}

.modal-box-outer {
  position: relative;
  width: 100%;
  padding-top: 59.8%
}

.modal-box-inner {
  height: 100%
}

.modal-box-inner p {
  margin-top: 25px
}

.modal-video-new.-txt .modal-box-outer {
  padding-top: 68.68%
}

.modal-video-new.-txt .modal-box-inner {
  overflow-x: hidden;
  overflow-y: scroll
}

.modal-video-movie-wrap-new {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-animation-name: modal-video-inner;
  animation-name: modal-video-inner;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-color: #333
}

.modal-video-movie-wrap-new video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.modal-video-movie-wrap-new .mejs__container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%!important;
  height: 100%!important
}

.modal-video-movie-wrap-new .mejs__overlay-play {
  width: 100%!important;
  height: 100%!important
}

.modal-video-movie-wrap-new .mejs__overlay:hover>.mejs__overlay-button {
  background-position: center center
}

.modal-video-movie-wrap-new .mejs__playpause-button button {
  position: relative;
  top: 0;
  display: block;
  width: 25px;
  height: 25px;
  margin: 6px auto;
  background-image: url(../images/btn_play.png);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100%
}

.modal-video-movie-wrap-new .mejs__pause.mejs__playpause-button button {
  background-image: url(../images/btn_pause.png)
}

.modal-video-movie-wrap-new .mejs__time-float {
  display: none
}

.modal-video-movie-wrap-new .mejs__time-float-current {
  display: none
}

.modal-video-movie-wrap-new .mejs__time-rail {
  width: 78%
}

.modal-video-movie-wrap-new .mejs__time-rail:hover .mejs__time-float {
  display: block
}

.modal-video-movie-wrap-new .mejs__time-rail:hover .mejs__time-float-current {
  display: block
}

.modal-video-close-btn-new {
  position: absolute;
  z-index: 2;
  top: -45px;
  right: -45px;
  display: inline-block;
  overflow: hidden;
  width: 90px;
  height: 90px;
  border: none;
  border-radius: 50%;
  background: rgba(51, 51, 51, 0.9)
}

.modal-video-close-btn-new:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.modal-video-close-btn-new:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.modal-video-close-btn-new:after, .modal-video-close-btn-new:before {
  position: absolute;
  top: 50%;
  left: 12px;
  width: 70%;
  height: 2px;
  content: "";
  border-radius: 5px;
  background: #fff
}

.modal-con-new {
  position: fixed;
  z-index: 1000000;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100%;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
  -webkit-animation-name: modal-video;
  animation-name: modal-video;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-color: rgba(0, 0, 0, 0.5)
}

.modal-con-close-new {
  opacity: 0
}

.modal-con-close-new .modal-con-movie-wrap-new {
  -webkit-transform: translate(0, 100px);
  transform: translate(0, 100px)
}

.modal-con-body-new {
  display: table;
  width: 100%;
  max-width: 1028px;
  height: 100%;
  margin: 0 auto;
  padding-right: 64px;
  padding-left: 64px
}

.modal-con-inner-new {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle
}

.js-button-new {
  cursor: pointer
}

.modal-con-movie-wrap-new {
  position: relative;
  width: 100%;
  height: 528.75px;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-animation-name: modal-video-inner;
  animation-name: modal-video-inner;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
  background-color: #fff
}

.modal-con-movie-wrap-new video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.scroll-modal-wrap-new {
  overflow-y: scroll;
  height: 100%;
  padding: 4%
}

.modal-con-close-btn-new {
  position: absolute;
  z-index: 2;
  top: -45px;
  right: -45px;
  display: inline-block;
  overflow: hidden;
  width: 90px;
  height: 90px;
  border: none;
  border-radius: 50%;
  background: rgba(51, 51, 51, 0.9)
}

.modal-con-close-btn-new:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.modal-con-close-btn-new:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.modal-con-close-btn-new:after, .modal-con-close-btn-new:before {
  position: absolute;
  top: 50%;
  left: 12px;
  width: 70%;
  height: 2px;
  content: "";
  border-radius: 5px;
  background: #fff
}

.annotation_list {
  line-height: 1.7;
  margin-bottom: 15px
}

.annotation_list>li {
  display: table
}

.annotation_list>li:before {
  display: table-cell;
  width: 1.9em;
  padding-right: 5px;
  content: "・"
}

.annotation_list>li:not(:last-child) {
  margin-bottom: 20px
}

.flexBox {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

.flexBox .space {
  -webkit-box-pack: justify;
  justify-content: space-between
}

.flexBox .center {
  -webkit-box-pack: center;
  justify-content: center
}

.category_ttl+.category_ttl, .category_ttl+.category_ttl_h4, .category_ttl+.sec_ttl, .category_ttl+.small_ttl, .sec_ttl+.category_ttl_h4, .sec_ttl+.sec_ttl, .sec_ttl+.small_ttl, .small_ttl+.category_ttl_h4, .small_ttl+.sec_ttl, .small_ttl+.small_ttl {
  margin-top: 0
}

@media print, screen and (min-width:768px) {
  img {
    width: auto
  }
}

@media print, screen and (max-width:1300px) {
  body {
    color: #333
  }
  .footer_nav_inner {
    width: 90%
  }
  main .container {
    width: 90%
  }
}

@media print, screen and (max-width:1100px) {
  body {
    color: #333
  }
  .footer_nav_menu {
    padding: 50px 10%
  }
  .header_pc_search_box .close_btn {
    right: 80px
  }
  .header_menu_item {
    width: 50%
  }
}

@media screen and (max-width:1024px) {
  body a[href] img:hover {
    opacity: inherit
  }
  main .img_col5_box {
    width: 32.07%;
    margin-right: 1.88%
  }
  main .img_col5_box:nth-child(5n) {
    margin-right: 1.88%
  }
  main .img_col5_box:nth-child(3n) {
    margin-right: 0
  }
  main .img_col5_box:nth-of-type(-n+5) {
    margin-top: 25px
  }
  main .img_col5_box:nth-of-type(-n+3) {
    margin-top: 0
  }
  main .img_big a:hover {
    opacity: 1
  }
  main .img_mdm a:hover {
    opacity: 1
  }
  main .img_small a:hover {
    opacity: 1
  }
  main .col4_inner>a:hover {
    opacity: 1
  }
}

@media print, screen and (max-width:950px) {
  body {
    color: #333
  }
  .footer_nav_top ul li {
    margin: 0 8px
  }
  .header_pc_headlink li {
    margin-right: 23px
  }
  .header_pc_headlink li:last-child {
    margin-right: 50px
  }
  .header_pc_search_box input[type=text] {
    width: 300px
  }
  .header_pc_search_box input[type=submit] {
    width: 100px
  }
  .header_pc_search_box .close_btn {
    right: 40px
  }
}

@media print, screen and (max-width:930px) {
  body.no-scroll {
    overflow: hidden;
    height: 100vh
  }
  main .ir_heading_inner {
    display: -webkit-box;
    display: flex;
    padding: 10px 10px;
    text-align: right;
    text-align: right
  }
  main .ir_heading_inner .code {
    margin-right: 0;
    margin-bottom: 10px
  }
  main .ir_heading_inner .stock {
    padding: 2px 12px
  }
  main .ir_heading_inner .stock:nth-of-type(2) {
    margin-left: 10px
  }
  main .ir_heading_inner.-product {
    padding: 10px 10px
  }
  main .ir_heading_inner.-product .stock {
    padding: 2px 7px
  }
}

@media print, screen and (max-width:768px) {
  body {
    font-size: 1.4rem
  }
  .footer {
    width: 100%;
    margin: 0
  }
  .footer .pagetop a:hover {
    opacity: 1
  }
  .footer_nav_top {
    display: block;
    padding-top: 0
  }
  .footer_nav_top .footer_logo {
    border-bottom: 1px solid #ccc
  }
  .footer_nav_top .footer_logo a {
    display: -webkit-box;
    display: flex;
    width: 100%;
    height: 100%;
    padding: 30px 20px;
    -webkit-box-align: center;
    align-items: center
  }
  .footer_nav_top ul {
    font-size: 1.2rem;
    padding: 22px 0 0 20px;
    flex-wrap: wrap
  }
  .footer_nav_top ul li {
    width: 50%;
    margin: 0 0 20px
  }
  .footer_nav_top ul li:first-child {
    display: none
  }
  .footer_nav_top ul li:nth-last-child(2) {
    margin-bottom: 0
  }
  .footer_nav_top ul li:last-child {
    margin-bottom: 0
  }
  .footer_nav_menu {
    display: block;
    padding: 0
  }
  .footer_nav_menu li {
    padding: 16px 0 16px 20px;
    border-bottom: 1px solid #ccc
  }
  .footer_nav_menu li:last-child {
    border-bottom: none
  }
  .footer_nav_sub {
    display: block;
    padding: 12px 0
  }
  .footer_nav_sub li {
    padding: 12px 0 12px 20px
  }
  .header_pc {
    display: none
  }
  .header_side {
    display: none
  }
  .header_menu {
    display: none
  }
  .header_sp {
    position: relative;
    display: block;
    width: 100%;
    height: 50px;
    box-shadow: 4px 0 8px 0 rgba(0, 0, 0, 0.2)
  }
  .header_sp_toggle {
    width: 65px;
    height: 50px
  }
  .header_sp_toggle div {
    position: relative;
    top: 15px;
    left: 20px;
    width: 25px;
    height: 20px
  }
  .header_sp_toggle span {
    position: absolute;
    display: block;
    width: 100%;
    height: 1.5px;
    background-color: #32ac57
  }
  .header_sp_toggle span:first-child {
    top: 0
  }
  .header_sp_toggle span:nth-child(2) {
    top: 9px
  }
  .header_sp_toggle span:last-child {
    top: 18px
  }
  .header_sp_toggle.open {
    position: absolute;
    z-index: 25;
    top: 0;
    top: 0;
    right: 0;
    width: 37px;
    border: 1px solid #555;
    border-radius: 5px;
    background-color: #333
  }
  .header_sp_toggle.open div {
    left: 10px;
    width: 17px;
    height: 19px
  }
  .header_sp_toggle.open span:first-child {
    top: 9px;
    left: 0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    background-color: #fff
  }
  .header_sp_toggle.open span:nth-child(2) {
    left: 0;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    background-color: #fff
  }
  .header_sp_toggle.open span:last-child {
    display: none
  }
  .header_sp_logo {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 110px;
    height: 20px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
  }
  .header_sp_logo img {
    display: block;
    width: 110px;
    height: 20px
  }
  .header_sp_gnav-overlay {
    position: absolute;
    z-index: 20;
    top: 0;
    right: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    -webkit-transform: translate(-100%);
    transform: translate(-100%);
    background-color: rgba(51, 51, 51, 0.8)
  }
  .header_sp_gnav-overlay.open {
    -webkit-transform: translate(0);
    transform: translate(0)
  }
  .header_sp_gnav {
    font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400;
    position: absolute;
    z-index: 10;
    top: 0;
    left: 0;
    width: calc(100% - 37px);
    color: #fff;
    background-color: #32ac57
  }
  .header_sp_gnav_main-top {
    display: -webkit-box;
    display: flex;
    height: 50px;
    background-color: #fff;
    -webkit-box-align: center;
    align-items: center
  }
  .header_sp_gnav_main-top img {
    width: 25.5px
  }
  .header_sp_gnav_main>li:nth-child(2) .header_sp_gnav_main_trigger {
    background: #198a3b
  }
  .header_sp_gnav_main>li:nth-child(3) .header_sp_gnav_main_trigger {
    background: #209342
  }
  .header_sp_gnav_main>li:nth-child(4) .header_sp_gnav_main_trigger {
    background: #249a47
  }
  .header_sp_gnav_main>li:nth-child(5) .header_sp_gnav_main_trigger {
    background: #2ba34f;
    padding: 10px 20px;
  }
  .header_sp_gnav_main>li:nth-child(6) .header_sp_gnav_main_trigger {
    background: #2ea752
  }
  .header_sp_gnav_main-search {
    width: 100%
  }
  .header_sp_gnav_main-search form {
    line-height: 0;
    position: relative
  }
  .header_sp_gnav_main-search form input[type=text] {
    font-size: 1.6rem;
    line-height: 24px;
    width: calc(100% - 13px);
    height: 24px;
    padding: 2px 0.5em;
    border: 1px solid #333
  }
  .header_sp_gnav_main-search form input[type=text]:focus {
    outline: 0
  }
  .header_sp_gnav_main-search form input[type=text]:focus::-webkit-input-placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form input[type=text]:focus::-moz-placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form input[type=text]:focus:-ms-input-placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form input[type=text]:focus::-ms-input-placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form input[type=text]:focus::placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form input[type=text]:focus::-webkit-input-placeholder {
    color: transparent
  }
  .header_sp_gnav_main-search form button {
    position: absolute;
    top: 50%;
    right: 20px;
    width: 15px;
    height: 24px;
    padding: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
  }
  .header_sp_gnav_main-search form button img {
    width: 15px
  }
  .header_sp_gnav_main-close span {
    position: absolute;
    top: 22px;
    right: 4px;
    display: block;
    width: 25px;
    height: 1.5px;
    background-color: #fff
  }
  .header_sp_gnav_main-close span:first-child {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
  }
  .header_sp_gnav_main-close span:last-child {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg)
  }
  .header_sp_gnav_main a {
    display: block;
    padding: 15px 20px
  }
  .header_sp_gnav_main-top a {
    padding: 0 30px 0 20px
  }
  .header_sp_gnav_main_trigger {
    display: -webkit-box;
    display: flex;
    padding: 15px 20px;
    cursor: pointer;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    -webkit-box-align: center;
    align-items: center
  }
  .header_sp_gnav_main_trigger:after {
    position: absolute;
    right: 20px;
    display: block;
    width: 7px;
    height: 7px;
    content: "";
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 1px solid #fff;
    border-right: 1px solid #fff
  }
  .header_sp_gnav_main_trigger.on:after {
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg)
  }
  .header_sp_gnav_main_trigger img {
    width: 28px;
    margin-right: 30px
  }
  .header_sp_gnav_sub {
    color: #333;
    background-color: #fff
  }
  .header_sp_gnav_sub li {
    border-bottom: 1px solid #eee
  }
  .header_sp_gnav_sub li a {
    display: block;
    padding: 15px 20px
  }
  .header_sp_gnav_lang {
    display: -webkit-box;
    display: flex
  }
  .header_sp_gnav_lang li {
    width: 50%;
    text-align: center;
    background: #198a3b
  }
  .header_sp_gnav_lang li:first-child {
    border-color: rgba(255, 255, 255, 0.2);
    border-right: 1px solid
  }
  .header_sp_gnav_lang li a {
    display: block;
    padding: 15px 20px
  }
  .header_sp_gnav_overlay {
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    display: block;
    width: 0;
    height: 0;
    content: "";
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
    opacity: 0;
    background-color: rgba(51, 51, 51, 0.8)
  }
  .header_sp_gnav_overlay.open {
    width: 100%;
    height: 100%;
    opacity: 1
  }
  .header_sp_gnav_menu {
    display: none;
    color: #333;
    background-color: #fff
  }
  .header_sp_gnav_menu a {
    padding-left: 78px
  }
  .header_sp_gnav_menu_top {
    color: #333;
    background-color: #fff
  }
  .header_sp_gnav_menu .accordion {
    color: #333
  }
  .header_sp_gnav_menu .accordion_trigger {
    padding: 15px 40px 15px 78px;
    cursor: pointer;
    border-bottom: 1px solid #fff;
    background: #eee url(../images/ac_open.png) no-repeat;
    background-position: right 19px center;
    background-size: 10px 10px
  }
  .header_sp_gnav_menu .accordion_trigger.on {
    position: relative;
    background-image: none
  }
  .header_sp_gnav_menu .accordion_trigger.on:after {
    position: absolute;
    top: 50%;
    right: 20px;
    display: block;
    width: 10px;
    height: 2px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #32ac57
  }
  .header_sp_gnav_menu .accordion_open {
    display: none
  }
  .header_sp_gnav_menu .accordion_open li {
    border-bottom: 1px dashed #f6f6f6
  }
  .header_sp_gnav_menu .accordion_open li:last-child {
    border-bottom: none
  }
  .header_sp_gnav_menu .no_accordion {
    border-bottom: 1px dashed #f6f6f6
  }
  .heading_btn {
    display: block;
    width: 38px;
    height: 38px;
    margin-left: auto;
    border: 1px solid #fff;
    background: url(../images/heading_btn.png) no-repeat center center;
    background-size: 22px 16px
  }
  .heading_btn.active {
    background: url(../images/heading_btn_close.png) no-repeat center center;
    background-size: 16.5px 16.5px
  }
  .localnav.-slide ul li a {
    white-space: normal
  }
  .localnav_wrapper {
    position: fixed;
    z-index: 10;
    display: none;
    overflow-y: scroll;
    width: 100%;
    height: calc(100vh - 148px);
    background: #f9f9f9
  }
  .localnav_wrapper.no-scroll {
    overflow-y: hidden
  }
  .localnav.-slide {
    position: relative;
    top: 0;
    display: block;
    width: 100%;
    margin-bottom: 60px;
    padding: 0;
    padding-bottom: 80px;
    background: #f9f9f9
  }
  .localnav.-slide>ul {
    display: block;
    background: #fff
  }
  .localnav.-slide>ul li {
    position: relative;
    margin-top: 0;
    margin-left: 1.2em;
    padding: 0;
    border-right: none;
    border-bottom: 1px solid #e6e6e6
  }
  .localnav.-slide>ul li:first-child {
    margin: 0
  }
  .localnav.-slide>ul li:first-child a {
    display: -webkit-box;
    display: flex;
    padding-right: 1.2em;
    padding-left: 1.2em;
    -webkit-box-align: center;
    align-items: center
  }
  .localnav.-slide>ul li:first-child a:before {
    display: inline-block;
    width: 25.5px;
    height: 25px;
    margin-right: 18px;
    content: "";
    vertical-align: middle;
    background: url(../images/icon_home.png) no-repeat;
    background-size: contain;
    -webkit-box-flex: 0;
    flex: 0 0 25.5px
  }
  .localnav.-slide>ul li:first-child a:after {
    content: none
  }
  .localnav.-slide>ul li a {
    padding: 1em 0
  }
  .localnav.-slide>ul li a.a_current {
    text-decoration: underline;
    border-bottom: none
  }
  .localnav.-slide>ul li.arw a:after {
    position: absolute;
    top: 50%;
    right: 18px;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    -webkit-transform: rotate(-45deg) translateY(-50%);
    transform: rotate(-45deg) translateY(-50%);
    border-right: 1px solid #333;
    border-bottom: 1px solid #333
  }
  .localnav_back {
    position: relative;
    display: block;
    padding: 1em 30px 1em 56px;
    background: #eee
  }
  .localnav_back:before {
    position: absolute;
    top: 50%;
    left: 30px;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    border-bottom: 1px solid #333;
    border-left: 1px solid #333
  }
  .sublnav {
    position: absolute;
    top: 55px;
    overflow-y: scroll;
    width: 100%;
    height: calc(100vh - 246px);
    padding: 0;
    padding-bottom: 60px;
    background: #f9f9f9
  }
  .sublnav_ttl {
    font-size: 1.1rem;
    line-height: 1.2;
    display: -webkit-box;
    display: flex;
    padding-top: 36px;
    padding-bottom: 10px;
    padding-left: 20px;
    border-bottom: 1px solid #e6e6e6;
    background: #f9f9f9;
    -webkit-box-align: center;
    align-items: center
  }
  .sublnav_ttl:before {
    display: inline-block;
    width: 2px;
    height: 17px;
    margin-right: 6px;
    content: "";
    background: #32ac57
  }
  .sublnav_lists {
    display: block;
    margin-bottom: 80px;
    background: #fff
  }
  .sublnav_lists_item {
    position: static;
    margin: 0 0 0 1.2em;
    padding: 0;
    border-bottom: 1px solid #e6e6e6
  }
  .sublnav_lists_item:first-child {
    display: block
  }
  .sublnav_lists_item:first-child a:after {
    content: none
  }
  .sublnav_lists_item>a {
    padding: 1em 1em 1em 0;
    white-space: normal
  }
  .sublnav_lists_item>a.arw:after {
    right: 18px;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
    -webkit-box-flex: 0;
    flex: 0 0 10px
  }
  .sublnav_lists_item>a:hover {
    border-bottom: none
  }
  .sublnav_lists_item>a:before {
    content: none
  }
  .sublnav_lists_item .a_current {
    text-decoration: underline;
    border-bottom: none
  }
  .sublnav_sub {
    position: absolute;
    z-index: 10;
    top: 0;
    width: 100%;
    min-height: calc(100vh - 246px);
    background: #f9f9f9
  }
  .sublnav_sub_inner {
    display: block;
    overflow: visible;
    margin: 0 0 60px;
    padding: 0 0 60px
  }
  .sublnav_sub_lists {
    width: 100%;
    margin-top: 0;
    padding: 0
  }
  .sublnav_sub_lists .sublnav_sub_top {
    font-size: 1.4rem;
    position: relative;
    top: 0;
    display: block;
    width: calc(100% - 1.2em);
    margin-bottom: 0;
    margin-left: 1.2em;
    padding-left: 0;
    color: #333;
    border-bottom: 1px solid #e6e6e6
  }
  .sublnav_sub_lists .sublnav_sub_top a {
    display: block;
    padding: 1em 1em 1em 0
  }
  .sublnav_sub_lists .sublnav_sub_top:before {
    content: none
  }
  .sublnav_sub_lists.-right {
    border-left: none
  }
  .sublnav_sub_lists li {
    font-size: 1.4rem;
    margin-top: 0;
    margin-left: 1.2em;
    border-bottom: 1px solid #e6e6e6
  }
  .sublnav_sub_lists li a {
    padding: 1em 2em 1em 0
  }
  .sublnav_sub_lists li a.arw:after {
    top: calc(50% - 5px);
    right: 18px;
    width: 10px;
    height: 10px;
    content: "";
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    border-right: 1px solid #333;
    border-bottom: 1px solid #333
  }
  .sublnav_sub_lists li a:after {
    content: none
  }
  .sublnav_sub_close {
    display: none
  }
  main .ir_heading_inner .stock:hover {
    opacity: 1
  }
  main .localnav ul li a:hover {
    border-bottom: none
  }
  main .img_col5_box {
    width: 48.11%;
    margin-right: 3.77%
  }
  main .img_col5_box:nth-child(5n) {
    margin-right: 3.77%
  }
  main .img_col5_box:nth-child(3n) {
    margin-right: 3.77%
  }
  main .img_col5_box:nth-child(2n) {
    margin-right: 0
  }
  main .img_col5_box:nth-of-type(-n+3) {
    margin-top: 25px
  }
  main .img_col5_box:nth-of-type(-n+2) {
    margin-top: 0
  }
  main {
    width: 100%;
    margin: 0
  }
  main .container {
    width: calc(100% - 36px)
  }
  main .ir_heading {
    display: block;
    padding: 0
  }
  main .ir_heading .heading, main .ir_heading h1 {
    padding: 20px 18px
  }
  main .ir_heading .heading span, main .ir_heading h1 span {
    font-size: 1.3rem
  }
  main .ir_heading .heading .heading_sub, main .ir_heading h1 .heading_sub {
    display: block;
    width: 100%
  }
  main .ir_heading .heading .heading_main, main .ir_heading h1 .heading_main {
    font-size: 2.2rem;
    width: calc(100% - 38px)
  }
  main .ir_heading_inner {
    font-size: 1.4rem;
    display: -webkit-box;
    display: flex;
    padding: 10px 10px;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: end;
    justify-content: flex-end
  }
  main .ir_heading_inner .code {
    margin-right: 30px;
    margin-bottom: 0
  }
  main .ir_heading_inner .stock {
    font-size: 12px;
    padding: 2px 8px
  }
  main .ir_heading_inner .stock:nth-of-type(2) {
    margin-left: 5px
  }
  main .ir_heading_inner.-product .stock.-icon:before {
    width: 15px;
    height: 10px;
    margin-bottom: 0
  }
  main .breadcrumbs {
    display: none
  }
  main .heading {
    font-size: 2.2rem;
    line-height: 1.4;
    padding: 20px 18px
  }
  main .container .category_ttl:first-of-type {
    margin-top: 30px
  }
  main .localnav {
    display: none;
    padding: 0 8px 15px
  }
  main .localnav ul li {
    padding: 0 10px
  }
  main .subnav {
    padding: 0 8px
  }
  main .subnav.hidden {
    display: none
  }
  main .subnav ul li {
    padding: 0 10px
  }
  main .img_big {
    width: 75.47%
  }
  main .img_big .img_big_box figure p:first-of-type {
    display: none
  }
  main .img_big .img_big_box figure p:last-of-type {
    display: block
  }
  main .img_small .img_small_box {
    width: 48.11%
  }
  main .img_small .img_small_box:nth-of-type(-n+3) {
    margin-top: 25px
  }
  main .img_small .img_small_box:nth-of-type(-n+2) {
    margin-top: 0
  }
  main .img_small.left .img_small_box:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .img_small.left .img_small_box:not(:nth-child(2n)) {
    margin-right: 3.77%
  }
  main .img_small.right .img_small_box:not(:nth-child(3n)) {
    margin-left: 0
  }
  main .img_small.right .img_small_box:not(:nth-child(2n)) {
    margin-left: 3.77%
  }
  main .standard_list>ul.column2 {
    display: block
  }
  main .standard_list>ul.column2 li {
    width: 100%
  }
  main .standard_list>ul.column3 {
    display: block
  }
  main .standard_list>ul.column3 li {
    width: 100%
  }
  main .standard_list>ul.column3:after {
    display: none
  }
  main .arw_list .link_menu {
    font-size: 1.4rem
  }
  main .arw_list .link_menu.column2 {
    display: block
  }
  main .arw_list .link_menu.column2 li {
    width: 100%
  }
  main .arw_list .link_menu.column3 {
    display: block
  }
  main .arw_list .link_menu.column3 li {
    width: 100%
  }
  main .arw_list .link_menu.column3:after {
    display: none
  }
  main .strong_list>.decimal.column2 li {
    width: 100%;
    margin-right: 0
  }
  main .strong_list>.decimal.column2 li:nth-of-type(-n+2) {
    margin-top: 14px
  }
  main .strong_list>.decimal.column2 li:first-of-type {
    margin-top: 0
  }
  main .strong_list>.decimal.column3 li {
    width: 100%;
    margin-right: 0
  }
  main .strong_list>.decimal.column3 li:nth-of-type(-n+3) {
    margin-top: 14px
  }
  main .strong_list>.decimal.column3 li:first-of-type {
    margin-top: 0
  }
  main .btn_big {
    width: 100%
  }
  main .btn_big a {
    margin-top: 25px
  }
  main .btn_big a img {
    max-height: 24px
  }
  main .btn_mdm {
    width: 100%
  }
  main .btn_mdm a {
    width: 100%;
    margin-top: 25px
  }
  main .btn_mdm a:first-of-type {
    margin-top: 0
  }
  main .btn_mdm a:nth-of-type(2) {
    margin-top: 25px
  }
  main .btn_small {
    width: 100%
  }
  main .btn_small a {
    width: 100%;
    margin-top: 25px;
    margin-right: 0
  }
  main .btn_small a:nth-of-type(-n+3) {
    margin-top: 25px
  }
  main .btn_small a:first-of-type {
    margin-top: 0
  }
  main .standard_tbl {
    overflow: auto;
    white-space: nowrap
  }
  main .fluidImg {
    width: 100%
  }
  main .col4_inner {
    width: calc(50% - 10px);
    margin-right: 20px
  }
  main .col4_inner:nth-child(2n) {
    margin-right: 0
  }
  main .ir_more li figcaption {
    width: 90%
  }
  main .txt_img .txt img {
    display: block;
    max-height: 100px;
    margin-right: auto;
    margin-left: auto
  }
  main .category_ttl {
    font-size: 2.4rem
  }
  main .category_ttl img {
    max-height: 24px
  }
  main .sec_ttl {
    font-size: 2.2rem;
    padding: 10px 1em 10px 14px
  }
  main .small_ttl {
    font-size: 2rem
  }
  main .category_ttl_h4 {
    font-size: 1.8rem;
    padding-left: 20px
  }
  main .category_ttl_h4:before {
    top: 8px;
    width: 8px;
    height: 8px
  }
}

@media screen and (max-width:480px) {
  body .img_big {
    width: 100%
  }
  body .img_big .img_big_box figure p {
    text-align: center
  }
  body .img_big .img_big_box figure p img {
    width: auto
  }
  body .img_mdm {
    display: block
  }
  body .img_mdm .img_mdm_box {
    width: 100%
  }
  body .img_mdm .img_mdm_box:nth-of-type(-n+2) {
    margin-top: 25px
  }
  body .img_mdm .img_mdm_box:first-of-type {
    margin-top: 0
  }
  body .img_mdm .img_mdm_box figure {
    display: block
  }
  body .img_mdm .img_mdm_box figure p {
    position: static;
    padding-top: 0;
    text-align: center
  }
  body .img_mdm .img_mdm_box figure p img {
    position: static;
    width: auto
  }
  body .img_mdm .img_mdm_box figure figcaption {
    margin-top: 0
  }
  body .img_mdm.left .img_mdm_box:not(:nth-child(2n)) {
    margin-right: 0
  }
  body .img_mdm.right .img_mdm_box:not(:nth-child(2n)) {
    margin-left: 0
  }
  body .img_small {
    display: block
  }
  body .img_small .img_small_box {
    width: 100%
  }
  body .img_small .img_small_box:nth-of-type(-n+2) {
    margin-top: 25px
  }
  body .img_small .img_small_box:first-of-type {
    margin-top: 0
  }
  body .img_small .img_small_box figure {
    display: block
  }
  body .img_small .img_small_box figure p {
    position: static;
    padding-top: 0;
    text-align: center
  }
  body .img_small .img_small_box figure p img {
    position: static;
    width: auto
  }
  body .img_small .img_small_box figure figcaption {
    margin-top: 0
  }
  body .img_small.left .img_small_box:not(:nth-child(2n)) {
    margin-right: 0
  }
  body .img_small.right .img_small_box:not(:nth-child(2n)) {
    margin-left: 0
  }
  body .txt_img {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap
  }
  body .txt_img figure {
    width: 100%;
    margin: 0;
    -webkit-box-ordinal-group: 3;
    order: 2
  }
  body .txt_img figure.right {
    float: none;
    margin: 0
  }
  body .txt_img figure.left {
    float: none;
    margin: 0
  }
  body .txt_img .txt {
    margin-bottom: 20px;
    -webkit-box-ordinal-group: 2;
    order: 1
  }
  body .txt_img .txt img {
    max-width: 100%
  }
  body .txt_img .txt .small_ttl {
    width: 100%
  }
  body .txt_img .txt .category_ttl_h4 {
    display: inline-block
  }
  body .txt_img .txt .feature_list_box {
    width: 100%!important
  }
  body .txt_img .txt>p:last-child, body .txt_img .txt>ul:last-child {
    margin-bottom: 0
  }
  body .txt_img_new {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap
  }
  body .txt_img_new figure {
    width: 100%;
    margin: 0;
    -webkit-box-ordinal-group: 3;
    order: 2
  }
  body .txt_img_new figure.right {
    float: none;
    margin: 0
  }
  body .txt_img_new figure.left {
    float: none;
    margin: 0
  }
  body .txt_img_new .txt {
    margin-bottom: 20px;
    -webkit-box-ordinal-group: 2;
    order: 1
  }
  body .txt_img_new .txt img {
    max-width: 100%
  }
  body .txt_img_new .txt .small_ttl {
    width: 100%
  }
  body .txt_img_new .txt .category_ttl_h4 {
    display: inline-block
  }
  body .txt_img_new .txt .feature_list_box {
    width: 100%!important
  }
  body .txt_img_new .txt>p:last-child, body .txt_img_new .txt>ul:last-child {
    margin-bottom: 0
  }
  body .standard_list>ul.datelist>li {
    display: block
  }
  body .standard_list>ul.datelist>li .date {
    display: block;
    width: 100%;
    padding-right: 0
  }
  body .related_link {
    display: block;
    margin-bottom: 59px
  }
  body .related_link p {
    width: 100%;
    padding: 10px;
    text-align: left
  }
  body .related_link ul {
    width: 100%;
    border-top: 2px solid #ccc;
    border-left: none
  }
}

@media (max-width:480px) {
  .txt_img .txt .blue_bk {
    width: 100%!important
  }
  .txt_img .txt .blue_bk .blue_li li:before {
    left: 8px
  }
  .txt_img .txt .feature_list_box {
    width: 100%!important
  }
  .modal-con-close-btn-new {
    top: -16px;
    right: -16px;
    width: 32px;
    height: 32px
  }
  .modal-con-close-btn-new:after, .modal-con-close-btn-new:before {
    left: 5px
  }
  .modal-con-body-new {
    padding-right: 20px;
    padding-left: 20px
  }
  br.br_pc {
    display: none!important
  }
  br.br_sp {
    display: block!important
  }
  .show-pc {
    display: none!important
  }
  .show-sp {
    display: block!important
  }
  .lb-nav a.lb-next {
    opacity: 1
  }
  .lb-nav a.lb-prev {
    opacity: 1
  }
  .lb-closeContainer {
    position: absolute;
    top: -28px;
    right: 0
  }
  .lb-container {
    width: 100%
  }
  main .list_contact .content_list_contact .item>dt {
    position: inherit;
    top: 0;
    left: 0;
    width: 100%;
    -webkit-transform: inherit;
    transform: inherit;
    border-bottom: none
  }
  main .list_contact.csr .content_list_contact {
    width: 100%;
    margin-left: 0
  }
  main .list_contact.csr .content_list_contact .item:first-of-type>dt {
    border-top: 1px solid #ccc
  }
  main .list_contact.csr .content_list_contact .item:first-of-type>dd {
    border-top: none
  }
  main .list_contact.csr .content_list_contact .item>dt {
    height: auto;
    padding: 10px 10px 10px 20px
  }
  main .list_contact.csr .content_list_contact .item>dd {
    padding: 10px 10px 10px 20px
  }
  main .modal-video-close-btn-new {
    top: -16px;
    right: -16px;
    width: 32px;
    height: 32px
  }
  main .modal-video-close-btn-new:after, main .modal-video-close-btn-new:before {
    left: 5px
  }
  main .modal-video-body-new {
    padding-right: 20px;
    padding-left: 20px
  }
  main .modal-box {
    padding: 4%
  }
  main .modal-box-outer {
    padding-top: 60%
  }
  main .modal-box-inner p {
    margin-top: 16px
  }
  main .modal-video-new.-txt .modal-box-outer {
    padding-top: 100%
  }
  main .modal-video-new.-txt .modal-box-inner {
    overflow-x: hidden;
    overflow-y: scroll
  }
  main .standard_tbl_new_wrap .standard_tbl_new {
    overflow: auto;
    margin-bottom: 10px;
    white-space: nowrap
  }
  main .img_big_big .img_big_big_box figure p:first-of-type {
    display: none
  }
  main .img_big_big .img_big_big_box figure p:last-of-type {
    display: block
  }
  main .img_wide .img_wide_box figure p:first-of-type {
    display: none
  }
  main .img_wide .img_wide_box figure p:last-of-type {
    display: block
  }
  main .info .tab_box_btn {
    flex-wrap: wrap
  }
  main .info .tab_box_btn li:first-child {
    width: 100%
  }
  main .info .tab_box_btn li:first-child a {
    border-right: 1px solid #ccc
  }
  main .info .tab_box_btn li:nth-child(n+2) {
    width: 50%
  }
  main .info .tab_box_btn li:nth-child(3) a {
    border-right: 1px solid #ccc
  }
  main .info .tab_box_btn li:nth-child(4) a {
    border-bottom: 1px solid #ccc
  }
  main .info .tab_box_btn li:last-child a {
    border-bottom: 1px solid #ccc
  }
  main .info .tab_box_btn li a {
    border-bottom: none
  }
  main .info .tab_box_btn li a.select:after {
    content: none
  }
  main .info_lists li a {
    padding: 15px 0.5em
  }
  main .info_lists li a [class*=" icon_"], main .info_lists li a [class^=icon_] {
    display: block;
    min-width: 55px;
    text-align: center
  }
  main .info_lists li a [class*=" icon_"]:before, main .info_lists li a [class^=icon_]:before {
    display: block;
    margin: 0 auto
  }
  main .info_lists .date {
    margin-bottom: 10px
  }
  main .info_lists .date time {
    width: 100%;
    margin-bottom: 5px
  }
  main .content_list_sp {
    border: 1px solid #ccc
  }
  main .content_list_sp h2 {
    font-size: 1.4rem;
    font-weight: 400;
    padding: 10px 0;
    text-align: center
  }
  main .content_list_sp h2:after {
    position: relative;
    top: 0;
    display: inline-block;
    width: 20px;
    height: 10px;
    content: "";
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
    -webkit-transform: rotate(88deg);
    transform: rotate(88deg);
    background-image: url(../images/ar-icon.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: contain
  }
  main .content_list_sp h2.route:after {
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg)
  }
  main .content_list_sp .main_content_list_sp {
    padding: 30px 15px;
    border-top: 1px solid #ccc
  }
  main .content_list_sp .main_content_list_sp .arw_list .link_menu {
    margin-bottom: 0
  }
  main .drawing.drawing_new .drawing_btn {
    padding-right: 50px
  }
  main .drawing.drawing_new .drawing_btn span {
    width: 40%
  }
  main .drawing.drawing_new .drawing_btn span.img-sp-draw {
    display: -webkit-box;
    display: flex;
    width: 60%;
    -webkit-box-pack: justify;
    justify-content: space-between
  }
  main .drawing.drawing_new .drawing_btn img {
    width: 49%;
    height: auto
  }
  main .drawing.drawing_new .drawing_btn:after {
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
  }
  main .drawing.drawing_new .drawing_contents.col-2 {
    display: block;
    padding: 0 10px
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents {
    width: 100%;
    padding-right: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox {
    padding: 15px 0;
    text-align: center
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox img {
    width: 80%;
    max-height: 100%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl {
    display: block;
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt {
    width: 100%;
    margin-right: 0;
    padding: 15px 0;
    padding-right: 3.5%;
    padding-left: 3.5%;
    border-right: none;
    border-bottom: 1px solid #ddd
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link {
    padding-left: 3.5%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt:last-child {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd {
    width: 100%;
    margin-right: 0;
    padding-right: 3.5%;
    padding-left: 3.5%;
    border-bottom: 1px solid #ddd;
    border-left: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link {
    padding-right: 3.5%;
    padding-left: 3.5%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl:first-child {
    margin-bottom: 0;
    padding-bottom: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl:last-child dd {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents .dl_last dt {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents .dl_last dd {
    padding: 0
  }
  main .list_contact .content_list_contact .item {
    display: block
  }
  main .list_contact .content_list_contact .item>dt {
    width: 100%;
    padding: 10px 10px 10px 20px;
    border-bottom: none
  }
  main .list_contact .content_list_contact .item>dd {
    position: relative;
    width: 100%;
    padding: 10px 10px 10px 20px;
    border-bottom: none;
    border-left: none
  }
  main .list_category2_new .list_category2_box_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_category2_new .list_category2_box_new:first-of-type {
    margin-top: 0
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new {
    width: 100%
  }
  main .back_sub_txt_new span {
    font-size: 14px;
    position: relative;
    z-index: 9;
    top: -23px;
    left: 0;
    display: inline-block;
    width: auto;
    margin: 0 17px;
    padding: 5px 10px;
    color: #fff;
    background: #32ac57
  }
  main .back_sub_txt_new p {
    margin-top: -30px
  }
  main .page_link {
    margin-bottom: 20px
  }
  main .faq_ttl {
    margin-bottom: 28px
  }
  main .faq_btn a {
    width: 90%;
    max-width: 300px
  }
  main .faq .a, main .q {
    padding-bottom: 10px
  }
  main .faq .a:before, main .q:before {
    padding-right: 8px
  }
  main .a {
    padding-bottom: 15px
  }
  main .a:before {
    padding-right: 8px
  }
  main .plan_ttl {
    font-size: 2.5rem
  }
  main .img_small_new {
    display: block
  }
  main .img_small_new .img_small_box_new {
    width: 100%;
    max-width: none;
    margin-top: 25px;
    border: 1px solid #ccc
  }
  main .img_small_new .img_small_box_new:nth-of-type(-n+3) {
    margin-top: 25px
  }
  main .img_small_new .img_small_box_new:first-of-type {
    margin-top: 0
  }
  main .img_small_new .img_small_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .list_category_new {
    display: block
  }
  main .list_category_new .list_category_box_new {
    width: 100%;
    margin-top: 25px;
    border: 1px solid #ccc
  }
  main .list_category_new .list_category_box_new:nth-of-type(-n+2) {
    margin-top: 25px
  }
  main .list_category_new .list_category_box_new:first-of-type {
    margin-top: 0
  }
  main .list_category_new .list_category_box_new .cont_list_category_box_new {
    display: block;
    padding: 15px 15px;
    padding-bottom: 22px
  }
  main .list_category_new .list_category_box_new .cont_list_category_box_new .r_cont_list_category_box_new {
    width: 100%;
    padding-top: 7px;
    padding-left: 0;
    text-align: center
  }
  main .list_category_new .list_category_box_new .cont_list_category_box_new .r_cont_list_category_box_new img {
    width: 140px;
    max-height: 150px
  }
  main .list_category_new .list_category_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .ttl_category_box_wrap {
    width: 100%;
    margin-top: 25px
  }
  main .list_thums_new .box_list_thums_new {
    display: block
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new {
    width: 100%
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+3) {
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:first-of-type {
    margin-top: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .l_main_item_list_thums_new {
    margin-right: 10px
  }
  main .box_list_link_back_new {
    display: block
  }
  main .box_list_link_back_new .item_list_link_back_new {
    width: 100%
  }
  main .list_category2_new {
    display: block
  }
  main .list_category2_new .list_category2_box_new {
    width: 100%
  }
  main .list_category2_new .list_category2_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .button-arrow-link:after {
    display: block;
    clear: both;
    content: ""
  }
  main .button-arrow-link a {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link a.left-button-arrow-link {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link a.right-button-arrow-link {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
  main .button-arrow-link span {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link span.left-button-arrow-link.-disable {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link span.right-button-arrow-link.-disable {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
  main .list_cate_link_new .box_list_cate_link_new {
    display: block
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new {
    width: 100%;
    margin-bottom: 20px
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:first-of-type {
    margin-top: 0
  }
  main .list_cate_link_new.column1 .box_list_cate_link_new {
    max-width: none
  }
  main .button-arrow-link2 a.left-button-arrow-link2 {
    width: 49%
  }
  main .button-arrow-link2 a.right-button-arrow-link2 {
    width: 49%
  }
  main .blog_new .main_blog_new {
    display: block
  }
  main .blog_new .main_blog_new .l_blog_new {
    width: 100%
  }
  main .blog_new .main_blog_new .r_blog_new {
    width: 100%
  }
  main .blog_new .main_blog_new .l_blog_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .link_menu_new.column3 li {
    width: 100%
  }
  main .link_menu_new.column3 li a {
    font-size: 13px
  }
  main .link_menu_new.column3 li:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_video {
    display: block
  }
  main .list_video.column2 .item_list_video {
    width: 100%
  }
  main .list_video.column2 .item_list_video:nth-of-type(-n+2) {
    margin-top: 25px
  }
  main .list_video.column2 .item_list_video:first-of-type {
    margin-top: 0
  }
  main .list_video.column3 .item_list_video {
    width: 100%
  }
  main .list_video.column3 .item_list_video:nth-of-type(-n+2) {
    margin-top: 25px
  }
  main .list_video.column3 .item_list_video:first-of-type {
    margin-top: 0
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    display: block;
    width: 80px;
    height: 80px
  }
  main .list_video .item_list_video .content_item_list_video:after {
    display: block;
    width: 80px;
    height: 80px
  }
  main .catch_copy.-large {
    font-size: 2.2rem
  }
  main .catch_copy_box_inner {
    width: 80%
  }
  main .lineup_box_inner {
    padding: 20px
  }
  main .feature_point_ttl {
    padding-bottom: 12px;
    flex-wrap: wrap
  }
  main .feature_point_ttl_num {
    font-size: 1.4rem;
    display: -webkit-box;
    display: flex;
    width: 100px;
    margin-right: auto;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center
  }
  main .feature_point_ttl_num span {
    font-size: 1.4rem;
    margin-top: 0
  }
  main .feature_point_ttl_txt {
    width: 100%;
    margin-top: 10px
  }
  main .feature_point_ttl_txt .main {
    font-size: 2rem
  }
  main .feature_list>p {
    font-size: 1.4rem
  }
  main .feature_list li {
    font-size: 1.6rem;
    padding-left: 30px
  }
  main .feature_list li:before {
    top: 7px;
    left: 8px
  }
  main .feature_list li>p {
    font-size: 1.4rem
  }
  main .feature_list.column2 li {
    width: 100%;
    margin-right: 0
  }
  main .feature_list.column2 li:nth-of-type(-n+2) {
    margin-top: 8px
  }
  main .feature_list.column2 li:first-of-type {
    margin-top: 0
  }
  main .feature_list.column2 li:nth-last-of-type(-n+2)>p:last-child {
    margin-bottom: 8px
  }
  main .feature_list.column2 li:last-of-type>p:last-child {
    margin-bottom: 0
  }
  main .feature_list.column3 li {
    width: 100%;
    margin-right: 0
  }
  main .feature_list.column3 li:nth-of-type(-n+3) {
    margin-top: 8px
  }
  main .feature_list.column3 li:first-of-type {
    margin-top: 0
  }
  main .feature_list_box {
    padding: 16px
  }
  main .feature_list_box>p {
    font-size: 1.4rem
  }
  main .feature_list_ttl {
    margin-bottom: 16px;
    padding: 10px 12px
  }
  main .feature_list_ttl span {
    font-size: 1.4rem;
    width: 100px;
    margin-right: auto;
    margin-bottom: 4px
  }
  main .feature_list_ttl p {
    font-size: 2rem
  }
  main .feature_list_ttl span+p {
    width: 100%
  }
  main .feature_img_list .img {
    width: 100%;
    margin-bottom: 25px
  }
  main .feature_img_list .list {
    width: 100%
  }
  main .contact_box {
    width: 100%;
    margin-right: 0;
    margin-left: 0
  }
  main .contact_box_inner {
    padding: 20px
  }
  main .contact_box_inner_l {
    width: 100%
  }
  main .contact_box_inner_r {
    width: 100%
  }
  main .contact_box_inner .txt_green {
    font-size: 2rem
  }
  main .contact_box_inner .tel {
    font-size: 1.8rem
  }
  main .contact_box_inner a[href^="tel:"] {
    pointer-events: auto
  }
  main .txt_strong {
    font-size: 2rem
  }
  main .standard_txt_new {
    font-size: 1.4rem
  }
  main .backgreen_txt {
    font-size: 1.4rem
  }
  main .back_txt {
    font-size: 1.4rem
  }
  main .back_txt .txt_img_new.img_fit {
    padding: 5px 0 0
  }
  main .back_sub_txt_new p {
    font-size: 1.4rem
  }
  main .topics_box {
    padding: 15px 20px
  }
  main .topics_txt {
    font-size: 1.4rem
  }
  main .txt_img_new figure {
    width: 100%!important
  }
  main .txt_img_new.img_fit figure.right {
    margin: 0
  }
  main .txt_img_new.img_fit figure.left {
    margin: 0
  }
  main .block_box {
    width: 100%
  }
  main .block_box:nth-of-type(-n+2) {
    margin-top: 25px
  }
  main .block_box:first-of-type {
    margin-top: 0
  }
  main .block_box:not(:nth-child(2n)) {
    margin-right: 0
  }
}

@media (max-width:320px) {
  main .ir_heading_inner {
    padding: 10px 8px
  }
  main .ir_heading_inner .stock {
    font-size: 12px;
    padding: 2px 10px;
    letter-spacing: 0
  }
  main .ir_heading_inner .stock:nth-of-type(2) {
    margin-left: 3px
  }
  main .list_video {
    display: block
  }
  main .list_video.column2 .item_list_video {
    width: 100%
  }
  main .list_video.column3 .item_list_video {
    width: 100%
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    display: block;
    width: 75px;
    height: 75px
  }
  main .list_video .item_list_video .content_item_list_video:after {
    display: block;
    width: 75px;
    height: 75px
  }
}

@media only screen and (max-width:1309px) and (min-width:901px) {
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new {
    width: 100%
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
}

@media only screen and (min-width:1301px) {
  main .img_small_new .img_small_box_new {
    margin-top: 20px
  }
  main .img_small_new .img_small_box_new:not(:nth-child(3n)) {
    margin-right: 20px
  }
}

@media only screen and (max-width:1166px) and (min-width:951px) {
  main .list_thums_new .box_list_thums_new .item_list_thums_new {
    width: calc((100% - 20px) / 2);
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+3) {
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+2) {
    margin-top: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(2n)) {
    margin-right: 20px
  }
}

@media only screen and (max-width:1166px) and (min-width:600px) {
  main .list_thums_new .box_list_thums_new .item_list_thums_new {
    width: calc((100% - 20px) / 2);
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+3) {
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+2) {
    margin-top: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .r_main_item_list_thums_new {
    width: 69%
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(2n)) {
    margin-right: 20px
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new {
    width: calc(50% - 20px);
    margin-bottom: 20px
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new:not(:nth-child(2n)) {
    margin-right: 30px
  }
}

@media (max-width:1099px) {
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new {
    width: 100%
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new:first-of-type {
    margin-top: 0
  }
  main .list_cate_link_new.column1 .box_list_cate_link_new {
    max-width: none
  }
}

@media (max-width:1000px) {
  main .page_link {
    margin-bottom: 20px
  }
}

@media only screen and (max-width:1299px) and (min-width:1025px) {
  main .list_video.column2 .item_list_video {
    width: 47.2%
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    width: 68px;
    height: 68px
  }
}

@media (max-width:900px) {
  main .list_category2_new .list_category2_box_new {
    width: 100%
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new:first-of-type {
    margin-top: 0
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new {
    width: 100%
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .list_category2_new .list_category2_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .ttl_category2_box_wrap {
    width: 100%;
    margin-bottom: 25px
  }
  main .button-arrow-link2 a.left-button-arrow-link2 {
    margin: 10px 0
  }
  main .button-arrow-link2 a.right-button-arrow-link2 {
    margin: 10px 0
  }
}

@media (max-width:768px) {
  .hide_ac_pc {
    display: block!important
  }
  .hide_ac_sp {
    display: none!important
  }
}

@media only screen and (max-width:785px) and (min-width:769px) {
  main .button-arrow-link:after {
    display: block;
    clear: both;
    content: ""
  }
  main .button-arrow-link a {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link a.left-button-arrow-link {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link a.right-button-arrow-link {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
  main .button-arrow-link span {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link span.left-button-arrow-link.-disable {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link span.right-button-arrow-link.-disable {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
}

@media only screen and (max-width:1024px) and (min-width:768px) {
  main .list_video.column2 .item_list_video {
    width: 46.2%
  }
  main .list_video.column3 .item_list_video {
    width: 30.7%
  }
  main .back_sub_txt_new span {
    font-size: 14px;
    position: relative;
    z-index: 9;
    top: -23px;
    left: 0;
    display: inline-block;
    width: auto;
    margin: 0 17px;
    padding: 5px 10px;
    color: #fff;
    background: #32ac57
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    width: 75px;
    height: 75px
  }
  main .list_video .item_list_video .content_item_list_video:after {
    width: 75px;
    height: 75px
  }
}

@media (max-width:599px) {
  main .list_thums_new .box_list_thums_new .item_list_thums_new {
    width: 100%;
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:nth-of-type(-n+3) {
    margin-top: 20px
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:first-of-type {
    margin-top: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new {
    width: 100%;
    margin-bottom: 20px
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_link_back_new .box_list_link_back_new .item_list_link_back_new:not(:nth-child(2n)) {
    margin-right: 0
  }
}

@media only screen and (max-width:768px) and (min-width:481px) {
  .modal-con-close-btn-new {
    top: -32px;
    right: -32px;
    width: 64px;
    height: 64px
  }
  .modal-con-close-btn-new:after, .modal-con-close-btn-new:before {
    left: 10px
  }
  .show-pc {
    display: none!important
  }
  .show-sp {
    display: block!important
  }
  .lb-nav a.lb-next {
    opacity: 1
  }
  .lb-nav a.lb-prev {
    opacity: 1
  }
  .lb-closeContainer {
    position: absolute;
    top: -28px;
    right: 0
  }
  main .modal-video-close-btn-new {
    top: -32px;
    right: -32px;
    width: 64px;
    height: 64px
  }
  main .modal-video-close-btn-new:after, main .modal-video-close-btn-new:before {
    left: 10px
  }
  main .standard_tbl_new_wrap .standard_tbl_new {
    overflow: auto;
    margin-bottom: 10px;
    white-space: nowrap
  }
  main .img_big_big .img_big_big_box figure p:first-of-type {
    display: none
  }
  main .img_big_big .img_big_big_box figure p:last-of-type {
    display: block
  }
  main .img_wide .img_wide_box figure p:first-of-type {
    display: none
  }
  main .img_wide .img_wide_box figure p:last-of-type {
    display: block
  }
  main .list_video {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify
  }
  main .list_video.column2 .item_list_video {
    width: 46.2%
  }
  main .list_video.column2 .item_list_video:not(:nth-child(2n)) {
    margin-right: 35px
  }
  main .list_video.column3 .item_list_video {
    width: 48.11%
  }
  main .list_video.column3 .item_list_video:nth-of-type(-n+3) {
    margin-top: 25px
  }
  main .list_video.column3 .item_list_video:nth-of-type(-n+2) {
    margin-top: 0
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    width: 75px;
    height: 75px
  }
  main .list_video.column3 .item_list_video .content_item_list_video:hover {
    opacity: 0.7
  }
  main .list_video.column3 .item_list_video:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_video.column3 .item_list_video:not(:nth-child(2n)) {
    margin-right: 3.77%
  }
  main .info .tab_box_btn {
    flex-wrap: wrap
  }
  main .info .tab_box_btn li:first-child {
    width: 100%
  }
  main .info .tab_box_btn li:first-child a {
    border-right: 1px solid #ccc
  }
  main .info .tab_box_btn li:nth-child(n+2) {
    width: 50%
  }
  main .info .tab_box_btn li:nth-child(3) a {
    border-right: 1px solid #ccc
  }
  main .info .tab_box_btn li:nth-child(4) a {
    border-bottom: 1px solid #ccc
  }
  main .info .tab_box_btn li:last-child a {
    border-bottom: 1px solid #ccc
  }
  main .info .tab_box_btn li a {
    border-bottom: none
  }
  main .info .tab_box_btn li a.select:after {
    content: none
  }
  main .info_lists li a {
    padding: 15px 0.5em
  }
  main .info_lists li a [class*=" icon_"], main .info_lists li a [class^=icon_] {
    display: block;
    min-width: 55px;
    text-align: center
  }
  main .info_lists li a [class*=" icon_"]:before, main .info_lists li a [class^=icon_]:before {
    display: block;
    margin: 0 auto
  }
  main .info_lists .date {
    margin-bottom: 10px
  }
  main .info_lists .date time {
    width: 100%;
    margin-bottom: 5px
  }
  main .content_list_sp {
    border: 1px solid #ccc
  }
  main .content_list_sp h2 {
    font-size: 1.4rem;
    font-weight: 400;
    padding: 10px 0;
    text-align: center
  }
  main .content_list_sp h2:after {
    position: relative;
    top: 0;
    display: inline-block;
    width: 20px;
    height: 10px;
    content: "";
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
    -webkit-transform: rotate(88deg);
    transform: rotate(88deg);
    background-image: url(../images/ar-icon.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: contain
  }
  main .content_list_sp h2.route:after {
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg)
  }
  main .content_list_sp .main_content_list_sp {
    padding: 30px 15px;
    border-top: 1px solid #ccc
  }
  main .content_list_sp .main_content_list_sp .arw_list .link_menu {
    margin-bottom: 0
  }
  main .drawing.drawing_new .drawing_btn {
    padding-right: 50px
  }
  main .drawing.drawing_new .drawing_btn span {
    width: 40%
  }
  main .drawing.drawing_new .drawing_btn span.img-sp-draw {
    width: 60%
  }
  main .drawing.drawing_new .drawing_btn img {
    width: auto
  }
  main .drawing.drawing_new .drawing_btn:after {
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
  }
  main .drawing.drawing_new .drawing_contents.col-2 {
    display: block;
    padding: 0 10px
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents {
    width: 100%;
    padding-right: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox {
    padding: 15px 0;
    text-align: center
  }
  main .drawing.drawing_new .drawing_contents.col-2 .left_drawing_contents .image_lightbox img {
    width: 80%;
    max-height: 100%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl {
    display: block;
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt {
    width: 100%;
    margin-right: 0;
    padding: 15px 0;
    padding-right: 3.5%;
    padding-left: 3.5%;
    border-right: none;
    border-bottom: 1px solid #ddd
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt.drawing_link {
    padding-left: 3.5%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dt:last-child {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd {
    width: 100%;
    margin-right: 0;
    padding-right: 3.5%;
    padding-left: 3.5%;
    border-bottom: 1px solid #ddd;
    border-left: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl dd.drawing_link {
    padding-right: 3.5%;
    padding-left: 3.5%
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl:first-child {
    margin-bottom: 0;
    padding-bottom: 0
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents dl:last-child dd {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents>.dl_last dt {
    border-bottom: none
  }
  main .drawing.drawing_new .drawing_contents.col-2 .right_drawing_contents>.dl_last dd {
    padding: 0
  }
  main .list_contact .content_list_contact .item {
    display: block
  }
  main .list_contact .content_list_contact .item>dt {
    position: inherit;
    top: 0;
    left: 0;
    width: 100%;
    padding: 10px 10px 10px 20px;
    -webkit-transform: inherit;
    transform: inherit;
    border-bottom: none
  }
  main .list_contact .content_list_contact .item>dd {
    position: relative;
    width: 100%;
    padding: 10px 10px 10px 20px;
    border-bottom: none;
    border-left: none
  }
  main .list_contact.csr .content_list_contact {
    width: 100%;
    margin-left: 0
  }
  main .list_contact.csr .content_list_contact .item>dt {
    height: auto;
    padding: 10px 10px 10px 20px
  }
  main .list_contact.csr .content_list_contact .item>dd {
    padding: 10px 10px 10px 20px
  }
  main .list_contact.csr .content_list_contact .item:first-of-type>dt {
    border-top: 1px solid #ccc
  }
  main .list_contact.csr .content_list_contact .item:first-of-type>dd {
    border-top: none
  }
  main .link_menu_new.column3 li {
    width: 100%
  }
  main .link_menu_new.column3 li:not(:nth-child(3n)) {
    margin-right: 0
  }
  main .list_category2_new .list_category2_box_new:nth-of-type(-n+2) {
    margin-top: 20px
  }
  main .list_category2_new .list_category2_box_new:first-of-type {
    margin-top: 0
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new {
    width: 100%
  }
  main .list_category2_new .list_category2_box_new .main_list_category2_box_new .cont_list_category2_box_new .main_cont_list_category2_box_new .item_cont_list_category2_box_new .m_item_cont_list_category2_box_new:not(:nth-child(2n)) {
    margin-right: 0
  }
  main .back_sub_txt_new span {
    font-size: 14px;
    position: relative;
    z-index: 9;
    top: -23px;
    left: 0;
    display: inline-block;
    width: auto;
    margin: 0 17px;
    padding: 5px 10px;
    color: #fff;
    background: #32ac57
  }
  main .back_sub_txt_new p {
    margin-top: -30px
  }
  main .page_link {
    margin-bottom: 20px
  }
  main .faq_ttl {
    margin-bottom: 28px
  }
  main .faq_btn a {
    width: 90%;
    max-width: 300px
  }
  main .faq .a, main .q {
    padding-bottom: 10px
  }
  main .faq .a:before, main .q:before {
    padding-right: 8px
  }
  main .a {
    padding-bottom: 15px
  }
  main .a:before {
    padding-right: 8px
  }
  main .plan_ttl {
    font-size: 2.5rem
  }
  main .list_thums_new .box_list_thums_new .item_list_thums_new .main_item_list_thums_new .l_main_item_list_thums_new {
    width: 17%;
    margin-right: 7px
  }
  main .button-arrow-link:after {
    display: block;
    clear: both;
    content: ""
  }
  main .button-arrow-link a {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link a.left-button-arrow-link {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link a.right-button-arrow-link {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
  main .button-arrow-link span {
    margin: 0;
    padding: 8px 20px
  }
  main .button-arrow-link span.left-button-arrow-link.-disable {
    float: left;
    width: 49%;
    padding: 8px 20px;
    padding-left: 45px
  }
  main .button-arrow-link span.right-button-arrow-link.-disable {
    float: right;
    width: 49%;
    padding: 8px 20px;
    padding-right: 45px
  }
  main .button-arrow-link2 a.left-button-arrow-link2 {
    width: 49%
  }
  main .button-arrow-link2 a.right-button-arrow-link2 {
    width: 49%
  }
  main .list_video.column3 .item_list_video .content_item_list_video:after {
    width: 75px;
    height: 75px
  }
  main .list_video .item_list_video .content_item_list_video:after {
    width: 75px;
    height: 75px
  }
  main .contact_box_inner {
    padding: 20px
  }
  main .contact_box_inner_l {
    width: 100%
  }
  main .contact_box_inner_r {
    width: 100%
  }
  main .standard_txt_new {
    font-size: 1.4rem
  }
  main .backgreen_txt {
    font-size: 1.4rem
  }
  main .back_txt {
    font-size: 1.4rem
  }
  main .back_sub_txt_new p {
    font-size: 1.4rem
  }
  main .feature_list>p {
    font-size: 1.4rem
  }
  main .feature_list li {
    font-size: 1.6rem
  }
  main .feature_list li:before {
    top: 7px;
    left: 8px
  }
  main .feature_list li>p {
    font-size: 1.4rem
  }
  main .feature_list_box>p {
    font-size: 1.4rem
  }
  main .topics_txt {
    font-size: 1.4rem
  }
  .modal-video-movie-wrap-new .mejs__overlay-button {
    width: 60px;
    height: 60px
  }
  .modal-video-movie-wrap-new .mejs__time-rail {
    width: 69.53%
  }
}

@media (max-width:375px) {
  main .button-arrow-link2 a {
    font-size: 15px
  }
  main .button-arrow-link2 a.left-button-arrow-link2 {
    padding: 8px 8px;
    padding-left: 35px;
    text-align: right
  }
  main .button-arrow-link2 a.right-button-arrow-link2 {
    padding: 8px 8px;
    padding-right: 35px;
    text-align: left
  }
  .modal-video-movie-wrap-new .mejs__overlay-button {
    width: 40px;
    height: 40px
  }
  .modal-video-movie-wrap-new .mejs__time-rail {
    width: 42.68%
  }
}

main .sec_ttl .emphasis {
  position: relative
}

main .sec_ttl .emphasis:before {
  background-color: #fff;
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  position: absolute;
  top: -2px;
  right: 0;
  left: 0;
  margin: auto
}

main .list_category_new .list_category_box_new .ttl_list_category_box_new span.no-link {
  background-image: none
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid {
  color: #555;
  display: grid;
  grid-template-columns: 1fr 2.3fr;
  grid-template-rows: auto auto;
  gap: 0px 0px;
  grid-auto-flow: row;
  grid-template-areas: "left right" "bottom bottom";
  padding: 15px 20px;
  display: -ms-grid;
  -ms-grid-columns: 1fr 2.3fr;
  -ms-grid-rows: auto auto;
  gap: 0px 0px
}

@media screen and (max-width:768px) {
  main .list_category_new .list_category_box_new .cont_list_category_box_grid {
    display: block
  }
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .l_cont_list_category_box_grid {
  grid-area: left;
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  max-width: 140px
}

@media screen and (max-width:768px) {
  main .list_category_new .list_category_box_new .cont_list_category_box_grid .l_cont_list_category_box_grid {
    margin: 0 auto 20px
  }
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .r_cont_list_category_box_grid {
  grid-area: right;
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  margin-left: 20px
}

@media screen and (max-width:768px) {
  main .list_category_new .list_category_box_new .cont_list_category_box_grid .r_cont_list_category_box_grid {
    margin-left: 0
  }
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .b_cont_list_category_box_grid {
  grid-area: bottom;
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  margin-top: 17px
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .red {
  color: #da5442
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .label_box>dt {
  background-color: #32ac57;
  color: #fff;
  display: inline-block;
  margin-bottom: -2px;
  padding: 3px 35px 3px 12px
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .label_box .label_box_list li {
  display: table
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .label_box .label_box_list li:not(:last-child) {
  margin-bottom: -0.5em
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .label_box .label_box_list li:before {
  font-size: 2rem;
  display: table-cell;
  width: 0.5em;
  content: "⋅"
}

main .list_category_new .list_category_box_new .cont_list_category_box_grid .label_box .label_box_list+.note_list {
  margin-top: 20px
}

main .note_list.strong_red {
  font-size: 2.4rem;
  line-height: 1.3;
  color: #da5442
}

@media screen and (max-width:768px) {
  main .note_list.strong_red {
    font-size: 2rem
  }
}

main .note_list.strong_red li:not(:last-child) {
  margin-bottom: 25px
}

main .note_list .note_list_txt {
  color: #555;
  font-size: 1.6rem
}

@media screen and (max-width:768px) {
  main .note_list .note_list_txt {
    font-size: 1.4rem
  }
}

@media screen and (min-width:769px) {
  main .list_video.full .item_list_video {
    width: 32.08%
  }
}

@media screen and (max-width:768px) {
  main .list_video .item_list_video {
    margin-top: 25px!important
  }
}

main .img_mdm .ttl_underline {
  color: #555;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid #32ac57;
  font-size: 1.8rem
}

main .lh_15 {
  line-height: 1.5
}

main .service_inner.container .service_bnr.column3 {
  width: auto;
  max-width: none
}

main .service_inner.container .service_bnr.column3 .service_bnr_item {
  width: 31.3%;
  margin-top: 26px;
  margin-right: 3%
}

@media screen and (max-width:1051px) and (min-width:650px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item {
    width: 48%
  }
}

main .service_inner.container .service_bnr.column3 .service_bnr_item:nth-child(-n+3) {
  margin-top: 0
}

@media screen and (max-width:1051px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item:nth-child(-n+3) {
    margin-top: 15px
  }
}

main .service_inner.container .service_bnr.column3 .service_bnr_item:nth-child(3n) {
  margin-right: 0
}

@media screen and (max-width:1051px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item:nth-child(3n) {
    margin-right: 3%
  }
}

main .service_inner.container .service_bnr.column3 .service_bnr_item:first-child {
  align-self: center
}

@media screen and (max-width:1051px) and (min-width:650px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item:first-child {
    width: 100%;
    margin-top: 0
  }
}

@media screen and (max-width:649px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item:first-child {
    margin-top: 0!important;
    margin-bottom: 30px
  }
}

@media screen and (max-width:1051px) and (min-width:650px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item:nth-child(2n-1) {
    margin-right: 0
  }
}

@media screen and (max-width:649px) {
  main .service_inner.container .service_bnr.column3 .service_bnr_item {
    width: 100%;
    margin-top: 15px;
    margin-right: 0
  }
}

@media screen and (max-width:1051px) and (min-width:650px) {
  main .service_inner.container .service_bnr.column3 {
    margin-top: 0
  }
}

@media screen and (max-width:649px) and (min-width:481px) {
  main .service_inner.container .service_bnr.column3 {
    margin-top: 0
  }
}

main .service_inner.container .service_ttl {
  margin-left: 0;
  width: auto
}

@media screen and (max-width:1051px) and (min-width:650px) {
  main .service_inner.container .service_ttl {
    margin-bottom: 30px
  }
}

main .contact_box.mb_60 {
  margin-bottom: 60px
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new.no_link:hover {
  opacity: 1
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new span.no_link {
  display: block;
  padding: 12px 10px
}

main .list_cate_link_new .box_list_cate_link_new .item_list_cate_link_new .main_item_list_cate_link_new span.no_link .con_main_item_list_cate_link_new .r_main_item_list_cate_link_new:after {
  display: none
}