@charset "UTF-8";
/**
* base design

 */
/*{font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}*/
* {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

body {
  position: relative;
  margin: 0;
  width: 100%;
  height: 100%;
  letter-spacing: 2px;
  font-feature-settings: "palt" 1;
  background-color: #f7f7ee; }

* html body {
  height: 100%;
  font-size: 90%; }

/*各種基本クラス初期設定*/
a {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }

a:hover {
  opacity: 0.6;
  filter: alpha(opacity=80); }

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
  font-size: 100%;
  font-weight: normal; }

h3 {
  font-size: 110%;
  margin-top: 10px;
  margin-bottom: 10px;
  letter-spacing: 1px; }

ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
  line-height: 160%; }

a {
  color: #333333;
  text-decoration: none; }

a:hover {
  color: #aaaaaa;
  text-decoration: underline; }

p {
  margin: 15px 0 20px 0px;
  font-size: 95%;
  color: #333333;
  line-height: 180%;
  letter-spacing: 0px;
  text-align: justify; }

p a {
  color: #168f82; }

ol li {
  margin: 10px 0px;
  line-height: 160%; }

hr {
  border: none;
  border-bottom: dotted 1px #cccccc;
  margin: 50px 0px; }

/*イメージ*/
img {
  max-width: 100%;
  border: none;
  height: auto; }

/*コンテンツ・基本レイアウト*/
#wrap {
  margin: 0px auto;
  min-height: 100%;
  max-width: 100%;
  padding: 0px 0 0px 0;
  z-index: 3; }

.cont p {
  line-height: 180%;
  margin: 18px 0 10px;
  padding: 0 5px 0 5px;
  font-size: 100%; }

#main_con {
  max-width: 100%;
  width: 880px;
  vertical-align: top;
  display: inline-block;
  padding-left: 5px;
  box-sizing: border-box; }

.cont {
  margin: 0px auto 0px;
  width: 100%;
  padding: 10px 0px 30px;
  z-index: 1;
  max-width: 1080px;
  box-sizing: border-box; }

/*共通ボックスCSS*/
.cont_box {
  width: 100%;
  text-align: center;
  margin: 10px auto 15px;
  display: flex; }

.wraper {
  width: 100%;
  margin: 0 auto; }

