@charset "UTF-8";
* {
  box-sizing: border-box;
  word-wrap: break-word;
  word-break: break-all;
  margin: 0;
  padding: 0;
  /* はみ出しdebug */
  /* border: 1px solid #f00; */
}
/* リセット */
body,
div,
p,
blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
table,
caption,
tr,
td,
th,
address,
header,
footer,
nav,
main,
article,
section,
aside,
figure,
figcaption {
  margin: 0;
  padding: 0;
}

body,
div,
p,
blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
address,
header,
footer,
nav,
main,
article,
section,
aside,
figure,
figcaption {
  display: block;
}

body,
div,
p,
blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
table,
caption,
tr,
td,
th,
address,
header,
footer,
nav,
main,
article,
section,
aside,
figure,
figcaption,
img,
span,
a {
  box-sizing: border-box;
}

ul,
ol {
  list-style-type: none;
}

img {
  border: none;
  vertical-align: middle;
}

table {
  border-collapse: collapse;
}

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

/* ユーティリティー */
a {
  color: #333333;
  zoom: 1;
  text-decoration: none;
  transition: opacity 0.7s;
  display: block;
}

a:hover {
  opacity: 0.7;
}

/*フォント*/
/*筑紫A丸ゴシック*/
.ftukushi {
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-style: normal;
  font-weight: 700; /*レギュラー→400*/
}

/*A-OTF リュウミン P*/
/*いくらほたてなどの文字に使用*/
.fotf {
  font-family: "a-otf-ryumin-pr6n", serif;
  font-weight: 300;
}

/*游ゴシック(YuGoPr6N の代わり)*/
.fyugo {
  font-family: "yu-gothic-pr6n", sans-serif;
  font-weight: 400;
}
img {
  width: 100%;
  height: auto;
  display: block;
}

a.sptel {
  cursor: default;
  pointer-events: none;
}

.nolink {
  pointer-events: none;
  cursor: default;
}

.sp {
  display: none;
}

img[src*="_sp"] {
  display: none;
}

.inv_mov {
  opacity: 0;
  transition: opacity 1s, transform 1s;
}

.tl_yb {
  transform: translate(0, 60px);
}

.tl_yt {
  transform: translate(0, -60px);
}

.tl_xl {
  transform: translate(-60px, 0);
}

.tl_xr {
  transform: translate(60px, 0);
}

.tl_rol {
  transform: rotate(-10deg);
}

.tl_ror {
  transform: rotate(10deg);
}

.mov {
  opacity: 1;
  transform: translate(0, 0) rotate(0deg);
  transition: opacity 1s, transform 1s;
}

.mov.delay100 {
  transition-delay: 100ms;
}

.mov.delay200 {
  transition-delay: 200ms;
}

.mov.delay300 {
  transition-delay: 300ms;
}

.mov.delay400 {
  transition-delay: 400ms;
}

.mov.delay500 {
  transition-delay: 500ms;
}
.mov.delay600 {
  transition-delay: 600ms;
}
.mov.delay700 {
  transition-delay: 700ms;
}
@media screen and (max-width: 750px) {
  a.sptel {
    cursor: pointer;
    pointer-events: auto;
  }

  img[src*="_sp"] {
    display: block;
  }
  img[src*="_pc"] {
    display: none;
  }
}
@media screen and (max-width: 640px) {
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
}
