@charset "UTF-8";
/* ================================================================= 
 License : e-TRUST Inc.
 File name : common.css
 Style : common
================================================================= */
/* ================================================================= 
 common
================================================================= */
.inner {
  width: 100%;
  max-width: 1210px;
  margin: 0 auto;
  position: relative; }

.inner2 {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  position: relative; }

/* ================================================================= 
 header
================================================================= */
header#global_header {
  height: auto; }

header#global_header #header {
  width: 100%;
  height: auto;
  margin: 0 auto; }

#siteID {
  padding: 23px 0 12px; }

#siteID img {
  width: 220px;
  height: 50px; }

#nav_header {
  float: right;
  margin: 10px 0 20px; }

#nav_header li {
  float: left; }

#nav_header li a {
  display: block;
  background-color: #0d2258;
  color: #fff;
  padding: 7px 15px 5px;
  margin-left: 10px;
  text-decoration: none;
  line-height: 1; }

/* ================================================================= 
 nav_global
================================================================= */
nav#nav_global {
  width: 100%;
  margin: 0 auto;
  background: #0d2258; }

nav#nav_global ul {
  width: 940px;
  margin: 0 auto; }

nav#nav_global ul li {
  float: left;
  width: 20%; }

nav#nav_global ul li a {
  background: #0d2258;
  display: block;
  padding: 10px 0 9px;
  margin: 0 auto;
  color: #fff;
  text-decoration: none; }

nav#nav_global ul li a:hover {
  background: #3a4f85; }

/* ================================================================= 
 main_image
================================================================= */
#main_image {
  width: 100%;
  margin: 0 auto;
  background: #fff; }

#main_image ul li img {
  max-width: 100%;
  height: auto; }

/* ================================================================= 
 footer
================================================================= */
nav#nav_footer {
  float: left;
  padding-top: 20px;
  margin-bottom: 30px; }

nav#nav_footer .col {
  border-left: 5px solid #a3a3a3;
  padding: 0 0 0 10px;
  margin-right: 90px;
  color: #fff;
  float: left;
  text-align: left; }

nav#nav_footer p {
  font-size: 116%;
  font-weight: bold;
  padding: 0;
  margin-bottom: 10px; }

nav#nav_footer ul li {
  padding-bottom: 5px; }

nav#nav_footer ul li a {
  display: block;
  text-decoration: none;
  color: #fff; }

#pagetop {
  float: right;
  padding-top: 20px; }

#pagetop a.pagetop {
  background: url(../images/common/ico_pagetop.png) no-repeat left 0;
  font-size: 108%;
  font-weight: bold;
  text-decoration: none;
  color: #fff;
  padding-left: 25px; }

#nav_footer_sub {
  float: left; }

#copyright small {
  float: right; }

/* ================================================================= 
 contents
================================================================= */
#side_col1 {
  margin-bottom: 20px; }

#side_col2 {
  margin-bottom: 20px; }

/* #main_col
------------------------------------------- */
.index_title {
  font-size: 154%;
  font-weight: bold;
  color: #0d2258;
  border-top: 14px solid #0d2258;
  position: relative; }

.index_title:after {
  content: "";
  background: url(../images/common/ico_arrow02.jpg);
  width: 10px;
  height: 10px;
  position: absolute;
  top: -12px;
  left: 2px;
  display: block;
  clear: both; }

.index_title02 {
  line-height: 1.4;
  font-size: 139%;
  font-family: 'HG明朝E','ＭＳ Ｐ明朝','MS PMincho','ヒラギノ明朝 Pro W3','Hiragino Mincho Pro',serif; }

.ico_01 {
  background: url(../images/common/ico_01.png) no-repeat left 0;
  padding: 0 0 0 25px; }

.ico_02 {
  background: url(../images/common/ico_02.png) no-repeat left 0;
  padding: 0 0 0 25px; }

/* #side_col1
------------------------------------------- */
#nav_local h2 {
  background: #0d2258;
  font-size: 116%;
  line-height: 1.4;
  padding: 10px 0 10px 15px;
  color: #fff;
  position: relative; }

#nav_local h2:after {
  content: "";
  border-left: 4px solid #4760a2;
  width: 4px;
  height: 47%;
  position: absolute;
  top: 25%;
  left: 0px;
  display: block; }

#nav_local ul {
  padding: 0; }

#nav_local ul li {
  background: #fff; }

#nav_local ul li a {
  display: block;
  padding: 10px;
  border-bottom: 1px dashed #ccc;
  text-decoration: none; }