.btn--green {
  font-weight: bold;
  position: relative;
  display: block;
  padding: 15px 1rem;
  padding-right: 50px;
  transition: opacity 2s;
  text-decoration: none;
  color: #fff;
  background: #26A69A;
  border-radius: 30px;
  box-shadow: 0 0 3px 0 rgba(0, 0, 0, 0.12), 0 2px 3px 0 rgba(0, 0, 0, 0.22);
  -webkit-transition: all .5s;
  transition: all .5s; }
  .btn--green:before {
    position: absolute;
    top: 0;
    right: 21px;
    bottom: 0;
    display: block;
    width: calc(0.75em - 2px);
    height: calc(0.75em - 2px);
    margin: auto;
    content: '';
    border-width: 3px 3px 0px 0;
    border-style: solid;
    border-color: #26A69A;
    transform: rotate(45deg);
    z-index: 2; }
  .btn--green:after {
    position: absolute;
    top: 0;
    right: 10px;
    bottom: 0;
    display: block;
    box-sizing: border-box;
    width: 30px;
    height: 30px;
    margin: auto;
    content: '';
    border-radius: 50%;
    background-color: #fff; }

.btn--blue {
  font-weight: bold;
  position: relative;
  display: block;
  padding: 15px 1rem;
  padding-right: 50px;
  transition: opacity 2s;
  text-decoration: none;
  color: #fff;
  background: #3498db;
  border-radius: 30px;
  box-shadow: 0 0 3px 0 rgba(0, 0, 0, 0.12), 0 2px 3px 0 rgba(0, 0, 0, 0.22);
  -webkit-transition: all .5s;
  transition: all .5s; }
  .btn--blue:before {
    position: absolute;
    top: 0;
    right: 21px;
    bottom: 0;
    display: block;
    width: calc(0.75em - 2px);
    height: calc(0.75em - 2px);
    margin: auto;
    content: '';
    border-width: 3px 3px 0px 0;
    border-style: solid;
    border-color: #3498db;
    transform: rotate(45deg);
    z-index: 2; }
  .btn--blue:after {
    position: absolute;
    top: 0;
    right: 10px;
    bottom: 0;
    display: block;
    box-sizing: border-box;
    width: 30px;
    height: 30px;
    margin: auto;
    content: '';
    border-radius: 50%;
    background-color: #fff; }

.btn--red {
  font-weight: bold;
  position: relative;
  display: block;
  padding: 15px 1rem;
  padding-right: 50px;
  transition: opacity 2s;
  text-decoration: none;
  color: #fff;
  background: #f44336;
  border-radius: 30px;
  box-shadow: 0 0 3px 0 rgba(0, 0, 0, 0.12), 0 2px 3px 0 rgba(0, 0, 0, 0.22);
  -webkit-transition: all .5s;
  transition: all .5s; }
  .btn--red:before {
    position: absolute;
    top: 0;
    right: 21px;
    bottom: 0;
    display: block;
    width: calc(0.75em - 2px);
    height: calc(0.75em - 2px);
    margin: auto;
    content: '';
    border-width: 3px 3px 0px 0;
    border-style: solid;
    border-color: #f44336;
    transform: rotate(45deg);
    z-index: 2; }
  .btn--red:after {
    position: absolute;
    top: 0;
    right: 10px;
    bottom: 0;
    display: block;
    box-sizing: border-box;
    width: 30px;
    height: 30px;
    margin: auto;
    content: '';
    border-radius: 50%;
    background-color: #fff; }

/*テーブル設定*/
table {
  clear: both;
  border-collapse: collapse;
  margin-left: 0px;
  margin-top: 15px;
  margin-bottom: 25px;
  width: 100%; }

table .big {
  color: #8C8B1F; }

th, td {
  padding: 10px 5px 10px 7px;
  vertical-align: top;
  color: #111111;
  line-height: 160%;
  letter-spacing: 0px; }

th span, td span {
  font-weight: bold;
  margin: 10px 0px; }

th p, td p {
  font-size: 100%;
  margin: 10px 0 !important; }

/*
* メニューテーブル
 */
.menu_table {
  width: 96%;
  border: double 3px #ccc;
  margin: 20px auto; }

.menu_table th, .menu_table td {
  border: solid #ccc 3px; }

.menu_table th {
  background: #8de7ef; }

/**
animation
 */
.fade {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }

.fade:hover {
  opacity: 0.6;
  filter: alpha(opacity=80); }

.bounce {
  animation: bounce_4933 2.5s ease infinite;
  transform-origin: 50% 50%;
  height: 74px; }

@keyframes bounce_4933 {
  0% {
    transform: translateY(0); }
  5.55556% {
    transform: translateY(0); }
  11.11111% {
    transform: translateY(0); }
  22.22222% {
    transform: translateY(-15px); }
  27.77778% {
    transform: translateY(0); }
  33.33333% {
    transform: translateY(-15px); }
  44.44444% {
    transform: translateY(0); }
  100% {
    transform: translateY(0); } }

/*フェードイン*/
.fade-in2 li ul {
  opacity: 0;
  top: 50%;
  visibility: hidden;
  transition: .5s;
  width: 100%; }

.fade-in2 li:hover ul {
  top: 100%;
  visibility: visible;
  opacity: 1; }

.fade-in2 li ul li a:hover {
  opacity: 1 !important; }

/**
**js
 */
/*スライダー*/
.flexslider .slides {
  position: relative; }

.no1, .no2 {
  filter: alpha(opacity=0);
  -moz-opacity: 0;
  opacity: 0; }

.no1 {
  position: absolute;
  z-index: 11;
  /* text-align: center; */
  max-width: 40%;
  left: 50%;
  bottom: 28%;
  height: auto;
  transform: translateX(-50%); }

.no1 img {
  margin: 0 auto !important;
  max-width: 100% !important; }

/**
component

 */
.sns_button {
  padding: 13px 5px !important; }

.sns_button a {
  padding: 0px !important; }

.c-btn {
  padding: 11px 24px;
  color: #ffffff;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 1.72px;
  background-color: #b20000; }

.c-row {
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: left;
  -webkit-box-pack: left;
  -ms-flex-pack: left;
  align-items: top;
  -webkit-box-align: top;
  -ms-flex-align: top;
  padding-right: 6px;
  padding-left: 6px;
  flex-wrap: wrap; }

@media screen and (min-width: 769px) {
  .c-md-col-1 {
    width: 9.14826%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-2 {
    width: 18.4858%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-3 {
    width: 28.01262%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-4 {
    width: 37.72871%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-5 {
    width: 47.63407%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-6 {
    width: 57.72871%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-7 {
    width: 68.01262%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-8 {
    width: 78.4858%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-9 {
    width: 89.14826%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-col-10 {
    width: 100%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-md-gutter-col-1 {
    margin-left: 10.09464%; }
  .c-md-gutter-col-2 {
    margin-left: 19.43218%; }
  .c-md-gutter-col-3 {
    margin-left: 28.95899%; }
  .c-md-gutter-col-4 {
    margin-left: 38.67508%; }
  .c-md-gutter-col-5 {
    margin-left: 48.58044%; }
  .c-md-gutter-col-6 {
    margin-left: 58.67508%; }
  .c-md-gutter-col-7 {
    margin-left: 68.95899%; }
  .c-md-gutter-col-8 {
    margin-left: 79.43218%; }
  .c-md-gutter-col-9 {
    margin-left: 90.09464%; }
  .c-md-gutter-col-10 {
    margin-left: 100.94637%; } }

@media screen and (max-width: 768px) {
  .c-sm-col-1 {
    width: 9.14826%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-2 {
    width: 18.4858%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-3 {
    width: 28.01262%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-4 {
    width: 37.72871%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-5 {
    width: 47.63407%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-6 {
    width: 57.72871%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-7 {
    width: 68.01262%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-8 {
    width: 78.4858%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-9 {
    width: 89.14826%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-col-10 {
    width: 100%;
    padding-left: 6px;
    padding-right: 6px; }
  .c-sm-gutter-col-1 {
    margin-left: 10.09464%; }
  .c-sm-gutter-col-2 {
    margin-left: 19.43218%; }
  .c-sm-gutter-col-3 {
    margin-left: 28.95899%; }
  .c-sm-gutter-col-4 {
    margin-left: 38.67508%; }
  .c-sm-gutter-col-5 {
    margin-left: 48.58044%; }
  .c-sm-gutter-col-6 {
    margin-left: 58.67508%; }
  .c-sm-gutter-col-7 {
    margin-left: 68.95899%; }
  .c-sm-gutter-col-8 {
    margin-left: 79.43218%; }
  .c-sm-gutter-col-9 {
    margin-left: 90.09464%; }
  .c-sm-gutter-col-10 {
    margin-left: 100.94637%; } }

/*ローダー*/
#loader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #fff;
  z-index: 201; }

.zero {
  height: 0px; }

#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 300px;
  height: 50px;
  margin-top: -25px;
  margin-left: -150px;
  text-align: center;
  color: #fff;
  z-index: 200; }

/*メインメニュー*/
.drawer-dropdown {
  max-width: 100%;
  margin: 0 auto;
  padding: 0; }

.drawer-dropdown a {
  display: block;
  padding: 14px;
  box-sizing: border-box;
  text-decoration: none;
  line-height: 1; }

.drawer-dropdown label {
  display: block;
  margin: 0;
  padding: 15px;
  line-height: 1;
  color: #fff;
  background: #CDAD7E;
  cursor: pointer;
  position: relative;
  border-bottom: 1px #fff solid; }

.drawer-dropdown label:after {
  position: absolute;
  top: 50%;
  right: 7px;
  content: '';
  margin-top: -5px;
  border: 7px solid transparent;
  border-top-width: 8px;
  border-bottom-width: 5px;
  border-top-color: #fff; }

.drawer-dropdown input {
  display: none; }

.drawer-dropdown ul {
  margin: 0;
  padding: 0;
  list-style: none; }

.drawer-dropdown li {
  max-height: 0;
  overflow-y: hidden;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s; }

#menu_bar01:checked ~ #links01 li,
#menu_bar02:checked ~ #links02 li,
#menu_bar03:checked ~ #links03 li {
  max-height: 46px;
  opacity: 1; }

/*ヘッダーメニュー*/
#headercont {
  min-width: 1280px;
  margin: 0 auto;
  position: relative;
  padding: 0px;
  z-index: 10;
  width: 100%; }

#top_mainmenu {
  max-width: 100%;
  width: 1280px;
  margin: 0 auto; }

#top_mainmenu ul {
  margin: 0 auto;
  display: block;
  box-sizing: border-box;
  padding: 14px 0px;
  width: 100%;
  text-align: right; }

#top_mainmenu li {
  display: inline-block;
  letter-spacing: 1px; }

#top_mainmenu li:first-child {
  border: none !important; }

#top_mainmenu li a {
  color: #fff;
  padding: 8px 20px;
  font-size: 105%; }

#top_mainmenu li a span {
  display: block;
  text-align: right;
  font-size: 70%; }

#top_mainmenu li ul li {
  border: none !important;
  padding: 0px;
  border-bottom: none !important; }

#top_mainmenu li ul li a {
  color: #8C8B1F; }

.c-list_style {
  width: 100%;
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: space-between;
  -webkit-box-pack: space-between;
  -ms-flex-pack: space-between;
  align-items: center;
  -webkit-box-align: center;
  -ms-flex-align: center; }
  .c-list_style li {
    width: 100%; }
  .c-list_style a {
    display: inline-block;
    padding:10px 5px; }

.c-list_style-a li {
  background-color: #eeeeee;
  padding: 5px;
  display: inline-block; }

.c-list_style-a a {
  color: #333;
  font-size: 13px; }

.c-list_style-b {
  text-align: left; }
  .c-list_style-b a {
    font-size: 15px;
    font-weight: 400;
    line-height: 18px;
    letter-spacing: 0.73px; }
  .c-list_style-b span {
    color: #8c8c00;
    font-size: 15px;
    font-weight: 400;
    line-height: 18px;
    letter-spacing: 1.5px;
    margin-right: 33px; }

.c-title-section, .c-title-section--text-left {
  color: #333333;
  font-weight: 400;
  letter-spacing: 2.46px;
  text-align: center; }
  .c-title-section .title, .c-title-section--text-left .title {
    margin: 0;
    font-size: 20px !important;
    font-weight: 400; }
  .c-title-section span, .c-title-section--text-left span {
    color: #dedeae;
    font-size: 13px;
    letter-spacing: 2px; }

.c-title-section--text-left {
  text-align: left; }
  @media screen and (max-width: 768px) {
    .c-title-section--text-left {
      text-align: center; } }

.c-card-a {
  padding-top: 27px;
  padding-bottom: 43px;
  margin-bottom: 30px; }
  .c-card-a__body {
    text-align: center;
    padding-left: 30px;
    padding-right: 30px; }
    .c-card-a__body .title {
      text-align: center;
      color: #333333;
      font-size: 25px;
      font-weight: 400;
      letter-spacing: 3.08px;
      text-align: center;
      margin-bottom: 15px; }
      .c-card-a__body .title .sub_title {
        display: block;
        margin-bottom: 12px;
        font-size: 16px; }
    .c-card-a__body .c-list_style-a {
      text-align: center; }
    .c-card-a__body .desc {
      text-align: center; }
    .c-card-a__body .link_btn {
      margin-top: 20px; }

/*　ロールアップ　*/
#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 77%;
  z-index: 100; }

#page-top a {
  background: url(img/up.png) no-repeat;
  text-decoration: none;
  color: #fff;
  width: 45px;
  height: 45px;
  text-indent: -99999px;
  display: block; }

#page-top a:hover {
  width: 45x;
  margin-bottom: 0px;
  height: 45px; }

.space {
  border: none;
  display: block;
  height: 10px;
  margin: 15px 0; }

/*タブ*/
.cp_tab *, .cp_tab *:before, .cp_tab *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.cp_tab {
  margin: 1em auto; }

.cp_tab > input[type='radio'] {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
  -webkit-appearance: none;
  appearance: none;
  display: none; }

.cp_tab .cp_tabpanel {
  display: none;
  width: 100%;
  opacity: 0;
  padding: 0.5em 1em;
  transform: translateY(-10px);
  -webkit-transition: opacity 0.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: transform 1.5s, opacity 1.5s;
  transition: transform 1.5s, opacity 1.5s, -webkit-transform 1.5s; }

.cp_tab > input:first-child:checked ~ .cp_tabpanels > .cp_tabpanel:first-child,
.cp_tab > input:nth-child(3):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(2),
.cp_tab > input:nth-child(5):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(3),
.cp_tab > input:nth-child(7):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(4),
.cp_tab > input:nth-child(9):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(5),
.cp_tab > input:nth-child(11):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(6) {
  display: block;
  opacity: 1;
  background: rgba(255, 255, 255, 0.9);
  color: #333;
  box-sizing: border-box;
  padding: 4%; }

.cp_tab > label {
  position: relative;
  display: inline-block;
  padding: 15px 20px;
  cursor: pointer;
  border: 1px solid transparent;
  border-bottom: 0;
  background: rgba(200, 200, 200, 0.87);
  color: #fff; }

.cp_tab > label:hover,
.cp_tab > input:focus + label {
  color: #0066cc; }

.cp_tab > input:checked + label {
  margin-bottom: 6px;
  font-weight: bold;
  background: rgba(255, 255, 255, 0.9);
  color: #333; }

.cp_tab .cp_tabpanel {
  padding: 20px 0px;
  border-top: 1px solid #cccccc; }

/**
layout
 */
/*ACCORDION*/
/***
* div#pa

 */
#panel {
  width: 100%;
  margin-bottom: 30px; }

#panel > h3 {
  border-left: none !important;
  border-bottom: solid 1px white !important;
  background-color: #00779c !important;
  color: #fff !important;
  cursor: pointer;
  padding: 10px !important;
  position: relative;
  margin: 0px auto !important;
  max-width: 96%;
  font-size: 100% !important;
  letter-spacing: 2px; }

#panel > h3:after {
  content: "▼";
  position: absolute;
  right: 10px; }

#panel > .active:after {
  content: "▲";
  position: absolute;
  right: 10px; }

#panel .ac {
  padding: 10px;
  box-sizing: border-box; }

/* お問い合わせフォーム調整 */
.wpcf7-form {
  padding: 20px 0;
  /*ボックス内の余白*/
  margin-top: -50px;
  border-radius: 20px; }

/*ボックスを角丸に指定*/
div.wpcf7 {
  margin: 0;
  padding: 50px 0 0 0px !important; }

.wpcf7-form span.hissu {
  color: #aa0000;
  /*必須の文字色指定*/
  font-size: smaller; }

/*文字サイズを一回り小さく*/
.wpcf7-form textarea {
  width: 80%;
  height: 150px; }

/*テキストエリア幅*/
.wpcf7-form p.submit {
  text-align: left; }

/*送信ボタンの場所*/
.wpcf7-form .wpcf7-submit {
  width: 30%; }

/*送信ボタンの横幅指定*/
/*お問合せ*/
.contact_table {
  width: 100%; }

.contact_table td, .contact_table th {
  padding: 15px 8px;
  font-size: 95%; }

.contact_table td {
  border: 1px solid #ddd;
  padding: 15px 10px; }

.contact_table th {
  background: #C9DDE7;
  min-width: 190px;
  text-align: left;
  border: 1px solid #ccc;
  letter-spacing: 0; }

/*ロゴ*/
.header {
  min-height: 80px;
  position: relative;
  /*for fixed */ }
  .header .logo {
    width: 243px; }
  .header .fix_area {
    position: relative;
    height: 80px; }
  .header_fix {
    width: 100%;
    position: fixed;
    margin: 0 auto;
    top: 0;
    left: 0;
    display: flex;
    height: 133px;
    z-index: 80;
    background: #f7f7ee; }
  .header .inner {
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: "left";
    -webkit-box-pack: "left";
    -ms-flex-pack: "left";
    align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 80px;
    margin: 0 auto; }
    @media screen and (min-width: 769px) {
      .header .inner {
        width: 1080px; } }
    @media screen and (max-width: 768px) {
      .header .inner {
        width: 100%; } }
  .header__nav {
    min-width: 546px;
    margin-left: 243px; }

.footer__inner {
  padding-top: 120px; }

.footer__content {
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: space-between;
  -webkit-box-pack: space-between;
  -ms-flex-pack: space-between;
  align-items: flex-star;
  -webkit-box-align: flex-star;
  -ms-flex-align: flex-star; }
  @media screen and (max-width: 768px) {
    .footer__content {
      flex-direction: column;
      padding: 12px; }
      .footer__content .left {
        margin-bottom: 30px;
        text-align: center; } }
  .footer__content .right {
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    justify-content: space-between;
    -webkit-box-pack: space-between;
    -ms-flex-pack: space-between;
    align-items: flex-star;
    -webkit-box-align: flex-star;
    -ms-flex-align: flex-star; }
    @media screen and (max-width: 768px) {
      .footer__content .right {
        justify-content: center;
        padding: 20px; } }
    @media screen and (max-width: 768px) {
      .footer__content .right ul {
        text-align: left; } }
    .footer__content .right li {
      margin-bottom: 30px;
      padding-left: 56px; }
      @media screen and (max-width: 768px) {
        .footer__content .right li {
          padding: 0;
          text-align: left;
          display: inline-block; } }
      .footer__content .right li .fas {
        padding-right: 18px; }

/*YouTube Googlemap*/
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%; }

.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%; }

.gmap {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden; }

.gmap iframe, .gmap object, .gmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#mapCas {
  width: 90%;
  height: 480px;
  margin: 10px auto; }

.fb_iframe_widget,
.fb_iframe_widget span,
.fb_iframe_widget iframe[style] {
  width: 100% !important; }

/*メインコンテンツ*/
/*サイドバー */
#sidebar {
  margin-left: 20px;
  width: 240px;
  vertical-align: top;
  display: inline-block;
  padding-top: 30px; }

#sidebar h2 {
  color: #8C8B1F;
  border-left: 7px solid #8C8B1F;
  padding: 0px 0 0px 20px;
  margin: 20px 0 20px;
  font-weight: bold; }

#sidebar .sideinfo {
  margin: 15px auto 5px;
  letter-spacing: 1px;
  text-align: left; }

#sidebar .sidemenu ul {
  margin: 10px auto 20px; }

#sidebar .sidemenu ul li {
  margin: 2px auto;
  padding: 12px 0;
  font-size: 100%;
  border-bottom: #0EACB8 solid 1px; }

#sidebar .sidemenu ul li a {
  color: #0EACB8;
  padding: 15px 0 15px 25px;
  position: relative; }

#sidebar .sidemenu ul li a:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  left: 5px;
  box-sizing: border-box;
  width: 6px;
  height: 6px;
  border: 6px solid transparent;
  border-left: 6px solid #0EACB8; }

#sidebar img {
  text-align: center;
  display: block;
  margin: 15px auto; }

#sidebar #list li {
  font-size: 85%; }

#sidebar #list li .footer {
  border: 1px solid #ccc;
  padding: 1px 14px;
  display: inline-block; }

#sidebar .side_contact {
  background: #39d4c4;
  border: 3px solid #7aecf5;
  border-radius: 4px;
  padding: 14px 10px;
  margin: 10px 0;
  box-sizing: border-box;
  color: #fff;
  display: block;
  text-align: center; }

#sidebar #list li .thumb {
  display: inline-block;
  width: 30%;
  vertical-align: top; }

#sidebar #list li .rightCon {
  width: 66%;
  padding: 0 10px;
  display: inline-block;
  vertical-align: top;
  box-sizing: border-box;
  line-height: 140%; }

