@charset "UTF-8";
/* ===================================================================
CSS information

file name  : default.css
author	 : hagiwara
style info : 汎用リセット記述
=================================================================== */
html,
article,
aside,
audio,
blockquote,
body,
dd,
dialog,
div,
dl,
dt,
fieldset,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
input,
li,
mark,
menu,
nav,
ol,
p,
pre,
section,
td,
textarea,
th,
time,
ul,
video,
main {
  margin: 0;
  padding: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
  font-feature-settings: "palt";
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

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

caption,
th {
  text-align: left;
}

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

embed,
object {
  vertical-align: top;
}

hr,
legend {
  display: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
}

abbr,
acronym,
fieldset,
img {
  border: 0;
}

li {
  list-style-type: none;
}

sup {
  vertical-align: super;
  font-size: 0.5em;
}

img {
  vertical-align: top;
}

i {
  font-style: normal;
}

svg {
  vertical-align: middle;
}

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

nav,
ul {
  list-style: none;
}

/* ===================================================================
CSS information

file name  : common.css
author	   : hagiwara
style info : 基本・共通設定
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author	 : hagiwara
style info : 汎用設定
=================================================================== */
.mod-search, .p-footer, .topicpath {
  width: 90%;
  max-width: 1280px;
  margin: auto;
}
@media only screen and (max-width: 1199px) {
  .mod-search, .p-footer, .topicpath {
    width: 87.5%;
  }
}

.mod-search:after, .o_nav:after, .l-footer:after, .topicpath:after, .l-hero:after {
  content: "";
  display: table;
  clear: both;
}

body.active {
  height: 100%;
  overflow: hidden;
}

@font-face {
  font-display: swap;
  font-family: "Lato";
  font-style: normal;
  font-weight: 400;
  src: url("../webfonts/lato-v16-latin-regular.woff2") format("woff2"), url("../webfonts/lato-v16-latin-regular.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans CJK JP Regular"), local("NotoSansCJKjp-Regular"), local("NotoSansJP-Regular"), local("Noto Sans JP Regular"), url("../webfonts/noto-sans-jp-v28-latin-regular.woff2") format("woff2"), url("../webfonts/noto-sans-jp-v28-latin-regular.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
html {
  line-height: 1.5;
}

body {
  color: #444444;
  background: #ffffff;
  font-size: 18px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  body {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  body {
    font-size: 16px;
  }
}
body a {
  color: #444444;
  text-decoration: underline;
}
body a:hover {
  text-decoration: none;
}
body img {
  max-width: 100%;
  -webkit-touch-callout: none;
  line-height: 1;
}

body,
pre,
input,
textarea,
select {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "MS Ｐゴシック", "MS PGothic", "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  word-wrap: break-word;
  overflow-wrap: break-word;
  font-feature-settings: "palt";
}

input,
select,
textarea {
  font-size: 100%;
}

@media only screen and (max-width: 767px) {
  select {
    font-size: 16px;
  }
}

html.ie8 .view_tab,
html.ie8 .view_tab_sp,
html.ie8 .view_sp {
  display: none !important;
}
html.ie8 #abi_page {
  min-width: 1280px !important;
  margin: auto;
}

html.ie .ie_hidden {
  display: none;
}
html.ie .ie_show {
  display: block;
}

.ie_show {
  display: none;
}

@media only screen and (min-width: 1200px) {
  body .view_tab-sp,
  body .view_tab {
    display: none !important;
  }
}
@media print {
  body .view_tab-sp,
  body .view_tab {
    display: none !important;
  }
}
@media only screen and (min-width: 768px) {
  body .view_sp {
    display: none !important;
  }
}
@media only screen and (max-width: 1199px) {
  body .view_pc {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  body .view_pc-tab,
  body .view_tab {
    display: none !important;
  }
}

.mouse .over:hover, .touch .over.touchstart {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}
.touch .over {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.touch .over.touchend {
  transition-delay: 200ms;
}

#abi_page {
  overflow: hidden;
}
@media only screen and (min-width: 1200px) {
  #abi_page {
    width: 100%;
    margin: auto;
  }
}
@media print {
  #abi_page {
    width: 100%;
    margin: auto;
  }
}
@media only screen and (min-width: 768px) {
  #abi_page {
    font-size: 100% !important;
  }
}

.box_lang {
  position: relative;
  margin-left: 1em;
  border-bottom: 1px solid #fff;
}
.box_lang .accordion {
  text-align: center;
  cursor: pointer;
  transition: all 0.5s;
  font-weight: bold;
  color: #fff;
  padding: 0 28px 5px 0;
}
.box_lang .accordion:hover {
  opacity: 0.7;
}
.box_lang .accordion::before {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(135deg);
  position: absolute;
  top: 0;
  bottom: 8px;
  margin: auto;
  right: 0.25em;
}
.box_lang svg {
  margin-right: 10px;
  vertical-align: middle;
  width: 20px;
}
.box_lang ul.active {
  display: block;
}
.box_lang ul {
  z-index: 10000;
  position: absolute;
  left: 0;
  top: 2em;
  width: 100%;
  background: rgba(0, 0, 0, 0.4);
  display: none;
}
.box_lang ul li {
  width: 80%;
  margin: 0 auto;
}
.box_lang ul li:not(:last-child) a {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
.box_lang ul li a {
  text-decoration: none;
  color: #fff;
  padding: 0.5em 0;
  display: block;
  text-align: center;
  font-size: 14px;
}
.box_lang ul li a:hover {
  opacity: 0.6;
}

.l-header {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 10;
}
.p-header {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: auto;
  margin-top: 50px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-header {
    margin-top: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .p-header {
    margin-top: 30px;
  }
}
@media only screen and (min-width: 768px) {
  .p-header {
    max-width: 1920px;
    width: 93.2291666667%;
  }
}
@media only screen and (max-width: 767px) {
  .p-header {
    width: 85.4166666667%;
  }
}
@media only screen and (min-width: 768px) {
  .p-header__logo {
    max-width: 260px;
    width: calc(210px + 50 * (100vw - 767px) / 1153);
    margin-left: 1.5625%;
  }
}
@media only screen and (min-width: 1920px) {
  .p-header__logo {
    width: 260px;
  }
}
@media only screen and (max-width: 767px) {
  .p-header__logo {
    max-width: 160px;
    width: 100%;
    margin: auto;
  }
}
.p-header__logo_link {
  display: block;
  cursor: pointer;
  transition: all 0.3s ease;
}
.p-header__logo_link:hover:hover {
  opacity: 0.65;
}
.p-header__logo svg {
  width: 100%;
  fill: #ffffff;
}
.p-header__nav {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .p-header__nav {
    height: calc(65px + 20 * (100vw - 767px) / 1153);
  }
}
@media only screen and (min-width: 1920px) {
  .p-header__nav {
    height: 85px;
  }
}
.p-header__sns {
  display: flex;
  align-items: center;
  margin-right: 2em;
}
@media only screen and (min-width: 1561px) {
  .p-header__sns {
    font-size: 156%;
  }
}
@media print {
  .p-header__sns {
    font-size: 156%;
  }
}
@media only screen and (min-width: 1200px) and (max-width: 1560px) {
  .p-header__sns {
    font-size: 134%;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-header__sns {
    font-size: 112%;
  }
}
@media only screen and (max-width: 767px) {
  .p-header__sns {
    font-size: 89%;
  }
}
.p-header__sns_item:not(:first-of-type) {
  margin-left: 1.5em;
}
.p-header__sns_link {
  color: #ffffff;
  transition: all 0.3s ease;
}
.p-header__sns_link:hover {
  opacity: 0.6;
}
.p-header__rsrv {
  height: 100%;
}
@media only screen and (min-width: 768px) {
  .p-header__rsrv {
    margin-right: calc(15px + 15 * (100vw - 767px) / 1153);
  }
}
@media only screen and (min-width: 1920px) {
  .p-header__rsrv {
    margin-right: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .p-header__rsrv {
    margin-right: 20px;
  }
}
.p-header__menu {
  cursor: pointer;
}
@media only screen and (min-width: 768px) {
  .p-header__menu {
    height: 100%;
  }
}

.l-header.is-active {
  position: fixed;
  animation-name: fadeUpAnime1; /*アニメーションの定義名*/
  animation-duration: 1s; /*アニメーション変化時間 ※デフォルト*/
  animation-fill-mode: forwards; /*アニメーションの開始と終了時の状態を指定*/
  opacity: 0;
}
.l-header.is-active .p-header__logo, .l-header.is-active .p-header__sns {
  display: none;
}
.l-header.is-active .p-header__nav {
  position: absolute;
  top: 0;
  right: 0;
}
.l-header.is-active .p-header__nav .opener_icon_line {
  background: #444 !important;
}
.l-header.is-active .p-header__nav .opener_text {
  color: #444 !important;
}

@keyframes fadeUpAnime1 {
  from {
    opacity: 0;
    transform: translateY(-100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.l-hero {
  position: relative;
  overflow: hidden;
  margin: auto;
  z-index: 1;
}
.p-hero {
  position: relative;
  width: 100%;
  height: 100%;
}
.p-hero__lower {
  position: relative;
  width: 100%;
}
.p-hero__lower_copy {
  position: absolute;
  bottom: 10%;
  right: 0;
  left: 0;
  transform: translateY(-50%);
  padding: 0 8.8541666667%;
  color: #ffffff;
  z-index: 1;
}
.p-hero__lower_copy_en {
  font-family: modesto-text, serif;
  font-size: 528%;
  letter-spacing: 0.045em;
  font-weight: 300;
  font-style: normal;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-hero__lower_copy_en {
    font-size: 528%;
  }
}
@media only screen and (max-width: 767px) {
  .p-hero__lower_copy_en {
    font-size: 528%;
  }
}
@media only screen and (min-width: 768px) {
  .p-hero__lower_copy_en {
    font-size: calc(35px + 60 * (100vw - 767px) / 1153);
  }
}
@media only screen and (min-width: 1920px) {
  .p-hero__lower_copy_en {
    font-size: 528%;
  }
}
@media only screen and (max-width: 767px) {
  .p-hero__lower_copy_en {
    font-size: 195%;
  }
}
.p-hero__lower_copy_jp {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "MS Ｐゴシック", "MS PGothic", "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  letter-spacing: 0.3em;
  font-weight: 400;
  font-style: normal;
}
@media only screen and (min-width: 768px) {
  .p-hero__lower_copy_jp {
    font-size: calc(14px + 10 * (100vw - 767px) / 1153);
  }
}
@media only screen and (min-width: 1920px) {
  .p-hero__lower_copy_jp {
    font-size: 134%;
  }
}
@media only screen and (max-width: 767px) {
  .p-hero__lower_copy_jp {
    font-size: 78%;
  }
}
.p-hero__lower_image {
  position: relative;
}
.p-hero__lower_image:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  padding-top: 13.0208333333%;
  background: url(../images/header/mask.png) no-repeat 0 0/cover;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
  .p-hero__lower_image img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 40vh;
  }
}

@media only screen and (max-width: 767px) {
  #abi_page {
    padding-bottom: 65px;
  }
}

.topicpath {
  display: flex;
  align-items: center;
  padding: 1.5em 0;
  font-size: 89%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .topicpath {
    font-size: 78%;
  }
}
@media only screen and (max-width: 767px) {
  .topicpath {
    font-size: 67%;
  }
}
@media only screen and (min-width: 768px) {
  .topicpath {
    width: 82.2916666667%;
    max-width: 1580px;
  }
}
.topicpath li {
  position: relative;
  margin-left: 1.8em;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.topicpath li:first-child {
  margin-left: 0;
}
.topicpath li:last-child {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
.topicpath li:last-child:after {
  content: none;
}
.topicpath li:after {
  content: "/";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  margin-right: -1.25em;
  font-size: 94%;
}
.topicpath li a {
  text-decoration: underline;
}
.topicpath li a:hover {
  text-decoration: none;
}
.topicpath li a, .topicpath li > strong {
  font-weight: normal;
}
.topicpath li strong {
  display: inline-block;
  padding-bottom: 0.3em;
}

.l-footer {
  position: relative;
  color: #444444;
  background: url(../images/footer/img_footer.jpg) no-repeat 0 0/cover;
}
@media only screen and (min-width: 768px) {
  .l-footer {
    padding-top: 13.5416666667%;
  }
}
@media only screen and (max-width: 767px) {
  .l-footer {
    padding-top: 33.8983050847%;
  }
}
.l-footer:before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  padding-top: 12.65625%;
  background: url(../images/footer/mask.png) no-repeat 0 0/cover;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .p-footer {
    max-width: 1580px;
  }
}
.p-footer__logo {
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-footer__logo_link {
  display: block;
  transition: all 0.3s ease;
}
@media only screen and (min-width: 768px) {
  .p-footer__logo_link {
    width: calc(134px + 34 * (100vw - 767px) / 1153);
  }
}
@media only screen and (min-width: 1920px) {
  .p-footer__logo_link {
    width: 168px;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__logo_link {
    width: 100px;
  }
}
.p-footer__logo_link:hover {
  opacity: 0.8;
}
.p-footer__logo_link svg {
  display: block;
  width: 100%;
  fill: #444444;
}
.p-footer__content {
  position: relative;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .p-footer__content {
    padding-bottom: 8.8607594937%;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__content {
    padding-bottom: 18.2529335072%;
  }
}
.p-footer__name {
  margin-top: 2em;
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  font-size: 112%;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-footer__name {
    font-size: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__name {
    font-size: 89%;
  }
}
.p-footer__address {
  margin-top: 1.25em;
  font-size: 78%;
  letter-spacing: 0.1em;
  line-height: 2;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-footer__address {
    font-size: 73%;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__address {
    font-size: 67%;
  }
}
.p-footer__tel {
  margin-bottom: 1.25em;
  font-size: 78%;
  letter-spacing: 0.1em;
  line-height: 2;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-footer__tel {
    font-size: 73%;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__tel {
    font-size: 67%;
  }
}
.p-footer__sns {
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-footer__sns_item {
  font-size: 78%;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .p-footer__sns_item {
    font-size: 73%;
  }
}
@media only screen and (max-width: 767px) {
  .p-footer__sns_item {
    font-size: 67%;
  }
}
.p-footer__sns_item:not(:first-of-type) {
  border-left: 1px solid #dddddd;
}
.p-footer__sns_link {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.25em 1.8em;
  text-decoration: none;
  transition: all 0.3s ease;
}
.p-footer__sns_link:hover {
  opacity: 0.8;
}
.p-footer__sns_icon {
  font-size: 143%;
}
.p-footer__sns_text {
  margin-left: 0.6em;
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  text-transform: uppercase;
}
.copyright {
  width: 100%;
  padding: 2em 0;
  color: #ffffff;
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  font-size: 78%;
  font-weight: normal;
  letter-spacing: 0.1em;
  text-align: center;
  box-sizing: border-box;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .copyright {
    font-size: 73%;
  }
}
@media only screen and (max-width: 767px) {
  .copyright {
    font-size: 67%;
  }
}

.o_tbl {
  width: 100%;
  font-size: 84%;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .o_tbl {
    font-size: 78%;
  }
}
@media only screen and (max-width: 767px) {
  .o_tbl {
    font-size: 73%;
  }
}
@media only screen and (max-width: 767px) {
  .o_tbl tr {
    margin-bottom: 5px;
  }
}
.o_tbl tr th, .o_tbl tr td {
  position: relative;
  padding: 1em 1.5em;
  border-bottom: 1px solid #dddddd;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .o_tbl tr th, .o_tbl tr td {
    display: block;
    width: 100%;
  }
}
.o_tbl tr th {
  font-weight: normal;
}
@media only screen and (min-width: 768px) {
  .o_tbl tr th {
    min-width: 100px;
    width: 25%;
    border-bottom: 1px solid #bfbfbf;
  }
  .o_tbl tr th:before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #bfbfbf;
    z-index: 1;
  }
}
@media only screen and (max-width: 767px) {
  .o_tbl tr th {
    background-color: #dddddd;
    border: none;
  }
}
.o_tbl tr td {
  position: relative;
  border-bottom: 1px solid #dddddd;
}
@media only screen and (max-width: 767px) {
  .o_tbl tr td {
    padding-bottom: 10px;
  }
  .o_tbl tr td:after {
    content: none;
  }
}

.o_nav {
  position: relative;
  max-width: 1280px;
  width: 100%;
  font-size: 84%;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .o_nav {
    font-size: 78%;
  }
}
@media only screen and (max-width: 767px) {
  .o_nav {
    font-size: 73%;
  }
}
@media only screen and (min-width: 768px) {
  .o_nav {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.o_nav_item {
  position: relative;
}
.o_nav_link {
  display: block;
  padding: 1.25em 2em 1em 2em;
  text-decoration: none;
  border-left: 1px solid #dddddd;
  transition: all 0.3s ease;
}
.o_nav_link:before {
  content: "";
  opacity: 0;
  position: absolute;
  top: 3px;
  left: 50%;
  transform: translateX(-50%);
  width: 10px;
  height: 10px;
  background-color: #01a2bf;
  border-radius: 100%;
  z-index: 1;
  transition: all 0.3s ease;
}
.o_nav_link:hover:before {
  opacity: 1;
}
.o_nav_link span {
  display: inline-block;
  padding-top: 0.25em;
}

.opener {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .opener {
    width: 90px;
    height: 100%;
  }
}
.opener:hover .opener_icon_line.line1 {
  top: 2px;
}
.opener:hover .opener_icon_line.line3 {
  bottom: 2px;
}
.opener:hover .close .opener_icon_line.line1 {
  transform: rotate(40deg);
}
.opener:hover .close .opener_icon_line.line3 {
  transform: rotate(-40deg);
}
.opener_icon {
  position: relative;
  margin: auto;
}
@media only screen and (min-width: 768px) {
  .opener_icon {
    width: 40px;
    height: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .opener_icon {
    width: 24px;
    height: 12px;
  }
}
.opener_icon.close .opener_icon_line {
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  height: 1px;
  background-color: #444444;
  transition: all 0.3s ease;
}
.opener_icon.close .opener_icon_line.line1 {
  top: 50%;
  transform: rotate(45deg);
}
.opener_icon.close .opener_icon_line.line2 {
  width: 0;
  left: 50%;
  -webkit-transform: translateZ(0) scale(1, 1);
}
.opener_icon.close .opener_icon_line.line3 {
  top: 50%;
  transform: rotate(-45deg);
  width: 100%;
}
.opener_icon_line {
  display: block;
  position: absolute;
  right: 0;
  left: 0;
  height: 1px;
  background-color: #ffffff;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
  -webkit-backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
  -webkit-transform: translateZ(0) scale(1, 1);
}
.opener_icon_line.line1 {
  top: 0;
}
.opener_icon_line.line2 {
  top: 50%;
}
.opener_icon_line.line3 {
  bottom: 0;
}
.opener_icon_line.black {
  background-color: #444444;
}
.opener_text {
  display: block;
  margin-top: 0.5em;
  color: #ffffff;
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  font-size: 89%;
  letter-spacing: 0.1em;
  text-align: center;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .opener_text {
    font-size: 78%;
  }
}
@media only screen and (max-width: 767px) {
  .opener_text {
    font-size: 67%;
  }
}
.opener_text.black {
  color: #444444;
}

.l-snav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #ffffff;
  z-index: 10;
}
.l-snav.is-show {
  transform: translateZ(0);
}
.l-snav.is-hide {
  transform: translate3d(0, -100%, 0);
}
@media only screen and (min-width: 768px) and (max-width: 983px) {
  .l-snav {
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .l-snav {
    display: block;
  }
}
.p-snav {
  display: flex;
  justify-content: space-between;
}
.p-snav__page {
  display: flex;
  justify-content: space-between;
  width: calc(100% - 65px);
  color: #444444;
}
.p-snav__page_item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  font-size: 12px;
  text-align: center;
  line-height: 1;
}
.p-snav__page_anchor {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  color: #444444;
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  text-decoration: none;
}
.p-snav__page_anchor.page {
  letter-spacing: 0.16em;
}
.p-snav__page_anchor.rsrv {
  overflow: hidden;
  color: #ffffff;
  background: #df4a42;
  background: linear-gradient(to right, #df4a42 0%, #df7242 38%, #df8842 64%, #dfb142 100%);
  letter-spacing: 0.1em;
}
.p-snav__page_anchor.rsrv:hover:before {
  bottom: 0;
}
.p-snav__page_anchor.rsrv:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -60px;
  width: 100%;
  height: 60px;
  background: #2b2b2b;
  z-index: -1;
  transition: all 0.3s ease;
}
.p-snav__menu {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 65px;
  height: 65px;
  background: #444444;
  cursor: pointer;
  box-sizing: border-box;
  transition: all 0.3s ease;
}
.p-snav__menu_opener {
  width: 100%;
  height: 100%;
}

.mod-search {
  position: relative;
}
.mod-search .mod-search-tab {
  display: flex;
  justify-content: center;
  position: relative;
  margin-bottom: 60px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .mod-search .mod-search-tab {
    margin-bottom: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .mod-search .mod-search-tab {
    margin-bottom: 40px;
  }
}
.mod-search .mod-search-tab:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #dddddd;
}
.mod-search .mod-search-tab .tab-item {
  font-size: 89%;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .mod-search .mod-search-tab .tab-item {
    font-size: 78%;
  }
}
@media only screen and (max-width: 767px) {
  .mod-search .mod-search-tab .tab-item {
    font-size: 67%;
  }
}
@media only screen and (min-width: 768px) {
  .mod-search .mod-search-tab .tab-item {
    width: 39.0625%;
  }
}
@media only screen and (max-width: 767px) {
  .mod-search .mod-search-tab .tab-item {
    width: auto;
  }
}
.mod-search .mod-search-tab .tab-item:last-child {
  margin-left: 10px;
}
.mod-search .mod-search-tab .tab-item a {
  display: block;
  position: relative;
  padding: 1.3em 1em;
  background: #ececec;
  border: 1px solid #ececec;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  transition: all 0.5s ease;
}
.mod-search .mod-search-tab .tab-item a.is-active {
  background: #ffffff;
  border: 1px solid #dddddd;
}
.mod-search .mod-search-tab .tab-item a.is-active:before {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #ffffff;
}
.mod-search .mod-search-tab .tab-item a.is-active:hover {
  background: #ffffff;
}
.mod-search .mod-search-tab .tab-item a:hover {
  background: #ececec;
}
.mod-search .mod-search-body .body-item {
  display: none;
  box-sizing: border-box;
}
.mod-search .mod-search-body .body-item.is-active {
  display: block;
}

/* ===================================================================
CSS information

=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author	 : hagiwara
style info : 汎用設定
=================================================================== */
.topicpath, .p-footer, .mod-search {
  width: 90%;
  max-width: 1280px;
  margin: auto;
}
@media only screen and (max-width: 1199px) {
  .topicpath, .p-footer, .mod-search {
    width: 87.5%;
  }
}

.l-hero:after, .topicpath:after, .l-footer:after, .o_nav:after, .mod-search:after {
  content: "";
  display: table;
  clear: both;
}

.rsrv-btn {
  text-decoration: none;
}