@charset "UTF-8";
/*!
* html5doctor.com Reset Stylesheet v1.6.1 (http://html5doctor.com/html-5-reset-stylesheet/)
* Richard Clark (http://richclarkdesign.com)
* http://cssreset.com
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0px;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-weight: normal;
  vertical-align: baseline;
  background: transparent; }

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

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

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

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #4d4d4d;
  margin: 5px 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

.flL {
  float: left; }

.flR {
  float: right; }

.clb {
  clear: both; }

.taL {
  text-align: left; }

.taR {
  text-align: right; }

.taC {
  text-align: center; }

.position-8 {
  position: relative;
  top: 8px; }

.position-10 {
  position: relative;
  top: 10px; }

.imgR {
  float: right;
  margin: 10px 0px 5px 10px;
  width: 150px; }
  @media screen and (max-width: 960px) {
    .imgR {
      float: none;
      margin: 5px auto 5px auto;
      width: 150px; } }

.imgL {
  float: left;
  margin: 5px 10px 5px 0;
  width: 200px; }
  .imgL p {
    text-align: left;
    font-size: 14px;
    line-height: 1.5;
    color: #fff;
    margin-top: 0px;
    padding-top: 0; }
  @media screen and (max-width: 960px) {
    .imgL {
      float: none;
      margin: 5px auto 5px auto;
      width: 100%; } }

.img60 {
  width: 60%;
  margin: auto; }
  @media screen and (max-width: 960px) {
    .img60 {
      width: 100%; } }

.img70 {
  width: 70%;
  margin: auto; }
  @media screen and (max-width: 960px) {
    .img70 {
      width: 100%; } }

.img80 {
  width: 80%;
  margin: auto; }
  @media screen and (max-width: 960px) {
    .img80 {
      width: 100%; } }

.img90 {
  width: 90%;
  margin: auto; }
  @media screen and (max-width: 960px) {
    .img90 {
      width: 100%; } }

.red {
  color: #FF0000; }

.purple {
  color: #282AA0; }

.blue {
  color: #A4C0FF; }

.white {
  color: #fff; }

.black {
  color: #000; }

.bgW {
  background-color: #fff; }

.bgG {
  background-color: #606f62; }

.bgP {
  background-color: #524161; }

.bgR {
  background-color: #D0232C; }

.bgY {
  background-color: #ED6307; }

.bgB {
  background-color: #2C438D; }

.bgB-dark {
  background-color: #313D6B; }

.bgH {
  background-color: #464646; }

.pl10 {
  padding-left: 10px; }

.p20 {
  padding: 10px 20px; }

.mt10 {
  margin-top: 10px; }

.mt20 {
  margin-top: 20px; }

.mt30 {
  margin-top: 30px; }

.mt50 {
  margin-top: 50px; }

.mb10 {
  margin-bottom: 10px; }

.mb20 {
  margin-bottom: 20px; }

.mr30 {
  margin-right: 30px; }

.ml10 {
  margin-left: 10px; }

.pt0 {
  padding-top: 0px; }

.pt10 {
  padding-top: 10px; }

.pt20 {
  padding-top: 20px; }

.pt30 {
  padding-top: 30px; }

.foSS {
  font-size: 60%; }

.foSSS {
  font-size: 40%; }

.foS {
  font-size: 80%; }

.foM {
  font-size: 100%; }

.foL {
  font-size: 120%; }

.foLL {
  font-size: 140%; }

.foSB {
  font-size: 0.6em;
  font-weight: bold; }

.foMB {
  font-size: 1.0em;
  font-weight: bold; }

.foLB {
  font-size: 1.2em;
  font-weight: bold; }

.foLLB {
  font-size: 1.4em;
  font-weight: bold; }

.foB {
  font-weight: bold; }

.strong {
  font-weight: bold; }

.caption {
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 5px;
  margin-bottom: 5px;
  color: #ADA95D; }

.grid4, .grid2, .grid3, .grid3-5, .grid5, .grid6, .grid7, .grid8, .grid9, .grid10, .grid12 {
  width: 31.3%;
  margin: 10px 1%  0px;
  float: left; }
  @media screen and (max-width: 960px) {
    .grid4, .grid2, .grid3, .grid3-5, .grid5, .grid6, .grid7, .grid8, .grid9, .grid10, .grid12 {
      width: 98%; } }
  .grid4 img, .grid2 img, .grid3 img, .grid3-5 img, .grid5 img, .grid6 img, .grid7 img, .grid8 img, .grid9 img, .grid10 img, .grid12 img {
    width: 100%;
    margin: 0px 0 0; }
    @media screen and (max-width: 960px) {
      .grid4 img, .grid2 img, .grid3 img, .grid3-5 img, .grid5 img, .grid6 img, .grid7 img, .grid8 img, .grid9 img, .grid10 img, .grid12 img {
        width: 100%;
        margin: 0px 0% 0; } }

.grid2 {
  width: 14.6%; }
  @media screen and (max-width: 960px) {
    .grid2 {
      width: 48%; } }

.grid3 {
  width: 23%; }
  @media screen and (max-width: 960px) {
    .grid3 {
      width: 98%; } }

.grid3-5 {
  width: 27%; }
  @media screen and (max-width: 960px) {
    .grid3-5 {
      width: 98%; } }

.grid5 {
  width: 39.6%; }
  @media screen and (max-width: 960px) {
    .grid5 {
      width: 98%; } }

.grid6 {
  width: 48%; }
  @media screen and (max-width: 960px) {
    .grid6 {
      width: 98%; } }

.grid7 {
  width: 56.3%; }
  @media screen and (max-width: 960px) {
    .grid7 {
      width: 98%; } }

.grid8 {
  width: 64.6%; }
  @media screen and (max-width: 960px) {
    .grid8 {
      width: 98%; } }

.grid9 {
  width: 73%; }
  @media screen and (max-width: 960px) {
    .grid9 {
      width: 98%; } }

.grid10 {
  width: 81.3%; }
  @media screen and (max-width: 960px) {
    .grid10 {
      width: 98%; } }

.grid12 {
  width: 98%; }

.space1 {
  width: 6.3%;
  margin: 10px 1%  10px;
  float: left; }
  @media screen and (max-width: 960px) {
    .space1 {
      display: none; } }

.space2 {
  width: 14.6%;
  margin: 10px 1%  10px;
  float: left; }
  @media screen and (max-width: 960px) {
    .space2 {
      display: none; } }

.space3 {
  width: 23%;
  margin: 10px 1%  10px;
  float: left; }
  @media screen and (max-width: 960px) {
    .space3 {
      display: none; } }

.space4 {
  width: 31%;
  margin: 10px 1%  10px;
  float: left; }
  @media screen and (max-width: 960px) {
    .space4 {
      display: none; } }

.space1-5 {
  width: 10.5%;
  margin: 10px 1%  10px;
  float: left; }
  @media screen and (max-width: 960px) {
    .space1-5 {
      display: none; } }

.bd {
  margin-top: 10px;
  border: 1px solid #b3b3b3;
  padding: 20px; }

.table-bd40, .table-bd60, .table-bd80, .table-bd90, .table-bd95, .table-bd100 {
  margin: 10px auto;
  width: 40%;
  border-collapse: collapse;
  background-color: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 2; }
  @media screen and (max-width: 520px) {
    .table-bd40, .table-bd60, .table-bd80, .table-bd90, .table-bd95, .table-bd100 {
      width: 98%; } }
  .table-bd40 th, .table-bd60 th, .table-bd80 th, .table-bd90 th, .table-bd95 th, .table-bd100 th {
    border: 1px #999 solid;
    padding: 2px auto;
    text-align: center;
    background-color: #cccccc;
    font-weight: normal;
    vertical-align: middle; }
  .table-bd40 td, .table-bd60 td, .table-bd80 td, .table-bd90 td, .table-bd95 td, .table-bd100 td {
    border: 1px #999 solid;
    padding: 2px 5px;
    text-align: center;
    vertical-align: middle; }
    @media screen and (max-width: 520px) {
      .table-bd40 td, .table-bd60 td, .table-bd80 td, .table-bd90 td, .table-bd95 td, .table-bd100 td {
        text-align: center;
        padding: 2px; } }

.table-bd60 {
  width: 60%; }
  @media screen and (max-width: 520px) {
    .table-bd60 {
      width: 98%; } }

.table-bd80 {
  width: 80%; }
  @media screen and (max-width: 520px) {
    .table-bd80 {
      width: 98%; } }

.table-bd90 {
  width: 90%; }
  @media screen and (max-width: 520px) {
    .table-bd90 {
      width: 98%; } }

.table-bd95 {
  width: 95%; }
  @media screen and (max-width: 520px) {
    .table-bd95 {
      width: 98%; } }

.table-bd100 {
  width: 100%; }
  @media screen and (max-width: 520px) {
    .table-bd100 {
      width: 98%; } }

/*cell width*/
.w5p {
  width: 5%; }