#sidebar .date {
  color: #888 !important;
  background: none !important; }

#sidebar #list ul li .cat-name {
  position: static;
  display: inline-block;
  background: #eee;
  vertical-align: top;
  margin: 0px;
  width: auto;
  padding: 0 5px !important; }

/**
state
 */
.fixed {
  /*position: fixed;*/
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 9999; }

.hide {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  height: 0px !important;
  padding: 0px !important;
  margin: 0px !important; }

@media screen and (min-width: 769px) {
  .is-md-dn {
    display: none; } }

@media screen and (max-width: 768px) {
  .is-md-dn {
    display: block; } }

@media screen and (min-width: 769px) {
  .is-sm-dn {
    display: block; } }

@media screen and (max-width: 768px) {
  .is-sm-dn {
    display: none; } }

/**
utility
 */
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

.clearfix:before {
  content: "";
  display: block;
  clear: both; }

.clearfix {
  display: block; }

.green {
  color: #00C131 !important; }

.red {
  color: #bc3e3f; }

.u-color-color-dedeae {
  color: #dedeae; }

.mintyo {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

.u-text_center {
  text-align: center; }

.u-text-left {
  text-align: left; }

.u-text-right {
  text-align: right; }

/*文字サイズ・基本装飾*/
.strong {
  font-weight: bold !important; }

.big {
  font-size: 125% !important;
  display: block; }

.v_big {
  font-size: 150% !important; }

.vv_big {
  font-size: 180% !important; }

.blue {
  color: #00A3D9; }

.bun {
  text-indent: 1em; }

.small {
  font-size: 85% !important; }

.v_small {
  font-size: 70% !important; }

.center {
  text-align: center !important;
  display: block !important;
  margin: 10px auto 0 !important; }

.u-postion_center {
  position: relative; }
  .u-postion_center .u-positon_center__target {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0; }

@media screen and (max-width: 768px) {
  .big {
    font-size: 115% !important; }
  .vv_big {
    font-size: 140% !important; }
  .v_big {
    font-size: 120% !important; }
  .longtable {
    overflow-x: scroll; } }

/* ここからがIE8以下透過PNG適用のためのCSS */
html > body .sampleBox {
  background-image: url(img/bg.gif); }

* html .sampleBox {
  filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='img/bg.gif', sizingMethod='scale'); }

.alignright {
  float: right; }

.alignleft {
  float: left; }

/**
theme
 */
/*ワードプレス設定*/
.edit a {
  font-size: 12px;
  background: #007fff;
  color: #fff;
  padding: 1px 3px;
  margin-left: 20px;
  text-decoration: none; }

img.centered {
  display: block;
  margin-left: auto;
  margin-right: auto; }

img.alignright {
  padding: 4px;
  margin: 0 0 2px 7px;
  display: inline; }

img.alignleft {
  padding: 4px;
  margin: 0 7px 2px 0;
  display: inline; }

.more-link, .more-link:hover {
  color: #111111; }

.gallery {
  clear: both; }

/**
* 古いやつ_？
 */
/*新着情報・トピックス*/
.topics_bg {
  width: 100%;
  padding: 120px 0px; }

.title_box, .list_box {
  box-sizing: border-box;
  font-size: 0px;
  letter-spacing: 0px;
  display: inline-block;
  vertical-align: top; }

#list {
  width: 100%;
  margin: 0px auto 0px;
  border-bottom: #888 1px dashed;
  box-sizing: border-box; }

#list ul {
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  max-width: 100%;
  display: inline-block;
  box-sizing: border-box;
  line-height: 180%;
  letter-spacing: 1px; }

#list ul li {
  margin-bottom: 15px;
  font-size: 80%; }

.left_con, .right_con {
  display: inline-block;
  vertical-align: top;
  box-sizing: border-box; }

.left_con {
  width: 25%;
  text-align: center; }

.right_con {
  width: 70%; }

#list li h3 {
  display: block;
  margin: 5px 0px 3px; }

#list li h3 a {
  color: #333; }

#list li .read {
  border: 1px solid #333;
  color: #333;
  padding: 0px 30px;
  font-size: 85%;
  margin: 10px auto;
  display: inline-block; }

