@charset "UTF-8";
/* ======================================================================
 reset
====================================================================== */
html {
  overflow-y: scroll;
}

body {
  line-height: 1;
  color: #000;
}*/

/* html5doctor.com Reset Stylesheet v1.6.1
  Last Updated: 2010-09-17 Author: Richard Clark - http://richclarkdesign.com Twitter: @rich_clark */
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details,
dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup,
html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section,
small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
}

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

ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  background: transparent;
}

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

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

del {
  text-decoration: line-through;
}

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

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

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

input, select {
  vertical-align: middle;
}

/* YUI 3.4.1 (build 4118) Copyright 2011 Yahoo! Inc. All rights reserved.
Licensed under the BSD License. http://yuilibrary.com/license/ */ html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video,
input, select, textarea {
  box-sizing: border-box;
}

html {
  /* Sets a specific default `font-size` for user with `rem` type scales.*/
  font-size: 62.5%;
  /* Changes the default tap highlight to be completely transparent in iOS.*/
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
  color: #555;
  line-height: 1.6;
  background: #fff;
  font-family: "Noto Sans JP", 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Avenir, "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, sans-serif;
  font-weight: 400;
  min-width: 1040px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  body {
    min-width: auto;
  }
}

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

strong {
  font-weight: bold;
}

a {
  word-wrap: break-word;
  word-break: break-all;
}
a:link {
  color: #555;
  text-decoration: none;
  cursor: pointer;
}
a:visited {
  color: #555;
  text-decoration: none;
}
a:hover {
  color: #555;
  text-decoration: none;
  opacity: .8;
}
a:active {
  color: #555;
  text-decoration: none;
}

a[href^="tel"] {
  color: #555;
}

.contain {
  width: 1040px;
  min-width: 1040px;
  margin: 0 auto;
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .contain {
    width: auto;
    min-width: auto;
  }
}