.w10p {
  width: 10%; }

.w15p {
  width: 15%; }

.w20p {
  width: 20%; }

.w25p {
  width: 25%; }

.w30p {
  width: 30%; }

.w35p {
  width: 35%; }

.w40p {
  width: 40%; }

.w45p {
  width: 45%; }

.w50p {
  width: 50%; }

.w55p {
  width: 55%; }

.w60p {
  width: 60%; }

.w65p {
  width: 65%; }

.w70p {
  width: 70%; }

.w75p {
  width: 75%; }

.w80p {
  width: 80%; }

.swiper-container {
  width: 100%;
  height: auto; }

.slide-img img {
  width: 100%; }

.swiper-slide {
  position: relative; }

.swiper-slide .slide-content {
  position: absolute;
  text-align: center;
  width: 90%;
  position: absolute;
  top: 88%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #FFF;
  font-size: 40px;
  letter-spacing: 0.1em;
  font-weight: normal;
  text-shadow: black 3px 0px 0px, black 2.83487px 0.981584px 0px, black 2.35766px 1.85511px 0px, black 1.62091px 2.52441px 0px, black 0.705713px 2.91581px 0px, black -0.287171px 2.98622px 0px, black -1.24844px 2.72789px 0px, black -2.07227px 2.16926px 0px, black -2.66798px 1.37182px 0px, black -2.96998px 0.42336px 0px, black -2.94502px -0.571704px 0px, black -2.59586px -1.50383px 0px, black -1.96093px -2.27041px 0px, black -1.11013px -2.78704px 0px, black -0.137119px -2.99686px 0px, black 0.850987px -2.87677px 0px, black 1.74541px -2.43999px 0px, black 2.44769px -1.73459px 0px, black 2.88051px -0.838247px 0px; }
  @media screen and (min-width: 520px) and (max-width: 960px) {
    .swiper-slide .slide-content {
      top: 80%;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      color: #FFF;
      font-size: 26px; } }
  @media screen and (max-width: 520px) {
    .swiper-slide .slide-content {
      top: 80%;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      color: #FFF;
      font-size: 15px; } }