#list li .summary {
  font-size: 75%;
  color: #666;
  line-height: 170%; }

#list li .footer {
  margin-top: 3px;
  font-size: 80%;
  text-align: center; }

#list li .footer {
  border: 1px solid #333;
  padding: 3px 5px; }

#list li p {
  font-size: 70%;
  text-align: center;
  color: #333; }

#list li h2 {
  font-size: 150%;
  margin: 0 auto;
  text-align: center;
  color: #333; }

#list li img {
  display: block;
  width: 200px;
  height: auto; }

#list .thumb {
  margin-top: 10px;
  display: block;
  width: 210px;
  /*トリミング後の横幅*/
  height: 150px;
  /*トリミング後の縦幅*/
  overflow: hidden;
  position: relative;
  z-index: 1; }

#list .thumb img {
  max-width: none;
  margin: 0px auto;
  text-align: center;
  display: block;
  top: 50% !important;
  left: 50% !important;
  position: relative;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }

p.thumb img {
  float: left;
  position: absolute;
  max-width: 250px;
  height: auto; }

#list ul li .date {
  color: #0059B2;
  font-weight: bold;
  text-align: left;
  display: inline-block;
  padding: 3px 0px;
  /* position: absolute; */
  /* top: -15px; */
  margin: 0 auto; }

