@charset "UTF-8";

/*------------------------------------------
　*reset
------------------------------------------*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ul, ol, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, abbr, address, em, img, small, strong, sub, sup, var, b, i, a, article, aside, canvas, details, figcaption, figure, header, hgroup, menu, nav, section, summary, footer,
time, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
  font-size: 100%;
}

a {
  text-decoration: none;
  -webkit-text-decoration-skip: objects;
}

a:hover, a:focus {
  text-decoration: none;
  outline-width: 0;
}

ol, ul {
  list-style: none;
}

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

ol, ul {
  list-style: none;
  vertical-align: top;
}

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

img {
  border: none;
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

address, em, img, small, strong {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

* {
  box-sizing: border-box;
}

/*------------------------------------------
 *base
------------------------------------------*/
html {
  height: 100%;
  font-size: 62.5%;
}

body {
  min-height: 100%;
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: subpixel-antialiased;
  color: #333;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.6;
  display: flex;
  flex-direction: column;
}

#mainContent {
  flex: 1;
}

.contentsIn {
  width: 1360px;
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
  padding-left: 40px;
  padding-right: 40px;
}

.img-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

.fbox {
  display: -webkit-flex;
  display: flex;
}

.clear {
  clear: both;
}

/* link ---------------------------------*/
a {
  color: #000;
  transition: all 0.5s;
}

a:hover,
a:active,
a:focus {
  color: #888;
  text-decoration: none;
}

@media screen and (min-width: 769px) {
  .onlyMobile {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  body {
    font-size: 1.4em
  }

  .onlyPc {
    display: none;
  }

  .contentsIn {
    padding-left: 6vw;
    padding-right: 6vw;
  }
}

/*==========================================
 *header
==========================================*/
/*header area ----------------------------*/
#header .contentsIn {
  padding-top: 30px;
  padding-bottom: 30px;
}

#header h1 img {
  max-width: 360px;
  height: auto;
}

@media screen and (max-width: 768px) {
  #header .contentsIn {
    padding: 20px;
  }

  #header h1 img {
    display: block;
    width: 100%;
  }
}

/*mainvisual ----------------------------*/
.mainvisual {
  background-color: #fce1cc;
}

.mv-image {
  max-width: 1280px;
  margin: 0 auto;
}

.mv-image img {
  /* display: block; */
  max-width: 100%;
  height: auto;
}


/*==========================================
 *main
==========================================*/
/*------------------------------------------
 *introduction
------------------------------------------*/
.introduction {
  margin: 0 auto;
  padding: 60px 40px;
}

.introduction p {
  max-width: 720px;
  margin: 0 auto;
  padding: 30px;
  font-size: 2rem;
  line-height: 1.8;
  font-weight: 700;
  text-align: center;
  background-color: rgba(239, 120, 0, 0.05);
  border: solid 3px #ed765c;
}

@media screen and (max-width: 768px) {
  .introduction {
    padding: 40px 20px;
  }

  .introduction p {
    padding: 24px;
    text-align: left;
    font-size: 1.8rem;
    line-height: 1.6;
  }
}


/*------------------------------------------
 *shop
------------------------------------------*/
section.shop-list {
  padding-top: 60px;
  background-color: rgba(239, 120, 0, 0.05);
}

/*background -----------------------------*/
section.shop-list {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  padding: 5vw;
}

.background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

/* 円 */
.circle {
  position: absolute;
  border-radius: 50%;
  /* background-color: rgba(239, 120, 0, 0.3); */
  background-color: #f7e5c9;
  opacity: 0.8;
}

.circle1 {
  width: 50vw;
  height: 50vw;
  top: -8vw;
  left: -30vw;
}

.circle2 {
  width: 36vw;
  height: 36vw;
  bottom: -12vw;
  left: -10vw;
}

.circle3 {
  width: 36vw;
  height: 36vw;
  top: 56%;
  right: -10vw;
  transform: translateY(-50%);
}

@media (max-width: 600px) {
  .circle1 {
    width: 60vw;
    height: 60vw;
    top: -8vw;
    left: -35vw;
  }

  .circle2 {
    width: 45vw;
    height: 45vw;
    bottom: -20vw;
    left: -15vw;
  }

  .circle3 {
    width: 45vw;
    height: 45vw;
    top: 36%;
  }
}


/*Shop common ----------------------------*/
.shop_wide,
.shop {
  padding: 40px;
  background-color: #fff;
  border: solid 2px #e95433;
  border-radius: 10px;
}

.item-images img {
  display: block;
  max-width: 100%;
  height: auto;
}

.shop-list h2 {
  margin-bottom: 8px;
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
}

.shop-list h2 span {
  /* margin-right: 16px; */
  padding: 6px 15px 8px;
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: 0.15rem;
  color: #fff;
  background: #333;
  border-radius: 30px;
  display: inline-block;
}


[class^="shop"] h3,
[class^="shop"] .includ {
  color: #e95433;
  font-weight: 700;
  line-height: 1.4;
}


