@charset "UTF-8";
/*	cmn-color
------------------------------------ */
/*	transition,hover
------------------------------------ */
/*	media-screen
------------------------------------ */
/*	font
------------------------------------ */
/*	layout
------------------------------------ */
/*	font-size  cmn
------------------------------------ */
/************************************************

  SP layout

************************************************/
/*	cmn parts  SP
------------------------------------ */
.com-inner {
  padding: 50px 15px;
}

.com-md-inner {
  padding: 50px 15px;
}

.no-sb {
  margin: 30px auto 0;
}

.com-ib {
  display: inline;
}

.mb10 {
  margin-bottom: 10px;
}
.mb20 {
  margin-bottom: 20px;
}

.anchor-mp {
  margin: -70px auto 0;
  padding-top: 70px;
}

.com-txt-box p:nth-of-type(n+2) {
  margin-top: 15px;
}

/*  共通パーツ
------------------------------------ */
.com-box02 {
  background-size: 100%, auto;
}

.com-tel {
  padding-left: 30px;
  background-size: 25px;
  font-size: 2.6rem;
}

.com-mail {
  width: 184px;
  height: 50px;
}
.com-mail::before {
  width: 22px;
}

.com-bg01 {
  background-size: 100%;
}
.com-bg02 {
  background-size: 200px, 220px;
  background-position: -100px -100px, right calc(100% - 100px);
}
.com-bg03 {
  background-size: 200px, 220px, 100%;
  background-position: -100px -100px, right calc(100% + 150px), center;
}
.com-bg04 {
  background-size: 200px, 220px;
  background-position: -100px -100px, right calc(100% + 30px);
}
.com-bg05 {
  background-size: 48%;
}

.news-post-link {
  padding: 20px;
}
.news-post-ttl {
  margin-top: 5px;
  font-size: 1.4rem;
}
.news-post-tag-txt {
  font-size: 1.2rem;
  line-height: 1.2;
}
.news-post-time {
  font-size: 1.2rem;
}

.com-tag {
  flex-direction: column;
  align-items: center;
}
.com-tag-item:nth-of-type(n+2) {
  margin: 25px auto 0;
}
.com-tag-link {
  margin: auto;
}

/* =========================================

  main  SP

========================================= */
/* top-greeting  SP
------------------------------------ */
#top-greeting {
  background-size: 53%;
  background-position: right bottom;
}
#top-greeting::before {
  width: 20.78%;
  padding-top: 17.1%;
}
#top-greeting::after {
  content: none;
}
#top-greeting .greeting-ttl {
  text-align: center;
}
#top-greeting .greeting-img {
  position: static;
}
#top-greeting .greeting-txt-box {
  margin: 15px auto 0;
  padding: 15px;
  border-bottom: 1px solid #a81717;
  background: #fffcf5;
}
#top-greeting .greeting-list {
  flex-wrap: wrap;
  justify-content: space-between;
}
#top-greeting .greeting-list::before {
  width: 132px;
  padding-top: 102px;
  left: 0;
  bottom: -53px;
}
#top-greeting .greeting-list::after {
  width: 210px;
  padding-top: 143px;
}
#top-greeting .greeting-list li:nth-of-type(1) {
  width: 47%;
}
#top-greeting .greeting-list li:nth-of-type(2) {
  width: 35%;
  margin-right: 5%;
  margin-top: 15%;
}
#top-greeting .greeting-list li:nth-of-type(3) {
  width: 47%;
  margin-top: 15%;
  order: 4;
}
#top-greeting .greeting-list li:nth-of-type(4) {
  width: 35%;
  margin-top: 5%;
  margin-right: 15%;
  order: 3;
}

/* top-about  SP
------------------------------------ */
#top-about .about-box {
  padding: 30px 15px;
  flex-direction: column;
  align-items: center;
}
#top-about .about-ttl {
  width: 60px;
  margin: auto;
}
#top-about .about-txt-box {
  margin: 20px auto 0;
}
#top-about .about-bnr {
  max-width: 370px;
  margin: 20px auto 0;
  padding-bottom: 150px;
  background-size: 250px, auto, auto;
  background-position: center calc(100% + 100px), calc(100% + 206px) 155px, center;
  background-image: url(../img/top/bnr-img-sp.png), url(../img/top/bnr-rb.png), url(../img/ptn04.png);
}
#top-about .about-bnr-ttl {
  padding: 20px 15px 35px;
  background-position: calc(50% - 164px) 25px, calc(50% + 124px) 110px, center bottom;
  text-align: center;
}
#top-about .about-bnr-ttl .ttl {
  font-size: 3rem;
}
#top-about .about-bnr-ttl .sm {
  font-size: 2.4rem;
}
#top-about .about-bnr-ttl .lg {
  width: 214px;
  margin: 10px auto 0;
}

