@charset "UTF-8";
/* アニメーションベンダープレフィックス込み指定 */
/* アニメーションベンダープレフィックス込み指定 */
body {
  color: #221815;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: .1em; }

a {
  color: #8588de;
  text-decoration: none;
  transition: all 0.3s ease; }

.opacity img {
  transition: all 0.3s ease; }
.opacity:hover {
  opacity: .6; }
  .opacity:hover img {
    opacity: .6; }

img {
  max-width: 100%;
  height: auto; }

/* loader
----------------------------------*/
.loader {
  align-items: center;
  background: #fff;
  bottom: 0;
  display: flex;
  justify-content: center;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 8999; }
  .loader::after {
    animation: loader 1s linear infinite;
    border: 1px solid #99576a;
    border-radius: 50%;
    border-right: 1px solid rgba(153, 87, 106, 0.2);
    border-top: 1px solid rgba(153, 87, 106, 0.2);
    content: '';
    height: 70px;
    width: 70px; }

@keyframes loader {
  0% {
    transform: rotate(0); }
  100% {
    transform: rotate(360deg); } }
@keyframes hd-scrolled {
  0% {
    opacity: 0;
    transform: translate(0, -100%); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
/* header
----------------------------------*/
#header {
  position: relative;
  border-top: 3px solid #8588de; }
  #header .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    width: 1200px;
    margin: 0 auto;
    padding: 15px 0; }
    #header .inner #logo {
      width: 400px; }
      @media screen and (max-width: 667px) {
        #header .inner #logo {
          width: 85%; } }
    #header .inner .navi {
      display: flex;
      justify-content: space-around;
      flex-wrap: wrap; }
      #header .inner .navi li {
        padding: 15px 12px; }
        #header .inner .navi li a {
          position: relative;
          display: inline-block;
          text-align: center;
          color: #221815;
          font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
          font-weight: bold; }
          #header .inner .navi li a::after {
            position: absolute;
            bottom: .3em;
            left: 0;
            content: '';
            width: 100%;
            height: 1px;
            background-color: #99576a;
            opacity: 0;
            transition: .3s; }
          #header .inner .navi li a:hover::after, #header .inner .navi li a.active::after {
            bottom: 0;
            opacity: 1; }
          #header .inner .navi li a span {
            display: block;
            font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
            font-size: 1.4rem; }

/* page-top
----------------------------------*/
#page-top {
  position: fixed;
  bottom: 10px;
  right: 0;
  z-index: 9999; }

/* footer
----------------------------------*/
#footer {
  text-align: center; }
  #footer .inner {
    width: 1024px;
    margin: auto;
    padding: 10px 0; }
    #footer .inner .copyright {
      font-size: 1rem; }
    #footer .inner .navi {
      display: flex;
      justify-content: space-around;
      flex-wrap: wrap; }
      #footer .inner .navi li {
        padding: 15px 12px; }
        #footer .inner .navi li a {
          position: relative;
          display: inline-block;
          text-align: center;
          color: #221815;
          font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
          font-weight: bold; }
          #footer .inner .navi li a::after {
            position: absolute;
            bottom: .3em;
            left: 0;
            content: '';
            width: 100%;
            height: 1px;
            background-color: #99576a;
            opacity: 0;
            transition: .3s; }
          #footer .inner .navi li a:hover::after, #footer .inner .navi li a.active::after {
            bottom: 0;
            opacity: 1; }
          #footer .inner .navi li a span {
            display: block;
            font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
            font-size: 1.4rem; }
      @media screen and (max-width: 1024px) {
        #footer .inner .navi {
          display: none; } }

/* contact_btn
----------------------------------*/
.contact_btn {
  display: flex;
  justify-content: center;
  text-align: center;
  margin-top: 30px; }
  .contact_btn li {
    width: 40%;
    margin: 0 2%; }
    .contact_btn li a {
      display: block;
      background: #FFFFFF;
      padding: .7em 0;
      color: #99576a;
      text-align: center;
      font-size: 2rem; }
      .contact_btn li a:before {
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        margin-right: 10px;
        color: #99576a; }
      .contact_btn li a.tel_btn:before {
        content: "\f095"; }
      .contact_btn li a.mail_btn:before {
        content: "\f0e0"; }
      .contact_btn li a.fax_btn:before {
        content: "\f1ac"; }
      .contact_btn li a.access_btn:before {
        content: "\f3c5"; }

.link_btn {
  display: flex;
  justify-content: center;
  text-align: center;
  margin-top: 30px; }
  .link_btn li {
    width: 40%;
    margin: 0 2%; }
    .link_btn li a {
      display: block;
      background: #99576a;
      padding: .7em 0;
      color: #fff;
      text-align: center;
      font-size: 2rem; }
      .link_btn li a:before {
        font-family: "Font Awesome 5 Free";
        font-weight: 700;
        margin-right: 10px;
        color: #fff;
        content: "\f103"; }

/* sp
----------------------------------*/
#sp_navi, #humberger, #drawernav {
  display: none; }

/* slidepro_wrapper
----------------------------------*/
#slidepro_wrapper {
  position: relative; }
  #slidepro_wrapper #slidepro {
    width: 1024px;
    margin: 0 auto;
    position: relative; }