/* input */
input, textarea, select {
  display: block;
  margin: 0;
  padding: 0;
  outline: none;
  border: none;
  border-image: none;
  background: transparent;
  font-family: inherit;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
input::-ms-expand, textarea::-ms-expand, select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

input:placeholder-shown, textarea:placeholder-shown {
  color: #555;
}
input::placeholder, textarea::placeholder {
  color: #555;
}
input:focus:placeholder-shown, textarea:focus:placeholder-shown {
  color: #555;
}
input:focus::placeholder, textarea:focus::placeholder {
  color: #555;
}

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

  .u_sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .u_pc {
    display: none;
  }

  .u_sp {
    display: block;
  }
}
@keyframes bottom-top {
  0% {
    transform: translateY(30px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes top-bottom {
  0% {
    transform: translateY(-30px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes big-small {
  0% {
    opacity: 0;
    transform: scale(1.25);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/* ======================================================================
 layout
====================================================================== */
/* =================================
 l_content_size
================================= */
.l_content_size_sp_1 {
  padding: 0 4%;
}
@media screen and (min-width: 1025px) {
  .l_content_size_sp_1 {
    max-width: 1040px;
    margin: 0 auto;
  }
}

.l_content_size_pc_1 {
  width: 1040px;
  min-width: 1040px;
  margin: 0 auto;
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .l_content_size_pc_1 {
    width: auto;
    min-width: auto;
    padding: 0 4%;
  }
}

.l_content_size_pc_1_850 {
  max-width: 850px;
  width: auto;
  min-width: auto;
}

/* =================================
 l_container
================================= */
.l_container {
  position: relative;
}

/* =================================
 l_header
================================= */
.l_header {
  box-shadow: 0px 0px 25px 0px rgba(0, 0, 0, 0.1);
  margin-bottom: 50px;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  width: 100%;
  border-bottom: 4px solid #4394d0;
}
@media screen and (max-width: 1024px) {
  .l_header {
    width: auto;
  }
}
.l_header .l_content_size_pc_1 {
  background-image: url(../img/common/capo_illust.png);
  background-position: bottom left 10px;
  background-repeat: no-repeat;
  padding-left: 121px;
  display: flex;
  align-items: center;
}
.l_header .logo {
  margin-right: auto;
  margin-top: 10px;
}
.l_header .logo_small {
  display: none;
}
.l_header .gNav {
  display: flex;
  font-size: 1.6rem;
}
.l_header .gNav a, .l_header .gNav .current span {
  padding: 40px 1em;
  display: block;
  transition: padding 0.3s;
}
.l_header .gNav a {
  color: #555;
  transition: color 0.3s, padding 0.3s;
}
.l_header .gNav a:hover {
  color: #4394d0;
  opacity: 1;
}
.l_header .gNav .current a, .l_header .gNav .current span {
  color: #4394d0;
  border-bottom: 4px solid #4394d0;
}
.l_header.smaller .l_content_size_pc_1 {
  background-size: 66px auto;
  padding-left: 92px;
}
.l_header.smaller .logo_default {
  display: none;
}
.l_header.smaller .logo_small {
  display: block;
}
.l_header.smaller .gNav a, .l_header.smaller .gNav .current span {
  padding: 24px 1em;
  display: block;
}

/* =================================
 l_header_sp
================================= */
.l_header_sp {
  box-shadow: 0px 0px 16px 0px rgba(0, 0, 0, 0.1);
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  width: 100%;
  transition: transform .5s;
  border-bottom: 2px solid #4394d0;
}
.l_header_sp.hide {
  transform: translateY(-100%);
}
.l_header_sp .l_content_size_pc_1 {
  display: flex;
  align-items: center;
  padding: 0 0 0 70px;
  justify-content: space-between;
  background-image: url(../img/common/sp/capo_illust.png);
  background-position: bottom left 15px;
  background-repeat: no-repeat;
  background-size: 43.5px 45px;
}
.l_header_sp .logo {
  width: 83.5px;
  margin-top: 4px;
}
.l_header_sp #toggle {
  width: 50px;
  height: 50px;
  padding-top: 18px;
}
@media screen and (max-width: 768px) {
  .l_header_sp #toggle {
    display: flex;
    justify-content: center;
  }
}
.l_header_sp #toggle > div {
  width: 20px;
  position: relative;
}
.l_header_sp #toggle span {
  width: 100%;
  height: 2px;
  left: 0;
  display: block;
  background: #4394d0;
  position: absolute;
  transition: transform .6s ease-in-out, top .5s ease, -webkit-transform .6s ease-in-out;
}
.l_header_sp #toggle span:nth-of-type(1) {
  top: 0;
}
.l_header_sp #toggle span:nth-of-type(2) {
  top: 6px;
}
.l_header_sp #toggle span:nth-of-type(3) {
  top: 12px;
}
.l_header_sp.active #toggle span:nth-of-type(1) {
  top: 7px;
  transform: rotate(45deg);
}
.l_header_sp.active #toggle span:nth-of-type(2) {
  top: 7px;
  width: 0;
  left: 50%;
}
.l_header_sp.active #toggle span:nth-of-type(3) {
  top: 7px;
  transform: rotate(-45deg);
}