.cat-name {
  color: #fff;
  font-weight: normal;
  font-size: 90%;
  margin: 0 auto;
  display: inline-block;
  /* width: 90px; */
  z-index: 100;
  text-align: center;
  background: #333;
  margin: 0 8px;
  padding: 0px 4px !important; }

.readmore {
  display: block;
  float: right; }

.topicsall {
  text-align: right;
  display: block; }

.topicsall a {
  padding: 3px 10px;
  border-radius: 30px;
  background: #0059B2;
  color: #fff;
  margin: 10px auto;
  display: inline-block;
  text-align: center;
  font-size: 85%; }

/*カテゴリー用記事リスト*/
#page #list ul {
  text-align: left; }

#page #list ul li {
  margin: 5px;
  padding: 5px;
  /*min-height: 140px;*/ }

#sidebar #list ul {
  padding: 0 !important; }

#sidebar #list ul li {
  margin: 5px 0px !important;
  padding: 5px 0px !important; }

#page #list .thumb {
  max-width: 100%;
  height: auto; }

#page #list .thumb img {
  /*top: 50%!important;*/
  left: 0% !important;
  position: relative;
  width: 100%;
  -webkit-transform: translate(0%, 0%);
  -ms-transform: translate(0%, 0%);
  transform: translate(0%, 0%); }