/* top-products  SP
------------------------------------ */
#top-products .products-ttl {
  background-position-x: calc(50% - 78px), calc(50% + 78px);
  background-size: 30px;
}
#top-products .products-ttl::before, #top-products .products-ttl::after {
  width: calc(50% - 103px);
}
#top-products .products-list {
  margin-top: 25px;
}
#top-products .products-list::before {
  width: 130px;
  height: 130px;
  left: -15px;
  bottom: -29px;
}
#top-products .products-list li {
  width: 49%;
}
#top-products .products-list li:nth-of-type(2n) {
  margin-left: 2%;
}
#top-products .products-list li:nth-of-type(n+3) {
  margin-top: 2%;
}
#top-products .products-list-img {
  border-radius: 15px;
}
#top-products .products-btn {
  margin-top: 60px;
}

/* top-bnr  SP
------------------------------------ */
#top-bnr .bnr-list::before {
  width: 130px;
  height: 130px;
  right: -15px;
  bottom: -51px;
}
#top-bnr .bnr-list-item:nth-of-type(n+2) {
  margin: 35px auto 0;
}
#top-bnr .bnr-list-contents {
  padding: 20px 15px;
  background-size: 141px;
  background-position: calc(100% + 50px) top;
}
#top-bnr .bnr-list-ttl {
  background-size: 25px, 60px;
  font-size: 2.4rem;
}
#top-bnr .bnr-list-ttl01 {
  background-position-x: calc(50% - 68px), calc(50% + 76px);
}
#top-bnr .bnr-list-ttl02 {
  background-position-x: calc(50% - 92px), calc(50% + 105px);
}
#top-bnr .bnr-list-txt {
  margin-top: 10px;
}

/* top-news  SP
------------------------------------ */
#top-news {
  background-size: 48%;
}
#top-news .news-inner {
  display: block;
}
#top-news .news-ttl {
  text-align: center;
}
#top-news .news-post {
  margin: 25px auto 0;
}

/* =========================================

sub layout  SP

========================================= */
/* feature  SP
------------------------------------ */
#feature .history-ttl {
  margin-top: 20px;
}
#feature .history-ttl::before {
  width: 100px;
  height: 100px;
}
#feature .history-ttl::before {
  right: 0;
}
#feature .history-ttl .main {
  max-width: 250px;
  margin-top: 10px;
}
#feature .history-movie {
  margin-top: 20px;
  padding-top: 56.25%;
}
#feature .history-list {
  margin-top: 30px;
}
#feature .history-list::before {
  left: 7px;
}
#feature .history-list::after {
  width: 29px;
  height: 16px;
  left: -7px;
}
#feature .history-list li {
  padding-left: 50px;
}
#feature .history-list li::before {
  width: 14px;
  height: 14px;
  left: 0;
}
#feature .history-list li::after {
  left: 14px;
  top: 18px;
}
#feature .history-list li:nth-of-type(n+2) {
  margin: 30px auto 0;
}
#feature .history-list-ttl {
  position: relative;
  z-index: 1;
}
#feature .feature-list {
  margin-top: 25px;
}
#feature .feature-list-item {
  flex-direction: column-reverse !important;
  align-items: center;
}
#feature .feature-list-item:nth-of-type(n+2) {
  margin-top: 30px;
}
#feature .feature-list-img {
  width: 80%;
  margin: auto;
}
#feature .feature-list-img::before {
  width: 105%;
  height: 105%;
}
#feature .feature-list-con {
  margin: 20px auto 0;
}
#feature .feature-list-txt {
  margin-top: 10px;
}