/* #side_col2
------------------------------------------- */
/* ================================================================= 
 unique page
================================================================= */
/* ================================================================= 
 タブレット　CSS
================================================================= */
@media screen and (min-width: 469px) and (max-width: 768px) {
  .inner {
    width: 97.916666%;
    /* 940/960*100 */
    margin: 0 auto; }

  /*-----------------------------------------
   header
  ------------------------------------------- */
  header#global_header #header h1 {
    text-align: left;
    clear: both; }

  /*-----------------------------------------
   nav_global
  ------------------------------------------- */
  nav#nav_global {
    width: 100%;
    margin: 0 auto;
    background: #0d2258; }

  nav#nav_global ul {
    width: 100%;
    margin: 0 auto; }

  nav#nav_global ul li {
    float: left;
    width: 20%; }

  nav#nav_global ul li a {
    background: #0d2258;
    display: block;
    padding: 10px 0px 9px;
    margin: 0 auto;
    border-bottom: 1px solid #3a4f85;
    color: #fff;
    text-decoration: none; }

  nav#nav_global ul li a:hover {
    background: #3a4f85; }

  /*-----------------------------------------
   contents
  ------------------------------------------- */
  .banner {
    width: 100%; } }
/* ================================================================= 
 スマホ　CSS
================================================================= */
@media only screen and (max-width: 468px) {
  .inner {
    width: 97.87234%;
    /* 920/940*100 */
    margin: 0 auto; }

  /* スマホサイズになった際の余白のため */
  #contents {
    width: 98%;
    min-width: 98%;
    margin: 0 auto; }

  /*-----------------------------------------
   header
  ------------------------------------------- */
  header#global_header #header h1 {
    text-align: left; }

  #nav_header {
    display: none; }

  #siteID {
    text-align: left; }

  header#global_header .fltL, header#global_header .fltR {
    float: none; }

  /*-----------------------------------------
   nav_global
  ------------------------------------------- */
  nav#nav_global {
    width: 100%;
    margin: 0 auto; }

  nav#nav_global ul {
    width: 100%;
    margin: 0 auto; }

  nav#nav_global ul li {
    float: none;
    width: 100%; }

  nav#nav_global ul li a {
    background: #0d2258;
    display: block;
    padding: 10px 0 9px;
    margin: 0 auto;
    border-bottom: 1px solid #3a4f85;
    color: #fff;
    text-decoration: none; }

  /*-----------------------------------------
   footer
  ------------------------------------------- */
  nav#nav_footer {
    display: none;
    float: left;
    padding-top: 20px;
    margin-bottom: 30px; }

  #pagetop {
    float: right;
    padding: 5px 0; }

  #pagetop a.pagetop {
    background: url(../images/common/ico_pagetop.png) no-repeat left 0;
    font-size: 108%;
    font-weight: bold;
    text-decoration: none;
    color: #fff;
    padding-left: 25px; }

  #copyright {
    background: #2e472c;
    color: #fff;
    font-size: 93%;
    padding: 8px 0; }

  #nav_footer_sub {
    display: none; }

  #copyright small {
    float: none; }

  .banner img {
    min-width: 100%;
    height: auto; } }
/* ================================================================= 
tmple
================================================================= */
/* http://meyerweb.com/eric/tools/css/reset/ 
v2.0 | 20110126
License: none (public domain)
*/
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 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

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

@font-face {
  font-family: "Noto Serif Japanese";
  font-style: normal;
  font-weight: 400;
  src: url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Regular.woff") format("woff"), url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Regular.woff2") format("woff2"); }
@font-face {
  font-family: "Noto Serif Japanese";
  font-style: normal;
  font-weight: 500;
  src: url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Medium.woff") format("woff"), url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Medium.woff2") format("woff2"); }
@font-face {
  font-family: "Noto Serif Japanese";
  font-style: normal;
  font-weight: 700;
  src: url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Bold.woff") format("woff"), url("../font/NotoSerifCJKjp/NotoSerifCJKjp-Bold.woff2") format("woff2"); }
/* ================================================================= 
================================================================= */
@font-face {
  font-family: "Custom Yu Gothic";
  src: local("Yu Gothic");
  font-weight: 300; }
@font-face {
  font-family: "Custom Yu Gothic";
  src: local("Yu Gothic");
  font-weight: 500; }
@font-face {
  font-family: "Custom Yu Gothic";
  src: local("Yu Gothic");
  font-weight: bold; }
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }

.mauto {
  margin-right: auto;
  margin-left: auto; }

.col-1 {
  width: 8.33333%; }

.col-2 {
  width: 16.66667%; }

.col-3 {
  width: 25%; }

.col-4 {
  width: 33.33333%; }

.col-5 {
  width: 41.66667%; }

.col-6 {
  width: 50%; }

.col-7 {
  width: 58.33333%; }

.col-8 {
  width: 66.66667%; }

.col-9 {
  width: 75%; }

.col-10 {
  width: 83.33333%; }

.col-11 {
  width: 91.66667%; }

