@charset "UTF-8";

body {
  min-width: auto;
  font-size: 4.27vw;
}
.pc {
  display: none;
}
.sp {
  display: block;
}

/*===============================
　.button
================================*/
.l-button {
  justify-content: center;
  margin-bottom: 3.13vw;
}
.button + .button {
  margin-left: 2.5vw;
}
.button a {
  display: block;
  padding: 2.5vw 3.13vw;
  width: 40.63vw;
  font-size: 4.38vw;
  text-align: center;
  border-radius: 5.06vw;
}
.buttonPamphlet a::before,
.buttonShop a::before {
  margin: 0 auto 2.19vw;
}
.buttonPamphlet a::before {
  display: block;
  background-size: 5.63vw 8.75vw;
  width: 5.63vw;
  height: 8.75vw;
}
.buttonShop a::before {
  display: block;
  background-size: 9.69vw 8.44vw;
  width: 9.69vw;
  height: 8.44vw;
}

/*===============================
　.offer
================================*/
.offer {
  width: auto;
}
.offer .inner {
  margin-bottom: 3.91vw;
}
.offer .info {
  width: 100%;
  bottom: 3.75vw;
  right: auto;
  left: 50%;
  transform: translateX(-50%);
}
.offer .img {
  margin: 0 auto;
  width: 96%;
}
.offer .img img {
  width: 100%;
}
.offer .l-tel {
  display: block;
  margin-bottom: 1.25vw;
  text-align: center;
}
.offer .tel {
  justify-content: center;
}
.offer .telTitle {
  margin-right: 0;
  margin-bottom: 1.25vw;
  font-size: 3.13vw;
}
.offer .tel a {
  font-size: 10vw;
}
.offer .tel::before {
  background-size: 7.81vw 7.81vw;
  margin-right: 2.5vw;
  width: 7.81vw;
  height: 7.81vw;
}
.offer .businessHour,
.offer .note {
  font-size: 3.13vw;
  letter-spacing: -.05em;
}
.offer .businessHour {
  margin-left: 6.25vw;
}
.offerA {
  padding: 1.56vw 0 9.38vw;
}
.offerB {
  padding: 8.44vw 0;
}
.offerB .offerBTitle {
  margin-bottom: 3.13vw;
  font-size: 4.69vw;
  line-height: 1.7;
}
.offerB .offer {
  margin-bottom: 7.81vw;
}

/*===============================
　.header
================================*/
.header {
  border-bottom: 0.67vw solid #e03b3b;
}
.header .inner {
  padding: 2.5vw 1.33vw 1.56vw;
}
.header .info .tel {
  margin-right: 1.25vw;
}
.header .info .telNumber {
  margin-bottom: 1.07vw;
  font-size: 5.94vw;
}
.header .info .telNumber::before {
  background-size: 5vw 5vw;
  margin-right: 1.6vw;
  width: 5vw;
  height: 5vw;
}
.header .info .businessHour {
  margin-left: 0;
  font-size: 2.67vw;
  letter-spacing: -.05em;
}
.header .info .businessHour span {
  letter-spacing: -.1em;
}
.header .logo {
  margin: 0;
  width: 18.75vw;
  height: auto;
}
.header .button a {
  display: flex;
  align-items: center;
  padding: 1.88vw 0 2.03vw 2.5vw;
  width: 28.75vw;
  font-size: 3.13vw;
  letter-spacing: -.105em;
  border-radius: 3.91vw;
  box-sizing: border-box;
}
.header .buttonPamphlet a::before {
  background-size: 2.5vw 3.91vw;
  margin: 0 1.33vw 0 0;
  width: 2.5vw;
  height: 3.91vw;
}


/*===============================
　kv
================================*/
.kv {
  overflow-x: hidden;
}
.kv .inner {
  position: relative;
  padding: 0;
  left: 4.69vw;
  width: 100%;
}
.kv .inner img {
  width: 100%;
}

/*===============================
　.movie
================================*/
.movie {
  padding: 6.25vw 3.13vw 10vw;
}
.movie .inner {
  margin: 0 auto;
  width: 90%;
}
.movie .title {
  margin: 0 auto 5.94vw;
  padding: 1.56vw 0 1.88vw;
  width: auto;
  font-size: 3.44vw;
}
.movie .title:before {
  bottom: -3.44vw;
  left: 50%;
  margin-left: -1.64vw;
  border: 1.64vw solid transparent;
  border-top: 2.03vw solid #ffffff;
}
.movie .title span {
  font-size: 4.69vw;
}
.media {
  width: 100%;
}