/* experience  SP
------------------------------------ */
#experience .about-images {
  display: flex;
  margin: 25px auto 0;
  justify-content: center;
}
#experience .about-images li {
  width: 49%;
}
#experience .about-images li:nth-of-type(2n) {
  margin-top: 10%;
  margin-left: 2%;
}
#experience .about-box {
  margin: 20px auto 0;
}
#experience .about-box-txt {
  font-size: 1.7rem;
}
#experience .about-box dl dt {
  font-size: 1.8rem;
}
#experience .about-box dl dd {
  margin-left: 10px;
  font-size: 2rem;
}
#experience .about-txt {
  margin-top: 25px;
}
#experience .feature-list {
  flex-direction: column;
  align-items: center;
}
#experience .feature-list-item:nth-of-type(n+2) {
  margin: 30px auto 0;
}
#experience .feature-list-ttl {
  font-size: 1.8rem;
}
#experience .voice {
  margin-top: -80px;
  padding-top: 80px;
}
#experience .voice-list-item:nth-of-type(n+2) {
  margin: 50px auto 0;
}
#experience .voice-list-images li:nth-of-type(2n) {
  margin-left: 7px;
}
#experience .voice-list-dl {
  padding: 17px 13px 21px;
}
#experience .voice-list-dl dt {
  font-size: 1.8rem;
  align-items: flex-start;
}
#experience .voice-list-dl dt::before {
  margin-top: 7px;
  margin-right: 7px;
  flex-shrink: 0;
}
#experience .flow-list::before {
  margin: auto;
  left: 0;
  right: 0;
}
#experience .flow-list-box {
  padding: 20px 15px;
  flex-direction: column;
  align-items: center;
}
#experience .flow-list-con {
  margin: 15px auto 0;
}
#experience .flow-list-txt {
  margin-top: 10px;
}
#experience .detail {
  border-top: none;
}
#experience .detail .voice-list-ico {
  left: 20px;
}
#experience .detail .voice-list-box {
  padding: 75px 20px 20px;
}
#experience .detail .voice-list-dl {
  padding: 17px 13px 21px;
}
#experience .detail .voice-list-dl dt {
  font-size: 1.8rem;
  align-items: flex-start;
}
#experience .detail .voice-list-dl dt::before {
  margin-top: 7px;
  margin-right: 7px;
  flex-shrink: 0;
}
#experience .detail .voice-list-images {
  margin-left: 10px;
  flex-wrap: wrap;
}
#experience .detail .voice-list-images li {
  width: 49%;
}
#experience .detail .voice-list-images li:nth-of-type(2n) {
  margin-left: 2%;
}
#experience .detail .voice-list-images li:nth-of-type(n+3) {
  margin-top: 2%;
}

/* com-contact  SP
------------------------------------ */
.com-contact {
  margin-top: 25px;
  padding: 29px 0 30px;
}
.com-contact .contact-list li:nth-of-type(n+2) {
  margin: 20px auto 0;
}

/* spot  SP
------------------------------------ */
#spot .spot-list-item {
  flex-direction: column-reverse;
  align-items: center;
}
#spot .spot-list-item:nth-of-type(n+2) {
  margin-top: 30px;
  padding-top: 30px;
}
#spot .spot-list-img {
  width: 100%;
  height: 0;
  padding-top: 80%;
}
#spot .spot-list-con {
  margin: 15px auto 0;
}

/* access  SP
------------------------------------ */
#access .cafe {
  margin-top: -80px;
  padding-top: 80px;
  background-size: 220px;
  background-position: right calc(100% + 30px);
}
#access .cafe-inner {
  background-position: center 58px;
  background-size: 100%;
}
#access .cafe-img-ttl {
  width: 109px;
  margin: auto;
  padding: 60% 0 0;
}
#access .menu {
  margin: 50px auto 0;
}
#access .menu-table th {
  width: 50%;
  padding-left: 10px;
}
#access .menu-table th, #access .menu-table td {
  vertical-align: middle;
}
#access .menu-table .hc {
  display: block;
  width: auto;
}
#access .information-table {
  margin-top: 25px;
}
#access .products-ttl {
  background-position-x: calc(50% - 82px), calc(50% + 78px);
}
#access .products-ttl::before, #access .products-ttl::after {
  width: calc(50% - 108px);
}
#access .products-scroll {
  height: 400px;
  margin-top: 30px;
  padding-right: 5px;
}
#access .products-scroll::-webkit-scrollbar {
  width: 5px;
}
#access .products-list li {
  width: 49%;
}
#access .products-list li:nth-of-type(2n) {
  margin-left: 2%;
}
#access .products-list li:nth-of-type(n+3) {
  margin-top: 2%;
}
#access .products-list-img {
  border-radius: 20px;
}
#access .detail-img-wrap {
  width: 80%;
  margin-top: 25px;
}
#access .detail-list-ttl {
  margin-top: 20px;
  padding: 20px;
}

/* news  SP
------------------------------------ */
#news .com-tag {
  margin-top: 25px;
}
#news .com-news-link {
  padding: 5%;
}
#news .com-news-ttl {
  font-size: 5vw;
}
#news .com-news-img {
  border-radius: 10px;
  margin-left: 5%;
}
#news .detail .com-news-ttl {
  font-size: 1.8rem;
}/*# sourceMappingURL=style_sp.css.map */