.col-12 {
  width: 100%; }

.gutterL {
  margin-left: 12px; }

.gutter {
  padding-right: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

@media only screen and (max-width: 768px) {
  .col-1 {
    width: 8.33333%; }

  .col-tb-2 {
    width: 16.66667%; }

  .col-tb-3 {
    width: 25%; }

  .col-tb-4 {
    width: 33.33333%; }

  .col-tb-5 {
    width: 41.66667%; }

  .col-tb-6 {
    width: 50%; }

  .col-tb-7 {
    width: 58.33333%; }

  .col-tb-8 {
    width: 66.66667%; }

  .col-tb-9 {
    width: 75%; }

  .col-tb-10 {
    width: 83.33333%; }

  .col-tb-11 {
    width: 91.66667%; }

  .col-tb-12 {
    width: 100%; }

  .gutter.col-tb-12, .gutter.col-sp-12 {
    padding-right: 0px; }

  .flex {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; } }
@media only screen and (max-width: 468px) {
  .col-sp-1 {
    width: 8.33333%; }

  .col-sp-2 {
    width: 16.66667%; }

  .col-sp-3 {
    width: 25%; }

  .col-sp-4 {
    width: 33.33333%; }

  .col-sp-5 {
    width: 41.66667%; }

  .col-sp-6 {
    width: 50%; }

  .col-sp-7 {
    width: 58.33333%; }

  .col-sp-8 {
    width: 66.66667%; }

  .col-sp-9 {
    width: 75%; }

  .col-sp-10 {
    width: 83.33333%; }

  .col-sp-11 {
    width: 91.66667%; }

  .col-sp-12 {
    width: 100%; } }
/*================== common =================*/
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
b {
  font-weight: bold !important; }

.tac {
  text-align: center; }

.tar {
  text-align: right; }

.tal {
  text-align: left; }

.fltR {
  float: right; }

.fltL {
  float: left; }

.not-for-sp-td {
  display: table-cell; }

.not-for-sp {
  display: block; }

.not-for-pc {
  display: none; }

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

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

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

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

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

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

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

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

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

.pd4048 {
  padding: 40px 48px; }

.pd80 {
  padding: 80px !important; }

.pd10 {
  padding: 10px !important; }

.mb0 {
  margin-bottom: 0 !important; }

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

@media only screen and (max-width: 768px) {
  #main {
    min-width: 100%; }

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

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

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

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

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

  .mb10 {
    margin-bottom: 8px !important; }

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

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

  .mt20 {
    margin-top: 12px; } }
@media only screen and (min-width: 468px) {
  .for-sp {
    display: none !important; } }
@media only screen and (max-width: 468px) {
  .for-sp {
    display: block; }

  .not-for-sp {
    display: none !important; }

  .not-for-pc {
    display: block; }

  .not-for-sp-td {
    display: none !important; } }
html {
  font-size: 62.5%; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

body {
  background: #e8eae5 !important;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 500;
  -ms-overflow-x: hidden;
  overflow-x: hidden;
  margin: 0 auto;
  line-height: 1.8;
  color: #333;
  font-size: 1.6rem;
  overflow: hidden; }
  body p {
    font-size: 1.6rem; }
  body li {
    font-size: 1.6rem; }
  body img {
    vertical-align: bottom; }

@media only screen and (max-width: 768px) {
  html {
    font-size: 55%; } }
@media only screen and (max-width: 468px) {
  html {
    font-size: 55%; } }
#copyright {
  background: #2e472c;
  color: #fff;
  font-size: 93%;
  padding: 8px 0; }

/*―――――――――――――――――――――――――――――――――――@policy―――――――――――――――――――――――――――――――――――*/
.midashi h3 {
  font-size: 18px;
  color: #333;
  font-weight: 700;
  border-bottom: 1px solid #333; }

.policy h3 {
  font-size: 18px;
  color: #333;
  font-weight: 700;
  border-bottom: 1px solid #333; }
.policy p {
  font-size: 1.5rem; }

/*―――――――――――――――――――――――――――――――――――@common―――――――――――――――――――――――――――――――――――*/
#main {
  width: 100%;
  margin: 0 auto;
  float: none !important; }

#contents {
  width: 100% !important;
  padding: 0;
  background: #e8eae5 !important; }

#contents_wrap {
  min-width: auto !important;
  margin-top: 60px;
  margin-bottom: 60px;
  background: #e8eae5 !important; }

#col_main {
  width: 100% !important; }

