/**
* body.css
* Web site Name: ranco
* URL: https://ranco.jp/
* Author: ranco.jp
*/


/* --------------------------------------------------------------
# Responsive
-------------------------------------------------------------- */

/*
@media (min-width:576px) {}

@media (min-width:768px) {}

@media (min-width:992px) {}

@media (min-width:1200px) {}

@media (min-width:1400px) {}

@media (max-width:575.98px) {}

@media (max-width:767.98px) {}

@media (max-width:991.98px) {}

@media (max-width:1199.98px) {}

@media (max-width:1399.98px) {}
*/


/* --------------------------------------------------------------
# Property
-------------------------------------------------------------- */

body {
  background-image: url(../img/bg.png);
  background-repeat: repeat;
  background-size: 256px;
}

p {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}


/* --------------------------------------------------------------
# Hero Section
-------------------------------------------------------------- */

#hero img {
  width: 100%;
  height: 100%;
}

#hero h1 {
  color: #FFF;
  text-shadow: 1px 1px 2px #000;
  margin-top: 2rem;
}

#hero h1 span {
  font-size: 50px;
}

#hero h2 {
  background-color: rgba(255, 249, 177, .9);
  margin-top: .6rem;
  padding: .4rem 1.4rem .4rem 1.4rem;
  border-radius: 20px;
  color: #3e3a39;
  font-size: 22px;
  text-shadow: 1px 1px 2px #FFF;
  display: inline-block;
}

#hero h3 {
  color: #EEE;
  margin-top: 2rem;
  margin-bottom: 10px;
  font-size: 28px;
  text-shadow: 1px 1px 2px #000;
}

#hero p {
  color: #EEE;
  margin-bottom: 10px;
  font-size: 22px;
  text-shadow: 1px 1px 2px #000;
}

@media (max-width: 768px) {
  #hero h1 {
    font-size: 22px;
  }

  #hero h1 span {
    font-size: 22px;
  }

  #hero h2 {
    font-size: 14px;
  }

  #hero h3 {
    font-size: 1rem;
    margin-top: 2rem;
  }

  #hero p {
    font-size: .9rem;
  }

  #hero .btn-get-started .bi-chevron-double-down {
    font-size: 1.5rem !important;
  }
}

#hero .btn-get-started .bi-chevron-double-down {
  color: #FFF;
  font-size: 3rem;
}


/* --------------------------------------------------------------
# Header
-------------------------------------------------------------- */

@media (max-width:575.98px) {
  #header h2 {
    font-size: 1.2rem;
    margin-top: .5rem;
    margin-left: .6rem;
  }
}

@media (min-width:576px) {
  #header h2 {
    font-size: 1.2rem;
    margin-top: .5rem;
    margin-left: .6rem;
  }
}

@media (min-width:768px) {}

@media (min-width:992px) {}

@media (min-width:1200px) {}

@media (min-width:1400px) {}


/* --------------------------------------------------------------
# Nav
-------------------------------------------------------------- */




/* --------------------------------------------------------------
# Breadcrumbs
-------------------------------------------------------------- */



/* --------------------------------------------------------------
# Video
-------------------------------------------------------------- */

.wrap-video {
  position: relative;
}

.wrap-video video {
  width: 100%;
  height: 100%
}

.wrap-video .text {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  /*上下左右中央寄せ*/
  text-align: center;
}

.wrap-video .text p {
  font-size: 16px;
  font-weight: bold;
  color: white;
}

.wrap-video .text .headline {
  font-size: 20px;
}


/* --------------------------------------------------------------
# Background color
-------------------------------------------------------------- */