.swiper-slide .slide-content-s {
  position: absolute;
  text-align: center;
  width: 80%;
  max-width: 600px;
  position: absolute;
  bottom: 10%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #FFF;
  font-size: 40px;
  letter-spacing: 0.1em;
  font-weight: normal;
  text-shadow: black 3px 0px 0px, black 2.83487px 0.981584px 0px, black 2.35766px 1.85511px 0px, black 1.62091px 2.52441px 0px, black 0.705713px 2.91581px 0px, black -0.287171px 2.98622px 0px, black -1.24844px 2.72789px 0px, black -2.07227px 2.16926px 0px, black -2.66798px 1.37182px 0px, black -2.96998px 0.42336px 0px, black -2.94502px -0.571704px 0px, black -2.59586px -1.50383px 0px, black -1.96093px -2.27041px 0px, black -1.11013px -2.78704px 0px, black -0.137119px -2.99686px 0px, black 0.850987px -2.87677px 0px, black 1.74541px -2.43999px 0px, black 2.44769px -1.73459px 0px, black 2.88051px -0.838247px 0px; }
  @media screen and (min-width: 520px) and (max-width: 960px) {
    .swiper-slide .slide-content-s {
      bottom: 10%;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      color: #FFF;
      font-size: 26px; } }
  @media screen and (max-width: 520px) {
    .swiper-slide .slide-content-s {
      bottom: 10%;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      color: #FFF;
      font-size: 15px; } }

@-webkit-keyframes fadein {
  0% {
    opacity: 0; }
  20% {
    opacity: 1; }
  100% {
    opacity: 1; } }