.seven_box .date {
  color: #00a5d9; }

.seven_box .cat-name {
  background: #00a5d9;
  color: #fff;
  padding: 1px 4px;
  font-size: 90%; }

.archive-list {
  font-size: 80%; }

.year {
  font-style: italic;
  font-weight: inherit; }

.month-archive-list li {
  margin: 5px 0px; }

.t-home_info .wrap_bg {
  background-image: url(".././images/info_bg.jpg");
  background-position: center;
  background-size: cover;
  max-height: 640px;
  height: 640px; }

.t-home_info .c-title-section, .t-home_info .c-title-section--text-left {
  margin-top: 125px; }

.t-home_info .desc {
  margin-top: 52px;
  font-size: 17px; }

.t-home_info .link_btn {
  margin-top: 95px; }

.t-home_info .fix_area {
  max-height: 274px;
  height: 274px;
  position: relative; }
  .t-home_info .fix_area .fix_img {
    position: absolute;
    right: 0;
    top: -65px;
    width: calc(1141/1280*100%);
    height: 340px;
    background-image: url(".././images/sashikomi.jpg");
    background-position: center;
    background-size: cover; }
    @media screen and (max-width: 768px) {
      .t-home_info .fix_area .fix_img {
        position: inherit;
        height: 274px;
        width: 100%; } }

.t-home_shop {
  padding-top: 96px;
  padding-bottom: 92px; }

.t-home_news {
  padding: 62px 108px 34px;
  background-color: #f1f1e9; }
  @media screen and (max-width: 768px) {
    .t-home_news {
      padding: 62px  10px 34px; } }
  .t-home_news__left {
    height: auto;
    border-right: 2px solid;
    width: calc(211/1280*100%); }
    .t-home_news__left .title {
      margin: 0; }
    @media screen and (max-width: 768px) {
      .t-home_news__left {
        border-right: 0;
        width: 100%; } }
  .t-home_news__right {
    height: auto;
    padding-left: 12px; }
    @media screen and (max-width: 768px) {
      .t-home_news__right {
        width: 100%; } }
  .t-home_news__footer {
    margin-top: 30px;
    align-items: flex-end; }
    @media screen and (max-width: 768px) {
      .t-home_news__footer {
        text-align: center; } }

.t-home_guid {
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: space-between;
  -webkit-box-pack: space-between;
  -ms-flex-pack: space-between;
  align-items: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  flex-wrap: wrap;
  margin: 0;
  padding: 0; }
  .t-home_guid__left {
    width: 50%;
    height: 370px;
    background: url(".././images/02.jpg");
    background-size: cover; }
    @media screen and (max-width: 768px) {
      .t-home_guid__left {
        width: 100%; } }
  .t-home_guid__right {
    width: 50%;
    padding-left: 90px;
    box-sizing: border-box; }
    @media screen and (max-width: 768px) {
      .t-home_guid__right {
        padding: 0;
        width: 100%;
        justify-content: space-around;
        padding: 20px;
        text-align: center; } }
  .t-home_guid__body {
    margin-top: 36px; }
    @media screen and (max-width: 768px) {
      .t-home_guid__body .desc p {
        text-align: center; } }
  .t-home_guid__footer {
    margin-top: 60px; }

.t-home_image_section {
  height: 343px;
  width: 100%;
  background: url(".././images/foot_bg.jpg");
  background-size: cover;
  background-position: center; }