.sub-page h3 {
  font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
  font-weight: 400;
  font-weight: 400;
  font-size: 2.4rem;
  color: #333; }
.sub-page h2 {
  font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
  font-weight: 400;
  padding: 0 0 16px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  font-size: 3rem; }

.line-deco {
  font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
  font-weight: 400;
  padding: 0 0 40px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  font-size: 3rem; }
  .line-deco span {
    min-width: 100px; }

.line-deco:after {
  content: "";
  background: url("../images/home/line-deco.png") no-repeat;
  display: inline-block;
  height: auto;
  width: 100%;
  background-size: contain;
  background-position: center;
  max-width: 412px;
  margin-left: 16px; }

h3 .line-deco {
  padding: 0 !important; }

h4 {
  font-size: 2.4rem; }

@media only screen and (max-width: 768px) {
  #contents_wrap {
    padding: 0 10px; }

  img.imgL {
    float: none;
    margin: 0 0 16px 0 !important; } }
.flex3 {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .flex3 .box {
    -ms-flex: 0 1 32%;
    -webkit-box-flex: 0;
    flex: 0 1 32%;
    max-width: 32%; }

@media only screen and (max-width: 468px) {
  img.imgL {
    max-width: 100%;
    width: 100%;
    display: block;
    margin: 0 0 16px 0 !important; }

  .flex3 .box {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%; }
  .flex3 .box:nth-child(n+2) {
    display: none; }

  .line-deco {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    font-size: 2.2rem; }

  .line-deco:after {
    height: 3px;
    margin-left: 0; } }
a {
  color: #a32120;
  text-decoration: none; }

.pankuzu {
  text-align: right;
  font-size: 13px;
  margin-bottom: 20px; }

.sitemap {
  margin: 0 auto; }
  .sitemap ul li {
    display: block;
    width: 100%;
    font-size: 1.8rem; }

.policy-box h2 {
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 24px; }

.opa0 {
  opacity: 0; }

.error-text p span {
  font-size: 3.2rem;
  display: block; }

@media screen and (min-width: 469px) and (max-width: 768px) {
  .transHeader {
    -webkit-transform: translateY(-30px);
    transform: translateY(-30px); } }
@media screen and (max-width: 469px) {
  .transHeader {
    -webkit-transform: translateY(0px);
    transform: translateY(0px); } }
.garamond {
  font-family: 'EB Garamond', serif; }

.contact-btn {
  text-align: center; }
  .contact-btn a {
    padding: 4px 8px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    background: #6e7b1f;
    font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
    font-weight: 400;
    font-weight: bold;
    font-size: 2.4rem;
    color: #fff !important; }

.close-btn {
  position: absolute;
  top: 15px;
  right: 25px;
  letter-spacing: 0.5rem;
  padding-bottom: 0px;
  border-bottom: 1px solid #295635;
  color: #295635;
  cursor: pointer; }

.menu-btn {
  z-index: 101;
  cursor: pointer;
  background: url("../images/common/menu-btn.png") no-repeat;
  -webkit-background-size: contain;
  -o-background-size: contain;
  background-size: contain;
  width: 70px;
  height: 120px;
  position: fixed;
  right: 50px;
  top: 10px; }

.hum-menu {
  border: double #2e472c 4px;
  position: fixed;
  height: 100vh;
  top: 0;
  width: 600px;
  left: calc(50% - 300px);
  background: rgba(255, 255, 255, 0.98);
  z-index: 100; }
  .hum-menu ul {
    height: 100%;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-top: 50px;
    padding-bottom: 50px; }
    .hum-menu ul li {
      -webkit-flex: 1 1 100%;
      -ms-flex: 1 1 100%;
      flex: 1 1 100%;
      max-width: 100%;
      display: flex;
      -webkit-justify-content: center;
      justify-content: center;
      -webkit-align-items: center;
      align-items: center; }
      .hum-menu ul li a {
        -webkit-transition-duration: 0.8s;
        -moz-transition-duration: 0.8s;
        -ms-transition-duration: 0.8s;
        -o-transition-duration: 0.8s;
        transition-duration: 0.8s;
        color: #295635;
        font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
        font-weight: 400;
        font-weight: bold; }

@media screen and (max-width: 469px) {
  .menu-btn {
    background-size: contain;
    width: 40px;
    height: 74px;
    right: 20px;
    bottom: 0px; }

  .subpage.wrap {
    height: 176px !important; }

  .hum-menu {
    -ms-overflow-y: scroll;
    overflow-y: scroll; }
    .hum-menu ul {
      height: 720px; } }
.tel01 a, .tel02 a {
  color: #aa1b48 !important; }

/*―――――――――――――――――――――――――――――――――――@header―――――――――――――――――――――――――――――――――――*/
header#global_header {
  min-width: 100%; }
  header#global_header #header {
    background: #fff !important;
    border-bottom: solid #2e472c 3px;
    padding-bottom: 16px;
    height: 100%; }
    header#global_header #header .inner {
      display: flex;
      -webkit-justify-content: center;
      justify-content: center;
      -webkit-align-items: center;
      align-items: center;
      height: 100%; }
      header#global_header #header .inner .wrap {
        position: relative;
        z-index: 100;
        height: 248px;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-justify-content: flex-end;
        justify-content: flex-end; }
        header#global_header #header .inner .wrap .site-logo {
          width: 100%;
          -webkit-align-self: flex-end;
          align-self: flex-end; }
          header#global_header #header .inner .wrap .site-logo img {
            width: 480px;
            filter: drop-shadow(0px 0px 5px #FFF); }
        header#global_header #header .inner .wrap .page-title {
          width: 320px;
          -webkit-align-self: flex-end;
          align-self: flex-end;
          -webkit-justify-content: flex-end;
          justify-content: flex-end;
          text-shadow: 0px 0px 5px #ffffff,0px 0px 5px #ffffff; }
          header#global_header #header .inner .wrap .page-title .big-txt {
            line-height: 1.2;
            font-size: 3rem;
            color: #aa1b48; }
          header#global_header #header .inner .wrap .page-title .small-txt {
            font-weight: bold; }
      header#global_header #header .inner .header-img {
        position: absolute;
        right: 40px;
        width: 160px; }