@keyframes fadein {
  0% {
    opacity: 0; }
  20% {
    opacity: 1; }
  100% {
    opacity: 1; } }
.swiper-slide-active .slide-content {
  -webkit-animation: fadein 6s ease-in-out 0s 1 normal both;
          animation: fadein 6s ease-in-out 0s 1 normal both; }

@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1); }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2); } }

@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1); }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2); } }
.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img {
  -webkit-animation: zoomUp 11s linear 0s 1 normal both;
          animation: zoomUp 11s linear 0s 1 normal both; }

.slide-img img {
  display: block; }

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

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden; }

.cf:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden; }

.forP {
  display: inline; }
  @media screen and (max-width: 960px) {
    .forP {
      display: none; } }

.forPT {
  display: inline; }
  @media screen and (max-width: 520px) {
    .forPT {
      display: none; } }

.forTS {
  display: none; }
  @media screen and (max-width: 960px) {
    .forTS {
      display: inline; } }

.forS {
  display: none; }
  @media screen and (max-width: 520px) {
    .forS {
      display: inline; } }

a {
  color: #74004B;
  text-decoration: none; }
  a:link, a:visited {
    text-decoration: none; }
  a:hover {
    text-decoration: underline;
    color: #4d4d4d; }
  a:active {
    text-decoration: none; }

html {
  overflow-y: scroll;
  font-size: 62.5%;
  color: #333333; }

body {
  -webkit-text-size-adjust: 100%;
  font-size: 16px;
  font-size: 1.6rem;
  font-family: 'ヒラギノ角ゴ ProN W3','Lucida Grande','Hiragino Kaku Gothic ProN', Meiryo, メイリオ, sans-serif;
  line-height: 1.5;
  margin: 0;
  padding: 0px;
  background-color: #fff;
  color: #333333;
  min-width: 1240px; }
  @media screen and (max-width: 960px) {
    body {
      min-width: 0px; } }

.container {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh; }

.header {
  position: relative;
  width: 100%;
  background: #fff;
  height: 130px;
  margin-bottom: 20px; }
  @media screen and (max-width: 960px) {
    .header {
      margin-bottom: 10px;
      height: 150px; } }
  .header .btn-menu {
    position: absolute;
    bottom: 30px;
    right: 40px; }
    @media screen and (max-width: 960px) {
      .header .btn-menu {
        width: 300px;
        left: 50%;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
        bottom: 20px; } }
    .header .btn-menu ul {
      margin: 0;
      padding: 0;
      list-style: none; }
    .header .btn-menu li {
      float: left;
      display: inline;
      padding: 0;
      margin: 0;
      margin-left: 10px;
      background-color: #fff; }
      .header .btn-menu li a {
        display: block;
        border: 1px solid gray;
        padding: 1px 0px 0;
        text-decoration: none;
        color: #4d4d4d;
        margin: 0px;
        text-align: center;
        font-size: 14px;
        font-size: 1.4rem;
        font-weight: lighter;
        width: 137px;
        -webkit-transition-duration: 0.3s;
                transition-duration: 0.3s; }
      .header .btn-menu li a:hover {
        background-color: #981E56;
        color: #fff; }
      .header .btn-menu li .now {
        background-color: #6B8268;
        color: #fff; }

.logo {
  position: absolute;
  top: 10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 360px; }
  @media screen and (max-width: 960px) {
    .logo {
      width: 300px;
      left: 65%;
      -webkit-transform: translateX(-65%);
              transform: translateX(-65%); } }

.tel {
  position: absolute;
  top: 70px;
  left: 40px;
  width: 300px; }
  @media screen and (min-width: 520px) and (max-width: 960px) {
    .tel {
      top: 15px;
      left: 20px;
      width: 160px; } }
  @media screen and (max-width: 520px) {
    .tel {
      top: 15px;
      left: 20px; } }

.wrap, .wrap-90p, .wrap-80p, .wrap-70p, .wrap-60p, .wrap-55p, .wrap-832 {
  overflow: hidden;
  width: 1240px;
  margin: 0px auto 50px; }
  @media screen and (max-width: 960px) {
    .wrap, .wrap-90p, .wrap-80p, .wrap-70p, .wrap-60p, .wrap-55p, .wrap-832 {
      width: 96%;
      margin: 0px auto 30px; } }

.wrap-90p {
  width: 1116px; }
  @media screen and (max-width: 960px) {
    .wrap-90p {
      width: 96%; } }

.wrap-80p {
  width: 992px; }
  .wrap-80p img {
    border: 2px solid #b3b3b3; }
  @media screen and (max-width: 960px) {
    .wrap-80p {
      width: 96%; } }

.wrap-70p {
  width: 868px; }
  @media screen and (max-width: 960px) {
    .wrap-70p {
      width: 96%; } }

.wrap-60p {
  width: 744px; }
  @media screen and (max-width: 960px) {
    .wrap-60p {
      width: 96%; } }

.wrap-55p {
  width: 682px; }
  .wrap-55p img {
    border: 2px solid #b3b3b3; }
  @media screen and (max-width: 960px) {
    .wrap-55p {
      width: 96%; } }

.wrap-832 {
  width: 832px; }
  @media screen and (max-width: 960px) {
    .wrap-832 {
      width: 96%; } }

.bread {
  padding-left: 20px;
  text-align: left;
  color: gray;
  font-size: 14px;
  margin-top: 10px;
  margin-bottom: 20px; }
  @media screen and (max-width: 960px) {
    .bread {
      font-size: 12px; } }
  .bread a {
    color: #4d4d4d;
    text-decoration: none; }
  .bread a:hover {
    color: gray;
    text-decoration: underline; }

.h2 {
  margin: 0px 0 10px;
  padding: 5px;
  width: 100%;
  color: #fff;
  text-align: center;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.5;
  border-radius: 8px; }
  @media screen and (max-width: 960px) {
    .h2 {
      font-size: 18px;
      font-size: 1.8rem; } }

.h3 {
  margin: 10px 0 10px;
  color: #033184;
  padding: 0 20px;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.4;
  text-align: justify; }
  @media screen and (max-width: 960px) {
    .h3 {
      font-size: 16px;
      font-size: 1.6rem;
      padding: 0 10px; } }

.h4 {
  margin: 10px 0 10px;
  color: #333333;
  padding: 0 20px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  text-align: justify; }
  @media screen and (max-width: 960px) {
    .h4 {
      padding: 0 10px; } }

.h5 {
  text-align: center;
  background-color: #4d4d4d;
  color: #e6e6e6;
  padding: 4px;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.5; }
  @media screen and (max-width: 960px) {
    .h5 {
      font-size: 16px;
      font-size: 1.6rem; } }

p {
  margin-top: 10px;
  color: #333333;
  padding: 0 20px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5; }
  @media screen and (max-width: 960px) {
    p {
      padding: 0 10px; } }

.index-main {
  float: left;
  width: 700px; }
  @media screen and (max-width: 960px) {
    .index-main {
      margin: 0px 0px 0px 0px;
      width: 100%; } }

.info {
  margin-bottom: 20px; }
  @media screen and (max-width: 960px) {
    .info {
      margin: 0px 0px 20px 0px;
      width: 100%; } }
  .info dl {
    margin-top: 5px;
    color: #4d4d4d;
    padding: 0 10px;
    font-size: 14px;
    font-size: 1.4rem; }
  .info dl dt {
    float: left;
    width: 12em;
    padding: 5px 0.5em; }
    @media screen and (max-width: 520px) {
      .info dl dt {
        float: none;
        padding: 5px 0.5em 0px; } }
  .info dl dd {
    margin-left: 0;
    padding: 5px 0.5em 5px 12em;
    border-bottom: solid 1px #b3b3b3; }
    .info dl dd:last-child {
      border-bottom: 0px; }
    @media screen and (max-width: 520px) {
      .info dl dd {
        padding: 0px 0.5em 5px 2em; } }

.side-block {
  float: right;
  width: 360px;
  margin-top: 30px;
  margin-bottom: 30px; }
  @media screen and (max-width: 960px) {
    .side-block {
      width: 98%;
      float: none;
      margin-left: auto;
      margin-right: auto; } }

.index-bnr {
  padding: 5px;
  text-align: center;
  border: 1px solid #999;
  background-color: #333333;
  width: 360px;
  margin: 10px 0;
  color: #fff;
  font-size: 11pt;
  line-height: 140%; }
  @media screen and (max-width: 960px) {
    .index-bnr {
      clear: both;
      float: none;
      width: 280px;
      margin: 10px auto  0px; } }

.calendar {
  width: 100%;
  margin: 30px 0 0 0; }
  .calendar p {
    margin: 10px 10px 0px 10px;
    color: #b3b3b3;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.5; }
  @media screen and (max-width: 960px) {
    .calendar {
      clear: both;
      float: none;
      width: 100%;
      margin: 10px auto  0px; } }
  .calendar img {
    width: 100%;
    margin: 0px 0 0; }
    @media screen and (max-width: 960px) {
      .calendar img {
        width: 80%;
        margin: 0px 10% 0; } }

.bnr {
  margin: 50px 1% 0px;
  border-radius: 5px;
  text-align: center; }
  @media screen and (max-width: 960px) {
    .bnr {
      margin: 10px 10% 0px;
      width: 80%; } }
  .bnr img {
    width: 100%;
    margin: 15px 0% 0px 0%;
    border-radius: 5px; }
    @media screen and (max-width: 960px) {
      .bnr img {
        width: 80%; } }

.index-slider {
  overflow: hidden;
  border: 1px solid #b3b3b3;
  background: -webkit-gradient(linear, left top, left bottom, from(#c60101), to(#520102));
  background: linear-gradient(to bottom, #c60101, #520102);
  margin: 0px auto 20px;
  width: 960px;
  height: auto;
  padding: 20px; }
  @media screen and (max-width: 960px) {
    .index-slider {
      width: 96%;
      padding: 5px; } }
  .index-slider p {
    color: #fff;
    margin-left: 20px; }
    @media screen and (max-width: 960px) {
      .index-slider p {
        margin-left: 10px; } }
  .index-slider .slider-h2 {
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1.0;
    color: #fff;
    margin-left: 20px;
    padding-top: 5px;
    padding-bottom: 10px; }
    @media screen and (max-width: 960px) {
      .index-slider .slider-h2 {
        margin-left: 10px; } }
  .index-slider .slider-h1 {
    margin-left: 10px;
    margin-top: 80px; }
    @media screen and (max-width: 960px) {
      .index-slider .slider-h1 {
        margin-top: 0;
        display: none; } }
  .index-slider .slider-h1-story {
    margin-left: -20px;
    margin-top: 0px; }
    @media screen and (max-width: 960px) {
      .index-slider .slider-h1-story {
        margin-top: 0;
        display: none; } }
  .index-slider .nivo {
    width: 630px;
    height: auto;
    margin: 0px 0 0px 290px; }
    @media screen and (max-width: 960px) {
      .index-slider .nivo {
        width: auto;
        height: auto;
        margin: 0px 0 0px 0px; } }

.to-cost {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  float: left;
  text-align: left;
  margin-top: 10px;
  margin-left: 20px;
  padding: 0px 20px;
  border-radius: 5px;
  font-size: 14px;
  font-size: 1.4rem;
  background-color: #008080; }
  .to-cost a {
    color: #fff;
    text-decoration: none; }
  .to-cost a:hover {
    color: #fff;
    text-decoration: underline; }

.extend {
  float: right;
  text-align: right;
  padding: 0px 20px;
  color: #4B51A7;
  font-size: 14px;
  font-size: 1.4rem; }

.story-grp {
  width: 100%;
  height: auto;
  margin: 10px auto 0px;
  clear: both;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap; }

.story-part {
  width: 190px;
  height: auto;
  margin: 0px 6px 10px;
  border: 1px solid #CCC;
  padding: 5px; }
  @media screen and (min-width: 520px) and (max-width: 960px) {
    .story-part {
      width: 24%;
      margin: 0px 0.5% 10px; } }
  @media screen and (max-width: 520px) {
    .story-part {
      width: 48%;
      margin: 0px 1% 10px; } }

.story-part img {
  display: block;
  margin: auto; }

.story-part p {
  text-align: left;
  font-size: 0.8em;
  line-height: 1.2em;
  text-align: justify; }

.before {
  position: relative;
  width: 23%;
  margin: 10px 1%  0px;
  float: left; }
  @media screen and (max-width: 960px) {
    .before {
      width: 48%; } }
  .before .triangle {
    z-index: 1;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    right: -18px; }

.after {
  width: 23%;
  margin: 10px 1%  0px;
  float: left; }
  @media screen and (max-width: 960px) {
    .after {
      width: 48%; } }

.work {
  float: left;
  width: 100%;
  margin: 0px; }
  @media screen and (max-width: 960px) {
    .work {
      margin: 0px 0px 0px 0px;
      width: 100%; } }
  .work dl {
    margin-top: 5px;
    color: #4d4d4d;
    padding: 0 10px;
    font-size: 14px;
    font-size: 1.4rem; }
  .work dl dt {
    float: left;
    width: 85%;
    padding: 5px 0.5em; }
    @media screen and (max-width: 520px) {
      .work dl dt {
        width: 100%;
        float: none;
        padding: 5px 0.5em 5px; } }
  .work dl dd {
    text-align: right;
    margin-left: 0px;
    padding: 5px 0.5em 5px 5px;
    border-bottom: dotted 1px gray; }
    .work dl dd:last-child {
      border-bottom: 0px; }
    @media screen and (max-width: 520px) {
      .work dl dd {
        padding: 0px 0.5em 5px 10em; } }

.cost {
  text-align: left;
  font-size: 18px;
  color: #FC001B;
  margin-bottom: 10px; }
  .cost a:link, .cost a:visited {
    display: block;
    color: #e6e6e6;
    text-decoration: none;
    background: #333333 url("../img/midasi.png") no-repeat 0px -18px;
    padding: 15px 30px 5px 80px; }
  .cost a:hover {
    color: #e6e6e6;
    background: #333333 url("../img/midasi_on.png") no-repeat 0px -18px; }

.meisai {
  width: 100%;
  text-align: center;
  margin-top: 40px;
  border: 1px solid gray;
  padding: 5px; }

.h2-cost-midasi {
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 3.0;
  color: #e6e6e6;
  width: 100%;
  text-align: center;
  margin-top: 30px;
  background: url("../../cost/img/title-bg.jpg") repeat-x; }

.movie {
  position: relative;
  width: 100%;
  height: auto;
  margin: 20px 0 0px 0px; }
  .movie .text {
    position: absolute;
    top: 0px;
    right: 0px;
    z-index: 1000; }
  .movie .to-dtl {
    position: absolute;
    bottom: 20px;
    right: 30px;
    z-index: 1000;
    width: 206px; }
  .movie .sold {
    position: absolute;
    top: 20px;
    right: 30px;
    z-index: 1000; }
  .movie video {
    width: 100%;
    height: auto; }

.profile {
  margin-top: 0px;
  margin-left: 1%;
  margin-right: 10%; }
  @media screen and (max-width: 960px) {
    .profile {
      width: 100%;
      margin-top: 10px; } }
  .profile dl {
    padding: 0 10px;
    font-size: 14px;
    font-size: 1.4rem; }
  .profile dl dt {
    color: #4d4d4d;
    float: left;
    width: 6em;
    padding: 5px 0.5em; }
    @media screen and (max-width: 520px) {
      .profile dl dt {
        float: none;
        padding: 5px 0.5em 0px; } }
  .profile dl dd {
    color: #4d4d4d;
    margin-left: 0;
    padding: 5px 0.5em 5px 7em;
    border-bottom: dotted 1px gray; }
    @media screen and (max-width: 520px) {
      .profile dl dd {
        padding: 0px 0.5em 5px 2em; } }

.footer {
  margin-top: auto;
  width: 100%;
  background-color: #333333;
  background: #fff url("../img/bg-footer.png") repeat-x top center; }

.footerCont {
  width: 100%;
  padding: 0px 0px 0;
  height: 80px;
  margin: 0 auto; }
  @media screen and (max-width: 960px) {
    .footerCont {
      width: 100%;
      height: 80px; } }

.copyright {
  padding-top: 30px;
  margin: 0px 0px 0 0px;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  color: #4d4d4d; }

.page_top {
  z-index: 1000;
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 10px; }

.page_top a {
  border: 1px solid #b3b3b3;
  background: #6B8268;
  text-decoration: none;
  color: #fff;
  padding: 10px;
  text-align: center;
  display: block;
  border-radius: 5px; }

.page_top a:hover {
  text-decoration: none;
  background: #2D432F; }