/*===============================
　.check
================================*/
.check {
  padding: 6.25vw 0 0;
}
.check .inner {
  display: block;
  margin-bottom: 7.81vw;
  padding: 0 6.25vw;
  width: auto;
}
.check .title {
  margin-bottom: 6.25vw;
  margin-left: 41.25vw;
  font-size: 4.38vw;
  text-align: left;
  line-height: 1.6;
}
.check .img {
  position: absolute;
  margin-right: 0;
  width: 38.44vw;
}
.check .img img {
  width: 100%;
}
.check .checkList {
  padding: 4.38vw 6.25vw;
  border-radius: 4.69vw;
}
.check .checkList::after {
  display: none;
}
.check .checkItem + .checkItem {
  margin-top: 3.13vw;
}
.check .checkItem {
  font-size: 3.75vw;
}
.check .checkItem::before {
  margin-right: 2.19vw;
  background-size: 4.69vw 4.06vw;
  width: 4.69vw;
  height: 4.06vw;
}
.check .bg .comment {
  bottom: 5vw;
  left: 50%;
  transform: translateX(-50%);
  padding: 2.19vw 0;
  width: 90.63vw;
  font-size: 3.75vw;
}

/*===============================
　.coordinate
================================*/
.coordinate {
  padding: 7.03vw 0 10.94vw;
}
.coordinate .title {
  margin-bottom: 7.03vw;
  padding: 0;
  font-size: 4.06vw;
}
.coordinate .title::before,
.coordinate .title::after {
  width: 9.38vw;
  height: 0.39vw;
  top: auto;
  bottom: 4.38vw;
}
.coordinate .title::before {
  left: -9.38vw;
}
.coordinate .title::after {
  right: -9.38vw;
}
.coordinate .title span {
  font-size: 5.63vw;
}
.coordinate .title span span {
  font-size: 3.13vw;
}
.coordinate .img {
  margin: 0 auto 7.81vw;
  width: 93.91vw;
}
.coordinate .comment {
  position: relative;
  font-size: 3.75vw;
}
.coordinate .comment::before,
.coordinate .comment::after {
  content: "";
  position: absolute;
  bottom: 0;
  display: inline-block;
  background-repeat: no-repeat;
}
.coordinate .comment::before {
  left: 3.13vw;
  background-image: url(../img/imgHimarin01_sp.png);
  background-image: image-set(url(../img/imgHimarin01_sp.png) 1x, url(../img/imgHimarin01_sp@2x.png) 2x);
  background-image: -webkit-image-set(url(../img/imgHimarin01_sp.png) 1x, url(../img/imgHimarin01_sp@2x.png) 2x);
  background-size: 15.47vw 16.56vw;
  width: 15.47vw;
  height: 16.56vw;
}
.coordinate .comment::after {
  right: 2.5vw;
  background-image: url(../img/imgHimarin02_sp.png);
  background-image: image-set(url(../img/imgHimarin02_sp.png) 1x, url(../img/imgHimarin02_sp@2x.png) 2x);
  background-image: -webkit-image-set(url(../img/imgHimarin02_sp.png) 1x, url(../img/imgHimarin02_sp@2x.png) 2x);
  background-size: 15.78vw 17.66vw;
  width: 15.78vw;
  height: 17.66vw;
}

/*===============================
　.comparison
================================*/
.comparison .inner {
  padding: 8.59vw 0 3.75vw;
  width: auto;
}
.comparison .comparisonTitle {
  margin: 0 auto 6.25vw;
  padding: 2.19vw 0;
  font-size: 3.75vw;
  width: 93.75vw;
}
.comparison .box {
  display: block;
}
.comparison .box .img {
  margin: 0 auto 9.38vw;
  width: 59.38vw;
}
.comparison .box .img img {
  width: 100%;
}
.comparison .box .text {
  font-size: 3.75vw;
  line-height: 1.8;
  text-align: center;
}
.linkOther a {
  padding: 2.5vw 0 2.5vw 2.19vw;
  width: 87.5vw;
  max-height: 18.75vw;
  font-size: 3.13vw;
  border-radius: 1.56vw;
}
.linkOther a span {
  display: block;
}
.linkOther .textOther {
  top: 0.47vw;
  right: 0.47vw;
  padding: 4.38vw 0 0 3.13vw;
  width: 42.5vw;
  height: 17.66vw;
  font-size: 3.44vw;
  border-radius: 0 1.25vw 1.25vw 0;
}
.linkOther .textOther::after {
  margin-left: 4.38vw;
  background-size: 8.75vw 2.34vw;
  width: 8.75vw;
  height: 2.34vw;
}
.linkOther .emphasis {
  display: inline-block;
  margin: 1.25vw 0;
  font-size: 4.69vw;
}

/*===============================
　footer
================================*/
footer {
  padding: 3.13vw;
  width: auto;
  font-size: 3.13vw;
}