[class^="shop"] h3 {
  margin-bottom: 8px;
  font-size: 2.6rem;
}

[class^="shop"] .includ {
  font-size: 1.8rem;
  margin-left: -1rem;
}

[class^="shop"] .includ.none {
  margin-left: 0;
}

[class^="shop"] p {
  margin-bottom: 8px;
  font-size: 1.8rem;
  line-height: 1.4;
}

[class^="shop"] p.item-price {
  font-size: 2rem;
  font-weight: 700;
}

[class^="shop"] p.item-price span {
  font-size: 1.6rem;
}

.item-text {
  margin-top: 20px;
  padding: 20px 24px;
  background-color: rgba(233, 84, 51, 0.1);
  border-radius: 10px;
  font-size: 1.8rem;
}

/*Shop-wide ----------------------------*/
section .shop_wide h2 span {
  margin-right: 16px;
}

section .shop_wide {
  margin-bottom: 60px;
  display: flex;
  /* flex-wrap: wrap; */
  justify-content: space-between;
}

section .shop_wide-text {
  width: 45%;
}

section .shop_wide .item-images {
  width: 52%;
}

/*Shop ---------------------------------*/
.shop {
  width: 100%;
  margin-bottom: 30px;
}

section .shop h2 {
  margin-bottom: 24px;
  text-align: center;
}

section .shop h2 span {
  margin-bottom: 16px;
}

section .shop h3 {
  margin: 1.6em 0 0.2em;
}


@media screen and (min-width: 769px) {
  .shop-wrap {
    display: flex;
    flex-wrap: wrap;
    align-content: stretch;
    justify-content: space-between;
  }

  .shop {
    width: 48%;
    margin-bottom: 60px;
  }
}

@media screen and (max-width: 768px) {
  section.shop-list {
    padding-top: 30px;
    padding-bottom: 30px;
    /* background: #FEFEF2 url(../images/bg-sp.png) repeat-y center top / cover; */
  }

  /*Shop common ----------------------------*/
  .shop_wide,
  .shop {
    padding: 24px;
  }

  .shop:last-child {
    margin-bottom: 0;
  }

  section.shop-list h2 {
    margin-bottom: 8px;
    font-size: 2rem;
    /* letter-spacing: 0.1rem; */
  }

  section.shop-list h2 span {
    font-size: 1.4rem;
  }

  [class^="shop"] h3 {
    font-size: 2.4rem;
  }

  [class^="shop"] .includ {
    font-size: 1.6rem;
  }

  /* 
  [class^="shop"] p {
    font-size: 1.6rem;
  } */

  [class^="shop"] p.item-price {
    font-size: 1.8rem;
  }

  .item-text {
    margin-top: 16px;
    padding: 16px;
  }

  /*Shop ---------------------------------*/
  section .shop h2 {
    margin-bottom: 20px;
  }

  section .shop h2 span {
    margin-bottom: 10px;
  }

  section .shop h3 {
    margin: 1.4em 0 0.2em;
  }
}

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

  .shop-box .shop {
    width: 100%;
    margin-bottom: 30px;
  }
}

@media screen and (min-width: 961px) {
  .onlyMobile-b {
    display: none;
  }
}

/*------------------------------------------
 *page top
------------------------------------------*/
#pageTop {
  position: fixed;
  bottom: 20px;
  right: 20px;
}

#pageTop a {
  width: 60px;
  height: 60px;
  padding: 24px 0 0;
  background: #333;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  color: #fff;
  display: block;
  font-size: 80%;
  border-radius: 100%;
  transition: background-color 0.5s ease-out;
}

#pageTop a:hover {
  text-decoration: none;
  background-color: #666;
}

#pageTop .icon-arrow-up {
  border: 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  display: inline-block;
  transform: rotate(-45deg);
  width: 16px;
  height: 16px;
}


/*==========================================
 *footer
==========================================*/
#footer {
  padding: 60px 0 0px;
  background: rgba(233, 84, 51, 0.85);
}

#footer ul.notes {
  max-width: 880px;
  margin: 0 auto 60px;
  padding: 40px;
  font-size: 1.4rem;
  /* line-height: 30px; */
  background-color: #fff;
}

#footer ul.notes li {
  margin-bottom: 0.5rem;
  text-indent: -1em;
  padding-left: 1em;
}

/*banner ---------------------------------*/
.banner-area {
  max-width: 600px;
  margin: 0 auto 60px;
}

/*logo -----------------------------------*/
.footer-logo {
  width: 100%;
  margin: 0 auto;
  padding: 60px 0 60px;
  background-color: #e60012;
}

.footer-logo div {
  max-width: 305px;
  margin: 0 auto;
}

.footer-logo img,
.banner-area img {
  display: block;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  #footer {
    padding-top: 30px;
  }

  #footer ul.notes {
    margin: 0 auto 30px;
    padding: 24px;
  }

  /*banner ---------------------------------*/
  .banner-area {
    margin-bottom: 30px;
  }

  /*logo -----------------------------------*/
  .footer-logo {
    padding: 30px 0;
  }
}