@media screen and (max-width: 769px) {
  #global_header {
    padding-bottom: 0 !important; }
    #global_header #header .inner {
      -webkit-justify-content: flex-start !important;
      justify-content: flex-start !important;
      padding-left: 20px; }
    #global_header #header .wrap .site-logo {
      text-align: left;
      width: 100%;
      -webkit-align-items: flex-start;
      align-items: flex-start;
      -webkit-align-self: flex-end;
      align-self: flex-end; }
      #global_header #header .wrap .site-logo img {
        width: 250px !important; }
    #global_header #header .wrap .page-title {
      padding-top: 16px;
      -webkit-align-self: flex-start !important;
      align-self: flex-start !important;
      width: 100% !important; }
      #global_header #header .wrap .page-title .big-txt {
        text-align: left; }
      #global_header #header .wrap .page-title .small-txt {
        text-align: left; }
    #global_header #header img.header-img {
      right: 20px !important; } }
@media screen and (max-width: 469px) {
  #global_header #header .inner {
    padding-left: 0 !important; }
    #global_header #header .inner img.header-img {
      overflow: 0.8;
      right: 0px !important; } }
/*―――――――――――――――――――――――――――――――――――@footer―――――――――――――――――――――――――――――――――――*/
#global_footer {
  border-top: 2px solid #2e472c;
  background: #FFF !important; }
  #global_footer .footer-inner {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    background: #FFF;
    padding: 50px 0;
    max-width: 1000px;
    margin: 0 auto;
    display: flex; }
    #global_footer .footer-inner div.footer-logo {
      text-align: left;
      width: 100%;
      max-width: 100%;
      margin-bottom: 40px; }
      #global_footer .footer-inner div.footer-logo a img {
        max-width: 50%; }
      @media only screen and (max-width: 468px) {
        #global_footer .footer-inner div.footer-logo a img {
          width: 80%;
          max-width: 80%; } }
    #global_footer .footer-inner address {
      padding-left: 16px; }
      #global_footer .footer-inner address ul li {
        line-height: 2;
        text-align: left;
        color: #333;
        font-size: 1.6rem;
        font-weight: bold; }
    #global_footer .footer-inner div.footer-nav {
      max-width: 100%;
      width: 100%;
      display: flex;
      -webkit-align-items: center;
      align-items: center; }
      #global_footer .footer-inner div.footer-nav ul {
        width: 100%;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        display: flex;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        height: 150px; }
        #global_footer .footer-inner div.footer-nav ul li {
          font-size: 1.4rem;
          -webkit-flex: 1 1 25%;
          -ms-flex: 1 1 25%;
          flex: 1 1 25%;
          text-align: left;
          font-weight: bold; }
          #global_footer .footer-inner div.footer-nav ul li a {
            color: #2e472c; }
      #global_footer .footer-inner div.footer-nav ul:after {
        content: "";
        display: block;
        height: 25%; }
  #global_footer .footer-inner > div {
    width: 50%;
    max-width: 50%;
    flex: 1 1 auto;
    display: flex;
    -webkit-align-items: center;
    align-items: center; }

@media only screen and (max-width: 540px) {
  #global_footer .footer-inner {
    padding-bottom: 30px !important; }
    #global_footer .footer-inner .footer-logo {
      -webkit-justify-content: center;
      justify-content: center; }
    #global_footer .footer-inner .footer-nav ul {
      padding: 10px 20px 0;
      height: 210px !important; }
      #global_footer .footer-inner .footer-nav ul li {
        display: flex;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
        -webkit-align-items: center;
        align-items: center;
        width: 33.3333%; }
  #global_footer .footer-inner > div {
    width: 100%;
    max-width: 100%; } }