.section-bg {
  background: linear-gradient(180deg, #c3f4f0 0%, #FFF 100%) !important;
}


/* --------------------------------------------------------------
# Intro
-------------------------------------------------------------- */

.intro {
  padding-top: 5rem 0 !important;
}

.about {
  padding-bottom: 5rem 0 !important;
}

@media (max-width: 767.98px) {
  .intro .content h3 {
    font-size: 1.4rem;
  }
}

.about h3 {
  text-indent: 1rem;
}

.intro .image {
  background: url("../img/universe.jpg") center center no-repeat;
  background-size: cover;
  min-height: 400px;
}

@media (max-width: 991.98px) {
  .intro .image {
    text-align: center;
  }

  .intro .image img {
    max-width: 80%;
  }
}

@media (max-width: 575.98px) {
  .intro .image img {
    max-width: 100%;
  }
}


/* --------------------------------------------------------------
# Heading Decoration
-------------------------------------------------------------- */

.h-deco1 {
  position: relative;
  color: #333;
}

.h-deco1:before {
  content: '';
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 4px;
  background-color: #2589d0;
}


/* --------------------------------------------------------------
# Menu
-------------------------------------------------------------- */

.menu h3 {
  font-size: 1.6rem;
  margin: 1rem 0;
  text-align: center;
}

.menu p {
  text-indent: 1rem;
}

.menu img {
  border: 6px groove #edc7d2;
  border-radius: 50%;
}

@media (max-width: 767.98px) {
  .menu img {
    width: 80%;
    height: auto;
  }
}

.menu .menu-contents {
  width: 90%;
}


/* --------------------------------------------------------------
# Footer
-------------------------------------------------------------- */

.footer {
  padding: 2rem !important;
  background-color: #edc7d2 !important;
}

.footer-logo-mark img {
  height: 64px;
  margin-bottom: .4rem;
}

.footer ul li {
  margin-left: 1.5rem;
  line-height: 2;
}

.copyright {
  padding: .5rem;
  background-color: #000;
  box-sizing: border-box;
}

.copyright p {
  color: #FFF;
  text-align: center;
  margin-top: .8rem;
}


/* --------------------------------------------------------------
# Fee
-------------------------------------------------------------- */

.fee .arrow-right,
.fee .arrow-down {
  font-size: 3.4rem;
  text-align: center;
  margin: 2rem 0 0 0;
}

@media (max-width: 991.98px) {
  .fee .arrow-right {
    display: none;
  }
}

@media (min-width: 992px) {
  .fee .arrow-down {
    display: none;
  }
}


/* --------------------------------------------------------------
# Google Calendar
-------------------------------------------------------------- */

.cal-wrapper {
  max-width: 800px;
  /* 最大幅 */
  min-width: 300px;
  /* 最小幅 */
  margin: 2.0833% auto;
}

.googlecal {
  position: relative;
  padding-bottom: 100%;
  /* 縦横比 */
  height: 0;
  overflow: hidden;
}

.googlecal iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

@media only screen and (min-width: 600px) {

  /* 画面幅が600px以上の場合の縦横比の指定 */
  .googlecal {
    padding-bottom: 75%;
  }
}


/* --------------------------------------------------------------
# After reservation
-------------------------------------------------------------- */






/* --------------------------------------------------------------
# www/sitemap.html
-------------------------------------------------------------- */

.sitemap .main-color {
  background-color: #c3f4f0;
}

.sitemap .sub-color {
  background-color: #edc7d2;
}

.sitemap .heading-text-color {
  background-color: #2c4964;
}

.sitemap .sub-text-color {
  background-color: #437099;
}


/* --------------------------------------------------------------
# www/sitemap.html
-------------------------------------------------------------- */

.thanks ol li {
  line-height: 1.8;
}


/* --------------------------------------------------------------
# www/thanks.html
-------------------------------------------------------------- */

.thanks .dog img {
  width: 380px;
  height: auto;
  border-radius: 50%;
  border: outset 10px #2ec2e1;
  box-shadow: 6px 6px 6px rgba(0, 0, 0, .3);
}

@media (max-width:575.98px) {
  .thanks .dog img {
    width: 200px;
  }
}

@media (min-width:576px) {
  .thanks .dog img {
    width: 380px;
  }
}