/* =================================
 l_menu_sp
================================= */
.l_menu_sp {
  display: none;
  position: fixed;
  background: #fff;
  width: 100%;
}
.l_menu_sp .gNav {
  border-top: 1px solid rgba(0, 0, 0, 0.15);
}
.l_menu_sp .gNav li {
  text-align: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
.l_menu_sp .gNav a {
  font-size: 1.4rem;
  font-weight: 500;
  display: block;
  padding: 15px 10px;
}
.l_menu_sp .gNav a:link, .l_menu_sp .gNav a:visited, .l_menu_sp .gNav a:hover, .l_menu_sp .gNav a:active {
  color: #4394d0;
}

/* =================================
 l_breadcrumbs
================================= */
/* =================================
 l_main_visual
================================= */
/* =================================
 l_content
================================= */
/* =================================
 l_main
================================= */
/* =================================
 l_side
================================= */
.l_side {
  background: #ededed;
  padding: 70px 0;
}
.l_side ul {
  display: flex;
  justify-content: space-between;
}

/* =================================
 l_footer
================================= */
.l_footer .footer_top {
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
@media screen and (max-width: 768px) {
  .l_footer .footer_top {
    border-bottom: none;
  }
}
.l_footer .footer_top-list {
  display: flex;
  justify-content: center;
  padding: 34px 0;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_top-list {
    display: block;
    text-align: center;
    border-top: 1px solid rgba(0, 0, 0, 0.15);
    margin: 20px 0 18px;
    padding: 0;
  }
}
.l_footer .footer_top a {
  font-size: 1.6rem;
  font-weight: 500;
}
.l_footer .footer_top a:link, .l_footer .footer_top a:visited, .l_footer .footer_top a:hover, .l_footer .footer_top a:active {
  color: #4394d0;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_top a {
    padding: 15px 10px;
    font-size: 1.4rem;
    display: block;
    font-weight: 500;
  }
}
@media screen and (max-width: 768px) {
  .l_footer .footer_top li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.15);
  }
}
.l_footer .footer_top li + li {
  margin-left: 4em;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_top li + li {
    margin-left: 0;
  }
}
.l_footer .footer_middle-list {
  display: flex;
  justify-content: center;
  padding: 30px 0;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_middle-list {
    flex-wrap: wrap;
    padding: 0 0 75px;
    line-height: 2.916;
  }
}
.l_footer .footer_middle a {
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_middle a {
    font-size: 1.2rem;
  }
}
.l_footer .footer_middle a:link, .l_footer .footer_middle a:visited, .l_footer .footer_middle a:hover, .l_footer .footer_middle a:active {
  color: #999;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_middle li {
    margin-left: 1em;
    margin-right: 1em;
  }
}
.l_footer .footer_middle li + li {
  margin-left: 2em;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_middle li + li {
    margin-left: 0;
  }
}
.l_footer .footer_bottom {
  background: #4394d0;
  padding: 44px 0;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_bottom {
    padding: 4vw 0;
  }
}
.l_footer .footer_bottom .l_content_size_pc_1 {
  display: flex;
  align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_bottom .l_content_size_pc_1 {
    display: block;
  }
}
.l_footer .footer_bottom-right {
  margin-left: auto;
  text-align: right;
}
.l_footer .footer_capo {
  position: absolute;
  top: -115px;
  left: 48px;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_capo {
    width: calc(119/750*100vw);
    top: -19vw;
    left: 0;
    right: 0;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .l_footer .footer_logo {
    text-align: center;
    width: calc(191/750*100vw);
    margin: 0 auto 13px;
  }
}
.l_footer .footer_address {
  color: #fff;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_address {
    text-align: center;
    font-size: 1.1rem;
    margin-bottom: 4px;
  }
}
.l_footer .footer_copy {
  color: rgba(255, 255, 255, 0.6);
  font-size: 1.1rem;
}
@media screen and (max-width: 768px) {
  .l_footer .footer_copy {
    text-align: center;
    font-size: .9rem;
  }
}

@media screen and (max-width: 768px) {
  .footer_bg .l_content_size_pc_1 {
    padding: 0;
  }
}
.footer_bg figure {
  margin-left: -361px;
  margin-right: -360px;
}
@media screen and (max-width: 768px) {
  .footer_bg figure {
    margin-left: 0;
    margin-right: 0;
  }
}

/* =================================
 l_hoge
================================= */
/* ======================================================================
 layout p_top
====================================================================== */
/* =================================
 l_container_top
================================= */
.l_container_top {
  position: relative;
}

/* =================================
 l_header_top
================================= */
/* =================================
 l_header_sp_top
================================= */
/* =================================
 l_main_visual_top
================================= */
/* =================================
 l_content_top
================================= */
/* =================================
 l_main_top
================================= */
/* =================================
 l_side_top
================================= */
/* =================================
 l_footer_top
================================= */
/* =================================
 l_hoge_top
================================= */
.alpha {
  font-family: "Lato", sans-serif;
}

.content_ttl {
  font-size: 1.6rem;
  color: #999;
  text-align: center;
  padding: 75px 0 0;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .content_ttl {
    font-size: calc(24/750*100vw);
    padding-top: 40px;
  }
}
.content_ttl .alpha {
  font-size: 3.4rem;
  color: #4394d0;
  letter-spacing: 6px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .content_ttl .alpha {
    font-size: calc(55/750*100vw);
    letter-spacing: 4px;
  }
}

.btn {
  text-align: center;
  margin: 50px auto 20px;
}
@media screen and (max-width: 768px) {
  .btn {
    margin: 30px auto 10px;
  }
}
.btn a {
  display: block;
  width: 300px;
  height: 50px;
  background: #999;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 500;
  border-radius: 25px;
  line-height: 50px;
  margin: 0 auto;
  transition: background 0.3s;
}
@media screen and (max-width: 768px) {
  .btn a {
    font-size: 1.4rem;
  }
}
.btn a:link, .btn a:visited, .btn a:hover, .btn a:active {
  color: #fff;
}
.btn a:hover {
  opacity: 1;
  background: #4394d0;
}