/* slideshow
----------------------------------*/
#slideshow {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: 100%;
  max-height: 100vh;
  margin-bottom: 70px; }
  #slideshow #catch {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    width: 500px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    animation: fadeIn 6s ease 0s 1 normal;
    -webkit-animation: fadeIn 6s ease 0s 1 normal; }
  #slideshow .next_contents {
    display: block;
    position: absolute;
    z-index: 2;
    bottom: 3%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    padding-top: 60px; }
    #slideshow .next_contents span {
      position: absolute;
      top: 0;
      left: 50%;
      width: 30px;
      height: 50px;
      margin-left: -15px;
      border: 2px solid #fff;
      border-radius: 50px;
      box-sizing: border-box; }
      #slideshow .next_contents span::before {
        position: absolute;
        top: 10px;
        left: 50%;
        content: '';
        width: 6px;
        height: 6px;
        margin-left: -3px;
        background-color: #fff;
        border-radius: 100%;
        -webkit-animation: sdb 2s infinite;
        animation: sdb 2s infinite;
        box-sizing: border-box; }

.swiper-slide {
  overflow: hidden; }

.slide-img {
  overflow: hidden;
  height: 100vh; }
  .slide-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    font-family: "object-fit: cover;"; }

/* contents
----------------------------------*/
.single {
  margin: auto;
  width: 1024px;
  padding-bottom: 50px; }
  .single.btm {
    padding-bottom: 100px; }

.single_02 {
  width: 860px;
  padding-top: 20px; }

.single_03 {
  width: 100%; }

