@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 .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: 3.13vw;
  width: 100%;
}
.kv_btn1,
.kv_btn2 {
  bottom: 5.63vw;
}
.kv_btn1 {
  left: 6.88vw;
  width: 35.94vw;
}
.kv_btn2 {
  left: 53.13vw;
  width: 36.72vw;
}

/*===============================
　.movie
================================*/
.movie .inner {
  margin: 0 auto;
  width: 90%;
}
.movieOffer {
  margin: 0 auto 5.94vw;
  font-size: 3.75vw;
}
.movieOffer span {
  font-size: 5vw;
}
.movieOffer:before {
  bottom: -3.44vw;
  left: 50%;
  margin-left: -1.64vw;
  border: 1.64vw solid transparent;
  border-top: 2.03vw solid #ffffff;
}
.movieTitle {
  margin-bottom: 2.5vw;
  font-size: 3.75vw;
}
.media + .movieTitle {
  margin-top: 5.63vw;
}
.movie .title span {
  font-size: 4.69vw;
}
.media {
  width: 100%;
}

/*===============================
　.cushion
================================*/
.cushion {
  padding: 4.06vw 0;
  font-size: 4.69vw;
}
.cushion .text {
  margin-right: 3.13vw;
}
.cushion .img {
  width: 12.5vw;
}

/*===============================
　.worry
================================*/
.worry {
  padding: 16.25vw 0 0;
}
.worry .inner {
  display: block;
  padding: 0 6.25vw;
  width: auto;
}
.worry .title {
  margin-bottom: 9.38vw;
  margin-left: 34.38vw;
  font-size: 4.38vw;
  line-height: 1.3;
}
.worry .img {
  position: absolute;
  top: 3.13vw;
  margin-right: 0;
  width: 38.28vw;
}
.worry .img img {
  width: 100%;
}
.worry .worryList {
  padding: 4.38vw 2.5vw 4.38vw 4.38vw;
  border-radius: 4.69vw;
  line-height: 1.3;
}
.worry .worryItem + .worryItem {
  margin-top: 3.13vw;
}
.worry .worryItem {
  font-size: 3.75vw;
  padding-left: 6vw;
  text-indent: -6vw;
}
.worry .worryItem::before {
  margin-right: 2.19vw;
  background-size: 4.69vw 4.06vw;
  width: 4.69vw;
  height: 4.06vw;
}
.worry .bg .comment {
  bottom: 13.75vw;
  left: 50%;
  transform: translateX(-50%);
  font-size: 4.69vw;
}
.worry .bg .comment::before,
.worry .bg .comment::after {
  width: 7.03vw;
  height: 0.31vw;
}
.worry .bg .comment::before {
  left: -10vw;
}
.worry .bg .comment::after {
  right: -10vw;
}

/*===============================
　.resolution
================================*/
.resolution {
  padding: 10vw 4.69vw 10.94vw;
}
.resolution .point {
  margin: 0 0 7.19vw;
  padding:6.88vw 6.88vw 5vw;
  width: auto;
  border: 0.31vw solid #ea6400;
}
.resolution .pointTitle {
  margin-bottom: 3.13vw;
  font-size: 4.69vw;
  line-height: 1.5;
}
.resolution .pointTitle span {
  margin: 0 1.56vw 0 0;
  padding: 0.94vw 3.13vw;
}
.resolution .point .text {
  font-size: 3.44vw;
  text-align: left;
}
.resolution .point::before,
.resolution .point::after {
  top: -3.13vw;
  bottom: auto;
}
.resolution .point::before {
  left: 3.75vw;
  background-size: 19.22vw 21.09vw;
  width: 19.22vw;
  height: 21.09vw;
}
.resolution .point::after {
  right: 3.75vw;
  background-size: 19.69vw 22.19vw;
  width: 19.69vw;
  height: 22.19vw;
}
.resolution .title {
  margin-bottom: 7.5vw;
  font-size: 5vw;
}
.resolution .title span {
  padding-top: 1.25vw;
  background-size: 1em 1.25vw;
  background-image: -webkit-radial-gradient(0.63vw 0.63vw at center center,#e03b3b,#e03b3b 100%,transparent);
  background-image: radial-gradient(0.63vw 0.63vw at center center,#e03b3b,#e03b3b 100%,transparent);
}
.resolution .title::before,
.resolution .title::after {
  width: 9.38vw;
  height: 0.39vw;
  top: auto;
  bottom: 4.38vw;
}
.resolution .title::before {
  left: -9.38vw;
}
.resolution .title::after {
  right: -9.38vw;
}
.resolution .comment {
  position: relative;
  margin-top: 4.38vw;
  font-size: 3.75vw;
}
.resolution .comment::before,
.resolution .comment::after {
  content: "";
  position: absolute;
  bottom: 0;
  display: inline-block;
  background-repeat: no-repeat;
}
.resolution .comment::before {
  left: 3.13vw;
  background-image: url(../img/imgHimarin01_sp.png);
  background-size: 15.47vw 16.56vw;
  width: 15.47vw;
  height: 16.56vw;
}
.resolution .comment::after {
  right: 2.5vw;
  background-image: url(../img/imgHimarin02_sp.png);
  background-size: 15.78vw 17.66vw;
  width: 15.78vw;
  height: 17.66vw;
}
.resolution.inherited .point {
  margin: 0 0 5.63vw;
  border: 0.31vw solid #1366be;
}
.resolution.inherited .movieOffer {
  margin-bottom: 7.19vw;
}
.resolution.inherited .point .text {
  width: auto;
  padding-left: 2.34vw;
  text-indent: -2.34vw;
}
.resolution.inherited .point .text li + li {
  margin-top: 3.13vw;
}

/*===============================
  .linkOther
================================*/
.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: 38.28vw;
  height: 17.66vw;
  font-size: 3.44vw;
  border-radius: 0 1.25vw 1.25vw 0;
}
.linkOther .textOther::after {
  display: inline-block;
  margin-top: 0;
  margin-left: 2.34vw;
  background-size: 8.75vw 2.34vw;
  width: 8.75vw;
  height: 2.34vw;
}
.linkOther .emphasis {
  margin: 1.25vw 0 0;
  font-size: 4.06vw;
  line-height: 1.2;
}

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