/*―――――――――――――――――――――――――――――――――――@index header―――――――――――――――――――――――――――――――――――*/
.logo2 {
  text-align: center !important; }
  .logo2 img {
    width: 120px; }

.logo-txt2 {
  text-align: center !important; }

.main-image .main-img img {
  -webkit-box-sizing: unset !important;
  -moz-box-sizing: unset !important;
  box-sizing: unset !important;
  border-top: solid 80px #295635;
  border-bottom: solid 80px #295635;
  border-left: solid 70px #295635;
  border-right: solid 70px #295635; }
@media only screen and (max-width: 768px) {
  .main-image .main-img img {
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
    border: 10px solid #295635 !important; } }

.main-text p {
  font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
  font-weight: 400;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 2.4;
  text-align: center !important; }

.index-nav {
  padding-top: 60px;
  border-top: 1px solid #295643;
  padding-bottom: 30px;
  border-bottom: 1px solid #295643; }
  .index-nav ul {
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .index-nav ul li {
      -webkit-flex: 1 1 20%;
      -ms-flex: 1 1 20%;
      flex: 1 1 20%;
      max-width: 20%; }
      @media only screen and (max-width: 468px) {
        .index-nav ul li {
          -webkit-flex: 1 1 100%;
          -ms-flex: 1 1 100%;
          flex: 1 1 100%;
          max-width: 100%; } }
      .index-nav ul li a {
        text-align: center;
        font-weight: 500 !important;
        font-family: 'Noto Serif Japanese' , "游明朝体", "Yu Mincho", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif !important;
        font-weight: 400;
        -webkit-transition-duration: 0.8s;
        -moz-transition-duration: 0.8s;
        -ms-transition-duration: 0.8s;
        -o-transition-duration: 0.8s;
        transition-duration: 0.8s;
        font-size: 1.8rem;
        width: 100%;
        display: block;
        color: #295635;
        margin-bottom: 24px; }

nav a:hover {
  color: #b63463 !important;
  letter-spacing: 0.08rem; }

.index-h2 {
  text-align: center;
  font-size: 3.5rem;
  color: #4f3034;
  letter-spacing: 0.3rem; }

.subpage-h2 {
  text-align: center;
  font-size: 3rem;
  color: #4f3034;
  letter-spacing: 0.3rem; }

.index-address-wrap {
  background: #FFF;
  padding: 60px 30px; }

.index-address p {
  text-align: center !important; }

.map-wrap .inner {
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center; }
  .map-wrap .inner div:first-child {
    display: none; }
  .map-wrap .inner div:last-child {
    display: none; }
  .map-wrap .inner div {
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    max-width: 46%;
    -webkit-flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto; }

@media screen and (max-width: 769px) {
  .access-way dl {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .access-way dl dd {
      width: 100% !important; }
    .access-way dl dt {
      width: 100% !important; }

  .map-wrap .inner .ggmap {
    margin-bottom: 20px; }
  .map-wrap .inner div {
    max-width: 100%;
    width: 100%; } }
.table-temp01 tr td {
  border: none !important; }
.table-temp01 .table-temp01-title {
  height: 30%;
  padding-left: 0 !important;
  border-bottom: 2px solid #aa1b48 !important;
  padding-bottom: 0 !important;
  vertical-align: bottom !important; }
  .table-temp01 .table-temp01-title p {
    padding-bottom: 4px;
    font-weight: bold;
    font-size: 3rem; }
.table-temp01 .table-temp01-text {
  padding-top: 20px !important;
  vertical-align: top !important; }

@keyframes blur {
  0% {
    filter: blur(0px); }
  100% {
    filter: blur(4px); } }
@keyframes blurRev {
  0% {
    filter: blur(2px); }
  100% {
    filter: blur(0px); } }
.concept-img01::before {
  content: '';
  position: absolute;
  /* 輪郭がぼやけてしまうのでブラー範囲を広げる */
  top: -5px;
  bottom: -5px;
  left: -5px;
  right: -5px;
  background: inherit;
  -webkit-animation: blur 3s;
  -moz-animation: blur 3s;
  -o-animation: blur 3s;
  animation: blur 3s;
  filter: blur(4px); }

.concept-img01 {
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-size: cover;
  height: 400px;
  background-position: 50%;
  display: flex;
  align-items: center;
  justify-content: flex-end; }
  .concept-img01 div {
    -webkit-animation: blurRev 3s;
    -moz-animation: blurRev 3s;
    -o-animation: blurRev 3s;
    animation: blurRev 3s;
    padding-right: 20px; }
    .concept-img01 div p.txt01 {
      margin-left: auto;
      width: 50%;
      color: #fff;
      font-size: 4.8rem; }
    .concept-img01 div span {
      display: block;
      margin-left: auto;
      width: 50%;
      font-size: 2.4rem;
      text-align: right;
      color: #fff;
      padding-right: 3rem; }
    .concept-img01 div p.txt02 {
      padding-top: 20px;
      color: #FFF;
      font-size: 1.6rem;
      width: 50%;
      margin-left: auto;
      text-align: left;
      letter-spacing: 0.1rem; }
  @media only screen and (max-width: 468px) {
    .concept-img01 div {
      padding-right: 0; }
      .concept-img01 div p {
        font-size: 4.2rem; }
      .concept-img01 div span {
        font-size: 2rem; } }
  @media only screen and (max-width: 768px) {
    .concept-img01 .inner {
      padding-left: 0 !important; }
    .concept-img01 span {
      width: 100% !important; }
    .concept-img01 p {
      width: 100% !important; }
    .concept-img01 .txt02 {
      font-size: 1.8rem !important; } }

.concept-img02 table tr td {
  border: none !important; }
.concept-img02 p.txt01 {
  text-align: center;
  font-size: 4rem; }
.concept-img02 span {
  font-size: 2.4rem;
  text-align: center;
  display: block; }
.concept-img02 p.txt02 {
  font-size: 1.8rem;
  line-height: 3rem; }
@media only screen and (max-width: 768px) {
  .concept-img02 .inner {
    padding-left: 0 !important; }
  .concept-img02 span {
    width: 100% !important; }
  .concept-img02 p {
    width: 100% !important; }
  .concept-img02 .txt02 {
    font-size: 1.8rem !important; } }
@media only screen and (max-width: 468px) {
  .concept-img02 div {
    padding-right: 0; }
    .concept-img02 div p {
      font-size: 4.2rem; }
    .concept-img02 div span {
      font-size: 2rem; } }

.jusconC {
  -webkit-justify-content: center;
  justify-content: center; }

.jusconSB {
  -webkit-justify-content: space-between;
  justify-content: space-between; }

.jusconSA {
  -webkit-justify-content: space-around;
  justify-content: space-around; }

.fww {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.fwnw {
  -webkit-flex-wrap: nowrap !important;
  -ms-flex-wrap: nowrap !important;
  flex-wrap: nowrap !important; }

.makian-flex01 img {
  padding: 5px; }

.shop-table01 .small-txt {
  font-size: 1.2rem;
  opacity: 0.9; }
@media only screen and (max-width: 768px) {
  .shop-table01 {
    overflow: scroll; } }
.shop-table01 table {
  min-width: 1070px;
  background: #FFF; }
  .shop-table01 table tr:first-child {
    background: #295635;
    color: #fff !important;
    font-size: 1.8rem; }
  .shop-table01 table tr td:nth-child(2) p {
    font-size: 1.6rem; }
  .shop-table01 table tr td:first-child {
    text-align: center !important; }
  .shop-table01 table tr td {
    padding: 20px 10px !important; }
    .shop-table01 table tr td img {
      max-height: 100px; }
    .shop-table01 table tr td a {
      color: #aa1b48; }
  .shop-table01 table tr .holiday {
    width: 120px; }

.waku01 {
  border: double 3px #2e472c;
  padding: 30px;
  background: #fff; }
  .waku01 p {
    font-size: 1.8rem; }

.leonard-main-img img {
  border: 40px #85640f solid;
  -webkit-box-sizing: unset;
  -moz-box-sizing: unset;
  box-sizing: unset; }
@media only screen and (max-width: 468px) {
  .leonard-main-img img {
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important; } }

.main-text.leonard span {
  font-size: 1.8rem !important; }

.leonard-link .box {
  -webkit-flex: 1 1 auto;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto; }
  .leonard-link .box p {
    text-align: center; }
    .leonard-link .box p a {
      color: #644c0c;
      font-weight: 500;
      letter-spacing: 0.6rem;
      padding-bottom: 3px;
      position: relative; }
  .leonard-link .box a:after {
    background-color: #644c0c;
    bottom: 0;
    content: '';
    display: block;
    height: 1px;
    left: 0;
    position: absolute;
    transition: .5s all;
    width: 0; }
  .leonard-link .box a:hover:after {
    width: 100%; }

.leonard-flex01 {
  font-weight: bold;
  -webkit-justify-content: space-between !important;
  justify-content: space-between !important; }
  .leonard-flex01 .box {
    width: 48%; }
  .leonard-flex01 img {
    height: 400px; }
  @media only screen and (max-width: 768px) {
    .leonard-flex01 img {
      height: 210px !important; } }

@media only screen and (max-width: 468px) {
  .leonard-flex01 {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .leonard-flex01 .box {
      width: 100%; }
      .leonard-flex01 .box p {
        font-size: 1.5rem;
        padding: 0 6px; } }
.leonard-flex02 {
  font-weight: bold; }
  .leonard-flex02 img {
    height: 400px; }
  @media only screen and (max-width: 768px) {
    .leonard-flex02 img {
      height: 250px !important; } }

@media only screen and (max-width: 468px) {
  .scr-wrap {
    -ms-overflow-x: scroll;
    overflow-x: scroll; }

  .leonard-flex02 {
    width: 660px; }
    .leonard-flex02 .box {
      padding: 0 10px; } }
.opt01.leonard-flex01 .box {
  padding: 10px; }

.service-table {
  padding: 30px 0;
  background: #977b31; }
  .service-table tr td {
    border: none !important; }
    .service-table tr td p {
      padding-top: 8px;
      color: #fff; }

.bg-wrap {
  padding: 40px 0;
  margin-bottom: 60px; }
  .bg-wrap h2, .bg-wrap p {
    color: #fff !important; }

.room-table {
  padding: 20px;
  background: #fafafa; }
  .room-table table tr td {
    border: none; }

.living-flex01 .box {
  padding: 10px; }

@media only screen and (max-width: 468px) {
  .scr-wrap .living-flex01 {
    height: 200px;
    -webkit-flex-wrap: nowrap !important;
    -ms-flex-wrap: nowrap !important;
    flex-wrap: nowrap !important;
    width: 1210px; } }
.sizen-table-title p {
  font-size: 2.4rem; }

.sizen-table01 table tr:first-child {
  border-bottom: 2px solid #aa1b48; }
.sizen-table01 table tr td {
  border: none !important; }

.bg02 {
  background: #FFF2F2;
  padding: 50px 0; }

.rental .leonard-flex01 .box {
  text-align: center; }
  .rental .leonard-flex01 .box p {
    text-align: center; }
.rental a {
  color: #aa1b48; }

.menu .menu-table {
  background: #fff; }
  .menu .menu-table table tr td {
    vertical-align: top !important;
    padding: 20px !important; }
  .menu .menu-table table tr .name {
    color: #aa1b48;
    font-size: 1.8rem; }
  .menu .menu-table table tr .price {
    color: #aa1b48; }

.saijiki .saijiki.sizen-table01 tr td img {
  max-height: 250px !important; }

.salon-access-title {
  border: none !important;
  background: rgba(255, 255, 255, 0) !important; }

.salon.leonard-link .box {
  -webkit-flex: 1 1 50%;
  -ms-flex: 1 1 50%;
  flex: 1 1 50%;
  max-width: 50%;
  margin-bottom: 1rem; }
  .salon.leonard-link .box p {
    text-align: left; }
.salon.leonard-link a {
  color: #68102c !important; }
.salon.leonard-link a:after {
  background: #68102c !important; }
@media only screen and (max-width: 468px) {
  .salon.leonard-link .box {
    -webkit-flex: 1 1 100%;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%;
    max-width: 100%; } }

.okashi a {
  color: #68102c !important;
  border-bottom: 1px solid #68102c !important; }

.topBtnBox {
  position: fixed;
  right: 20px;
  bottom: 1px;
  color: #fff;
  font-weight: bold;
  background: #546b35;
  width: 72px;
  height: 48px;
  cursor: pointer;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  border: 1px solid #6f7763; }

.living-con02 > div {
  -webkit-justify-content: space-between !important;
  justify-content: space-between !important; }
  .living-con02 > div .box {
    width: 30%;
    max-width: 30%; }
    @media only screen and (max-width: 468px) {
      .living-con02 > div .box {
        width: 50%;
        max-width: 50%; } }

.view-container-border {
  background: #fff2f2 !important; }

#mvDaynamesTable tr {
  background: #ffcbcb !important;
  color: #994760 !important; }

section .calender {
  border: 1px solid #b15b75;
  overflow-y: scroll;
  height: 248px; }
  section .calender dl {
    border-bottom: 1px dotted #999; }
  section .calender dt {
    padding: 20px !important;
    border: none !important;
    background-color: #fff !important;
    color: #7a3a4e !important;
    font-size: 1.8rem !important;
    /* justify-self: center; */
    justify-content: center !important; }
  section .calender dd {
    padding: 20px !important;
    font-size: 1.5rem;
    border: none !important;
    background-color: none !important; }

.sub-page.small-txt h1 {
  font-size: 2.4rem;
  color: #4f3034;
  font-family: 'EB Garamond', serif; }

.box h3 {
  display: none; }

.bg-white {
  background: #FFF;
  padding-top: 60px;
  padding-bottom: 40px; }
  @media only screen and (max-width: 768px) {
    .bg-white {
      padding-top: 30px;
      padding-bottom: 20px; } }

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