.contents {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .contents .main {
    width: 70%; }
  .contents .side {
    width: 26%; }

/* bg
----------------------------------*/
.bg_common {
  padding-top: 50px; }

.bg_b {
  margin-bottom: 60px; }

.bg_01 {
  background-image: url(../img/bg_01.jpg);
  background-repeat: repeat;
  background-position: center;
  color: #FFFFFF; }

.bg_02 {
  background: #F4F4FF; }

.bg_03 {
  background-image: url(../img/bg_03.png);
  background-repeat: no-repeat;
  background-position: top right; }

/*
.bg_03 {
 background-image: url(../img/bg_03_01.png),url(../img/bg_03_02.png);
 background-repeat: no-repeat, no-repeat;
 background-position: top right, bottom left;
 background-attachment: scroll, scroll;
}
*/
/* mtitle
----------------------------------*/
.mtitle_big {
  position: relative;
  margin-bottom: 30px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 3.2rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.2; }
  .mtitle_big span {
    display: block;
    color: #99576a;
    font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 2rem; }
  .mtitle_big.mtitle_big_white span {
    color: #FFFFFF; }
  .mtitle_big.sub {
    color: #8588de;
    line-height: 1.5em;
    font-weight: bold; }

.mtitle {
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 4rem;
  color: #8588de;
  letter-spacing: .2em; }

.mtitle_middle {
  position: relative;
  margin-bottom: 30px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 2.4rem;
  font-weight: normal;
  text-align: center;
  line-height: 1.2; }
  .mtitle_middle:after {
    content: "";
    width: 80px;
    height: 1px;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    bottom: -15px;
    background: #8588de; }

.mtitle_small {
  margin-bottom: 10px;
  padding-bottom: 5px;
  color: #99576a;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 2rem;
  font-weight: normal; }

.mtitle_sub {
  position: relative;
  margin-bottom: 10px;
  padding-left: 20px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.8rem;
  font-weight: bold; }
  .mtitle_sub:before {
    content: "";
    background-color: #8588de;
    width: 10px;
    height: 4px;
    position: absolute;
    top: .6em;
    left: 0; }

/* btn
----------------------------------*/
.cbtn {
  margin-top: 30px; }
  .cbtn a, .cbtn button {
    display: table;
    background: transparent;
    border: 1px solid #99576a;
    border-radius: 50px;
    color: #99576a;
    padding: .7em 4em;
    margin: 0 auto; }
    .cbtn a:after, .cbtn button:after {
      font-family: "Font Awesome 5 Free";
      font-weight: 900;
      content: "\f105";
      margin-left: 10px; }
    .cbtn a:hover, .cbtn button:hover {
      background: #99576a;
      color: #FFFFFF; }
  .cbtn.cbtn_white a {
    background: #FFFFFF;
    border: 1px solid #FFFFFF;
    color: #99576a; }
    .cbtn.cbtn_white a:hover {
      background: transparent;
      color: #FFFFFF; }

/* news
----------------------------------*/
.news-bl {
  overflow: hidden; }
  .news-bl dt {
    float: left;
    width: 8em;
    padding: 3px 5px;
    line-height: 1.3;
    background: #8588de;
    color: #FFFFFF;
    text-align: center; }
  .news-bl dd {
    padding: 0 0 10px 10em;
    line-height: 1.6;
    border-bottom: 1px dotted #CCCCCC;
    margin: 0 0 10px; }
    .news-bl dd:last-child {
      margin: 0;
      border-bottom: none; }

/* tbl
----------------------------------*/
.tbl {
  background: #FFFFFF;
  width: 100%; }
  .tbl th, .tbl td {
    vertical-align: middle;
    border: 1px solid #CCCCCC;
    padding: 10px; }
  .tbl th {
    background: #F5F5F5;
    font-weight: initial; }

.tbl_01 th {
  width: 30%; }

.tbl_new {
  width: 100%;
  background: #FFFFFF; }
  .tbl_new tr th, .tbl_new tr td {
    vertical-align: top;
    padding: 10px; }
  .tbl_new tr th {
    font-weight: initial;
    width: 20%;
    text-align: left; }
  .tbl_new tr:nth-child(odd) th, .tbl_new tr:nth-child(odd) td {
    background: #F5F5F5; }

.company {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 5px; }
  .company th, .company td {
    padding: 10px;
    vertical-align: middle; }
  .company th {
    text-align: left;
    width: 20%;
    position: relative;
    background: #99576a;
    color: #FFFFFF;
    font-weight: normal; }
    .company th::after {
      left: 100%;
      top: 50%;
      border: solid transparent;
      content: " ";
      height: 0;
      width: 0;
      position: absolute;
      pointer-events: none;
      border-color: #FFFFFF;
      border-width: 10px;
      border-left-color: #99576a;
      margin-top: -10px; }
  .company td {
    background: #FFFFFF;
    padding-left: 20px;
    border: 1px solid #99576a; }

/* tbl_scroll */
.tbl_scroll {
  padding-bottom: 10px;
  overflow: auto;
  white-space: nowrap; }
  .tbl_scroll::-webkit-scrollbar {
    height: 5px; }
  .tbl_scroll::-webkit-scrollbar-track {
    background: #F1F1F1; }
  .tbl_scroll::-webkit-scrollbar-thumb {
    background: #BCBCBC; }

/* ggmap
----------------------------------*/
.ggmap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden; }
  .ggmap iframe, .ggmap object, .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.page {
  min-height: 400px; }
  .page .fb_iframe_widget,
  .page .fb_iframe_widget span,
  .page .fb_iframe_widget iframe[style] {
    width: 100% !important; }

/* sns_list
----------------------------------*/
.sns_list {
  /*
  display: flex;
  justify-content: start;
  flex-wrap: wrap;
  margin-bottom: -3%;
  li {
   width: 31.3%;
   margin: 0 3% 3% 0;
   &:nth-child(3n) {
    margin: 0 0 3% 0;
   }
  }
  */ }
  .sns_list li {
    margin-bottom: 15px; }
    .sns_list li:last-child {
      margin-bottom: 0; }

.sns_btn {
  overflow: hidden;
  color: #FFFFFF;
  position: relative;
  display: block;
  border-radius: 7px;
  height: 60px;
  text-align: center;
  line-height: 60px;
  vertical-align: middle; }
  .sns_btn:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
  .sns_btn i {
    font-size: 2rem;
    position: relative;
    top: 3px;
    margin-right: 10px; }
  .sns_btn span {
    display: inline-block;
    position: relative;
    transition: .5s; }
  .sns_btn:hover {
    color: #FFFFFF; }
    .sns_btn:hover span {
      -webkit-transform: rotateX(360deg);
      -ms-transform: rotateX(360deg);
      transform: rotateX(360deg); }

.facebook_btn {
  background: #4267b2; }

.insta_btn {
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat; }
  .insta_btn:before {
    background: -webkit-linear-gradient(15deg, #ffdb2c, #f9764c 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
    background: linear-gradient(15deg, #ffdb2c, #f9764c 25%, rgba(255, 77, 64, 0) 50%) no-repeat; }

.line_btn {
  background: #00b82b; }

/* column
----------------------------------*/
.half {
  display: flex;
  justify-content: space-between; }
  .half .child {
    width: 50%; }

.triple {
  display: flex;
  justify-content: space-between; }
  .triple .child {
    width: 33.3%; }

.column2, .column2_2 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: -3%; }
  .column2 .child, .column2_2 .child {
    width: 48.44%;
    margin: 0 3% 3% 0; }
    .column2 .child:nth-child(2n), .column2_2 .child:nth-child(2n) {
      margin: 0 0 3% 0; }

.column3, .column3_2, .column3_1 {
  display: flex;
  justify-content: center;
  flex-wrap: wrap; }
  .column3.c_l, .column3_2.c_l, .column3_1.c_l {
    justify-content: flex-start; }
  .column3 .child, .column3_2 .child, .column3_1 .child {
    width: 31.3%;
    margin: 0 3% 3% 0; }
    .column3 .child:nth-child(3n), .column3_2 .child:nth-child(3n), .column3_1 .child:nth-child(3n) {
      margin: 0 0 3% 0; }

.column4 {
  display: flex;
  justify-content: start;
  flex-wrap: wrap; }
  .column4 .child {
    width: 22.7%;
    margin: 0 3% 3% 0; }
    .column4 .child:nth-child(4n) {
      margin: 0 0 3% 0; }

.column5 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .column5 .child {
    width: 18.4%;
    margin: 0 2% 3% 0; }
    .column5 .child:nth-child(5n) {
      margin: 0 0 3% 0; }

/* list
----------------------------------*/
.list_common li {
  padding-bottom: 10px;
  padding-left: 1rem;
  margin-bottom: 10px;
  border-bottom: 1px dotted #CCCCCC; }
  .list_common li:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none; }
  .list_common li:before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin: 0 5px 0 -1rem;
    color: #99576a;
    padding: 1px; }

.list_check li:before {
  content: "\f058";
  color: #8588de; }

.list_note {
  font-size: 1.3rem; }
  .list_note li {
    margin-bottom: 5px;
    padding-left: 1.5em; }
    .list_note li:last-child {
      margin-bottom: 0; }
    .list_note li:before {
      content: "※";
      margin: 0 5px 0 -1.5em;
      color: #FF0000; }

.list_disc li {
  margin-bottom: 5px;
  padding-left: 1.5em; }
  .list_disc li:last-child {
    margin-bottom: 0; }
  .list_disc li:before {
    content: "・";
    margin: 0 5px 0 -1.5em;
    color: #8588de; }

.list_line li {
  position: relative;
  display: inline-block;
  padding: 0 10px; }
  .list_line li:after {
    position: absolute;
    right: 0;
    content: "/"; }
  .list_line li:last-child:after {
    display: none; }

.list_macker {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 30px;
  text-align: center;
  font-size: 1.1em;
  font-weight: bold; }
  .list_macker li {
    width: 18.4%;
    margin: 0 2% 1% 0; }
    .list_macker li:nth-child(5n) {
      margin: 0 0 1% 0; }

.rounded-list {
  counter-reset: li;
  padding-left: 1em;
  list-style: none; }
  .rounded-list li {
    position: relative;
    padding: .4em .4em .4em 2em;
    margin: .5em 0;
    background: #fafafa;
    border-radius: .3em;
    transition: all .3s ease-out;
    box-sizing: border-box; }
    .rounded-list li:before {
      content: counter(li);
      counter-increment: li;
      position: absolute;
      left: -1.3em;
      top: 50%;
      margin-top: -1.3em;
      background: #8588de;
      color: #FFFFFF;
      height: 2em;
      width: 2em;
      line-height: 2em;
      border: .3em solid #fff;
      text-align: center;
      font-weight: bold;
      border-radius: 2em;
      transition: all .3s ease-out; }

/* box_style
----------------------------------*/
.box_style {
  overflow: hidden;
  padding: 50px; }
  .box_style:nth-child(even) {
    background: #f5f4e1; }

/* article
----------------------------------*/
.article {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  border: 1px solid #CCCCCC; }
  .article .article_image {
    width: 60%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center; }
  .article .article_image2 {
    width: 30%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center; }
  .article .article_detail {
    width: 40%;
    box-sizing: border-box;
    padding: 50px 0; }
    .article .article_detail .inner {
      margin: 0 auto;
      width: 80%; }
  .article .article_detail2 {
    width: 70%;
    box-sizing: border-box;
    padding: 50px 0; }
    .article .article_detail2 .inner {
      margin: 0 auto;
      width: 85%; }
  .article.article_01 .article_image {
    background-image: url(../img/article_01.jpg); }
  .article.article_02 .article_image, .article.article_02 .article_image2 {
    background-image: url(../img/article_02.jpg); }
  .article.article_03 .article_image {
    background-image: url(../img/article_03.jpg);
    background-position: top; }
  .article.article_04 .article_image {
    background-image: url(../img/article_04.jpg); }
  .article.article_05 .article_image {
    background-image: url(../img/article_05.jpg); }
  .article.article_06 .article_image {
    background-image: url(../img/article_06.jpg);
    background-position: bottom; }
  .article.article_07 .article_image {
    background-image: url(../img/article_07.jpg); }
  .article.article_b {
    margin-bottom: 60px; }

/* gallery_ul
----------------------------------*/
.gallery_ul {
  display: flex;
  justify-content: start;
  flex-wrap: wrap; }
  .gallery_ul li {
    width: 31.3%;
    margin: 0 3% 3% 0;
    text-align: center; }
    .gallery_ul li:nth-child(3n) {
      margin: 0 0 3% 0; }
    .gallery_ul li a {
      display: block;
      overflow: hidden;
      height: 220px;
      position: relative; }
      .gallery_ul li a img {
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        width: 100%;
        height: auto; }
    .gallery_ul li span {
      display: block;
      margin-top: 5px;
      font-size: 1.2rem; }

/* blog entry 2column */
#blog_flexwrap {
  display: -webkit-flex;
  display: flex;
  width: 860px;
  margin: 20px auto 100px; }
  #blog_flexwrap #blog_side {
    width: 300px;
    margin-left: 20px; }
  #blog_flexwrap #blog_main {
    flex: 1; }
    #blog_flexwrap #blog_main section {
      margin-bottom: 25px; }

/* blog side */
.blog_sttl01 {
  color: #8588de;
  text-indent: 5px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.3em;
  padding: 5px 0 5px 10px;
  text-align: left;
  margin-bottom: 10px;
  font-weight: 900;
  border-bottom: 2px solid #8588de; }
  .blog_sttl01:before {
    font-family: "Font Awesome 5 free";
    font-weight: 900;
    content: "\f0c9";
    margin-right: 5px; }

/* blog main */
.blog_mttl {
  width: calc(100% - 20px);
  background: #f1f1f1;
  color: #8588de;
  font-size: 1.8rem;
  overflow: hidden;
  font-weight: bold;
  border-left: 2px solid #8588de;
  margin: 0px 0 20px;
  padding: 5px 10px;
  line-height: 1.8; }

.blog_time {
  padding-top: 0px;
  font-weight: normal; }
  .blog_time:before {
    font-family: "Font Awesome 5 free";
    font-weight: 900;
    content: "\f017";
    margin-right: 5px;
    font-weight: normal; }

.blog_box {
  min-height: 500px;
  position: relative; }
  .blog_box img {
    max-width: 100%;
    padding: 15px 0; }

.pages {
  position: absolute;
  bottom: -100px;
  width: 100%;
  right: 0; }

.page_next {
  float: left;
  text-align: left;
  width: 48%; }

.page_prev {
  float: right;
  text-align: right;
  width: 48%; }
  .page_prev a {
    display: block;
    padding: 5px 10px;
    background: #8588de; }

.page_next a {
  display: block;
  padding: 5px 10px;
  background: #8588de; }

.page_prev a:hover, .page_next a:hover {
  opacity: 0.7; }

.page_prev a:link, .page_prev a:visited, .page_prev a:hover {
  color: #fff; }

.page_next a:link, .page_next a:visited, .page_next a:hover {
  color: #fff; }

.list_flex {
  padding: 5px 0;
  font-size: 15px;
  font-weight: normal;
  overflow: hidden;
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  .list_flex li {
    width: calc(33% - 20px);
    background: #8588de;
    color: #fff;
    padding: 15px 10px;
    margin-bottom: 5px;
    border-radius: 5px; }
    .list_flex li:before {
      font-family: "Font Awesome 5 Free";
      font-weight: 900;
      content: "\f0a9";
      margin-right: 5px; }
    .list_flex li:nth-child(3n+2):last-child {
      margin-right: 33.4%; }
    @media screen and (max-width: 768px) {
      .list_flex li {
        width: calc(100% - 0px); }
        .list_flex li:nth-child(3n+2):last-child {
          margin-right: 100%; } }

.listFlow li {
  margin-bottom: 9px;
  padding-bottom: 9px; }
.listFlow .lastItem {
  margin-bottom: 0;
  padding-bottom: 0;
  background: none; }
.listFlow h4 {
  font-size: 20px;
  font-weight: normal;
  border-bottom: solid 1px #ccc;
  margin-bottom: 10px;
  overflow: hidden; }
.listFlow dl {
  display: table;
  width: 100%; }
  .listFlow dl dt {
    display: table-cell;
    padding: 10px 0;
    border: 1px solid #8588de;
    width: 100px;
    background: #8588de;
    font-size: 1.8rem;
    font-weight: normal;
    color: #fff;
    text-align: center;
    vertical-align: middle;
    line-height: 1.2; }
    .listFlow dl dt .num {
      display: block;
      font-size: 3rem; }
  .listFlow dl dd {
    display: table-cell;
    padding: 15px 20px;
    border-top: 1px solid #c8c8c8;
    border-right: 1px solid #c8c8c8;
    border-bottom: 1px solid #c8c8c8;
    vertical-align: middle;
    background-color: white; }

@media screen and (max-width: 800px) {
  .listFlow h4 {
    font-size: 18px;
    font-weight: normal;
    border-bottom: solid 1px #ccc;
    margin-bottom: 5px;
    overflow: hidden; }
  .listFlow dl {
    display: block;
    width: 100%; }
    .listFlow dl dt {
      display: block;
      padding: 5px 0;
      width: 100%;
      border: none; }
      .listFlow dl dt .num {
        display: block; }
    .listFlow dl dd {
      display: block;
      padding: 15px 10px;
      border: none; } }
/* blog_side_list */
.blog_side_list {
  position: relative;
  margin: 0 0 0px !important;
  padding: 0 !important;
  width: 100% !important;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start; }
  .blog_side_list .blog_bx {
    /*アニメーション*/
    transition: .3s ease-in-out;
    width: calc(100% - 0px) !important;
    font-size: 12px;
    margin-bottom: 10px;
    border: 1px solid #ccc;
    position: relative;
    padding: 10px 10px 10px; }
    .blog_side_list .blog_bx a {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      z-index: 1; }
    .blog_side_list .blog_bx .blog_bx_flex {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; }
      .blog_side_list .blog_bx .blog_bx_flex div {
        width: calc(100% - 120px); }
    .blog_side_list .blog_bx:hover {
      background: #f2f2f2; }
    .blog_side_list .blog_bx figcaption {
      display: block;
      text-align: center;
      width: 100px;
      height: 100px;
      overflow: hidden;
      background-color: #fff;
      background-position: center center;
      background-repeat: no-repeat;
      float: left; }
    .blog_side_list .blog_bx * {
      -moz-transition: 0.3s;
      -ms-transition: 0.3s;
      -o-transition: 0.3s;
      transition: 0.3s; }
    .blog_side_list .blog_bx p {
      line-height: 1.6em;
      font-size: 15px; }
    .blog_side_list .blog_bx img {
      vertical-align: middle;
      height: 100px;
      width: 100%;
      object-fit: cover; }
    .blog_side_list .blog_bx:hover img {
      opacity: 1 !important;
      transform: scale(1.1); }
    .blog_side_list .blog_bx .ttl {
      font-weight: bold;
      font-size: 12px;
      color: #fff;
      float: left;
      background: #99576a;
      padding: 0 15px;
      margin-bottom: 5px; }
    .blog_side_list .blog_bx .ttm {
      float: right;
      padding-top: 0px;
      font-size: 12px;
      font-weight: bold; }
      .blog_side_list .blog_bx .ttm:before {
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        content: "\f017";
        margin-right: 5px;
        font-weight: normal; }
    .blog_side_list .blog_bx .blog_ttl {
      clear: both;
      font-weight: 900; }

/* blog_top_list */
.blog_top_list {
  position: relative;
  margin: 0 0 0px !important;
  padding: 0 !important;
  width: 100% !important;
  /* height: auto; */
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start; }
  .blog_top_list .blog_bx {
    /*アニメーション*/
    transition: .3s ease-in-out;
    width: 90% !important;
    font-size: 12px;
    margin: 10px;
    border: 1px solid #ccc;
    position: relative;
    padding: 10px 10px 10px;
    background: #fff; }
    .blog_top_list .blog_bx a {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      z-index: 1; }
    .blog_top_list .blog_bx .blog_bx_flex {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; }
      .blog_top_list .blog_bx .blog_bx_flex div {
        width: 100%; }
    .blog_top_list .blog_bx:hover {
      background: #f2f2f2; }
    .blog_top_list .blog_bx figcaption {
      display: block;
      text-align: center;
      width: 100%;
      height: 200px;
      overflow: hidden;
      background-color: #fff;
      background-position: center center;
      background-repeat: no-repeat;
      float: none;
      margin-bottom: 15px; }
    .blog_top_list .blog_bx * {
      -moz-transition: 0.3s;
      -ms-transition: 0.3s;
      -o-transition: 0.3s;
      transition: 0.3s; }
    .blog_top_list .blog_bx p {
      line-height: 1.6em;
      font-size: 13px; }
    .blog_top_list .blog_bx img {
      vertical-align: middle;
      height: 100%;
      width: 100%;
      object-fit: cover; }
    .blog_top_list .blog_bx:hover img {
      opacity: 1 !important;
      transform: scale(1.1); }
    .blog_top_list .blog_bx .ttl {
      font-weight: bold;
      font-size: 12px;
      color: #fff;
      float: left;
      background: #99576a;
      padding: 0 15px;
      margin-bottom: 5px;
      font-weight: bold; }
    .blog_top_list .blog_bx .ttm {
      float: right;
      padding-top: 0px;
      font-size: 13px;
      font-weight: bold; }
      .blog_top_list .blog_bx .ttm:before {
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        content: "\f017";
        margin-right: 5px;
        font-weight: normal; }
    .blog_top_list .blog_bx .blog_ttl {
      clear: both;
      font-weight: bold; }
    .blog_top_list .blog_bx .blog_text {
      margin-top: 5px; }

@media screen and (max-width: 768px) {
  .blog_top_list .blog_bx {
    /*アニメーション*/
    width: calc(100% - 22px) !important;
    margin: 0px 0 20px; }
    .blog_top_list .blog_bx figcaption {
      height: 200px; } }
@media screen and (max-width: 768px) {
  /* 2column */
  #blog_flexwrap {
    display: -webkit-block;
    display: block;
    width: 95%;
    margin: 20px auto 30px; }
    #blog_flexwrap #blog_main {
      background: #fff;
      width: 100%;
      flex: 1;
      margin-bottom: 20px; }
    #blog_flexwrap #blog_side {
      width: 100%;
      margin-left: 0px; }

  .pages {
    position: static;
    bottom: 0;
    width: 100%;
    margin-top: 30px; }

  .page_next {
    float: none;
    width: 100%;
    margin-bottom: 10px; }

  .page_prev {
    float: none;
    text-align: left;
    width: 100%; } }
/* item_flow
----------------------------------*/
.item_flow .cut {
  position: relative; }
.item_flow .item_flow_num {
  position: absolute;
  top: 20px;
  left: 20px;
  line-height: 35px;
  width: 35px;
  height: 35px;
  background-color: #8588de;
  color: #FFFFFF;
  text-align: center;
  transform: rotate(-45deg);
  text-align: center; }
  .item_flow .item_flow_num span {
    display: block;
    font-size: 2rem;
    transform: rotate(45deg); }
.item_flow .item_flow_ttl {
  margin: 20px 0;
  font-size: 2.5rem;
  padding-left: 80px; }

/* slide_list
----------------------------------*/
.slide_list {
  display: flex;
  position: relative;
  text-align: center; }
  .slide_list li {
    margin-right: 3%; }
    .slide_list li img {
      width: auto;
      height: 120px; }
  .slide_list.slide_list_02 li img {
    height: 200px; }

/* length
----------------------------------*/
.length {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-text-orientation: upright;
  text-orientation: upright;
  text-align: left;
  line-height: 2.4;
  font-size: 1.6rem;
  height: 450px;
  margin: 0 auto;
  width: 860px; }
  .length .mtitle, .length .text {
    margin-left: 30px; }
  .length .image {
    margin: 250px 30px 0 0;
    width: 300px; }

/* product_image
----------------------------------*/
.product_image {
  margin-bottom: 10px; }

.product_name {
  text-align: center;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.1em;
  font-weight: bold; }

.product_text {
  font-size: .9em; }

.product_price {
  text-align: center; }
  .product_price .num {
    margin-right: 5px;
    font-size: 1.2em;
    font-weight: bold; }

/* etc
----------------------------------*/
.cut {
  overflow: hidden;
  zoom: 1; }

/* page_title
----------------------------------*/
#page_title_box {
  background-image: url(../img/bg_01.jpg);
  background-repeat: repeat;
  background-position: center;
  color: #FFFFFF;
  padding: 40px 0 1px;
  text-align: center; }

/* breadcrumb_box
----------------------------------*/
.breadcrumb_box {
  padding-top: 15px;
  margin-bottom: 30px; }
  .breadcrumb_box .breadcrumb {
    margin: 0 auto;
    width: 1024px;
    padding-left: 0;
    font-size: 1.4rem; }
    .breadcrumb_box .breadcrumb li {
      display: inline; }
      .breadcrumb_box .breadcrumb li + li:before {
        margin: 0 10px;
        content: ">"; }
      .breadcrumb_box .breadcrumb li .home {
        font-family: "Font Awesome 5 Free";
        font-weight: 900; }

/* form
----------------------------------*/
.form .required {
  background: #FF4F4F;
  color: #FFFFFF;
  padding: 0 5px 0;
  margin-right: 5px;
  font-size: 1.1rem;
  border-radius: 2px;
  position: relative;
  top: -2px; }
.form .textarea, .form textarea {
  border: 1px solid #ddd;
  padding: 5px;
  width: 100%;
  border-radius: 0;
  -webkit-appearance: none;
  box-sizing: border-box; }
.form .textarea {
  height: 30px; }
.form .textarea02 {
  width: 48.5%;
  margin-right: 3%; }
  .form .textarea02:last-child {
    margin-right: 0; }
.form .textarea03 {
  width: 20%;
  margin-right: 1%; }
.form button {
  display: block;
  cursor: pointer;
  transition: all 0.2s ease-in-out 0s;
  border: none;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 1.6rem;
  border: 1px solid #99576a; }
.form label.radio_text {
  cursor: pointer;
  position: relative;
  margin-right: 20px;
  overflow: hidden;
  padding-left: 20px;
  display: inline-block; }
  .form label.radio_text:before {
    position: absolute;
    width: 15px;
    height: 15px;
    border: 1px solid #ccc;
    border-radius: 50%;
    left: 0px;
    top: 2px;
    content: '';
    z-index: 3; }
  .form label.radio_text:after {
    content: '';
    position: absolute;
    width: 11px;
    height: 11px;
    border-radius: 100%;
    left: 3px;
    top: 5px;
    background-color: #8588de;
    z-index: 1; }
  .form label.radio_text input[type="radio"] {
    -moz-appearance: none;
    -webkit-appearance: none;
    position: absolute;
    z-index: 2;
    width: 20px;
    height: 20px;
    left: -23px;
    top: 0px;
    margin: 0px;
    box-shadow: 20px -1px #FFFFFF; }
    .form label.radio_text input[type="radio"]:checked {
      box-shadow: none; }
    .form label.radio_text input[type="radio"]:focus {
      opacity: 0.2;
      box-shadow: 20px -1px #eeebda; }
.form label.checkbox_text {
  cursor: pointer;
  position: relative;
  padding-left: 25px;
  margin-right: 20px;
  overflow: hidden;
  display: inline-block;
  box-sizing: border-box; }
  .form label.checkbox_text:before {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    left: 0px;
    top: 0;
    border: 1px solid #ccc;
    z-index: 3; }
  .form label.checkbox_text:after {
    content: '';
    position: absolute;
    top: 40%;
    left: 5px;
    display: block;
    margin-top: -9px;
    width: 8px;
    height: 12px;
    border-right: 3px solid #8588de;
    border-bottom: 3px solid #8588de;
    transform: rotate(45deg);
    z-index: 1; }
  .form label.checkbox_text input[type="checkbox"] {
    -moz-appearance: none;
    -webkit-appearance: none;
    position: absolute;
    left: -40px;
    width: 20px;
    height: 20px;
    display: block;
    box-shadow: 41px 0px #FFF;
    z-index: 2;
    margin: 0px;
    padding: 0px; }
    .form label.checkbox_text input[type="checkbox"]:checked {
      box-shadow: none; }
      .form label.checkbox_text input[type="checkbox"]:checked:focus {
        box-shadow: 40px 0px #666;
        opacity: 0.1; }
    .form label.checkbox_text input[type="checkbox"]:focus {
      box-shadow: 41px 0px #EEE; }

/* newsbox */
.newsbox {
  display: -webkit-flex;
  display: flex;
  width: 100%;
  margin: 0 auto; }

.news-ttl {
  width: 300px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  vertical-align: middle;
  text-align: left;
  color: #8588de;
  font-size: 3.5rem;
  font-weight: normal;
  border-right: 3px solid #8588de;
  line-height: 1.2; }
  .news-ttl span {
    font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 2rem;
    display: block;
    color: #555; }

.news-bx {
  flex: 1;
  width: calc(100% - 20px);
  padding: 0 10px; }

.news {
  overflow: hidden;
  line-height: 1.6;
  margin: 10px auto 0; }
  .news dt {
    float: left;
    width: 8em;
    font-weight: bold; }
  .news dd {
    padding-left: 8em;
    border-bottom: 1px solid #ccc;
    margin-bottom: 8px;
    padding-bottom: 5px; }

@media screen and (max-width: 768px) {
  .newsbox {
    flex-direction: column; } }
/*カレンダー*/
.calendar {
  width: 100%; }

.calendar table {
  margin: 10px 0;
  line-height: 2.6;
  width: 100%; }

.calendar table th {
  text-align: center;
  vertical-align: middle;
  background-color: #FFF209;
  padding: 5px 2px;
  font-weight: normal;
  line-height: 1.5;
  border: #4f5a3f 1px solid;
  width: 14%; }

.calendar table td {
  padding-left: 2px;
  padding-right: 2px;
  background-color: #FFF;
  height: 60px;
  border: #4f5a3f 1px solid;
  width: 14%;
  line-height: 2;
  vertical-align: top;
  font-size: 12px; }

.calendar table td .item {
  color: #db2e24;
  text-align: center; }

.calendar td.off {
  background: #fbd4d4; }

.table_jisseki td {
  text-align: right;
  padding-right: 45px; }

/*#calendar div.calendar:nth-child(1){
	float:left;
	width:50%;
	padding:0;
	margin:0;

}

#calendar div.calendar:nth-child(2){
	float:left;
	width:50%;
	padding:0;
	margin:0;
}*/
.calendar_head {
  padding: 0px 10px 0 10px;
  font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 20px;
  font-weight: bold;
  color: #E83E43; }

.calendar_body {
  padding: 0px 10px 10px 10px; }

/* スマホ */
@media screen and (max-width: 600px) {
  #calendar div.calendar:nth-child(1) {
    float: none;
    width: auto; }

  #calendar div.calendar:nth-child(2) {
    float: none;
    width: auto; } }
.snip1445 {
  float: left;
  position: relative;
  overflow: hidden;
  margin: 0px 1% 10px;
  width: 31.3%;
  color: #ffffff;
  text-align: center;
  font-size: 16px;
  background-color: #500c20; }
  .snip1445 * {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all 0.55s ease;
    transition: all 0.55s ease; }
    .snip1445 *:before, .snip1445 *:after {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      -webkit-transition: all 0.55s ease;
      transition: all 0.55s ease; }
  .snip1445 img {
    max-width: 100%;
    backface-visibility: hidden;
    vertical-align: top;
    opacity: 0.5; }
  .snip1445 figcaption {
    position: absolute;
    bottom: 25px;
    left: 25px;
    padding: 5px 10px 10px; }
    .snip1445 figcaption:before, .snip1445 figcaption:after {
      height: 2px;
      width: 800px;
      position: absolute;
      content: '';
      background-color: #ffffff; }
    .snip1445 figcaption:before {
      top: 0;
      left: 0;
      -webkit-transform: translateX(100%);
      transform: translateX(100%); }
    .snip1445 figcaption:after {
      bottom: 0;
      right: 0;
      -webkit-transform: translateX(-100%);
      transform: translateX(-100%); }
    .snip1445 figcaption div:before, .snip1445 figcaption div:after {
      width: 2px;
      height: 600px;
      position: absolute;
      content: '';
      background-color: #ffffff; }
    .snip1445 figcaption div:before {
      top: 0;
      left: 0;
      -webkit-transform: translateY(100%);
      transform: translateY(100%); }
    .snip1445 figcaption div:after {
      bottom: 0;
      right: 0;
      -webkit-transform: translateY(-100%);
      transform: translateY(-100%); }
  .snip1445 h2, .snip1445 h4 {
    margin: 0; }
  .snip1445 h2 {
    font-size: 4rem;
    line-height: 1.4;
    color: #fff;
    font-family: "YakuHanJP","Josefin Sans","sans-serif";
    font-weight: bold; }
  .snip1445 h4 {
    display: block;
    font-weight: normal;
    font-size: 1.4rem;
    letter-spacing: 5px;
    background-color: #ffffff;
    padding: 0px 10px;
    color: #000000; }
  .snip1445 a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }
  .snip1445:hover img, .snip1445.hover img {
    zoom: 1;
    filter: alpha(opacity=50);
    -webkit-opacity: 0.5;
    opacity: 0.9; }
  .snip1445:hover figcaption:before, .snip1445.hover figcaption:before, .snip1445:hover figcaption:after, .snip1445.hover figcaption:after, .snip1445:hover figcaption div:before, .snip1445.hover figcaption div:before, .snip1445:hover figcaption div:after, .snip1445.hover figcaption div:after {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0); }
  .snip1445:hover figcaption:before, .snip1445.hover figcaption:before, .snip1445:hover figcaption:after, .snip1445.hover figcaption:after {
    -webkit-transition-delay: 0.15s;
    transition-delay: 0.15s; }

/* link_block
----------------------------------*/
.link_block {
  position: relative;
  background: #f4f4ff; }
  .link_block::before, .link_block::after {
    display: block;
    content: "";
    width: 0;
    height: 1px;
    position: absolute;
    background: #8588de;
    -webkit-transition: all 0.4s 0s ease;
    transition: all 0.4s 0s ease;
    -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  .link_block::before {
    left: 0;
    top: 0; }
  .link_block::after {
    right: 0;
    bottom: 0; }
  .link_block a {
    display: block;
    padding: 15px;
    color: #221815;
    font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.8rem;
    font-weight: bold;
    -webkit-transition: all 0.4s 0s ease;
    transition: all 0.4s 0s ease;
    -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
    .link_block a::before, .link_block a::after {
      display: block;
      content: "";
      width: 1px;
      height: 0;
      position: absolute;
      background: #8588de;
      -webkit-transition: all 0.4s 0s ease;
      transition: all 0.4s 0s ease;
      -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
      transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
    .link_block a::before {
      left: 0;
      top: 0; }
    .link_block a::after {
      right: 0;
      bottom: 0; }
    .link_block a .image {
      margin-bottom: 15px; }
    .link_block a figcaption {
      position: relative;
      font-family: "YakuHanJP", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif; }
      .link_block a figcaption .icon_link_arrow {
        position: absolute;
        top: 50%;
        right: 0;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%); }
        .link_block a figcaption .icon_link_arrow:before {
          font-family: "Font Awesome 5 Free";
          content: "\f101";
          color: #8588de; }
    .link_block a p {
      background: #8588de;
      color: #fff;
      font-weight: normal;
      font-size: 1.5rem;
      padding-left: 3%;
      margin-top: 5px; }
  .link_block:hover::before, .link_block:hover::after {
    width: 100%; }
  .link_block:hover a::before, .link_block:hover a::after {
    height: 100%; }

.calendar {
  width: 460px; }

.calendar table {
  margin: 10px 0;
  line-height: 2.6;
  width: 100%; }

.calendar table th {
  text-align: center;
  vertical-align: middle;
  background-color: #99576a;
  padding: 5px 2px;
  font-weight: normal;
  line-height: 1.5;
  border: #99576a 1px solid;
  width: 14%;
  color: #fff; }

.calendar table td {
  padding-left: 2px;
  padding-right: 2px;
  background-color: #FFF;
  height: 60px;
  border: #99576a 1px solid;
  width: 14%;
  line-height: 2;
  vertical-align: top;
  font-size: 12px; }

.calendar table td .item {
  color: #db2e24;
  text-align: center; }

.calendar td.off {
  background: #fbd4d4; }

.table_jisseki td {
  text-align: right;
  padding-right: 45px; }

#calendar div.calendar:nth-child(1) {
  float: left;
  width: 50%;
  padding: 0;
  margin: 0; }

#calendar div.calendar:nth-child(2) {
  float: left;
  width: 50%;
  padding: 0;
  margin: 0; }

.calendar_head {
  padding: 0px 10px 0 10px;
  font-size: 16px;
  font-weight: bold;
  color: #8588de; }

.calendar_body {
  padding: 0px 10px 10px 10px; }

/* スマホ */
@media screen and (max-width: 600px) {
  #calendar div.calendar:nth-child(1) {
    float: none;
    width: auto; }

  #calendar div.calendar:nth-child(2) {
    float: none;
    width: auto; } }
.policy {
  padding: 30px;
  border: 1px solid #8588de;
  background: #fff;
  border-radius: 5px; }