.subcon_ttl {
  text-align: center;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1;
  margin: 210px 0 95px;
}
@media screen and (max-width: 768px) {
  .subcon_ttl {
    font-size: calc(50/750*100vw);
    margin: 150px 0 40px;
  }
}
@media screen and (max-width: 500px) {
  .subcon_ttl {
    margin: 90px 0 40px;
  }
}
.subcon_ttl .alpha {
  font-size: 2rem;
  font-weight: 400;
  color: #999;
  letter-spacing: 3px;
}
@media screen and (max-width: 768px) {
  .subcon_ttl .alpha {
    letter-spacing: 2px;
    font-size: calc(26/750*100vw);
  }
}

.c_btn_p_top {
  position: fixed;
  bottom: 50px;
  right: 50px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .c_btn_p_top {
    width: calc(90/750*100vw);
    bottom: 15px;
    right: 15px;
  }
}

.news {
  background: #f6f6f6;
  padding-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .news {
    padding-bottom: 30px;
  }
}
.news_tab {
  display: flex;
  justify-content: center;
  padding: 70px 0 50px;
}
@media screen and (max-width: 768px) {
  .news_tab {
    padding: 30px 0 40px;
    max-width: 260px;
    margin-right: auto;
    margin-left: auto;
  }
}
.news_tab li {
  border-right: 1px solid rgba(0, 0, 0, 0.15);
  font-size: 1.4rem;
  text-align: center;
  padding: 0 20px 12px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .news_tab li {
    width: 33.3333%;
    padding: 10px 0 8px;
    font-size: 1.2rem;
  }
  .news_tab li:first-child figure {
    padding-left: 20px;
    padding-right: 20px;
  }
}
.news_tab li .on {
  display: none;
}
.news_tab li.active {
  color: #4394d0;
  position: relative;
}
.news_tab li.active:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 13%;
  width: 74%;
  height: 2px;
  background: #4394d0;
}
.news_tab li.active:after {
  content: "";
  position: absolute;
  bottom: -14px;
  left: calc(50% - 4px);
  border: 5px solid transparent;
  border-top: 10px solid #4394d0;
}
.news_tab li.active .on {
  display: block;
}
.news_tab li.active .off {
  display: none;
}
.news_tab li:first-of-type {
  border-left: 1px solid rgba(0, 0, 0, 0.15);
}
.news_tab li figure {
  width: 112px;
  height: 56px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .news_tab li figure {
    width: auto;
    padding: 0 28px 10px;
  }
}
.news_list {
  display: none;
}
.news_list__subttl {
  text-align: center;
  color: #4394d0;
  font-size: 1.6rem;
  margin: 50px 0 44px;
}
@media screen and (max-width: 768px) {
  .news_list__subttl {
    font-size: 1.5rem;
    margin: 20px 0 15px;
  }
}
.news_list__subttl span {
  position: relative;
  display: inline-block;
}
.news_list__subttl span:before {
  position: absolute;
  top: 50%;
  left: -310px;
  content: '';
  height: 1px;
  width: 300px;
  background-color: #d1d1d1;
}
@media screen and (max-width: 768px) {
  .news_list__subttl span:before {
    width: 100px;
    left: -110px;
  }
}
.news_list__subttl span:after {
  position: absolute;
  top: 50%;
  right: -310px;
  content: '';
  height: 1px;
  width: 300px;
  background-color: #d1d1d1;
}
@media screen and (max-width: 768px) {
  .news_list__subttl span:after {
    width: 100px;
    right: -110px;
  }
}
.news_list > p {
  font-size: 1.6rem;
  margin: 1em 0;
  text-align: center;
  width: 100%;
}
.news_list.top_news_list {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 769px) {
  .news_list.top_news_list .news_box:nth-child(4) {
    display: none;
  }
}
.news_list.is-show {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .news_list {
    margin-right: -7.5px;
    margin-left: -7.5px;
  }
}
.news_box {
  background: #fff;
  box-shadow: 0px 3px 25px 0px rgba(0, 0, 0, 0.06);
  border-radius: 10px;
  overflow: hidden;
  width: 310px;
  margin-bottom: 35px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .news_box {
    width: calc(50% - 15px);
    margin-right: 7.5px;
    margin-left: 7.5px;
    margin-bottom: 15px;
    box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.06);
    border-radius: 5px;
  }
}
@media screen and (min-width: 769px) {
  .news_box:nth-of-type(3n - 1), .news_box:nth-of-type(3n) {
    margin-left: 35px;
  }
}
.news_box a {
  transition: opacity 0.3s;
}
.news_box a:hover .news_img {
  opacity: .8;
}
.news_box dl {
  padding: 35px 20px 65px;
}
@media screen and (max-width: 768px) {
  .news_box dl {
    padding: 22px 10px 40px;
  }
}
.news_box dt {
  font-size: 1.6rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .news_box dt {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
.news_box dd {
  font-size: 1.4rem;
  color: #999;
  position: absolute;
  right: 20px;
  bottom: 30px;
}
@media screen and (max-width: 768px) {
  .news_box dd {
    right: 10px;
    bottom: 12px;
    font-size: 1.1rem;
  }
}
.news_img {
  position: relative;
  border-bottom: 1px solid #eee;
  width: 310px;
  height: 181px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .news_img {
    width: 100%;
    height: 30vw;
    height: calc(30vw + 1px);
  }
}
.news_img img.attachment-post-thumbnail {
  width: 310px;
  height: 180px;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}
@media screen and (max-width: 768px) {
  .news_img img.attachment-post-thumbnail {
    width: 100%;
    height: 30vw;
  }
}
.news_tag {
  position: absolute;
  left: 20px;
  bottom: -11px;
  background: #4394d0;
  color: #fff;
  font-size: 1.3rem;
  border-radius: 3px;
  width: 94px;
  height: 26px;
  text-align: center;
  line-height: 26px;
}
@media screen and (max-width: 768px) {
  .news_tag {
    left: 10px;
    font-size: 1.1rem;
    width: 60px;
    height: 20px;
    line-height: 20px;
  }
}
.news_tag.news_tag_color_event {
  background-color: #317eec;
}
.news_tag.news_tag_color_news {
  background-color: #56ccac;
}
.news .btn {
  margin-top: 15px;
}

.p_page section {
  padding: 0 0 70px;
}
@media screen and (max-width: 768px) {
  .p_page section {
    padding: 0 0 70px;
  }
}
.p_page section h2 {
  font-size: 2.2rem;
  margin-top: 2em;
  margin-bottom: .5em;
  border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 768px) {
  .p_page section h2 {
    font-size: 2.0rem;
    margin-top: 1.2em;
  }
}
.p_page section h3 {
  margin-bottom: 1.5em;
  padding-bottom: .25em;
  font-weight: 500;
  font-size: 2.0rem;
  margin-top: 2em;
  border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 768px) {
  .p_page section h3 {
    font-size: 1.8rem;
    margin-bottom: .8em;
    margin-top: 1.2em;
  }
}
.p_page section h4 {
  font-size: 1.6rem;
  margin-top: 2em;
  margin-bottom: .25em;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .p_page section h4 {
    margin-top: 1.2em;
  }
}
.p_page section p {
  font-size: 1.4rem;
  line-height: 1.7;
}
.p_page section ul li {
  font-size: 1.4rem;
  padding-left: 1.7em;
  text-indent: -1.5em;
  margin-bottom: .4em;
}
@media screen and (max-width: 768px) {
  .p_page section ul li {
    padding-left: 1.2em;
    text-indent: -1.2em;
  }
}
.p_page section ul li:last-child {
  margin-bottom: 0;
}
.p_page section ul li:before {
  content: "● ";
  color: #aaa;
  font-size: 1.2rem;
  padding: 0 .5em 0 0;
}
@media screen and (max-width: 768px) {
  .p_page section ul li:before {
    font-size: 1.1rem;
    padding-right: .2em;
  }
}
.p_page section table {
  font-size: 1.4rem;
}
.p_page section table th {
  padding: 10px;
  border: 1px solid #eee;
}
.p_page section table td {
  padding: 10px;
  border: 1px solid #eee;
}
.p_page section .MB0 {
  margin-bottom: 0;
}
.p_page .contact .contact-lead.bg_gray {
  margin-bottom: 30px;
  margin-right: auto;
  margin-left: auto;
  font-size: 1.8rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .p_page .contact .contact-lead.bg_gray {
    text-align: center;
    font-size: 1.4rem;
  }
}
.p_page .contact dl {
  display: flex;
  border-bottom: 1px solid #d9d9d9;
  padding-bottom: 20px;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .p_page .contact dl {
    display: block;
    padding-bottom: 15px;
    margin-bottom: 15px;
  }
}
.p_page .contact dl dt {
  width: 200px;
  margin-right: 15px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .p_page .contact dl dt {
    width: 100%;
    margin-bottom: 8px;
  }
}
.p_page .contact dl dt span {
  display: inline-block;
  background-color: #B50908;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 400;
  padding: 2px 5px;
  border-radius: 1px;
  margin-left: 10px;
}
@media screen and (max-width: 768px) {
  .p_page .contact dl dt span {
    font-size: 1.2rem;
  }
}
.p_page .contact dl dd {
  font-size: 1.6rem;
  width: calc(100% - 215px);
}
@media screen and (max-width: 768px) {
  .p_page .contact dl dd {
    width: 100%;
  }
}
.p_page .contact dl dd textarea,
.p_page .contact dl dd input[type="text"],
.p_page .contact dl dd input[type="email"] {
  width: 100%;
  background-color: #FCF9E7;
  border-radius: 3px;
  border: 1px solid #DCDCDC;
  padding: 10px 15px;
  font-size: 1.6rem;
}
.p_page .contact dl dd .error {
  font-size: 1.6rem;
}
.p_page .contact .contact-contents-privacy {
  margin-bottom: 1em;
  font-size: 1.6rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .p_page .contact .contact-contents-privacy {
    font-size: 1.4rem;
  }
}
.p_page .contact .contact-contents-privacy a {
  text-decoration: underline;
}
.p_page .contact .mwform-checkbox-field {
  text-align: center;
}
.p_page .contact .mwform-checkbox-field .mwform-checkbox-field-text {
  font-size: 1.6rem;
  position: relative;
  padding-left: 1.5em;
}
@media screen and (max-width: 768px) {
  .p_page .contact .mwform-checkbox-field .mwform-checkbox-field-text {
    font-size: 1.4rem;
  }
}
.p_page .contact .mwform-checkbox-field input[type="checkbox"] + span:before {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  border-radius: 3px;
  transform: translateY(-50%);
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  width: .9em;
  height: .9em;
  display: block;
}
.p_page .contact .mwform-checkbox-field input[type="checkbox"]:checked + span:after {
  position: absolute;
  content: '';
  top: .5em;
  left: .15em;
  width: .65em;
  height: .2em;
  border-left: 2px solid #DA1514;
  border-bottom: 2px solid #DA1514;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.p_page .contact .mwform-checkbox-field input[type="checkbox"] {
  position: absolute;
  left: -1000em;
}
.p_page .contact .mwform-checkbox-field label {
  font-weight: normal;
  margin-bottom: 0;
}
.p_page .contact .mw_wp_form_confirm .contact-contents-privacy,
.p_page .contact .mw_wp_form_confirm .contact-contents-consent {
  display: none;
}
.p_page .contact .contact-contents-btn,
.p_page .contact .contact-contents-btn-back {
  text-align: center;
}
.p_page .contact .contact-contents-btn input,
.p_page .contact .contact-contents-btn-back input {
  display: inline-block;
  width: 300px;
  height: 50px;
  background: #999;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 500;
  border-radius: 25px;
  line-height: 50px;
  margin: 30px 10px 0;
  transition: background 0.3s;
}
.p_page .contact .contact-contents-btn input:hover,
.p_page .contact .contact-contents-btn-back input:hover {
  opacity: .8;
}
.p_page .contact .contact-contents-btn input {
  background: #4394d0;
}
.p_page .contact .contact-contents-btn input:hover {
  opacity: .8;
}
.p_page .contact .contact-contents-btn input:disabled {
  background: #999;
}
.p_page .contact .contact-contents-btn input:disabled:hover {
  opacity: 1;
}
@media screen and (min-width: 769px) {
  .p_page .contact .contact-btn-wrap {
    display: flex;
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .p_page .contact .contact-btn-wrap input {
    margin-top: 20px;
  }
}
.p_page .sitemap ul {
  display: flex;
  flex-wrap: wrap;
}
.p_page .sitemap ul li {
  width: 33.3333%;
  margin-top: .5em;
}
.p_page .sitemap ul li:before {
  content: '・';
}
@media screen and (max-width: 768px) {
  .p_page .sitemap ul li {
    width: auto;
    margin-right: 1em;
  }
}
.p_page .sitemap .sitemap_wrap {
  margin: 40px 0 0;
  display: flex;
  flex-wrap: wrap;
}
.p_page .sitemap .sitemap_wrap h3 {
  border: none;
  width: 33.3333%;
  margin: 0;
  font-size: 1.8rem;
}
.p_page .sitemap .sitemap_other {
  margin-top: 50px;
}
.p_page .faq {
  margin-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .p_page .faq {
    margin-bottom: 70px;
  }
}
.p_page .faq p {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .p_page .faq p {
    text-align: left;
    font-size: 1.4rem;
  }
}
.p_page .faq dl {
  border-bottom: #d9d9d9 1px solid;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .p_page .faq dl {
    margin-bottom: 16px;
  }
}
.p_page .faq dl:last-child {
  margin-bottom: 0;
}
.p_page .faq dl dt {
  position: relative;
  font-size: 2.0rem;
  padding: 8px 1.2em 8px 52px;
  margin-bottom: 1em;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .p_page .faq dl dt {
    font-size: 1.6rem;
    padding: 6px 1.5em 6px 40px;
  }
}
.p_page .faq dl dt:before {
  content: 'Q';
  background-color: #5b7fd8;
  width: 40px;
  height: 40px;
  border-radius: 2px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 4px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .p_page .faq dl dt:before {
    width: 30px;
    height: 30px;
  }
}
.p_page .faq dl dt:after {
  font-family: "Font Awesome 5 Free";
  font-weight: 400;
  content: "\f0fe";
  position: absolute;
  top: .5em;
  right: 0;
  color: #999;
}
.p_page .faq dl dt.open:after {
  font-family: "Font Awesome 5 Free";
  font-weight: 400;
  content: "\f146";
}
.p_page .faq dl dd {
  position: relative;
  font-size: 1.6rem;
  padding-left: 52px;
  padding-top: 12px;
  padding-bottom: 40px;
  display: none;
}
@media screen and (max-width: 768px) {
  .p_page .faq dl dd {
    font-size: 1.4rem;
    padding-left: 40px;
    padding: 8px 0px 20px 40px;
  }
}
.p_page .faq dl dd:before {
  font-size: 2rem;
  content: 'A';
  background-color: #e95272;
  width: 40px;
  height: 40px;
  border-radius: 2px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 4px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .p_page .faq dl dd:before {
    width: 30px;
    height: 30px;
  }
}
.p_page .about {
  padding-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .p_page .about {
    padding-bottom: 70px;
  }
}
.p_page .about-img {
  padding: 50px 0;
  background-color: #f6f6f6;
  margin-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .p_page .about-img {
    padding: 30px 0;
    margin-bottom: 40px;
  }
}
.p_page .about-img p {
  padding: 30px 10px 0;
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .p_page .about-img p {
    padding: 20px 0 0;
    font-size: 1.4rem;
  }
}
.p_page .about h4 {
  font-size: 2.4rem;
  margin-bottom: .8em;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  .p_page .about h4 {
    font-size: 1.6rem;
    text-align: center;
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 769px) {
  .p_page .about .about-concept {
    display: flex;
    align-items: center;
  }
}
@media screen and (min-width: 769px) {
  .p_page .about .about-concept .about-concept-txt {
    padding: 0 0 0 40px;
    width: calc(100% - 400px);
  }
}
.p_page .about .about-concept .about-concept-txt p {
  font-size: 1.4rem;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .p_page .about .about-concept .about-concept-txt p {
    font-size: 1.4rem;
    line-height: inherit;
  }
}
.p_page .about .about-concept figure {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .p_page .about .about-concept figure {
    margin-bottom: 30px;
  }
  .p_page .about .about-concept figure img {
    width: 80%;
  }
}
@media screen and (min-width: 769px) {
  .p_page .about .about-concept figure {
    width: 400px;
  }
}

.wp-pagenavi {
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .wp-pagenavi {
    margin-top: 10px;
  }
}
.wp-pagenavi .page {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  border: #dbdbdb 1px solid !important;
  width: 30px;
  height: 30px;
}
.wp-pagenavi .current {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  border: #dbdbdb 1px solid !important;
  width: 30px;
  height: 30px;
  background-color: #dbdbdb;
  font-weight: 400 !important;
}
.wp-pagenavi > span.pages,
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink {
  display: none;
}
.wp-pagenavi > span.pages {
  display: none;
}

.fancybox-is-open .fancybox-bg {
  opacity: 0.95 !important;
  background: #fff;
}

.img_half,
.switch {
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .img_half {
    width: auto !important;
  }
}
@media screen and (max-width: 768px) {
  .img_half {
    max-width: none !important;
  }
}
.no-news {
  width: 100%;
  margin-bottom: 30px;
  text-align: center;
  font-size: 1.5rem;
}

area:focus {
  outline: none;
}

/* ======================================================================
 z-index
====================================================================== */
.l_loader {
  z-index: 1000;
}

.l_menu_sp {
  z-index: 999;
}

.l_header {
  z-index: 998;
}

.l_header_sp {
  z-index: 998;
}

.c_btn_p_top {
  z-index: 997;
}

.l_side {
  z-index: 996;
}

/* =================================
 p_top
================================= */
.l_menu_sp_top {
  z-index: 999;
}

.l_header_top {
  z-index: 998;
}

.l_header_sp_top {
  z-index: 998;
}

.c_btn_p_top_top {
  z-index: 997;
}

.l_side_top {
  z-index: 996;
}

/*# sourceMappingURL=style.css.map */

/* 特定ページ（privacy, contact, terms）でのみhtmlフォントサイズを調整 */
body.p_page html {
  font-size: 16px; /* 通常のフォントサイズに戻す */
}

/* または、特定ページでのみヘッダーとフッターのフォントサイズを調整 */
body.p_page .header {
  font-size: 16px;
}
body.p_page .header__nav {
  width: 100%;
}
body.p_page .header__insta {
  font-size: 32px;
}
body.p_page .header__logo {
  width: 135px;
}
body.p_page .header__nav-label {
  font-size: 14px;
}

body.p_page .header__nav-label--en {
  font-size: 14px;
}

body.p_page .header__nav-label--jp {
  font-size: 13px;
}
body.p_page .footer__bussiness-time1 {
  font-size: 50px;
}
body.p_page p.footer__business-time2 {
  font-size: 26px;
}
body.p_page .commonNav__icon {
  font-size: 24px;
}
@media (max-width: 1100px) {
  body.p_page .footer__bussiness-time1{
      font-size: 4.3vw;
  }
}
@media (max-width: 768px) {
  body.p_page .header__insta {
    font-size: max(5.85vw, 28px);
  }
  body.p_page .header__logo {
    width: 28.2%;
  }
  body.p_page .header__nav-icon {
    font-size: 5.3vw;
  }
  body.p_page .header__nav-label--en {
    font-size: 3.48vw;
  }
  body.p_page .header__nav-label--jp {
    font-size: 4vw;
  }
  body.p_page .footer__bussiness-time1{
        font-size: 8vw;
    }
  body.p_page p.footer__business-time2 {
    font-size: 5.34vw;
  }
  body.p_page .commonNav__icon {
    font-size: 4vw;
  }
}
/* footer上の余白調整 */
body.p_page section {
  padding: 0 0 209px;
}
@media (max-width: 768px) {
  body.p_page section {
      padding: 0 0 38%;
  }
}

/* 250723 ヘッダーにLINE追加 */
.header__link a {
  color: #333333;
}
body.p_page .header__line {
  font-size: 28px;
}
@media screen and (max-width: 768px) {
  body.p_page .header__line {
      font-size: max(5.01vw, 24px);
  }
}
/* 250723 お問合せフォームテキスト・リンク追加 */
 .subcon_tex {
  font-size: 14px;
    color: #333333;
    text-align: center;
    margin-top: -20px;
    margin-bottom: 20px;
 }
 .l_content_link {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 80px;
 }
 .l_content_link a{
  border: 1px solid #eeeeee;
  width: 258px;
  height: 38px;
  font-size: 14px;
  color: #888888;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
 }
 .p_page .contact .contact-btn-wrap input {
  cursor: pointer;
}
 @media screen and (max-width: 768px) {
  .subcon_tex {
    font-size: 3.47vw;
    margin-top: 12.7%;
    margin-bottom: 4.8%;
  }
  .l_content_link {
    flex-direction: column;
    gap: 3.7vw;
    margin-bottom: 14%;
   }
   .l_content_link a{
    border: 0.08em solid #eeeeee;
    width: 94%;
    height: auto;
    padding: 3.37% 0;
    font-size: 3.47vw;
    border-radius: 45px;
   }
 }

  /* 250725 お問合せフォームセレクトボックス追加 */
  select {
    width: max(35%, 240px);
    background-color: #FCF9E7;
    border-radius: 3px;
    border: 1px solid #DCDCDC;
    padding: 10px 15px;
    font-size: 1.6rem;
    appearance: auto;
  }