@charset "UTF-8";
/*====================================================
*
* Style Index:
* 0. Reset #デフォルトスタイルのリセット
* 1. Layout #ページのレイアウトのスタイル
*   - Base
* 　- Header
* 　- Footer
*
* 2. Module #ページ内の共通パーツ等のスタイル
*    - Top Page
*
* 3. Cosmetic #共通パーツ等の装飾をするスタイル
*    - Navigation
*
* 4. Utility #部分的に調整をするスタイル
*
=======================================================*/
*,
::before,
::after {
  box-sizing: border-box;
}

::before,
::after {
  text-decoration: inherit;
  /* 1 */
  vertical-align: inherit;
  /* 2 */
}

html {
  cursor: default;
  /* 1 */
  line-height: 1.8;
  /* 2 */
  -moz-tab-size: 4;
  /* 3 */
  tab-size: 4;
  /* 3 */
  -webkit-tap-highlight-color: transparent;
  -ms-text-size-adjust: 100%;
  /* 5 */
  -webkit-text-size-adjust: 100%;
  /* 5 */
  word-break: break-word;
  /* 6 */
}

body {
  margin: 0;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

p {
  margin-top: 0;
  margin-bottom: 20px;
}

figure {
  margin: 0;
}

dl,
ol,
ul,
dt,
dd,
dl dl,
dl ol,
dl ul,
ol dl,
ul dl {
  margin: 0;
}

ol ol,
ol ul,
ul ol,
ul ul {
  margin: 0;
}

hr {
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

main {
  display: block;
}

nav ol,
nav ul {
  list-style: none;
  padding: 0;
}

pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

a {
  background-color: transparent;
}

a:hover {
  opacity: 0.9;
}

abbr[title] {
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

small {
  font-size: 80%;
}

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

audio,
video {
  display: inline-block;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

iframe {
  border-style: none;
}

img {
  border-style: none;
}

svg:not([fill]) {
  fill: currentColor;
}

svg:not(:root) {
  overflow: hidden;
}

table {
  border-collapse: collapse;
}

button,
input,
select {
  margin: 0;
}

button {
  padding: 0;
  border: none;
  overflow: visible;
  /* 1 */
  text-transform: none;
  /* 2 */
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

fieldset {
  border: 1px solid #a0a0a0;
  /* 1 */
  padding: 0.35em 0.75em 0.625em;
  /* 2 */
}

input {
  overflow: visible;
}

legend {
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  white-space: normal;
  /* 1 */
}

progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

select {
  text-transform: none;
}

textarea {
  margin: 0;
  /* 1 */
  overflow: auto;
  /* 2 */
  resize: vertical;
  /* 3 */
}

[type="checkbox"],
[type="radio"] {
  padding: 0;
}

[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

:-moz-focusring {
  outline: 1px dotted ButtonText;
}

:-moz-ui-invalid {
  box-shadow: none;
}

details {
  display: block;
}

dialog {
  background-color: white;
  border: solid;
  color: black;
  display: block;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content;
}

dialog:not([open]) {
  display: none;
}

summary {
  display: list-item;
}

canvas {
  display: inline-block;
}

template {
  display: none;
}

a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}

[hidden] {
  display: none;
}

/* ------------------------------------------------------------------------------------------
* 1. Layout
* ----------------------------------------------------------------------------------------- */
/* Base */
body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic","ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-size: 17px;
  line-height: 2.0;
  min-width: 1050px;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 16px;
    min-width: 0;
    padding-top: 60px;
  }
}

@media all and (-ms-high-contrast: none) {
  body {
    font-family: "メイリオ", Meiryo, sans-serif !important;
  }
}
.serif, .kv_wrap .kv_text, .hd_sec_01 h2, .lead, .h1, .h2, .h3, .h4 {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif !important;
}

a {
  color: #01267f;
}
a:hover, a:focus {
  text-decoration: none;
}

a.blank,
a.down,
a.word,
a.xls,
a.zip,
a.pdf {
  position: relative;
  padding-right: 32px;
  display: inline-block;
}

a.down:before,
a.word:before,
a.xls:before,
a.zip:before,
a.pdf:before {
  content: "";
  position: absolute;
  right: 0;
  top: -4px;
  display: inline-block;
  /*忘れずに！*/
  width: 34px;
  /*画像の幅*/
  height: 34px;
  /*画像の高さ*/
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}

a.blank:before {
  content: "";
  position: absolute;
  right: 3px;
  top: 0;
  display: inline-block;
  /*忘れずに！*/
  width: 20px;
  /*画像の幅*/
  height: 20px;
  /*画像の高さ*/
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}

a.blank:before {
  background-image: url(/img/common/icon_blank_blue.png);
}

a.down:before {
  background-image: url(/img/common/icon_down.png);
}

a.word:before {
  background-image: url(/img/common/icon_word.png);
}

a.xls:before {
  background-image: url(/img/common/icon_xls.png);
}

a.zip:before {
  background-image: url(/img/common/icon_zip.png);
}

a.pdf:before {
  background-image: url(/img/common/icon_pdf.png);
}

.ct_wrap {
  margin-top: 30px;
  padding-bottom: 80px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: flex-start;
  position: relative;
}
.ct_wrap img {
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .ct_wrap {
    margin-top: 30px;
  }
  .ct_wrap img {
    max-width: 100%;
    height: auto;
  }
}

.ct_main {
  min-width: 700px;
  max-width: 700px;
  margin-left: 50px;
}
@media screen and (max-width: 767px) {
  .ct_main {
    min-width: 100%;
    max-width: 100%;
    margin-left: 0;
  }
}

.ct_side {
  min-width: 250px;
  max-width: 250px;
}
@media screen and (max-width: 767px) {
  .ct_side {
    display: none;
  }
}
.ct_side .banner {
  margin-top: 20px;
}

.container {
  max-width: 1050px;
  padding-left: 25px;
  padding-right: 25px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .container {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.container_fluid {
  max-width: 100%;
  padding-left: 25px;
  padding-right: 25px;
}

.flex_box {
  display: flex;
}

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

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

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

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

.block_right {
  margin: 0 0 0 auto;
}

.page_include_parts {
  margin: 80px 0 0;
  border-top: 1px solid #ccc;
  position: relative;
  padding-top: 20px;
}
.page_include_parts:before {
  position: absolute;
  content: "";
  width: 100%;
  top: -4px;
  left: 0;
  border-top: 1px solid #bbb;
}
.page_include_parts:after {
  position: absolute;
  content: "";
  width: 100%;
  left: 0;
  top: -7px;
  border-top: 1px solid #aaa;
}

.text_large {
  font-size: 1.25em;
}

.text_small {
  font-size: 0.85em;
  line-height: 1.5;
}

.text-l {
  font-size: 1.25em;
}

.text-s {
  font-size: 0.85em;
  line-height: 1.7;
}

.text_align_center {
  text-align: center;
}

.text_align_right {
  text-align: right;
}

.img_float_right {
  float: right;
  max-width: 45% !important;
  min-width: 45%;
  display: block;
  margin-left: 1em;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .img_float_right {
    float: none;
    max-width: 100%;
    min-width: 100%;
    margin-left: 0;
    margin-bottom: 1em;
  }
}

.img_float_left {
  float: left;
  max-width: 45% !important;
  min-width: 45%;
  display: block;
  margin-right: 1em;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .img_float_left {
    float: none;
    max-width: 100%;
    min-width: 100%;
    margin-right: 0;
    margin-bottom: 1em;
  }
}

@media screen and (max-width: 767px) {
  .youtube, .gmap {
    width: 90%;
    height: calc(80vw * 0.56);
    margin: auto;
    display: block;
  }
}

/* form */
@media screen and (max-width: 767px) {
  #mrc_download .mrc_webform_group > input {
    width: 100% !important;
  }
}

.list_area {
  display: flex;
  flex-wrap: wrap;
  margin-top: 20px;
  list-style: none;
  text-align: center;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .list_area {
    display: block;
  }
}

.list_area li {
  width: calc((100% / 3) - 20px);
  margin: 20px 10px;
}
@media screen and (max-width: 767px) {
  .list_area li {
    width: 90%;
  }
}
.list_area li img {
  max-width: 100%;
}

/* Header */
.header {
  height: 145px;
}
@media screen and (max-width: 767px) {
  .header {
    height: 60px;
    position: fixed;
    top: 0;
    background-color: #fff;
    width: 100%;
    z-index: 999;
  }
}

.header_container {
  max-width: 1650px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  height: 100%;
  display: flex;
}
@media screen and (max-width: 767px) {
  .header_container {
    padding-left: 3vw;
    padding-right: 3vw;
  }
}

.header_logo {
  line-height: 0.9;
  display: block;
  text-decoration: none;
  color: #000000;
  margin: 0;
}
.header_logo a {
  display: block;
}
.header_logo img {
  width: auto;
  height: 46px;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .header_logo img {
    display: block;
    max-width: 46vw;
    height: auto;
  }
}

.header_logo_type {
  padding: 22px 0 3px 0;
  display: block;
  font-size: 18px;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .header_logo_type {
    padding: 2vw 0 2px 0;
    font-size: 2vw;
    padding-left: 0;
  }
}

.header_logo_img {
  display: block;
  height: 46px;
  width: auto;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .header_logo_img {
    margin-top: 0;
    height: 7vw;
  }
}

.header_logo_text {
  display: block;
  margin-top: 16px;
  font-size: 12px;
  line-height: 1;
  font-feature-settings: "palt";
  text-align: center;
}
@media screen and (max-width: 767px) {
  .header_logo_text {
    font-size: 2vw;
    margin-top: 2vw;
    white-space: nowrap;
    display: none;
  }
}

@media screen and (max-width: 767px) and (orientation: landscape) {
  .header_logo {
    line-height: 0.9;
    display: block;
    text-decoration: none;
    color: #000000;
    margin: 0;
  }
  .header_logo a {
    display: block;
  }
  .header_logo img {
    width: auto;
    margin-top: 5px;
    display: block;
    max-width: 15vw;
    height: auto;
  }

  .header_logo_type {
    display: block;
    line-height: 1;
    text-align: center;
    padding: 1vw 0 2px 0;
    font-size: 1vw;
    text-align: left;
    padding-left: 0;
  }

  .header_logo_img {
    display: block;
    width: auto;
    margin-top: 0;
    height: 18px;
  }

  .header_logo_text {
    display: block;
    line-height: 1;
    font-feature-settings: "palt";
    text-align: center;
    font-size: 1vw;
    margin-top: 1vw;
    white-space: nowrap;
  }
}
.header_right {
  padding-top: 23px;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .header_right {
    display: none;
  }
}

.header_contact_list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  list-style: none;
  padding: 0;
  margin-bottom: 0;
}
.header_contact_list > li {
  margin-left: 10px;
}
.header_contact_list > li:first-child {
  margin-left: 0;
}

.header_freedial img {
  width: 60px;
  height: auto;
  margin-right: 3px;
}

.header_freedial a,
.header_freedial div {
  display: flex;
  color: #000000;
  font-size: 26px;
  text-decoration: none;
  align-items: center;
  line-height: 1.3;
  font-weight: bold;
  margin-right: 2px;
}

.header_freedial a small,
.header_freedial div small {
  display: block;
  font-size: 12px;
}

.header_contact {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .header_contact {
    margin-top: 46px;
  }
}

.header_contact a {
  padding: 8px;
  display: flex;
  align-items: center;
  background-color: #ff5313;
  text-decoration: none;
  color: #ffffff;
  line-height: 1.25;
  letter-spacing: 1px;
  font-weight: bold;
}
.header_contact a:before {
  content: '';
  display: inline-block;
  width: 25px;
  height: 22px;
  background-image: url(/img/common/icon_contact.png);
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin-right: 6px;
}
.header_contact a:hover, .header_contact a:focus {
  opacity: 0.85;
}
.header_contact a img {
  margin-right: 5px;
  height: 22px;
}

.header_download a {
  padding: 8px 12px 8px 12px;
  display: flex;
  align-items: center;
  background-color: #f08e2c;
  text-decoration: none;
  color: #ffffff;
  line-height: 1.25;
  letter-spacing: 1px;
  font-weight: bold;
}
.header_download a:before {
  content: '';
  display: inline-block;
  width: 17px;
  height: 20px;
  background-image: url(/img/common/icon_download_catalog.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 8px;
}
.header_download a:hover, .header_download a:focus {
  opacity: 0.85;
}
.header_download a img {
  margin-right: 10px;
}

.header_menu {
  margin-top: 15px;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  color: #000000;
  letter-spacing: 2px;
}
.header_menu li:first-child {
  position: relative;
}
.header_menu li:first-child:before {
  content: '';
  display: block;
  position: absolute;
  top: 13px;
  left: -22px;
  height: 9px;
  width: 12px;
  border: 5px solid #000;
  border-bottom: 0;
}
.header_menu li:first-child:after {
  content: '';
  display: block;
  position: absolute;
  height: 0;
  width: 0;
  top: 5px;
  left: -24px;
  border-top: 4px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 6px solid #000;
  border-left: 8px solid transparent;
}
.header_menu li + li:before {
  margin-left: 20px;
  margin-right: 20px;
  position: relative;
  top: -2px;
  content: "";
  height: 1em;
  display: inline-block;
  width: 1px;
  background-color: #999;
  vertical-align: middle;
}
.header_menu li a {
  text-decoration: none;
  padding-left: 0;
  list-style: none;
  color: #000000;
  font-weight: bold;
  transition: all 0.2s ease-in-out;
}
.header_menu li a:hover, .header_menu li a:focus {
  color: #f1881f;
}
.header_menu li a img {
  position: relative;
  top: -2px;
  margin-right: 10px;
}

.sp-menu-trigger,
.sp-menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}

.sp-menu-trigger {
  position: fixed;
  width: 61px;
  height: 60px;
  right: 0;
  z-index: 10001;
  top: 0;
  outline: none;
  cursor: pointer;
  overflow: hidden;
  background-image: linear-gradient(to top, #f3810f, #f08e2c);
}
@media screen and (min-width: 768px) {
  .sp-menu-trigger {
    display: none;
  }
}

.sp-menu-trigger span {
  position: absolute;
  left: calc((100% - 19px) * 0.5);
  width: 21px;
  height: 2px;
  background-color: #ffffff;
}

.sp-menu-trigger span:nth-of-type(1) {
  top: 22px;
}

.sp-menu-trigger span:nth-of-type(2) {
  top: 29px;
}

.sp-menu-trigger span:nth-of-type(3) {
  top: 36px;
}

.nav-open .sp-hd-ticket {
  opacity: 0;
}
.nav-open .sp-menu-trigger span:nth-of-type(1) {
  -webkit-transform: translateY(7px) rotate(-45deg);
  transform: translateY(7px) rotate(-45deg);
}
.nav-open .sp-menu-trigger span:nth-of-type(2) {
  left: 50%;
  opacity: 0;
  -webkit-animation: active-menu-bar02 .8s forwards;
  animation: active-menu-bar02 .8s forwards;
}
.nav-open .sp-menu-trigger span:nth-of-type(3) {
  -webkit-transform: translateY(-7px) rotate(45deg);
  transform: translateY(-7px) rotate(45deg);
}

@-webkit-keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
.header_search {
  margin-top: 48px;
  border: 4px solid #ffe8c5;
  display: flex;
  height: 39px;
  background-color: #ffffff;
}
.header_search input {
  width: calc(100% - 60px);
  font-size: 16px;
}
.header_search button {
  width: 60px;
  background-color: #ff8300;
  color: #fff;
  font-size: 16px;
}

.has_search {
  position: relative;
  max-width: 60px;
}
.has_search .header_search {
  margin-top: 0;
  display: flex;
  top: 100%;
  right: 0;
  position: absolute;
  width: 300px;
  z-index: -100;
  opacity: 0;
  transition: all 0.2s ease-out !important;
}
.has_search .header_search input {
  font-size: 14px;
}
.has_search:hover .nav_search:before {
  background: url(/img/common/icon_search_orange.png) 50% 50% no-repeat;
}
.has_search.open .header_search {
  z-index: 100;
  opacity: 1;
}
.has_search.open .nav_search {
  font-size: 12px;
  background-color: #fff4e3;
  color: #f1881f;
}
.has_search.open .nav_search:before {
  position: absolute;
  display: block;
  margin-top: -4px;
  margin-bottom: 8px;
  content: "";
  width: 23px;
  height: 23px;
  background: #fff4e3 url(/img/common/icon_search_close.png) 50% 50%/contain no-repeat !important;
}

.sp_nav {
  position: fixed;
  top: 60px;
  bottom: 0;
  display: none;
  overflow: auto;
  width: 100%;
  z-index: 10000;
  padding-bottom: 100px;
  background-color: #3d3d3d;
}
.sp_nav .header_contact {
  min-width: 100%;
}
.sp_nav .header_contact a {
  width: 100%;
  display: flex;
  justify-content: center;
  height: 68px;
  line-height: 1.625;
}
.sp_nav .header_contact a img {
  height: 32px;
}
.sp_nav .header_freedial {
  margin-top: 26px;
}
.sp_nav .header_freedial img {
  width: auto;
  height: 58px;
}
.sp_nav .header_freedial span {
  font-size: 34px;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .sp_nav .header_freedial span {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    letter-spacing: 1px;
    font-size: 28px;
  }
}
.sp_nav .header_freedial small {
  font-size: 14px;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .sp_nav .header_freedial small {
    font-size: 12px;
  }
}
.sp_nav .header_close {
  margin-top: 38px;
  display: flex;
  justify-content: center;
}
.sp_nav .header_close button {
  background-color: transparent;
  color: #fff;
  font-size: 16px;
}
.sp_nav .header_close button:before {
  content: "";
  display: inline-block;
  width: 11px;
  height: 12px;
  background: url(/img/common/close.png) 50% 50% no-repeat;
  background-size: contain;
  margin-right: 9px;
}

.nav-open {
  overflow: hidden;
}

.sp_nav_lv1 {
  border-bottom: 1px solid #959595;
}
.sp_nav_lv1 > li {
  border-left: 1px solid #959595;
  border-right: 1px solid #959595;
}
.sp_nav_lv1 > li > a,
.sp_nav_lv1 > li > button {
  border-top: 1px solid #959595;
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 15px 20px;
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  background-color: #3d3d3d;
  outline: none;
  line-height: 1;
}
.sp_nav_lv1 > li > a:hover, .sp_nav_lv1 > li > a:focus,
.sp_nav_lv1 > li > button:hover,
.sp_nav_lv1 > li > button:focus {
  color: #f1881f;
}
.sp_nav_lv1 > li > a:after {
  position: absolute;
  right: 20px;
  bottom: 0;
  top: 0;
  margin: auto;
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
.sp_nav_lv1 > li > button {
  outline: none;
}
.sp_nav_lv1 > li > button.open:before {
  transform: rotate(0);
}
.sp_nav_lv1 > li > button:before {
  right: 16px;
  position: absolute;
  transform: rotate(90deg);
  display: block;
  width: 10px;
  height: 2px;
  bottom: 0;
  top: 0;
  margin: auto;
  background-color: #fff;
  content: "";
}
.sp_nav_lv1 > li > button:after {
  right: 16px;
  position: absolute;
  display: block;
  width: 10px;
  height: 2px;
  bottom: 0;
  top: 0;
  margin: auto;
  background-color: #fff;
  content: "";
}

.sp_nav_lv2 {
  padding: 20px;
  background-color: #707070;
  display: none;
}
.sp_nav_lv2 > li {
  margin-bottom: 5vw;
}
.sp_nav_lv2 > li + li {
  margin-top: 13px;
}
.sp_nav_lv2 > li > a {
  width: 100%;
  display: flex;
  align-items: flex-start;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.3;
}
.sp_nav_lv2 > li > a:before {
  position: relative;
  margin-top: 0.55em;
  width: 9px;
  height: 2px;
  content: "";
  margin-right: 5px;
  background-color: #f1881f;
}
.sp_nav_lv2 > li > a:hover, .sp_nav_lv2 > li > a:focus {
  color: #f1881f;
}

/* Footer */
.footer {
  margin-top: 10px;
  padding-top: 90px;
  padding-bottom: 140px;
  background-color: #efefef;
}
@media screen and (max-width: 767px) {
  .footer {
    padding-top: 0;
    padding-bottom: 92px;
    margin-top: 10vw;
    background-color: #3d3d3d;
  }
}
.footer address {
  display: block;
  text-align: right;
  margin-top: 35px;
  font-style: normal;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 1.44px;
  color: #000000;
  margin-bottom: 0;
  max-width: 1050px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .footer address {
    color: #ffffff;
    font-size: 10px;
    line-height: 1.7;
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .footer address {
    font-size: 9px;
  }
}
.footer .sp_nav {
  display: none;
}
@media screen and (max-width: 767px) {
  .footer .sp_nav {
    display: block;
    position: relative;
    overflow: visible;
    height: auto;
    top: 0;
    padding-bottom: 0;
    z-index: 1;
  }
}
.footer .sp_nav .header_close {
  display: none;
}

.footer_nav {
  display: flex;
  justify-content: space-between;
}

.footer_nav_lv1 > li + li {
  margin-top: 20px;
}
.footer_nav_lv1 > li > a {
  font-size: 18px;
  color: #000000;
  text-decoration: none;
  display: flex;
  align-items: flex-start;
  line-height: 1.25;
  transition: all 0.2s ease-in-out;
}
.footer_nav_lv1 > li > a:hover, .footer_nav_lv1 > li > a:focus {
  color: #f1881f;
}
.footer_nav_lv1 > li > a:before {
  margin-top: 10px;
  margin-right: 10px;
  display: block;
  content: "";
  width: 21px;
  height: 3px;
  background-color: #f1881f;
}

.footer_nav_lv2 {
  margin-top: 16px;
  padding-left: 24px;
}
.footer_nav_lv2 > li > a {
  display: flex;
  align-items: flex-start;
  color: #000000;
  text-decoration: none;
  line-height: 1.25;
  margin-bottom: 0.8em;
  transition: all 0.2s ease-in-out;
}
.footer_nav_lv2 > li > a:hover, .footer_nav_lv2 > li > a:focus {
  color: #f1881f;
}
.footer_nav_lv2 > li > a:before {
  margin-top: 8px;
  margin-right: 10px;
  display: block;
  content: "";
  width: 14px;
  height: 3px;
  background-color: #f1881f;
}

.footer_fix_ban {
  position: fixed;
  z-index: 99999;
  bottom: 0;
  left: 0;
  transform: translateY(100%);
  height: 13.425vw;
  transition: all 0.4s ease-out;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footer_fix_ban {
    display: none;
  }
}
.footer_fix_ban ul.footer_fix_ban_list {
  display: flex;
  justify-content: space-around;
  list-style: none;
  margin: 0;
  padding: 0;
  line-height: 1.2;
}
.footer_fix_ban ul.footer_fix_ban_list li.inquiry {
  width: 48vw;
  border-radius: 6px;
  background: #f85a1d;
  color: #fff;
  padding: 1vw 1vw 1vw 10vw;
  font-size: 3.5vw;
  position: relative;
}
.footer_fix_ban ul.footer_fix_ban_list li.inquiry:before {
  content: "";
  display: inline-block;
  width: 6vw;
  height: 6vw;
  background: url(/img/common/icon_contact.png) 50% 50% no-repeat;
  background-size: contain;
  margin: auto;
  position: absolute;
  left: 3vw;
  top: 0;
  bottom: 0;
}
.footer_fix_ban ul.footer_fix_ban_list a {
  text-decoration: none;
}
.footer_fix_ban ul.footer_fix_ban_list li.tel {
  width: 48vw;
  border-radius: 6px;
  background: #ed8a27;
  color: #fff;
  padding: 1vw 1vw 1vw 10vw;
  font-size: 3.5vw;
  position: relative;
}
.footer_fix_ban ul.footer_fix_ban_list li.tel:before {
  content: "";
  display: inline-block;
  width: 6vw;
  height: 6vw;
  background: url(/img/common/icon_freedial_white.png) 50% 50% no-repeat;
  background-size: contain;
  margin: auto;
  position: absolute;
  left: 2vw;
  top: 0;
  bottom: 0;
}
.footer_fix_ban ul.footer_fix_ban_list li.tel small {
  font-size: 2.5vw;
}

@media screen and (max-width: 767px) and (orientation: landscape) {
  .footer_fix_ban {
    height: 50px;
  }

  .footer_fix_ban ul.footer_fix_ban_list li.inquiry,
  .footer_fix_ban ul.footer_fix_ban_list li.tel,
  .footer_fix_ban ul.footer_fix_ban_list li.tel small {
    font-size: 14px;
  }

  .footer_fix_ban ul.footer_fix_ban_list li.inquiry:before,
  .footer_fix_ban ul.footer_fix_ban_list li.tel:before {
    width: 14px;
    height: 14px;
  }
}
html.scroll .footer_fix_ban {
  transform: translateY(0);
}

.footer_fix_contact {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  min-width: 1050px;
  background-color: #303030;
  height: 64px;
  display: flex;
  align-items: center;
  transition: all 0.4s ease-in-out;
  z-index: 99;
  transform: translateY(100px);
}
@media screen and (max-width: 767px) {
  .footer_fix_contact {
    display: none;
  }
}
.footer_fix_contact .container {
  position: relative;
}
.footer_fix_contact.close {
  bottom: -64px;
}
.footer_fix_contact.close .footer_fix_contact_tab {
  top: 0;
}
.footer_fix_contact.close .footer_fix_contact_toggle {
  top: -33px !important;
}

.scroll .footer_fix_contact {
  transform: translateY(0);
}

.footer_fix_contact_ct {
  display: flex;
}

.footer_contact_list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  list-style: none;
  padding: 0;
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}
.footer_contact_list > li {
  margin-left: 10px;
}
.footer_contact_list > li:first-child {
  margin-left: 14px;
}

.footer_fix_contact_tab {
  list-style: none;
  display: flex;
  position: absolute;
  top: -21px;
  transition: all 0.4s ease-out;
  padding-inline-start: 0;
}
.footer_fix_contact_tab li {
  display: block;
  line-height: 1;
}
.footer_fix_contact_tab li button {
  cursor: pointer;
  outline: none;
  height: 27px;
  color: #ff5313;
  border-radius: 3px 3px 0 0;
  padding: 0 6px 6px;
  border: 1px solid #ff5313;
  background-color: #ffffff;
}
.footer_fix_contact_tab li button.on {
  color: #ffffff;
  background-color: #ff5313;
}
.footer_fix_contact_tab li + li {
  margin-left: 6px;
}

#container .footer_fix_contact_toggle {
  position: absolute;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 78px;
  text-align: center;
  padding-bottom: 14px;
  right: 25px;
  top: -23px;
  background-color: #303030;
  border-radius: 3px 3px 0 0;
  font-size: 12px;
  color: #fff4e3;
  padding-top: 6px !important;
  z-index: 1;
  line-height: 1;
  vertical-align: top;
  outline: none;
  transition: all 0.4s ease-out;
}
#container .footer_fix_contact_toggle span {
  display: inline-block;
  vertical-align: top;
}
#container .footer_fix_contact_toggle.close {
  padding-top: 8px !important;
}
#container .footer_fix_contact_toggle.close:before {
  top: 0;
  transform: rotate(180deg);
}
#container .footer_fix_contact_toggle:before {
  vertical-align: top;
  position: relative;
  top: 1px;
  margin-right: 4px;
  display: inline-block;
  content: "";
  width: 0;
  height: 0;
  line-height: 1;
  border-style: solid;
  border-width: 11px 6px 0 6px;
  border-color: #fff4e3 transparent transparent transparent;
  transition: all 0.4s ease-out;
}
#container .footer_fix_contact_tab_ct {
  position: relative;
  z-index: 2;
  padding-inline-start: 0;
}
#container .footer_fix_contact_tab_ct li {
  display: none;
}
#container .footer_fix_contact_tab_ct li.on {
  display: block;
}
#container .footer_fix_contact_tab_ct li #mrc_webform {
  display: flex;
  align-items: center;
  background-color: #ff5313;
  padding: 8px;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_custtitle {
  display: none;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_questionnaire {
  width: 82% !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_name_r {
  margin-right: 10px;
  display: flex;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_button {
  max-width: 59px !important;
  margin-top: 0 !important;
  padding-left: 4px;
  padding-right: 5px;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_apply {
  max-width: 50px !important;
  height: 30px;
  background-color: #ffffff !important;
  border-radius: 6px !important;
  color: #ff5313 !important;
  font-weight: bold !important;
  padding-top: 5px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  filter: drop-shadow(0px 2px 0px rgba(190, 53, 2, 0.7));
  cursor: pointer;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_apply:hover {
  opacity: 0.9;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_row .mrc_webform_a {
  padding: 0 !important;
  background-color: transparent !important;
  border: none !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_row .mrc_webform_a input {
  margin-bottom: 0 !important;
  width: 100% !important;
  height: 30px;
  border: none !important;
  font-size: 12px !important;
  padding-left: 0.5em !important;
  padding-right: 0.5em !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_row th, #container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_row td {
  background-color: transparent !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform tbody {
  display: flex;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_premsg {
  display: none !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_req {
  display: none !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform .mrc_webform_title {
  font-size: 14px !important;
  text-align: center !important;
  font-weight: bold;
  color: #ffffff;
  min-width: 137px;
  max-width: 137px;
  line-height: 1.3 !important;
  margin: 0 10px 0 0 !important;
}
#container .footer_fix_contact_tab_ct li #mrc_webform form {
  display: flex !important;
}

.footer_fix_contact .mrc_webform_name_r th,
.footer_fix_contact .mrc_webform_email_r th {
  display: none;
}

.footer_freedial img {
  width: 56px;
  height: 43px;
  margin-right: 3px;
}

.footer_freedial a,
.footer_freedial div {
  display: flex;
  color: #ffffff;
  font-size: 21px;
  text-decoration: none;
  align-items: center;
  line-height: 1.3;
  font-weight: bold;
  margin-right: 2px;
}

.footer_freedial a small,
.footer_freedial div small {
  display: block;
  font-size: 11px;
}

.footer_download a {
  padding: 6px 10px;
  display: flex;
  align-items: center;
  background-color: #f08e2c;
  text-decoration: none;
  color: #ffffff;
  line-height: 1.25;
  font-size: 14px;
  width: 140px;
  height: 46px;
  letter-spacing: -0.05em;
}
.footer_download a:before {
  content: '';
  display: inline-block;
  width: 17px;
  height: 20px;
  background-image: url(/img/common/icon_download_catalog.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 8px;
}
.footer_download a img {
  margin-right: 10px;
}

.cv_area {
  border-top: 1px solid #aaa;
  margin-top: 100px;
  position: relative;
  padding-top: 30px;
}
.cv_area:before {
  position: absolute;
  content: "";
  width: 100%;
  top: -4px;
  left: 0;
  border-bottom: 1px solid #bbb;
}
.cv_area:after {
  position: absolute;
  content: "";
  width: 100%;
  left: 0;
  top: -7px;
  border-bottom: 1px solid #ccc;
}
.cv_area .cv_area_title {
  font-size: 28px;
  text-align: center;
  margin: 0;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_area_title {
    font-size: 6vw;
    margin-bottom: 10px;
  }
}
.cv_area .cv_area_lead {
  font-size: 18px;
  text-align: center;
  position: relative;
  padding: 30px 10px;
  background: #ffc66e;
  margin: 0;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_area_lead {
    font-size: 4vw;
  }
}
.cv_area .cv_area_lead:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 16px 13px 0 13px;
  border-color: #ffffff transparent transparent transparent;
}
.cv_area .cv_area_tel {
  font-size: 18px;
  text-align: center;
  position: relative;
  padding: 30px 10px;
  background-image: linear-gradient(-45deg, #ffebcd 25%, #ffdeab 25%, #ffdeab 50%, #ffebcd 50%, #ffebcd 75%, #ffdeab 75%, #ffdeab);
  background-size: 5px 5px;
  background-attachment: fixed;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_area_tel {
    font-size: 4vw;
  }
}
.cv_area .cv_area_tel:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 16px 13px 0 13px;
  border-color: #ffc66e transparent transparent transparent;
}
.cv_area .cv_area_tel:after {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 16px 13px 0 13px;
  border-color: #ffdeab transparent transparent transparent;
}
.cv_area div.cv_area_subtitle {
  text-align: center;
}
.cv_area .cv_area_subtitle p {
  font-size: 20px;
  color: #c70000;
  text-align: center;
  position: relative;
  margin: 30px auto 0;
  display: inline-block;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_area_subtitle p {
    font-size: 5vw;
  }
}
.cv_area .cv_area_subtitle p:before {
  content: "＼ ";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1em;
  margin: auto;
}
.cv_area .cv_area_subtitle p:after {
  content: " ／";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -1em;
  margin: auto;
}
.cv_area .cv_btn {
  display: flex;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn {
    display: block;
  }
}
.cv_area .cv_btn .cv_btn_01 {
  width: calc((100% / 2) - 10px);
  display: inline-block;
  border: solid 1px #ff5313;
  background: linear-gradient(to top, #ef4a0c, #ff5313);
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 1px;
  text-align: center;
  color: #fff;
  text-decoration: none;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
}
.cv_area .cv_btn .cv_btn_01 span {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_01 span {
    font-size: 3vw;
  }
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_01 {
    font-size: 6vw;
    padding: 0 6vw 2vw 4vw;
    width: calc( 100% - 20px );
  }
}
.cv_area .cv_btn .cv_btn_01:hover, .cv_area .cv_btn .cv_btn_01:focus {
  opacity: 0.8;
}
.cv_area .cv_btn .cv_btn_01:after {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_01:after {
    right: 2vw;
  }
}
.cv_area .cv_btn .cv_btn_02 {
  width: calc((100% / 2) - 10px);
  display: inline-block;
  border: solid 1px #e96e01;
  background: linear-gradient(to top, #c85407, #e96e01);
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 1px;
  text-align: center;
  color: #fff;
  text-decoration: none;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
}
.cv_area .cv_btn .cv_btn_02 span {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_02 span {
    font-size: 3vw;
  }
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_02 {
    font-size: 6vw;
    padding: 0 6vw 2vw 4vw;
    width: calc( 100% - 20px );
  }
}
.cv_area .cv_btn .cv_btn_02:hover, .cv_area .cv_btn .cv_btn_02:focus {
  opacity: 0.8;
}
.cv_area .cv_btn .cv_btn_02:after {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .cv_area .cv_btn .cv_btn_02:after {
    right: 2vw;
  }
}

/* ------------------------------------------------------------------------------------------
* 2. Module
* ----------------------------------------------------------------------------------------- */
/* Breadcrumb */
.breadcrumb {
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    margin-top: 10px;
  }
}
.breadcrumb ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .breadcrumb ul li {
    font-size: 12px;
  }
}
.breadcrumb ul li + li:before {
  display: inline-block;
  content: "＞";
  margin-left: 0.6em;
  margin-right: 0.6em;
}
@media screen and (max-width: 767px) {
  .breadcrumb ul li + li:before {
    font-size: 12px;
  }
}
.breadcrumb ul li a {
  color: #01267f;
}
@media screen and (max-width: 767px) {
  .breadcrumb ul li a {
    font-size: 12px;
  }
}
.breadcrumb ul li a:hover {
  text-decoration: none;
}

/* key visual */
.kv_wrap {
  position: relative;
}
.kv_wrap .kv_text {
  position: absolute;
  left: 50%;
  top: 50%;
  margin: 0;
  font-size: 38px;
  color: #ffffff;
  transform: translate(-50%, -50%);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .kv_wrap .kv_text {
    font-size: 9vw;
    width: 94%;
    text-align: center;
  }
}
.kv_wrap .kv_text b {
  z-index: 100;
}
.kv_wrap .kv_text span:after {
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.1;
  position: absolute;
  left: -5px;
  right: 0;
  bottom: 0;
  top: -5px;
  margin: auto;
  z-index: -1;
}
.kv_wrap .kv_text span:before {
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.1;
  position: absolute;
  left: 0;
  right: -5px;
  bottom: -5px;
  top: 0;
  margin: auto;
  z-index: -1;
}

/* List */
.list_fig_01 {
  display: flex;
  list-style: none;
  padding-left: 0;
  margin: 0 -5px;
}
@media screen and (max-width: 767px) {
  .list_fig_01 {
    display: block;
    margin-left: 0;
    margin-right: 0;
  }
}
.list_fig_01 li {
  flex-basis: 25%;
  max-width: 25%;
  padding-left: 5px;
  padding-right: 5px;
}
@media screen and (max-width: 767px) {
  .list_fig_01 li {
    flex-basis: 100%;
    max-width: 100%;
    margin-bottom: 20px;
  }
}
.list_fig_01 li figure > img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  transition: all 0.2s ease-in-out;
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .list_fig_01 li figure > img {
    width: 100%;
  }
}
.list_fig_01 li a {
  text-decoration: none;
}
.list_fig_01 li a:hover, .list_fig_01 li a:focus {
  color: #f1881f;
}
.list_fig_01 li a:hover dl dt, .list_fig_01 li a:hover dl dd, .list_fig_01 li a:focus dl dt, .list_fig_01 li a:focus dl dd {
  color: inherit;
}
.list_fig_01 li a:hover img, .list_fig_01 li a:focus img {
  opacity: 0.85;
}
.list_fig_01 li dl {
  margin-top: 5px;
}
.list_fig_01 li dl dt {
  color: #666;
  font-feature-settings: "palt";
  line-height: 1.8;
  transition: all 0.2s ease-in-out;
  font-size: 11px;
}
.list_fig_01 li dl dd {
  color: #000000;
  font-size: 13px;
  line-height: 1.4;
  font-feature-settings: "palt";
  transition: all 0.2s ease-in-out;
}

.list_index {
  display: flex;
  align-items: flex-start;
  margin-bottom: 30px;
}
.list_index dl {
  border: 0.7px solid #999;
  padding: 23px;
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .list_index dl {
    padding: 20px 22px;
    display: block;
    width: 100%;
  }
}
.list_index dt {
  font-size: 18.5px;
  font-weight: 900;
  line-height: 1.25;
  letter-spacing: 2.22px;
  text-align: left;
  color: #999;
  white-space: nowrap;
  margin-right: 39px;
}
@media screen and (max-width: 767px) {
  .list_index dt {
    font-size: 16px;
    margin-right: 22px;
    margin-bottom: 4vw;
  }
}
.list_index dd ul li.level2 {
  margin-left: 1.5em;
}
.list_index dd ul li + li {
  margin-top: 16px;
}
.list_index dd ul li a {
  display: flex;
  font-size: 18px;
  line-height: 1.25;
  text-decoration: none;
  align-items: flex-start;
  color: #000000;
  font-weight: bold;
  transition: all 0.2s ease-in-out;
  position: relative;
}
@media screen and (max-width: 767px) {
  .list_index dd ul li a {
    font-size: 16px;
    margin-left: 1em;
  }
}
.list_index dd ul li a:hover, .list_index dd ul li a:focus {
  color: #f1881f;
}
.list_index dd ul li a:before {
  position: absolute;
  left: -20px;
  top: 0.5em;
  margin-top: -4px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #f1881f;
  border-top: 2px solid #f1881f;
  transform: rotate(45deg);
}

.list_link {
  list-style: none;
  padding-left: 0;
  margin-bottom: 20px;
}
.list_link > li + li {
  margin-top: 10px;
  margin-bottom: 20px;
}
.list_link > li > a {
  display: inline-block;
  position: relative;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1px;
  color: #01267f;
  line-height: 1.8;
  padding-left: 20px;
  text-decoration: underline;
}
.list_link > li > a:after {
  position: absolute;
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  left: 0;
  top: 0.5em;
  border-right: 2px solid #01267f;
  border-top: 2px solid #01267f;
  transform: rotate(45deg);
}
.list_link > li > a:hover, .list_link > li > a:focus {
  text-decoration: none;
}
.list_link > li > a time {
  display: block;
  margin-right: 1em;
}

.news_list_link {
  padding-left: 0;
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .news_list_link {
    display: block;
  }
}
.news_list_link dt {
  width: 20%;
  margin-bottom: 20px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 767px) {
  .news_list_link dt {
    width: 100%;
    border: none;
    margin: 0;
  }
}
.news_list_link dd {
  width: 80%;
  margin-bottom: 20px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 767px) {
  .news_list_link dd {
    width: 100%;
  }
}
.news_list_link dd a {
  text-decoration: none;
  color: #000;
}
.news_list_link dd a:hover {
  text-decoration: underline;
}

.list_square {
  list-style: none;
  padding-left: 0;
  margin-bottom: 20px;
}
.list_square > li {
  position: relative;
  display: block;
  font-size: 16px;
  letter-spacing: 1px;
  color: #000000;
  line-height: 1.8;
  padding-left: 20px;
}
.list_square > li + li {
  margin-top: 12px;
}
.list_square > li:after {
  position: absolute;
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  left: 0;
  top: 0.45em;
  background-color: #f1881f;
}
.list_square.blue > li:after {
  background-color: #01267f;
}
.list_square.grey > li:after {
  background-color: #9fa8c1;
}

.box_tag {
  background-color: #fff4e3;
  padding: 14px 14px 4px 14px;
}
.box_tag dl {
  display: flex;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .box_tag dl {
    display: block;
    margin-bottom: 3vw;
    font-size: 3vw;
  }
}
.box_tag dl dt {
  font-weight: bold;
  margin-right: 0.5em;
  width: 5em;
}
.box_tag dl dd {
  width: calc(100% - 5em);
}
@media screen and (max-width: 767px) {
  .box_tag dl dd {
    width: 100%;
  }
}
.box_tag dl dd ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.box_tag dl dd ul li {
  margin-bottom: 12px;
}
.box_tag dl dd ul li:hover {
  cursor: pointer;
}
.box_tag dl dd ul li.border {
  border-bottom: 1px solid #333;
}
.box_tag dl dd ul li + li {
  position: relative;
  margin-left: 2em;
}
.box_tag dl dd ul li + li:before {
  content: "｜";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1.5em;
  margin: auto;
}
.box_tag dl dd a {
  color: #01267f;
}
.box_tag dl dd a:hover, .box_tag dl dd a:focus {
  text-decoration: none;
}

.index_list_2column {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .index_list_2column {
    display: block;
  }
}
.index_list_2column .column_box {
  width: calc( 50% - 20px );
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .index_list_2column .column_box {
    width: 100%;
  }
}
.index_list_2column .column_box h3 {
  font-weight: bold;
  font-size: 20px;
  margin: 0 0 10px 0;
}
.index_list_2column .column_box .tag {
  margin: 0 0 10px 0;
  font-size: 12px;
}
.index_list_2column .column_box .tag span {
  display: inline-block;
  color: #fff;
  background: #f1881f;
  margin: 0 4px 4px 0;
  padding: 1px 5px;
}
.index_list_2column .column_box .img {
  width: 100%;
  margin: 0 0 10px 0;
}
.index_list_2column .column_box .img img {
  max-width: 100%;
}
.index_list_2column .column_box .text {
  margin: 0 0 10px 0;
}
.index_list_2column .column_box .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 40px;
  border: solid 1.3px #ff8401;
  background-color: #ffffff;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 1px;
  text-align: center;
  color: #ff8401;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .index_list_2column .column_box .btn {
    font-size: 14px;
    height: 20vw;
    width: 80%;
  }
}
.index_list_2column .column_box .btn:hover, .index_list_2column .column_box .btn:focus {
  background-color: #ff8401;
  color: #ffffff;
}
.index_list_2column .column_box .btn:hover:after, .index_list_2column .column_box .btn:focus:after {
  border-color: #ffffff;
}
.index_list_2column .column_box .btn:after {
  transition: all 0.2s ease-in-out;
  margin-left: 6px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #ff8401;
  border-top: 2px solid #ff8401;
  transform: rotate(45deg);
}

.img_left_textbox {
  display: flex;
}
.img_left_textbox .img {
  width: auto;
  max-width: 35%;
  margin-bottom: 50px;
}
.img_left_textbox .img img {
  max-width: 100%;
  height: auto;
}
.img_left_textbox .text {
  width: calc(75% - 16px);
  margin-left: 16px;
  margin-bottom: 50px;
}
.img_left_textbox .text .h4 {
  margin-top: 0;
}

.img_left_textbox_bggrey {
  display: flex;
  background: #f3f3f3;
  padding: 20px;
  margin-bottom: 50px;
}
.img_left_textbox_bggrey .img {
  width: auto;
  max-width: 35%;
}
.img_left_textbox_bggrey .img img {
  max-width: 100%;
  height: auto;
}
.img_left_textbox_bggrey .text {
  width: calc(75% - 16px);
  margin-left: 16px;
}
.img_left_textbox_bggrey .text .h4 {
  margin-top: 0;
}

.img_right_textbox {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .img_right_textbox {
    display: block;
  }
}
.img_right_textbox .img {
  width: auto;
  max-width: 45%;
  margin-bottom: 50px;
  min-width: 45%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .img_right_textbox .img {
    max-width: 100%;
    margin-bottom: 4vw;
  }
}
.img_right_textbox .img img {
  max-width: 100%;
  height: auto;
}
.img_right_textbox .text {
  width: calc(55% - 16px);
  margin-right: 40px;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .img_right_textbox .text {
    width: 100%;
    margin-right: 0;
    margin-bottom: 4vw;
  }
}
.img_right_textbox .text .h4 {
  margin-top: 0;
}

.img_right_textbox_bggrey {
  display: flex;
  flex-direction: row-reverse;
  background: #f3f3f3;
  padding: 20px;
  margin-bottom: 50px;
  min-width: 45%;
  text-align: center;
}
.img_right_textbox_bggrey .img {
  width: auto;
  max-width: 45%;
}
.img_right_textbox_bggrey .img img {
  max-width: 100%;
  height: auto;
}
.img_right_textbox_bggrey .text {
  width: calc(55% - 16px);
  margin-right: 16px;
}
.img_right_textbox_bggrey .text .h4 {
  margin-top: 0;
}

.list_box_4rows {
  list-style: none;
  padding-left: 0;
  margin-bottom: 2em;
  display: flex;
  flex-wrap: wrap;
}
.list_box_4rows li {
  margin-top: 10px;
  width: calc((100% / 4) - 10px );
  margin: 20px 5px;
}
@media screen and (max-width: 767px) {
  .list_box_4rows li {
    width: calc((100% / 2) - 4vw);
    margin: 20px 2vw;
  }
}

.list_link_6rows {
  list-style: none;
  padding-left: 0;
  margin-bottom: 2em;
  display: flex;
  flex-wrap: wrap;
}
.list_link_6rows li {
  margin-top: 10px;
  width: calc(100% / 6);
  margin: 20px 0;
}
@media screen and (max-width: 767px) {
  .list_link_6rows li {
    width: calc(100% / 3);
    margin: 20px 0;
  }
}
.list_link_6rows li > a {
  display: inline-block;
  position: relative;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -1.6px;
  color: #01267f;
  line-height: 1.8;
  padding-left: 20px;
  text-decoration: underline;
}
.list_link_6rows li > a:after {
  position: absolute;
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  border-right: 2px solid #01267f;
  border-top: 2px solid #01267f;
  transform: rotate(45deg);
}
.list_link_6rows li > a:hover, .list_link_6rows li > a:focus {
  text-decoration: none;
}
.list_link_6rows li > a time {
  display: inline-block;
  margin-right: 1em;
}

.list_square_6rows {
  list-style: none;
  padding-left: 0;
  margin-bottom: 2em;
  display: flex;
  flex-wrap: wrap;
}
.list_square_6rows li {
  position: relative;
  display: block;
  font-size: 16px;
  letter-spacing: 1px;
  color: #000000;
  line-height: 1.8;
  padding-left: 20px;
  width: calc(100% / 6);
  margin: 20px 0;
}
@media screen and (max-width: 767px) {
  .list_square_6rows li {
    width: calc(100% / 3);
    margin: 20px 0;
    padding-left: 3.5vw;
  }
}
.list_square_6rows li:after {
  position: absolute;
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  left: 0;
  top: 0.5em;
  margin: auto;
  background-color: #f1881f;
}
@media screen and (max-width: 767px) {
  .list_square_6rows li:after {
    width: 2vw;
    height: 2vw;
  }
}

.emphasis_box {
  background: #ff9c00;
  font-size: 25px;
  padding: 10px 6px;
  color: #fff;
  text-shadow: 2px 2px 1px #f77e03;
  font-weight: bold;
  line-height: 1.6;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .emphasis_box {
    font-size: 6vw;
  }
}

.point_box {
  margin-bottom: 30px;
}
.point_box .point_box_title {
  background: #ff9c00;
  font-size: 18px;
  color: #fff;
  font-weight: bold;
  line-height: 1.6;
  padding: 6px 20px 4px;
  letter-spacing: 1px;
}
@media screen and (max-width: 767px) {
  .point_box .point_box_title {
    font-size: 4vw;
    padding: 6px 10px 4px;
  }
}
.point_box .point_box_content {
  border: 1px solid #ff9c00;
  padding: 20px 20px 0 20px;
}
.point_box.grey .point_box_title {
  background: #9fa8c1;
}
.point_box.grey .point_box_content {
  border: 1px solid #9fa8c1;
}

.list_qanda > dt {
  padding: 10px 10px 10px 35px;
  border-radius: 5px;
  background: #daecd4;
  text-indent: -25px;
}
.list_qanda > dt:before {
  content: "Q.";
  font-weight: bold;
  margin-right: 7px;
}
.list_qanda > dd {
  margin: 20px 10px 40px 35px;
  text-indent: -25px;
}
.list_qanda > dd:before {
  content: "A.";
  color: #1771c6;
  font-weight: bold;
  margin-right: 7px;
}

.s-sitemap-contents {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  background: #fff;
  padding: 50px 65px;
  line-height: 1.8571;
}

.s-sitemap-contents ul {
  list-style: none;
  padding-inline-start: 0;
}

.s-sitemap-list {
  list-style: none outside;
  line-height: 1.4;
}

.s-sitemap-list:first-child {
  width: 100%;
}

.s-sitemap-list:not(:first-child) {
  margin-top: 23px;
  width: 420px;
}

.s-sitemap-list > .s-sitemap-list__item:not(:first-child) {
  margin-top: 23px;
}

.s-sitemap-list-child {
  margin-left: 25px;
}

.s-sitemap-list-child .s-sitemap-list__item {
  position: relative;
  margin-top: 23px;
  padding-left: 25px;
}

.s-sitemap-list-child .s-sitemap-list__item::before {
  display: block;
  position: absolute;
  top: 0.4em;
  left: 0;
  width: 11px;
  height: 9px;
  border-bottom: 2px solid #f1881f;
  border-left: 2px solid #f1881f;
  content: "";
}

@media only screen and (max-width: 768px) {
  .s-sitemap-contents {
    display: block;
    margin: 0 10px;
    padding: 24px 20px 34px;
    line-height: 1.8461;
    padding-inline-start: 0;
  }

  .s-sitemap-list:not(:first-child) {
    margin-top: 13px;
    width: 100%;
  }

  .s-sitemap-list > .s-sitemap-list__item:not(:first-child) {
    margin-top: 13px;
  }

  .s-sitemap-list-child .s-sitemap-list__item {
    margin-top: 13px;
    padding-left: 20px;
  }

  .s-sitemap-list-child .s-sitemap-list__item::before {
    top: 2px;
    width: 12px;
    height: 8px;
  }
}
/* Table */
.table_01 {
  width: 100%;
  margin-bottom: 30px;
}
.table_01 th {
  padding-bottom: 40px;
  padding-top: 40px;
  padding-left: 15px;
  padding-right: 15px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 1.6px;
  text-align: left;
  color: #000000;
  border-bottom: 2px solid #f1881f;
  line-height: 1.8;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table_01 th {
    padding: 1vw;
    display: block;
    width: 100%;
    border-bottom: 1px solid #f1881f;
  }
}
.table_01 td {
  padding-bottom: 40px;
  padding-top: 40px;
  padding-left: 30px;
  padding-right: 15px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1.6px;
  text-align: left;
  color: #000000;
  border-bottom: 2px solid #dcdcdc;
  line-height: 1.8;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table_01 td {
    padding: 1vw;
    display: block;
    width: 100%;
    border-bottom: none;
    margin-bottom: 30px;
  }
}
.table_01.blue th {
  border-color: #01267f;
}
@media screen and (max-width: 767px) {
  .table_01.scroll {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding-top: 7vw;
  }
}
@media screen and (max-width: 767px) {
  .table_01.scroll:before {
    content: '※この表は横にスクロールできます→';
    font-size: 3vw;
    position: absolute;
    top: 1vw;
    left: 0;
  }
}

.table_02 {
  width: 100%;
  margin-bottom: 30px;
}
.table_02 thead th, .table_02 thead td {
  background-color: #f1881f;
  color: #ffffff;
}
.table_02 tbody tr:nth-child(2n) th, .table_02 tbody tr:nth-child(2n) td {
  background-color: #eeeeee;
}
.table_02 th {
  padding-bottom: 10px;
  padding-top: 10px;
  padding-left: 15px;
  padding-right: 15px;
  font-weight: bold;
  letter-spacing: 1.6px;
  text-align: left;
  line-height: 1.8;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table_02 th {
    padding-left: 15px;
    padding-right: 0;
  }
}
.table_02 td {
  padding-bottom: 10px;
  padding-top: 10px;
  padding-left: 45px;
  padding-right: 15px;
  font-weight: 500;
  letter-spacing: 1.6px;
  text-align: left;
  line-height: 1.8;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table_02 td {
    padding-left: 15px;
    padding-right: 0;
  }
}
.table_02.blue thead th, .table_02.blue thead td {
  background-color: #01267f;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .table_02.scroll {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding-top: 7vw;
  }
}
@media screen and (max-width: 767px) {
  .table_02.scroll:before {
    content: '※この表は横にスクロールできます→';
    font-size: 3vw;
    position: absolute;
    top: 1vw;
    left: 0;
  }
}

.table_03 {
  width: 100%;
  margin-bottom: 30px;
  border-collapse: collapse;
}
.table_03 th {
  padding-bottom: 8px;
  padding-top: 8px;
  padding-left: 12px;
  padding-right: 12px;
  letter-spacing: 1px;
  text-align: left;
  font-weight: normal;
  line-height: 1.8;
  vertical-align: center;
  background: #daecd4;
  border: solid 1px #aaa;
}
@media screen and (max-width: 767px) {
  .table_03 th {
    padding: 2vw;
  }
}
.table_03 td {
  padding-bottom: 8px;
  padding-top: 8px;
  padding-left: 12px;
  padding-right: 12px;
  letter-spacing: 1px;
  text-align: left;
  line-height: 1.8;
  vertical-align: center;
  border: solid 1px #aaa;
}
@media screen and (max-width: 767px) {
  .table_03 td {
    padding: 2vw;
  }
}
.table_03.pink th {
  background-color: #FCF3EA;
}
.table_03.grey th {
  background-color: #f5f5f5;
}
@media screen and (max-width: 767px) {
  .table_03.scroll {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding-top: 7vw;
  }
}
@media screen and (max-width: 767px) {
  .table_03.scroll:before {
    content: '※この表は横にスクロールできます→';
    font-size: 3vw;
    position: absolute;
    top: 1vw;
    left: 0;
  }
}

.table_04 {
  width: 100%;
  margin-bottom: 30px;
  border-collapse: collapse;
}
.table_04 th {
  padding-bottom: 8px;
  padding-top: 8px;
  padding-left: 12px;
  padding-right: 12px;
  letter-spacing: 1px;
  text-align: left;
  font-weight: normal;
  line-height: 1.8;
  vertical-align: center;
  background: #daecd4;
  border: solid 1px #aaa;
  width: 50%;
}
.table_04 th.grey {
  background: #e5e5e5;
}
@media screen and (max-width: 767px) {
  .table_04 th {
    padding: 2vw;
  }
}
.table_04 td {
  padding-bottom: 8px;
  padding-top: 8px;
  padding-left: 12px;
  padding-right: 12px;
  letter-spacing: 1px;
  line-height: 1.8;
  border: solid 1px #aaa;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table_04 td {
    padding: 2vw;
  }
}
.table_04.pink th {
  background-color: #FCF3EA;
}
@media screen and (max-width: 767px) {
  .table_04.scroll {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    position: relative;
    padding-top: 7vw;
  }
}
@media screen and (max-width: 767px) {
  .table_04.scroll:before {
    content: '※この表は横にスクロールできます→';
    font-size: 3vw;
    position: absolute;
    top: 1vw;
    left: 0;
  }
}

.table_text_center th,
.table_text_center td {
  text-align: center;
}

/* Top Page */
.list_news_wrap {
  margin-top: 26px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid #dcdcdc;
}
@media screen and (max-width: 767px) {
  .list_news_wrap {
    display: block;
    padding-top: 15px;
    padding-bottom: 0;
    border-top: solid 1px #dcdcdc;
    border-bottom: solid 0px #dcdcdc;
  }
}
.list_news_wrap > a {
  position: relative;
  top: -1px;
  margin-left: auto;
  font-size: 16px;
  color: #000000;
  text-decoration: none;
  display: flex;
  align-items: center;
  transition: all 0.2s ease-in-out;
}
@media screen and (min-width: 768px) {
  .list_news_wrap > a {
    min-width: 124px;
  }
}
@media screen and (max-width: 767px) {
  .list_news_wrap > a {
    display: block;
    text-align: center;
    top: 2vw;
    font-size: 4vw;
  }
}
.list_news_wrap > a:hover, .list_news_wrap > a:focus {
  color: #f1881f;
}
.list_news_wrap > a:hover:after, .list_news_wrap > a:focus:after {
  border-color: #f1881f;
}
.list_news_wrap > a:after {
  margin-left: 15px;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #000000;
  border-top: 2px solid #000000;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .list_news_wrap > a:after {
    margin-top: 18px;
    display: inline-block;
  }
}

@media screen and (max-width: 767px) {
  .list_news {
    display: block;
    border-bottom: 1px solid #dcdcdc;
  }
}
.list_news ul {
  margin-bottom: 0;
  min-width: 877px;
  max-width: 877px;
  padding-left: 0;
  padding-right: 80px;
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .list_news ul {
    min-width: 100%;
    max-width: 100%;
    padding-right: 0;
    padding-top: 16px;
    padding-bottom: 16px;
  }
}
.list_news ul li a {
  padding-top: 17px;
  padding-bottom: 18px;
  padding-left: 28px;
  color: #000000;
  text-decoration: none;
  display: flex;
  justify-content: flex-start;
  line-height: 1.25;
  transition: all 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .list_news ul li a {
    display: block;
    padding: 0 0 15px;
    font-size: 15px;
  }
}
.list_news ul li a:hover, .list_news ul li a:focus {
  color: #f1881f;
}
.list_news ul li a time {
  white-space: nowrap;
  padding-right: 90px;
}
@media screen and (max-width: 767px) {
  .list_news ul li a time {
    display: block;
    padding-right: 0;
    font-size: 3.5vw;
    font-weight: bold;
    margin-bottom: 1vw;
  }
}
@media screen and (max-width: 767px) {
  .list_news ul li a b {
    display: block;
    font-weight: normal;
    font-size: 4vw;
  }
}

.ticker {
  overflow: hidden;
}

.ticker ul {
  width: 100%;
  position: relative;
  height: 56px;
}

.ticker ul li {
  width: 100%;
  display: none;
}

.home_kv {
  position: relative;
}
@media screen and (max-width: 767px) {
  .home_kv > a {
    left: 20px;
    right: 20px;
    bottom: 27px;
    height: 40px;
    border: solid 2px #ffffff;
    background-color: rgba(255, 255, 255, 0.8);
    position: absolute;
    font-size: 4vw;
    font-weight: bold;
    line-height: 1.38;
    color: #000000;
    z-index: 100;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.2s ease-in-out;
  }
  .home_kv > a br {
    display: none;
  }
  .home_kv > a:hover, .home_kv > a:focus {
    opacity: 0.85;
  }
  .home_kv > a:after {
    margin-left: 10px;
    content: "";
    width: 8px;
    height: 8px;
    border-top: 2px solid #000000;
    border-right: 2px solid #000000;
    transform: rotate(45deg);
  }
}
@media screen and (min-width: 768px) {
  .home_kv > a {
    left: calc(50% + 17vw);
    top: 6.25vw;
    width: 288px;
    height: 164px;
    border: solid 2px #ffffff;
    background-color: #cccdd7;
    position: absolute;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.38;
    letter-spacing: 2.24px;
    text-align: left;
    color: #000000;
    z-index: 100;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.2s ease-in-out;
    padding-right: 14px;
  }
  .home_kv > a:hover, .home_kv > a:focus {
    opacity: 0.85;
  }
  .home_kv > a:after {
    top: 50%;
    margin-top: -5px;
    right: 16px;
    position: absolute;
    content: "";
    width: 10px;
    height: 10px;
    border-top: 2px solid #000000;
    border-right: 2px solid #000000;
    transform: rotate(45deg);
  }
}
.home_kv ul {
  list-style: none;
  padding-left: 0;
}
.home_kv ul a {
  display: block;
  transition: all 0.4s ease-out;
}
.home_kv ul a:hover, .home_kv ul a:focus {
  opacity: 0.85;
}

.home_copy {
  margin-top: 65px;
  position: relative;
  width: 970px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 58px;
  padding-bottom: 58px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  margin-bottom: 160px;
  letter-spacing: 2px;
}
@media screen and (max-width: 767px) {
  .home_copy {
    padding-top: 6px;
    padding-bottom: 6px;
    width: auto;
    margin-bottom: 26vw;
    margin-top: 16vw;
  }
}
.home_copy h2 {
  text-align: center;
  font-size: 33px;
  border-bottom: 2px solid #ffc66e;
  line-height: 1.25;
  margin-bottom: 0;
  padding-bottom: 5px;
  text-shadow: 0 0 1px #000;
}
@media screen and (max-width: 767px) {
  .home_copy h2 {
    border: none;
    font-size: 24px;
    line-height: 1.8;
  }
}
@media screen and (max-width: 767px) {
  .home_copy h2 span {
    display: inline-block;
    padding-bottom: 1px;
    border-bottom: 2px solid #ffc66e;
  }
}
@media screen and (max-width: 767px) {
  .home_copy h2 span:first-child {
    letter-spacing: 4px;
    margin-bottom: 4px;
  }
}
.home_copy p {
  margin-top: 21px;
  text-align: center;
  font-size: 22px;
  line-height: 1.68;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .home_copy p {
    font-size: 16px;
    font-weight: bold;
    text-align: left;
    padding: 0 4vw;
  }
}
.home_copy:before, .home_copy:after {
  position: absolute;
  display: block;
  content: "";
  width: 41px;
  height: 41px;
}
@media screen and (max-width: 767px) {
  .home_copy:before, .home_copy:after {
    width: 20px;
    height: 20px;
  }
}
.home_copy:before {
  left: 0;
  top: 0;
  background: url(/img/top/brd_deco_tl.png) 0 0 no-repeat;
}
@media screen and (max-width: 767px) {
  .home_copy:before {
    background-size: contain;
  }
}
.home_copy:after {
  right: 0;
  bottom: 0;
  background: url(/img/top/brd_deco_br.png) 0 0 no-repeat;
}
@media screen and (max-width: 767px) {
  .home_copy:after {
    background-size: contain;
  }
}

.home_box_menu_wrap {
  height: 472px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap {
    height: 625px;
  }
}
.home_box_menu_wrap .container {
  position: relative;
}
.home_box_menu_wrap .container .home_box_menu {
  position: absolute;
}
.home_box_menu_wrap + .home_box_menu_wrap, .home_box_menu_wrap + .home_box_menu_wrap_both {
  margin-top: 188px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap + .home_box_menu_wrap, .home_box_menu_wrap + .home_box_menu_wrap_both {
    margin-top: 132px;
  }
}

.home_box_menu_wrap_both + .home_box_menu_wrap_both {
  margin-top: 180px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both + .home_box_menu_wrap_both {
    margin-top: 117px;
  }
}

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

.home_ground_survey {
  background: url(/img/top/home_ground_survey.jpg) 100% 0 no-repeat;
  background-size: auto 100%;
}
@media screen and (max-width: 767px) {
  .home_ground_survey {
    height: 625px;
    background: url(/img/top/home_ground_survey_sp.jpg) 50% 50% no-repeat;
    background-size: cover;
  }
}

.home_ground_improvement {
  background: url(/img/top/home_ground_improvement.jpg) 0 0 no-repeat;
  background-size: auto 100%;
}
@media screen and (max-width: 767px) {
  .home_ground_improvement {
    height: 625px;
    background: url(/img/top/home_ground_improvement_sp.jpg) 50% 50% no-repeat;
    background-size: cover;
  }
}
.home_ground_improvement .container .home_box_menu {
  position: absolute;
  right: 0;
}

.home_ground_guarantee {
  background: url(/img/top/home_ground_guarantee.jpg) 100% 0 no-repeat;
  background-size: cover;
  height: 472px;
}

.home_soil_survey {
  background: url(/img/top/home_soil_survey.jpg) 100% 0 no-repeat;
  background-size: cover;
  height: 472px;
}

.home_subsidence_correction {
  background: url(/img/top/home_subsidence_correction.jpg) 100% 0 no-repeat;
  background-size: cover;
  height: 472px;
}

.home_liquefaction_judgment {
  background: url(/img/top/home_liquefaction_judgment.jpg) 100% 0 no-repeat;
  background-size: cover;
  height: 472px;
}

.home_box_menu {
  margin-top: -80px;
  padding: 30px;
  max-width: 50%;
  background-color: rgba(241, 136, 31, 0.9);
}
@media screen and (max-width: 767px) {
  .home_box_menu {
    margin-top: -60px;
    padding: 20px;
    max-width: 100%;
    width: calc(100% - 40px);
    left: 0;
    right: 0;
    top: -60px;
    margin: auto;
  }
}
.home_box_menu.s {
  background-color: #f1881f;
}
@media screen and (max-width: 767px) {
  .home_box_menu.s {
    position: relative;
    top: -57px;
    margin-top: 0;
    margin-bottom: -57px;
  }
}
@media screen and (min-width: 768px) {
  .home_box_menu.s {
    max-width: 370px;
    min-width: 370px;
  }
}
@media screen and (min-width: 768px) {
  .home_box_menu.left {
    margin-left: auto;
    margin-right: 70px;
  }
}
@media screen and (min-width: 768px) {
  .home_box_menu.right {
    margin-left: 70px;
    margin-right: auto;
  }
}

.home_box_menu_tit {
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 4px;
  text-align: center;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.25;
  margin-bottom: 21px;
  margin-top: 2px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_tit {
    margin-top: 10px;
    font-size: 5.5vw;
    letter-spacing: 3px;
    margin-bottom: 18px;
  }
}
.home_box_menu_tit:before, .home_box_menu_tit:after {
  content: "";
  display: block;
  width: 19px;
  height: 4px;
  background-color: #ffffff;
}
@media screen and (max-width: 767px) {
  .home_box_menu_tit:before, .home_box_menu_tit:after {
    width: 14px;
    height: 3px;
  }
}
.home_box_menu_tit:before {
  margin-right: 15px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_tit:before {
    margin-right: 13px;
  }
}
.home_box_menu_tit:after {
  margin-left: 15px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_tit:after {
    margin-left: 13px;
  }
}

.home_box_menu_lead {
  font-weight: bold;
  line-height: 1.59;
  letter-spacing: 2.56px;
  text-align: left;
  color: #ffffff;
  margin: 0 0 15px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_lead {
    margin-bottom: 20px;
    font-size: 4vw;
  }
}

.home_box_menu_links {
  display: flex;
  margin-left: -8px;
  margin-right: -8px;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .home_box_menu_links {
    align-items: stretch;
  }
}
.home_box_menu_links dt, .home_box_menu_links .home_box_menu_link {
  padding-left: 8px;
  padding-right: 8px;
  min-width: 100%;
  margin-bottom: 3px;
  max-width: 100%;
}
.home_box_menu_links dt a, .home_box_menu_links .home_box_menu_link a {
  padding-top: 9px;
  padding-bottom: 9px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #ffffff;
  text-decoration: none;
  font-size: 18.5px;
  font-weight: bold;
  letter-spacing: 0.93px;
  text-align: center;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .home_box_menu_links dt a, .home_box_menu_links .home_box_menu_link a {
    padding-top: 6px;
    padding-bottom: 6px;
    font-size: 16px;
  }
}
.home_box_menu_links dt a:after, .home_box_menu_links .home_box_menu_link a:after {
  position: absolute;
  right: 20px;
  top: 50%;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #000000;
  border-top: 2px solid #000000;
  transform: rotate(45deg);
  margin-top: -6px;
  font-feature-settings: "palt";
}
@media screen and (max-width: 767px) {
  .home_box_menu_links dt a:after, .home_box_menu_links .home_box_menu_link a:after {
    margin-top: -4px;
    right: 16px;
  }
}
.home_box_menu_links dt a:hover, .home_box_menu_links dt a:focus, .home_box_menu_links .home_box_menu_link a:hover, .home_box_menu_links .home_box_menu_link a:focus {
  opacity: 0.85;
}
.home_box_menu_links dd {
  padding-left: 8px;
  padding-right: 8px;
  min-width: 50%;
  max-width: 50%;
  margin: 13px 0 0;
  display: block;
}
.home_box_menu_links dd a {
  position: relative;
  padding-top: 7px;
  padding-bottom: 7px;
  padding-left: 20px;
  display: flex;
  align-items: center;
  text-align: left;
  justify-content: left;
  background-color: #ffffff;
  text-decoration: none;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.16;
  letter-spacing: 1.92px;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .home_box_menu_links dd a {
    height: 100%;
    padding-right: 32px;
    text-align: left;
    padding-left: 11px;
    justify-content: flex-start;
    font-size: 14px;
  }
}
.home_box_menu_links dd a:hover, .home_box_menu_links dd a:focus {
  opacity: 0.85;
}
.home_box_menu_links dd a:after {
  position: absolute;
  right: 20px;
  top: 50%;
  margin-top: -4px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #000000;
  border-top: 2px solid #000000;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .home_box_menu_links dd a:after {
    right: 9px;
  }
}

.home_box_menu_list {
  padding-left: 0;
  list-style: none;
  padding-top: 20px;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .home_box_menu_list {
    padding-top: 0;
    margin-top: 20px;
    margin-bottom: 0;
  }
}
.home_box_menu_list li {
  line-height: 1.6;
}
.home_box_menu_list li + li {
  margin-top: 8px;
}
.home_box_menu_list a {
  position: relative;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #ffffff;
}
.home_box_menu_list a:hover, .home_box_menu_list a:focus {
  text-decoration: underline;
}
.home_box_menu_list a:before {
  content: "";
  width: 12px;
  height: 2px;
  background-color: #ffffff;
  margin-right: 5px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_list a:before {
    width: 12px;
    height: 2px;
  }
}

.home_box_menu_wrap_both {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both {
    display: block;
  }
}
.home_box_menu_wrap_both > div,
.home_box_menu_wrap_both > article {
  min-width: 50%;
  max-width: 50%;
  height: 472px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both > div,
  .home_box_menu_wrap_both > article {
    position: relative;
    height: 355px;
    min-width: 100%;
    max-width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.home_box_menu_wrap_both > div .container,
.home_box_menu_wrap_both > article .container {
  padding-top: 50px;
  height: 100%;
  position: relative;
  width: 530px;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both > div .container,
  .home_box_menu_wrap_both > article .container {
    padding-top: 20px;
    padding-left: 0;
    padding-right: 0;
    width: 100%;
  }
}
.home_box_menu_wrap_both > div .container .flex_ct_center,
.home_box_menu_wrap_both > article .container .flex_ct_center {
  position: absolute;
  bottom: 30px;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both > div .container .flex_ct_center,
  .home_box_menu_wrap_both > article .container .flex_ct_center {
    position: static;
  }
}
@media screen and (max-width: 767px) {
  .home_box_menu_wrap_both > div + div, .home_box_menu_wrap_both > div + article,
  .home_box_menu_wrap_both > article + div,
  .home_box_menu_wrap_both > article + article {
    margin-top: 110px;
  }
}

.home_reason {
  min-height: 400px;
  background: url(/img/top/home_reason.jpg) 100% 0 no-repeat;
}
@media screen and (max-width: 767px) {
  .home_reason {
    min-height: 467px;
    background: url(/img/top/home_reason_sp.jpg) 100% 0/cover no-repeat;
  }
}
.home_reason .container {
  margin: 0 auto;
  padding-top: 30px;
}
.home_reason p {
  text-shadow: 0 0 4px white;
  margin-bottom: 0;
}

.home_data_security {
  min-height: 400px;
  background: url(/img/top/home_data_security.jpg) 100% 0 no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .home_data_security {
    min-height: 300px;
    background: url(/img/top/home_data_security_sp.jpg) 100% 0/cover no-repeat;
  }
}
.home_data_security p {
  text-shadow: 0 0 4px white;
  margin-bottom: 0;
}

.home_service_area {
  min-height: 400px;
  background: url(/img/top/home_service_area.jpg) 100% 0 no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .home_service_area {
    min-height: 300px;
    background: url(/img/top/home_service_area_sp.jpg) 100% 0/cover no-repeat;
  }
}
.home_service_area p {
  text-shadow: 0 0 4px white;
  margin-bottom: 0;
}

.home_list_ban {
  list-style: none;
  padding: 0;
  margin: 0;
  margin-top: 110px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: -18px;
  margin-right: -18px;
}
@media screen and (max-width: 767px) {
  .home_list_ban {
    margin-top: 45px;
    display: block;
    margin-bottom: 55px;
  }
}
.home_list_ban li {
  padding-left: 18px;
  padding-right: 18px;
}
@media screen and (max-width: 767px) {
  .home_list_ban li + li {
    margin-top: 20px;
  }
}
.home_list_ban li a {
  display: block;
  transition: all 0.2s ease-in-out;
}
.home_list_ban li a:hover, .home_list_ban li a:focus {
  opacity: 0.85;
}
.home_list_ban li a img {
  max-width: 100%;
  height: auto;
}

/* Slixk */
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
  margin-bottom: 0 !important;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir="rtl"] .slick-slide {
  float: right;
}
@media screen and (max-width: 767px) {
  .slick-slide img.pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .slick-slide img.sp {
    display: none !important;
  }
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}
.slick-slide a {
  display: block;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* Slider */
/* Icons */
@font-face {
  font-family: "slick";
  src: url("../fonts/../fonts/slick.eot");
  src: url("../fonts/../fonts/slick.eot?#iefix") format("embedded-opentype"), url("../fonts/../fonts/slick.woff") format("woff"), url("../fonts/../fonts/slick.ttf") format("truetype"), url("../fonts/../fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Arrows */
.slick .item {
  display: block !important;
}
.slick .item img {
  width: 100%;
}

.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  width: 22px;
  height: 64px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
  z-index: 10;
  background-color: rgba(255, 255, 255, 0.5);
}
@media (max-width: 767.98px) {
  .slick-prev,
  .slick-next {
    display: none;
  }
}
.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  opacity: 0.85;
}
.slick-prev:before,
.slick-next:before {
  display: block;
  width: 12px;
  height: 12px;
  content: "";
  position: absolute;
  transition: all 0.2s ease-in-out;
  margin-top: -5px;
}

.slick-prev {
  left: 0;
}
.slick-prev:before {
  left: 8px;
  display: block;
  border-top: 2px solid #000000;
  border-left: 2px solid #000000;
  transform: rotate(-45deg);
}

.slick-next {
  right: 0;
}
.slick-next:before {
  right: 8px;
  display: block;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: rotate(45deg);
  left: auto;
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  text-align: center;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 6px;
  width: 24px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
@media (max-width: 767.98px) {
  .slick-dots li {
    height: 6px;
    width: 24px;
  }
}
.slick-dots li button {
  border: 0;
  display: block;
  height: 6px;
  width: 24px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  cursor: pointer;
  background-color: #fff;
  transition: background-color 0.6s ease-out;
}
@media (max-width: 767.98px) {
  .slick-dots li button {
    height: 6px;
    width: 24px;
  }
}
.slick-dots li.slick-active button {
  background-color: #f1881f;
}

/* ------------------------------------------------------------------------------------------
* 3. Cosmetic
* ----------------------------------------------------------------------------------------- */
/* Navigation */
.navbar {
  height: 62px;
  background-color: #f08e2c;
  width: 100%;
}

@media screen and (min-width: 768px) {
  html.nav_fixed #content {
    padding-top: 62px;
  }
  html.nav_fixed .navbar {
    top: 0;
    position: fixed;
    z-index: 100;
    margin-top: 0 !important;
  }
  html.nav_fixed body.home .navbar + article {
    margin-top: 102px;
  }
}

.navbar_nav {
  margin-top: 0;
  display: flex;
  justify-content: space-between;
  margin-bottom: 0;
}
.navbar_nav > li {
  height: 62px;
  flex-grow: 1;
}
.navbar_nav > li > a, .navbar_nav > li > button {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  color: #ffffff;
  text-decoration: none;
  font-weight: bold;
  white-space: nowrap;
  transition: all 0.2s ease-in-out;
  width: 100%;
  background-color: transparent;
  font-size: 16px;
}
.navbar_nav > li > a.on, .navbar_nav > li > button.on {
  background-color: #fff4e3;
  color: #f1881f;
}
.navbar_nav > li > a.on.nav_home:before, .navbar_nav > li > button.on.nav_home:before {
  background: url(/img/common/icon_home_orange.png) 50% 50% no-repeat;
}
.navbar_nav > li > a:hover, .navbar_nav > li > button:hover {
  background-color: #fff4e3;
  color: #f1881f;
}
.navbar_nav > li > a:hover.nav_home:before, .navbar_nav > li > button:hover.nav_home:before {
  background: url(/img/common/icon_home_orange.png) 50% 50% no-repeat;
}
.navbar_nav > li > a.nav_search, .navbar_nav > li > button.nav_search {
  padding-top: 12px;
  font-size: 12px;
}
.navbar_nav > li > a.nav_search:before, .navbar_nav > li > button.nav_search:before {
  display: block;
  margin-bottom: 5px;
  content: "";
  width: 21px;
  height: 21px;
  background: url(/img/common/icon_search.png) 50% 50% no-repeat;
}
.navbar_nav > li > a.nav_home, .navbar_nav > li > button.nav_home {
  display: flex;
  flex-direction: row;
}
.navbar_nav > li > a.nav_home:before, .navbar_nav > li > button.nav_home:before {
  margin-right: 5px;
  content: "";
  width: 13px;
  height: 13px;
  background: url(/img/common/icon_home_white.png) 50% 50% no-repeat;
}

.container + .navbar {
  margin-top: 40px;
}

.nav_local {
  border: solid 1px #ffc66f;
  background-color: #ffffff;
}

.nav_local_lv1 > li {
  border-bottom: 1px solid #ffc66f;
}
.nav_local_lv1 > li:last-child {
  border-bottom: none;
}
.nav_local_lv1 > li > a,
.nav_local_lv1 > li > button {
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 1.28px;
  text-align: left;
  color: #000000;
  text-decoration: none;
  background-color: #fff4e3;
  padding-left: 20px;
  padding-right: 39px;
  padding-top: 11px;
  padding-bottom: 11px;
}
.nav_local_lv1 > li > a:after,
.nav_local_lv1 > li > button:after {
  position: absolute;
  right: 13px;
  top: 50%;
  margin-top: -4px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #f1881f;
  border-top: 2px solid #f1881f;
  transform: rotate(45deg);
}
.nav_local_lv1 > li > a:hover, .nav_local_lv1 > li > a:focus, .nav_local_lv1 > li > a.on,
.nav_local_lv1 > li > button:hover,
.nav_local_lv1 > li > button:focus,
.nav_local_lv1 > li > button.on {
  color: #f1881f;
}

.nav_local_lv2 {
  display: none;
}
.nav_local_lv2.on {
  display: block;
}
.nav_local_lv2 > li {
  border-top: 1px solid #ffc66f;
}
.nav_local_lv2 > li > a {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 1.28px;
  text-align: left;
  color: #000000;
  text-decoration: none;
  background-color: #ffffff;
  padding-left: 36px;
  padding-right: 39px;
  padding-top: 11px;
  padding-bottom: 11px;
}
.nav_local_lv2 > li > a:after {
  position: absolute;
  right: 13px;
  top: 50%;
  margin-top: -4px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #f1881f;
  border-top: 2px solid #f1881f;
  transform: rotate(45deg);
}
.nav_local_lv2 > li > a:hover, .nav_local_lv2 > li > a:focus, .nav_local_lv2 > li > a.on {
  color: #f1881f;
}

.nav_local_lv3 > li {
  border-top: 1px solid #ffc66f;
}
.nav_local_lv3 > li > a {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 14px;
  line-height: 1.4;
  letter-spacing: 1.28px;
  text-align: left;
  color: #000000;
  text-decoration: none;
  background-color: #ffffff;
  padding-left: 52px;
  padding-right: 39px;
  padding-top: 11px;
  padding-bottom: 11px;
}
.nav_local_lv3 > li > a:after {
  position: absolute;
  right: 13px;
  top: 50%;
  margin-top: -4px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #f1881f;
  border-top: 2px solid #f1881f;
  transform: rotate(45deg);
}
.nav_local_lv3 > li > a:hover, .nav_local_lv3 > li > a:focus, .nav_local_lv3 > li > a.on {
  color: #f1881f;
}

.navbar .has_child {
  position: relative;
}
.navbar .has_child:hover .nav_child_wrap, .navbar .has_child:focus .nav_child_wrap {
  display: flex;
}
.navbar .nav_child_wrap {
  position: absolute;
  top: 100%;
  z-index: 100;
  display: none;
  width: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.navbar .nav_child_wrap.wide {
  left: 30%;
  transform: translateX(-20%);
}
.navbar .nav_child {
  width: 262px;
  background-color: #fff4e3;
  padding: 40px 16px;
  flex-shrink: 0;
}
.navbar .nav_child.double {
  width: 492px;
}
.navbar .nav_child.double dd {
  display: flex;
  margin-left: -16px;
  margin-right: -16px;
}
.navbar .nav_child dt {
  line-height: 1.25;
  border-bottom: 1px solid #000;
  padding-bottom: 12px;
  margin-bottom: 20px;
}
.navbar .nav_child dt a {
  font-size: 19px;
  color: #000;
  text-decoration: none;
  position: relative;
  display: flex;
  padding-right: 20px;
  align-items: center;
}
.navbar .nav_child dt a:after {
  position: relative;
  margin-left: auto;
  display: inline-block;
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #f1881f;
  border-right: 2px solid #f1881f;
  transform: rotate(45deg);
}
.navbar .nav_child dt a:hover, .navbar .nav_child dt a:focus {
  color: #f1881f;
}
.navbar .nav_child dd {
  line-height: 1.25;
  margin-top: 13px;
}
.navbar .nav_child dd ul {
  list-style: none;
  margin-bottom: 0;
  padding-left: 16px;
  padding-right: 16px;
  width: 240px;
}
.navbar .nav_child dd ul li {
  font-size: 16px;
  margin-top: 13px;
  line-height: 1.25;
}
.navbar .nav_child dd a {
  font-size: 16px;
  color: #000;
  text-decoration: none;
  position: relative;
  display: flex;
  align-items: center;
  padding-right: 20px;
}
.navbar .nav_child dd a:after {
  margin-left: auto;
  position: absolute;
  top: 0.4em;
  right: 0.5em;
  display: inline-block;
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #f1881f;
  border-right: 2px solid #f1881f;
  transform: rotate(45deg);
}
.navbar .nav_child dd a:hover, .navbar .nav_child dd a:focus {
  color: #f1881f;
}

.nav_page {
  margin-top: 60px;
}
.nav_page ul {
  padding-left: 0;
  margin-bottom: 0;
  display: flex;
  justify-content: center;
}
.nav_page ul li {
  display: flex;
  justify-content: center;
}
.nav_page ul li a {
  font-size: 0.8em;
  color: #f1881f;
  display: block;
  border: 1px solid #f1881f;
  text-decoration: none;
  padding: 4px 12px;
  transition: all 0.2s;
}
.nav_page ul li a:hover, .nav_page ul li a:focus {
  background: #f1881f;
  color: #fff;
}
.nav_page .link_index {
  margin-left: 1em;
  margin-right: 1em;
}

.paginatioin {
  margin-top: 60px;
  display: flex;
  font-size: 16px;
  justify-content: center;
}
.paginatioin span, .paginatioin a {
  display: block;
  width: 1em;
  font-size: 16px;
}

.nav_tag {
  margin-bottom: 30px;
}
.nav_tag ul {
  margin-left: -0.5em;
  margin-right: -0.5em;
  padding-left: 0;
  margin-bottom: 0;
  display: flex;
  flex-wrap: wrap;
}
.nav_tag ul li {
  padding-left: 0.5em;
  padding-right: 0.5em;
}
.nav_tag ul li a {
  display: inline-block;
  color: #fff;
  font-size: 0.8em;
  background: #f1881f;
  margin: 0 4px 4px 0;
  padding: 0 5px;
  text-decoration: none;
  border: 1px solid #f1881f;
  transition: all 0.2s;
}
.nav_tag ul li a:hover, .nav_tag ul li a:focus {
  color: #f1881f;
  background: #fff;
  border: 1px solid #f1881f;
}

.wp-pagenavi {
  margin-top: 60px;
  display: flex;
  justify-content: center;
  line-height: 2.4;
}
.wp-pagenavi span.current {
  border-color: #f1881f;
  background: #f1881f;
  color: #fff;
  padding: 0 10px;
}
.wp-pagenavi a {
  border-color: #f1881f;
  color: #f1881f;
  padding: 0 10px;
  transition: all 0.2s;
}
.wp-pagenavi a:hover, .wp-pagenavi a:focus {
  border-color: #f1881f;
  background: #f1881f;
  color: #fff;
}

a.page_top {
  width: 40px;
  height: 40px;
  background: #999;
  opacity: 0.6;
  display: block;
  text-decoration: none;
  z-index: 1000;
  position: relative;
  margin: 5px 0 0 10px;
}
@media screen and (max-width: 767px) {
  a.page_top {
    width: 10vw;
    height: 10vw;
    position: absolute;
    right: 1vw;
    bottom: 16vw;
    background: #999;
    opacity: 0.6;
    display: block;
    text-decoration: none;
    z-index: 1000;
    margin-right: 0;
  }
}
a.page_top:before {
  content: '';
  width: 20px;
  height: 20px;
  border: 2px solid;
  border-color: #fff #fff transparent transparent;
  transform: rotate(-45deg);
  display: inline-block;
  position: absolute;
  top: 0;
  bottom: -10px;
  left: 0;
  right: 0;
  margin: auto;
}
@media screen and (max-width: 767px) {
  a.page_top:before {
    width: 4vw;
    height: 4vw;
    top: 0;
    bottom: -2vw;
    left: 0;
    right: 0;
    margin: auto;
  }
}
a.page_top:hover, a.page_top:focus {
  oacity: 0.2;
  background: #ccc;
}
@media screen and (max-width: 767px) {
  a.page_top:hover, a.page_top:focus {
    oacity: 0.6;
    background: #999;
  }
}

/* Button */
.btn_brd_01 {
  display: inline-block;
  border: solid 1px #ff8401;
  background-color: #ffffff;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 1px;
  text-align: center;
  color: #ff8401;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
}
@media screen and (max-width: 767px) {
  .btn_brd_01 {
    font-size: 14px;
    padding: 3vw 6vw 3vw 4vw;
  }
}
.btn_brd_01:hover, .btn_brd_01:focus {
  background-color: #ff8401;
  color: #ffffff;
}
.btn_brd_01:hover:after, .btn_brd_01:focus:after {
  border-color: #ffffff;
}
.btn_brd_01:after {
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #ff8401;
  border-top: 2px solid #ff8401;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .btn_brd_01:after {
    right: 2vw;
  }
}

.btn_brd_02_blue {
  display: inline-block;
  border: solid 1px #00267f;
  background-color: #dff3fe;
  font-size: 16px;
  letter-spacing: 1.48px;
  text-align: center;
  color: #00267f;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
}
@media screen and (max-width: 767px) {
  .btn_brd_02_blue {
    font-size: 14px;
    padding: 3vw 6vw 3vw 4vw;
  }
}
.btn_brd_02_blue:hover, .btn_brd_02_blue:focus {
  background-color: #00267f;
  color: #ffffff;
}
.btn_brd_02_blue:hover:after, .btn_brd_02_blue:focus:after {
  border-color: #ffffff;
}
.btn_brd_02_blue:after {
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #00267f;
  border-top: 2px solid #00267f;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .btn_brd_02_blue:after {
    right: 2vw;
  }
}

.btn_brd_02_green {
  display: inline-block;
  border: solid 1px #1d7016;
  background-color: #e0f3df;
  font-size: 16px;
  letter-spacing: 1.48px;
  text-align: center;
  color: #1d7016;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
}
@media screen and (max-width: 767px) {
  .btn_brd_02_green {
    font-size: 14px;
    padding: 3vw 6vw 3vw 4vw;
  }
}
.btn_brd_02_green:hover, .btn_brd_02_green:focus {
  background-color: #1d7016;
  color: #ffffff;
}
.btn_brd_02_green:hover:after, .btn_brd_02_green:focus:after {
  border-color: #ffffff;
}
.btn_brd_02_green:after {
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #1d7016;
  border-top: 2px solid #1d7016;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .btn_brd_02_green:after {
    right: 2vw;
  }
}

.btn_brd_02_grey {
  display: inline-block;
  border: solid 1px #555;
  background-color: #fbfbfb;
  font-size: 16px;
  letter-spacing: 1px;
  text-align: center;
  color: #333;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
  padding: 10px 40px 10px 20px;
  position: relative;
  margin: 10px;
  width: calc(100% - 20px);
}
@media screen and (max-width: 767px) {
  .btn_brd_02_grey {
    font-size: 14px;
    padding: 3vw 6vw 3vw 4vw;
  }
}
.btn_brd_02_grey:hover, .btn_brd_02_grey:focus {
  background-color: #b1aeae;
}
.btn_brd_02_grey:after {
  transition: all 0.2s ease-in-out;
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  border-right: 2px solid #555;
  border-top: 2px solid #555;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1vw;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .btn_brd_02_grey:after {
    right: 2vw;
  }
}

.read_more {
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease-in-out;
}
.read_more.open {
  margin-bottom: 20px;
}
.read_more.open:after {
  height: 0;
  opacity: 0;
}
.read_more:after {
  transition: all 0.3s ease-out;
  position: absolute;
  display: block;
  width: 100%;
  left: 0;
  content: "";
  bottom: 0;
  background: linear-gradient(to top, #fff, rgba(255, 255, 255, 0.8) 66.6%, rgba(255, 255, 255, 0) 100%);
  height: 110px;
}

.btn_read_more {
  outline: none;
  cursor: pointer;
  position: relative;
  z-index: 10;
  display: flex;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  width: 272px;
  height: 54px;
  border: solid 0.7px #000000;
  background-color: #ffffff;
  font-size: 16px;
  padding: 0;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
}
.btn_read_more:hover, .btn_read_more:focus {
  border: solid 0.7px #f1881f;
  color: #f1881f;
}
@media screen and (max-width: 767px) {
  .btn_read_more {
    font-size: 16px;
    height: 45px;
  }
}
.btn_read_more i {
  display: block;
  font-style: normal;
  font-weight: bold;
  margin-right: 10px;
}

/* Typography */
.hd_sec_01 small {
  display: block;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.25;
  letter-spacing: 1.44px;
  color: #f1881f;
  text-align: center;
  margin-bottom: 5px;
  text-shadow: -1px -1px 0 #ffffff, 1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px 1px 0 #ffffff;
}
@media screen and (max-width: 767px) {
  .hd_sec_01 small {
    font-size: 12px;
  }
}
.hd_sec_01 h2 {
  margin: 0;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0.56px;
  text-align: center;
  color: #000000;
  margin-bottom: 30px;
  text-shadow: 0 0 1px #000 ,-1px -1px 0 #ffffff, 1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px 1px 0 #ffffff;
}
@media screen and (max-width: 767px) {
  .hd_sec_01 h2 {
    font-size: 24px;
  }
}
.hd_sec_01 p {
  text-shadow: 0 0 1px #000 ,-1px -1px 0 #ffffff, 1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px 1px 0 #ffffff;
  letter-spacing: 2px;
  font-size: 18px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .hd_sec_01 p {
    font-size: 4vw;
    text-align: left;
  }
}

.lead {
  margin-bottom: 30px;
  margin-top: 0;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 2px;
  text-align: left;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .lead {
    font-size: 16px;
  }
}

.h1 {
  margin-top: 0;
  margin-bottom: 45px;
  position: relative;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 2px;
  color: #f1881f;
  border-bottom: 3px double #ff8300;
  padding-bottom: 4px;
  padding-left: 29px;
}
@media screen and (max-width: 767px) {
  .h1 {
    padding-left: 18px;
    font-size: 24px;
    margin-bottom: 25px;
  }
}
.h1:before {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 5px;
  content: "";
  display: block;
  width: 6px;
  background-color: #ff8300;
}

.h2 {
  font-size: 26px;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 1.5px;
  text-align: left;
  color: #000000;
  margin: 80px 0 30px;
  border-bottom: 2px double #ccc;
}
@media screen and (max-width: 767px) {
  .h2 {
    font-size: 24px;
    margin-bottom: 20px;
  }
}
.h2:after {
  margin-top: 5px;
  display: block;
  content: "";
  background-image: linear-gradient(to top, #f1881f, #ff8401);
  width: 100%;
  height: 4px;
}
@media screen and (max-width: 767px) {
  .h2:after {
    height: 3px;
    background-image: linear-gradient(to top, #f1881f, #ff8401);
  }
}

.h3 {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 1.5px;
  text-align: left;
  color: #000000;
  margin: 80px 0 30px;
  border-bottom: 3px double #ccc;
}
@media screen and (max-width: 767px) {
  .h3 {
    font-size: 18px;
    margin-bottom: 20px;
  }
}
.h3:after {
  margin-top: 5px;
  display: block;
  content: "";
  background-image: linear-gradient(to top, #f1881f, #ff8401);
  width: 100%;
  height: 2px;
}
@media screen and (max-width: 767px) {
  .h3:after {
    height: 2px;
    background-image: linear-gradient(to top, #f1881f, #ff8401);
  }
}

.h4 {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 1px;
  text-align: left;
  color: #000000;
  margin: 80px 0 30px;
  border-bottom: 3px double #ccc;
}
@media screen and (max-width: 767px) {
  .h4 {
    font-size: 18px;
    margin-bottom: 20px;
  }
}
.h4:after {
  margin-top: 5px;
  display: block;
  content: "";
  background: #999;
  width: 100%;
  height: 2px;
}
@media screen and (max-width: 767px) {
  .h4:after {
    height: 2px;
    background: #999;
  }
}

.h5 {
  margin-top: 80px;
  margin-bottom: 30px;
  font-size: 20px;
  line-height: 1.4;
  letter-spacing: 1px;
  text-align: left;
  color: #000000;
  font-weight: bold;
  padding-top: 8px;
  padding-bottom: 6px;
  padding-left: 17px;
  padding-right: 17px;
  background-image: linear-gradient(-45deg, #ffffff 25%, #ffe8c5 25%, #ffe8c5 50%, #ffffff 50%, #ffffff 75%, #ffe8c5 75%, #ffe8c5);
  background-size: 5px 5px;
  background-attachment: fixed;
}
@media screen and (max-width: 767px) {
  .h5 {
    font-size: 20px;
    padding: 10px;
    margin-top: 50px;
  }
}

.h6 {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 1px;
  text-align: left;
  color: #01267f;
  border-left: 6px solid #01267f;
  padding-left: 8px;
  margin-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .h6 {
    font-size: 22px;
  }
}

.strong {
  position: relative;
  font-weight: bold;
  color: #000000;
}
.strong:after {
  position: absolute;
  bottom: -7px;
  height: 15px;
  left: -2px;
  right: -1px;
  display: inline-block;
  z-index: -1;
  content: "";
  background-color: #fff4e3;
}

/* Figure */
.fig_01 {
  display: flex;
  background-color: #eeeeee;
  padding: 26px 28px;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .fig_01 {
    display: block;
    padding: 25px 23px;
  }
}
.fig_01 > div {
  margin-right: 1em;
  max-width: 45%;
  min-width: 45%;
  text-align: center;
  height: auto;
  display: block;
}
.fig_01 > div > img {
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  .fig_01 figcaption {
    margin-top: 10px;
  }
}
.fig_01 figcaption dt {
  font-weight: bold;
  font-size: 19.5px;
}
@media screen and (max-width: 767px) {
  .fig_01 figcaption dt {
    font-size: 20px;
  }
}
@media screen and (max-width: 767px) {
  .fig_01 figcaption dd {
    font-size: 16px;
  }
}
.fig_01 figcaption dd a {
  color: #000000;
  text-decoration: none;
}
.fig_01 figcaption dd a:hover, .fig_01 figcaption dd a:focus {
  color: #fff;
}
.fig_01 figcaption dd.continue {
  display: flex;
  justify-content: flex-end;
}

.fig_02 {
  margin-bottom: 20px;
}
.fig_02 img {
  max-width: 100%;
  height: auto;
  transition: all 0.2s ease-in-out;
}
.fig_02 a:hover img, .fig_02 a:focus img {
  opacity: 0.85;
}
.fig_02 figcaption {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.46;
  letter-spacing: 2.24px;
  text-align: left;
  color: #000000;
  transition: all 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .fig_02 figcaption {
    font-size: 10px;
  }
}
.fig_02 figcaption span a {
  display: inline-block;
  color: #fff;
  background: #f1881f;
  margin: 0 4px 4px 0;
  padding: 1px 5px;
  text-decoration: none;
  border: 1px solid #f1881f;
  transition: all 0.2s;
}
.fig_02 figcaption span a:hover, .fig_02 figcaption span a:focus {
  color: #f1881f;
  background: #fff;
  border: 1px solid #f1881f;
}

a:hover .fig_02, a:focus .fig_02 {
  display: block;
}
a:hover .fig_02 figcaption, a:focus .fig_02 figcaption {
  color: #f1881f;
}
a:hover .fig_02 img, a:focus .fig_02 img {
  opacity: 0.85;
}

.gray_box {
  padding: 20px 30px;
  background: #f5f5f5;
  border: 1px solid #d2d2d2;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .gray_box {
    padding: 4vw 5vw;
  }
}

/* ------------------------------------------------------------------------------------------
* 4. Utility
* ----------------------------------------------------------------------------------------- */
/* Grid System */
:root {
  --gutter-width: 20px;
  --outer-margin: 2rem;
  --gutter-compensation: calc((var(--gutter-width) * 0.5) * -1);
  --half-gutter-width: calc((var(--gutter-width) * 0.5));
  --xs-min: 0;
  --sm_min: 768;
  --screen-xs-min: var(--xs-min)px;
  --screen-sm_min: var(--sm_min)px;
  --container-sm: calc(var(--sm_min) + var(--gutter-width));
}

@custom-media --sm-viewport only screen and (min-width: 768px);
.row {
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-direction: row;
  flex-wrap: wrap;
  margin-right: var(--gutter-compensation, -0.5rem);
  margin-left: var(--gutter-compensation, -0.5rem);
}

.row.reverse {
  flex-direction: row-reverse;
}

.col.reverse {
  flex-direction: column-reverse;
}

.col,
.col_1,
.col_2,
.col_3,
.col_4,
.col_5,
.col_6,
.col_7,
.col_8,
.col_9,
.col_10,
.col_11,
.col_12,
.col_offset_0,
.col_offset_1,
.col_offset_2,
.col_offset_3,
.col_offset_4,
.col_offset_5,
.col_offset_6,
.col_offset_7,
.col_offset_8,
.col_offset_9,
.col_offset_10,
.col_offset_11,
.col_offset_12 {
  box-sizing: border-box;
  flex: 0 0 auto;
  padding-right: var(--half-gutter-width, 0.5rem);
  padding-left: var(--half-gutter-width, 0.5rem);
}

.col {
  flex-grow: 1;
  flex-basis: 0;
  max-width: 100%;
}

.col_1 {
  flex-basis: 8.33333333%;
  max-width: 8.33333333%;
}

.col_2 {
  flex-basis: 16.66666667%;
  max-width: 16.66666667%;
}

.col_3 {
  flex-basis: 25%;
  max-width: 25%;
}

.col_4 {
  flex-basis: 33.33333333%;
  max-width: 33.33333333%;
}

.col_5 {
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}

.col_6 {
  flex-basis: 50%;
  max-width: 50%;
}

.col_7 {
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}

.col_8 {
  flex-basis: 66.66666667%;
  max-width: 66.66666667%;
}

.col_9 {
  flex-basis: 75%;
  max-width: 75%;
}

.col_10 {
  flex-basis: 83.33333333%;
  max-width: 83.33333333%;
}

.col_11 {
  flex-basis: 91.66666667%;
  max-width: 91.66666667%;
}

.col_12 {
  flex-basis: 100%;
  max-width: 100%;
}

.col_offset_0 {
  margin-left: 0;
}

.col_offset_1 {
  margin-left: 8.33333333%;
}

.col_offset_2 {
  margin-left: 16.66666667%;
}

.col_offset_3 {
  margin-left: 25%;
}

.col_offset_4 {
  margin-left: 33.33333333%;
}

.col_offset_5 {
  margin-left: 41.66666667%;
}

.col_offset_6 {
  margin-left: 50%;
}

.col_offset_7 {
  margin-left: 58.33333333%;
}

.col_offset_8 {
  margin-left: 66.66666667%;
}

.col_offset_9 {
  margin-left: 75%;
}

.col_offset_10 {
  margin-left: 83.33333333%;
}

.col_offset_11 {
  margin-left: 91.66666667%;
}

.start-xs {
  justify-content: flex-start;
  text-align: start;
}

.center-xs {
  justify-content: center;
  text-align: center;
}

.end-xs {
  justify-content: flex-end;
  text-align: end;
}

.top-xs {
  align-items: flex-start;
}

.middle-xs {
  align-items: center;
}

.bottom-xs {
  align-items: flex-end;
}

.around-xs {
  justify-content: space-around;
}

.between-xs {
  justify-content: space-between;
}

.first-xs {
  order: -1;
}

.last-xs {
  order: 1;
}

@media (min-width: 768px) {
  .col_sm,
  .col_sm_1,
  .col_sm_2,
  .col_sm_3,
  .col_sm_4,
  .col_sm_5,
  .col_sm_6,
  .col_sm_7,
  .col_sm_8,
  .col_sm_9,
  .col_sm_10,
  .col_sm_11,
  .col_sm_12,
  .col_sm_offset_0,
  .col_sm_offset_1,
  .col_sm_offset_2,
  .col_sm_offset_3,
  .col_sm_offset_4,
  .col_sm_offset_5,
  .col_sm_offset_6,
  .col_sm_offset_7,
  .col_sm_offset_8,
  .col_sm_offset_9,
  .col_sm_offset_10,
  .col_sm_offset_11,
  .col_sm_offset_12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: var(--half-gutter-width, 0.5rem);
    padding-left: var(--half-gutter-width, 0.5rem);
  }

  .col_sm {
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }

  .col_sm_1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col_sm_2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col_sm_3 {
    flex-basis: 25%;
    max-width: 25%;
  }

  .col_sm_4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col_sm_5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col_sm_6 {
    flex-basis: 50%;
    max-width: 50%;
  }

  .col_sm_7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col_sm_8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col_sm_9 {
    flex-basis: 75%;
    max-width: 75%;
  }

  .col_sm_10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col_sm_11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col_sm_12 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col_sm_offset_0 {
    margin-left: 0;
  }

  .col_sm_offset_1 {
    margin-left: 8.33333333%;
  }

  .col_sm_offset_2 {
    margin-left: 16.66666667%;
  }

  .col_sm_offset_3 {
    margin-left: 25%;
  }

  .col_sm_offset_4 {
    margin-left: 33.33333333%;
  }

  .col_sm_offset_5 {
    margin-left: 41.66666667%;
  }

  .col_sm_offset_6 {
    margin-left: 50%;
  }

  .col_sm_offset_7 {
    margin-left: 58.33333333%;
  }

  .col_sm_offset_8 {
    margin-left: 66.66666667%;
  }

  .col_sm_offset_9 {
    margin-left: 75%;
  }

  .col_sm_offset_10 {
    margin-left: 83.33333333%;
  }

  .col_sm_offset_11 {
    margin-left: 91.66666667%;
  }

  .start-sm {
    justify-content: flex-start;
    text-align: start;
  }

  .center-sm {
    justify-content: center;
    text-align: center;
  }

  .end-sm {
    justify-content: flex-end;
    text-align: end;
  }

  .top-sm {
    align-items: flex-start;
  }

  .middle-sm {
    align-items: center;
  }

  .bottom-sm {
    align-items: flex-end;
  }

  .around-sm {
    justify-content: space-around;
  }

  .between-sm {
    justify-content: space-between;
  }

  .first-sm {
    order: -1;
  }

  .last-sm {
    order: 1;
  }
}
/* Width */
.img_responsive {
  max-width: 100%;
  height: auto;
}

.img_full {
  width: 100%;
  height: auto;
}

/* Content Position */
.flex_ct_center {
  display: flex;
  justify-content: center;
}

.flex_ct_end {
  display: flex;
  justify-content: flex-end;
}

.flex_al_center {
  display: flex;
  justify-content: center;
}

/* Content Margin  */
.mt_0 {
  margin-top: 0px !important;
}

.mt_5 {
  margin-top: 5px !important;
}

.mt_10 {
  margin-top: 10px !important;
}

.mt_15 {
  margin-top: 15px !important;
}

.mt_20 {
  margin-top: 20px !important;
}

.mt_25 {
  margin-top: 25px !important;
}

.mt_30 {
  margin-top: 30px !important;
}

.mt_35 {
  margin-top: 35px !important;
}

.mt_40 {
  margin-top: 40px !important;
}

.mt_45 {
  margin-top: 45px !important;
}

.mt_50 {
  margin-top: 50px !important;
}

.mt_55 {
  margin-top: 55px !important;
}

.mt_60 {
  margin-top: 60px !important;
}

.mt_65 {
  margin-top: 65px !important;
}

.mt_70 {
  margin-top: 70px !important;
}

.mt_75 {
  margin-top: 75px !important;
}

.mt_80 {
  margin-top: 80px !important;
}

.mt_85 {
  margin-top: 85px !important;
}

.mt_90 {
  margin-top: 90px !important;
}

.mt_95 {
  margin-top: 95px !important;
}

.mt_100 {
  margin-top: 100px !important;
}

.mt_105 {
  margin-top: 105px !important;
}

.mt_110 {
  margin-top: 110px !important;
}

.mt_115 {
  margin-top: 115px !important;
}

.mt_120 {
  margin-top: 120px !important;
}

.mb_0 {
  margin-bottom: 0px !important;
}

.mb_5 {
  margin-bottom: 5px !important;
}

.mb_10 {
  margin-bottom: 10px !important;
}

.mb_15 {
  margin-bottom: 15px !important;
}

.mb_20 {
  margin-bottom: 20px !important;
}

.mb_25 {
  margin-bottom: 25px !important;
}

.mb_30 {
  margin-bottom: 30px !important;
}

.mb_35 {
  margin-bottom: 35px !important;
}

.mb_40 {
  margin-bottom: 40px !important;
}

.mb_45 {
  margin-bottom: 45px !important;
}

.mb_50 {
  margin-bottom: 50px !important;
}

.mb_55 {
  margin-bottom: 55px !important;
}

.mb_60 {
  margin-bottom: 60px !important;
}

.mb_65 {
  margin-bottom: 65px !important;
}

.mb_70 {
  margin-bottom: 70px !important;
}

.mb_75 {
  margin-bottom: 75px !important;
}

.mb_80 {
  margin-bottom: 80px !important;
}

.mb_85 {
  margin-bottom: 85px !important;
}

.mb_90 {
  margin-bottom: 90px !important;
}

.mb_95 {
  margin-bottom: 95px !important;
}

.mb_100 {
  margin-bottom: 100px !important;
}

.mb_105 {
  margin-bottom: 105px !important;
}

.mb_110 {
  margin-bottom: 110px !important;
}

.mb_115 {
  margin-bottom: 115px !important;
}

.mb_120 {
  margin-bottom: 120px !important;
}

@media screen and (min-width: 768px) {
  .mt_sm_0 {
    margin-top: 0px !important;
  }

  .mt_sm_5 {
    margin-top: 5px !important;
  }

  .mt_sm_10 {
    margin-top: 10px !important;
  }

  .mt_sm_15 {
    margin-top: 15px !important;
  }

  .mt_sm_20 {
    margin-top: 20px !important;
  }

  .mt_sm_25 {
    margin-top: 25px !important;
  }

  .mt_sm_30 {
    margin-top: 30px !important;
  }

  .mt_sm_35 {
    margin-top: 35px !important;
  }

  .mt_sm_40 {
    margin-top: 40px !important;
  }

  .mt_sm_45 {
    margin-top: 45px !important;
  }

  .mt_sm_50 {
    margin-top: 50px !important;
  }

  .mt_sm_55 {
    margin-top: 55px !important;
  }

  .mt_sm_60 {
    margin-top: 60px !important;
  }

  .mt_sm_65 {
    margin-top: 65px !important;
  }

  .mt_sm_70 {
    margin-top: 70px !important;
  }

  .mt_sm_75 {
    margin-top: 75px !important;
  }

  .mt_sm_80 {
    margin-top: 80px !important;
  }

  .mt_sm_85 {
    margin-top: 85px !important;
  }

  .mt_sm_90 {
    margin-top: 90px !important;
  }

  .mt_sm_95 {
    margin-top: 95px !important;
  }

  .mt_sm_100 {
    margin-top: 100px !important;
  }

  .mt_sm_105 {
    margin-top: 105px !important;
  }

  .mt_sm_110 {
    margin-top: 110px !important;
  }

  .mt_sm_115 {
    margin-top: 115px !important;
  }

  .mt_sm_120 {
    margin-top: 120px !important;
  }

  .mb_sm_0 {
    margin-bottom: 0px !important;
  }

  .mb_sm_5 {
    margin-bottom: 5px !important;
  }

  .mb_sm_10 {
    margin-bottom: 10px !important;
  }

  .mb_sm_15 {
    margin-bottom: 15px !important;
  }

  .mb_sm_20 {
    margin-bottom: 20px !important;
  }

  .mb_sm_25 {
    margin-bottom: 25px !important;
  }

  .mb_sm_30 {
    margin-bottom: 30px !important;
  }

  .mb_sm_35 {
    margin-bottom: 35px !important;
  }

  .mb_sm_40 {
    margin-bottom: 40px !important;
  }

  .mb_sm_45 {
    margin-bottom: 45px !important;
  }

  .mb_sm_50 {
    margin-bottom: 50px !important;
  }

  .mb_sm_55 {
    margin-bottom: 55px !important;
  }

  .mb_sm_60 {
    margin-bottom: 60px !important;
  }

  .mb_sm_65 {
    margin-bottom: 65px !important;
  }

  .mb_sm_70 {
    margin-bottom: 70px !important;
  }

  .mb_sm_75 {
    margin-bottom: 75px !important;
  }

  .mb_sm_80 {
    margin-bottom: 80px !important;
  }

  .mb_sm_85 {
    margin-bottom: 85px !important;
  }

  .mb_sm_90 {
    margin-bottom: 90px !important;
  }

  .mb_sm_95 {
    margin-bottom: 95px !important;
  }

  .mb_sm_100 {
    margin-bottom: 100px !important;
  }

  .mb_sm_105 {
    margin-bottom: 105px !important;
  }

  .mb_sm_110 {
    margin-bottom: 110px !important;
  }

  .mb_sm_115 {
    margin-bottom: 115px !important;
  }

  .mb_sm_120 {
    margin-bottom: 120px !important;
  }
}
/* Content Visibility  */
@media screen and (max-width: 767px) {
  .pc:not(html) {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .sp:not(html) {
    display: none;
  }
}
