@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
* {
  box-sizing: border-box;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

ul,
li {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

body.nonscroll {
  position: fixed;
  overflow-y: hidden;
  width: 100%;
}

img {
  max-width: 100%;
  height: auto;
}

#suntory_contents {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  position: relative;
}
#suntory_contents.top_suntory_contents #qa_btn_wrap {
  display: none;
}
@media screen and (min-width: 768px) {
  #suntory_contents {
    padding: 0 20px;
  }
  #suntory_contents.top_suntory_contents {
    padding: 0;
  }
}

@media screen and (max-width: 767px) {
  .sp {
    display: inline-block;
  }
}
@media screen and (min-width: 768px) {
  .sp {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .pc {
    display: inline-block;
  }
}

@media screen and (max-width: 767px) {
  #eco_common_footer {
    display: none;
  }
}

.link_btn {
  margin: 0 auto;
  position: relative;
}
.link_btn:before {
  background-color: #2f2f2f;
  content: "";
  display: block;
  position: absolute;
}
.link_btn a {
  background-color: #fbd94f;
  color: #2f2f2f;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  position: absolute;
  top: 0;
  left: 0;
}
.link_btn a:after {
  background: url("../img_new2022/icon01.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
}
.link_btn.map a:after {
  background: url("../img_new2022/icon01.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
}
@media screen and (max-width: 767px) {
  .link_btn {
    height: 12vw;
    width: 54vw;
  }
  .link_btn:before {
    border-radius: 12vw;
    height: 12vw;
    top: 2px;
    left: 2px;
    width: 54vw;
  }
  .link_btn a {
    border: 2px solid #2f2f2f;
    border-radius: 12vw;
    height: 12vw;
    font-size: 4.2vw;
    padding-left: 4vw;
    width: 54vw;
  }
  .link_btn a:after {
    height: 4vw;
    margin-left: 3vw;
    width: 4vw;
  }
  .link_btn.map {
    margin-top: 8vw;
    margin-left: 19vw;
  }
  .link_btn .map_icon .pc {
    display: none;
  }

  .link_btn.map .small_txt {
    font-size: 3.433333333vw;
    display: contents;
  }

  .link_btn .new:before {
    background-color: #ef8602;
    border: 2px solid #2f2f2f;
    content: "NEW";
    font-size: 3.433333333vw;
    position: absolute;
    border-radius: 50px;
    font-weight: bold;
    align-items: center;
    text-align: center;
    display: grid;
    height: 6vw;
    top: -5.433333333vw;
    left: 3vw;
    width: 12vw !important;
    z-index: 3;
  }
  .link_btn .map_icon {
    width: 20vw;
    position: absolute;
    top: -5vw;
    left: -12vw;
    z-index: 2;
  }

  .link_btn_flex.ft .link_btn {
    width: 70vw;
    margin-bottom: 6vw;
  }
  .link_btn_flex.ft .link_btn:before {
    width: 70vw;
  }
  .link_btn_flex.ft .link_btn a {
    width: 70vw;
  }
  .link_btn_flex.ft .link_btn.map {
    line-height: 1.2em;
  }
}
@media screen and (min-width: 768px) {
  .link_btn_flex {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 60px;
  }

  .link_btn {
    height: 50px;
    width: 250px;
  }
  .link_btn:before {
    border-radius: 50px;
    height: 50px;
    top: 3px;
    left: 3px;
    width: 250px;
  }
  .link_btn a {
    border: 2px solid #2f2f2f;
    border-radius: 50px;
    font-size: 18px;
    height: 50px;
    padding-left: 30px;
    width: 250px;
  }
  .link_btn a:after {
    height: 18px;
    margin-left: 15px;
    width: 18px;
  }
  .link_btn:hover:before {
    opacity: 0;
  }
  .link_btn:hover a {
    background-color: #fff;
    top: 3px;
    left: 3px;
  }
  .link_btn.m0 {
    margin: 0;
  }
  .link_btn.map {
    height: 65px;
    margin-left: 60px;
    line-height: 1.2em;
  }
  .link_btn.map:before {
    height: 65px;
    top: 3px;
    left: 3px;
  }
  .link_btn.map a {
    border-radius: 50px;
    font-size: 18px;
    height: 65px;
    padding-left: 30px;
  }
  .link_btn.map .small_txt {
    font-size: 14px;
    display: contents;
  }
  .link_btn .new:before {
    background-color: #ef8602;
    border: 2px solid #2f2f2f;
    content: "NEW";
    position: absolute;
    border-radius: 50px;
    font-weight: bold;
    align-items: center;
    text-align: center;
    display: grid;
    height: 30px;
    top: -28px;
    left: 12px;
    width: 54px !important;
    z-index: 3;
  }
  .link_btn .map_icon {
    width: 85px;
    height: 85px;
    position: absolute;
    top: -17px;
    left: -41px;
    z-index: 2;
  }
  .link_btn .map_icon .sp {
    display: none;
  }

  .link_btn_flex.ft .link_btn {
    width: 290px;
    margin-bottom: 30px;
  }
  .link_btn_flex.ft .link_btn:before {
    width: 290px;
  }
  .link_btn_flex.ft .link_btn a {
    width: 290px;
  }
  .link_btn_flex.ft .link_btn.map {
    height: 65px;
    margin-left: 0;
    line-height: 1.2em;
  }
}

.menu_btn_position_wrap {
  display: flex;
  justify-content: flex-end;
  margin: 0 auto;
  max-width: 1310px;
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 300;
}
.menu_btn_position_wrap.active {
  position: fixed;
}
@media screen and (max-width: 767px) {
  .menu_btn_position_wrap {
    top: 5px;
  }
  .menu_btn_position_wrap.active {
    top: 85px;
  }
}
@media screen and (min-width: 768px) {
  .menu_btn_position_wrap {
    top: 40px;
    max-width: 1230px;
  }
  .menu_btn_position_wrap.active {
    top: 164px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1350px) {
  .menu_btn_position_wrap {
    left: auto;
    right: 40px;
  }
  .menu_btn_position_wrap.active {
    right: 64px;
  }
}

.top_wrap .menu_btn_position_wrap {
  left: auto;
}
@media screen and (min-width: 768px) {
  .top_wrap .menu_btn_position_wrap {
    max-width: 100%;
    top: 20px;
    right: 150px;
  }
  .top_wrap .menu_btn_position_wrap.active {
    top: 120px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1300px) {
  .top_wrap .menu_btn_position_wrap {
    right: 20px;
  }
}

.menu_btn_position {
  margin-left: auto;
  position: relative;
  width: 75px;
}
.menu_btn_position:before {
  background-color: #000;
  border-radius: 50%;
  content: "";
  height: 75px;
  position: absolute;
  top: 2px;
  left: 2px;
  width: 75px;
}
.menu_btn_position .menu_btn_wrap {
  border: 2px solid #000;
  border-radius: 50%;
  background-color: #fbd94f;
  height: 75px;
  position: absolute;
  top: 0;
  left: 0;
  width: 75px;
}
.menu_btn_position .menu_btn {
  cursor: pointer;
  height: 75px;
  position: relative;
  overflow: hidden;
  width: 75px;
}
.menu_btn_position .menu_btn.active .menu_btn_cont span:nth-of-type(1) {
  top: 24px;
  height: 3px;
  transform: translateY(10px) rotate(-135deg);
  left: 19px;
  width: 35px;
}
.menu_btn_position .menu_btn.active .menu_btn_cont span:nth-of-type(2) {
  opacity: 0;
}
.menu_btn_position .menu_btn.active .menu_btn_cont span:nth-of-type(3) {
  top: 43px;
  height: 3px;
  transform: translateY(-10px) rotate(135deg);
  left: 19px;
  width: 35px;
}
.menu_btn_position .menu_btn_cont {
  transition: all 0.3s linear;
}
.menu_btn_position .menu_btn_cont span {
  background-color: #000;
  display: inline-block;
  height: 4px;
  position: absolute;
  left: 22%;
  width: 50%;
  transition: all 0.3s linear;
}
.menu_btn_position .menu_btn_cont span:nth-of-type(1) {
  top: 30%;
}
.menu_btn_position .menu_btn_cont span:nth-of-type(2) {
  top: 45%;
}
.menu_btn_position .menu_btn_cont span:nth-of-type(3) {
  top: 60%;
}
@media screen and (max-width: 767px) {
  .menu_btn_position {
    top: 2.6vw;
    right: 2.6vw;
    width: 13vw;
  }
  .menu_btn_position.active {
    top: 15.6vw;
  }
  .menu_btn_position:before {
    height: 13vw;
    width: 13vw;
  }
  .menu_btn_position .menu_btn_wrap {
    height: 13vw;
    width: 13vw;
  }
  .menu_btn_position .menu_btn {
    height: 13vw;
    width: 13vw;
  }
  .menu_btn_position .menu_btn.active .menu_btn_cont span:nth-of-type(1) {
    height: 0.7vw;
    top: 5.5vw;
    transform: rotate(-135deg);
    left: 2.5vw;
    width: 7vw;
  }
  .menu_btn_position .menu_btn.active .menu_btn_cont span:nth-of-type(3) {
    height: 0.7vw;
    transform: rotate(135deg);
    top: 5.5vw;
    left: 2.5vw;
    width: 7vw;
  }
  .menu_btn_position .menu_btn_cont span {
    height: 0.8vw;
  }
}
@media screen and (min-width: 768px) {
  .menu_btn_position .menu_btn_wrap:hover {
    background-color: #fff;
    top: 2px;
    left: 2px;
  }
}

#suntory_contents {
  overflow: hidden;
}

.gmenu_wrap {
  display: none;
  opacity: 0;
  height: 100%;
  position: fixed;
  top: 100px;
  left: 0;
  width: 100%;
  z-index: 250;
  transition: all 0.5s ease-in-out;
}
.gmenu_wrap .gmenu_bg {
  background-color: #8bd2e1;
  border-radius: 0 0 50% 50%;
  content: "";
  display: block;
  position: absolute;
  top: 50px;
  right: 150px;
  height: 20px;
  width: 20px;
  transition: width 0.5s, height 0.5s;
}
.gmenu_wrap.is-enter {
  display: block;
  opacity: 0;
}
.gmenu_wrap.is-enter .gmenu_bg {
  top: 0;
  right: 0;
  width: 0;
  height: 0;
}
.gmenu_wrap.is-remove {
  display: block;
  opacity: 0;
}
.gmenu_wrap.is-remove .gmenu_bg {
  top: 0;
  right: 0;
  width: 0;
  height: 0;
}
.gmenu_wrap.is-active {
  display: block;
  opacity: 1;
}
.gmenu_wrap.is-active .gmenu_bg {
  top: 0;
  right: 0;
  width: 150vw;
  height: 150vw;
  transform: translate3d(30px, 0, 0);
}
.gmenu_wrap .gmenu_area {
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  .gmenu_wrap {
    top: 87px;
  }
  .gmenu_wrap:before {
    background: url("../img_new2022/menu_bg02.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    margin: 0 auto;
    height: 26.9334vw;
    position: absolute;
    opacity: 0;
    bottom: 55px;
    left: 0;
    right: 0;
    z-index: 10;
    width: 72.9334vw;
    transition: opacity 1s ease-in-out;
  }
  .gmenu_wrap .gmenu_bg {
    border-radius: 10vw 0 10vw 10vw;
    margin-top: -2vw;
  }
  .gmenu_wrap.is-enter .gmenu_bg {
    top: -2vw;
  }
  .gmenu_wrap.is-remove .gmenu_bg {
    top: -2vw;
  }
  .gmenu_wrap.is-active {
    background: url("../img_new2022/menu_bg02.png") no-repeat 50% 100%;
    background-size: 73vw;
  }
  .gmenu_wrap.is-active:before {
    opacity: 1;
  }
  .gmenu_wrap.is-active .gmenu_bg {
    top: -2vw;
    width: 150vw;
    height: 150vh;
  }
  .gmenu_wrap .gmenu_area {
    display: flex;
    align-items: center;
    justify-content: center;
    height: calc(100vh - 49px);
    padding: 0 8.5vw 5vw;
  }
  .gmenu_wrap .gmenu_cont {
    margin-top: -12vw;
  }
  .gmenu_wrap .gmenu_cont ul {
    padding-top: 6vw;
  }
  .gmenu_wrap .gmenu_cont ul li {
    background: url("../img_new2022/icon01.png") no-repeat 0 1px;
    background-size: 4.2vw;
    font-size: 5vw;
    font-weight: 700;
    margin-top: 5vw;
    padding-left: 7vw;
  }
  .gmenu_wrap .gmenu_cont ul li:first-child {
    margin-top: 0;
  }
  .gmenu_wrap .gmenu_cont ul li.blank_link a:before {
    background: url("../img_new2022/icon07.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 4.6vw;
    position: absolute;
    top: 0;
    right: -6.5vw;
    width: 4.6vw;
  }
  .gmenu_wrap .gmenu_cont ul li a {
    color: #2f2f2f;
    display: inline-block;
    position: relative;
    text-decoration: none;
  }
}
@media screen and (max-width: 767px) and (max-width: 400px) {
  .gmenu_wrap:before {
    height: 23.467vw;
    width: 64.8vw;
  }
  .gmenu_wrap .gmenu_cont {
    margin-top: -15vw;
  }
  .gmenu_wrap .gmenu_cont .gmenu_logo {
    margin: -17vw auto 0;
    width: 90%;
  }
  .gmenu_wrap .gmenu_cont ul {
    padding-top: 5vw;
  }
  .gmenu_wrap .gmenu_cont ul li {
    margin-top: 5vw;
  }
}

@media screen and (min-width: 768px) {
  .gmenu_wrap .gmenu_area {
    padding: 60px 20px 20px;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: -280px auto 0;
  }
  .gmenu_wrap .gmenu_cont {
    display: flex;
    justify-content: space-between;
    max-width: 900px;
    margin: 0 auto;
  }
  .gmenu_wrap .gmenu_cont .gmenu_logo {
    width: 50%;
  }
  .gmenu_wrap .gmenu_cont .gmenu_logo:after {
    background: url("../img_new2022/menu_bg01.png") no-repeat 0 0;
    content: "";
    height: 177px;
    display: block;
    margin: 20px auto 0;
    width: 279px;
  }
  .gmenu_wrap .gmenu_cont ul {
    padding-top: 40px;
    width: 41%;
  }
  .gmenu_wrap .gmenu_cont ul li {
    background: url("../img_new2022/icon01.png") no-repeat 0 3px;
    background-size: 18px;
    font-size: 24px;
    font-weight: 700;
    margin-top: 35px;
    padding-left: 30px;
  }
  .gmenu_wrap .gmenu_cont ul li:first-child {
    margin-top: 0;
  }
  .gmenu_wrap .gmenu_cont ul li.blank_link a:before {
    background: url("../img_new2022/icon07.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 18px;
    position: absolute;
    top: 3px;
    right: -25px;
    width: 18px;
  }
  .gmenu_wrap .gmenu_cont ul li a {
    color: #2f2f2f;
    display: inline-block;
    padding-bottom: 4px;
    position: relative;
    text-decoration: none;
    transition: color 0.4s ease-in-out;
  }
  .gmenu_wrap .gmenu_cont ul li a:after {
    background-color: #000;
    content: "";
    height: 2px;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    transition: width 0.4s ease-in-out;
  }
  .gmenu_wrap .gmenu_cont ul li a:hover {
    color: #2f2f2f;
  }
  .gmenu_wrap .gmenu_cont ul li a:hover:after {
    width: 100%;
  }
}

/* トップページ */
.top_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}

.top_head {
  text-align: center;
}
.top_head header {
  position: relative;
}
.top_head header h1 {
  position: relative;
  z-index: 5;
}
.top_head header .main_lead {
  color: #333;
  font-weight: 700;
}
.top_head .link_btn a:after {
  transform: rotate(90deg);
}
.top_head .link_btn.map a:after {
  transform: rotate(0deg);
}
@media screen and (max-width: 767px) {
  .top_head {
    margin-bottom: 8vw;
  }
  .top_head header {
    height: 260vw;
    padding-top: 56vw;
  }
  .top_head header .left_bg {
    background: url("../img_new2022/main_bg01_sp_2.png") no-repeat 0 0;
    background-size: 100%;
    height: 74.8vw;
    position: absolute;
    top: -5vw;
    left: 0;
    width: 100vw;
  }
  .top_head header .left_bg img {
    animation: bg_anime 25s 3s ease-in-out infinite;
  }
  .top_head header .right_bg {
    background: url("../img_new2022/main_bg02_sp_2.png") no-repeat 0 0;
    background-size: 100%;
    height: 45.7334vw;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100vw;
  }
  .top_head header .right_bg img {
    animation: bg_anime 25s 3s ease-in-out infinite;
  }
  .top_head header h1 {
    max-width: 90vw;
    margin: 0 auto 5vw;
  }
  .top_head header .main_lead {
    font-size: 4vw;
    margin: 0 auto 45vw;
    line-height: 200%;
    position: relative;
  }
  .top_head header .main_lead:after {
    background: url("../img_new2022/main_bg03_sp.png") no-repeat 100% 0;
    background-size: 100%;
    content: "";
    height: 39.334vw;
    position: absolute;
    left: 3vw;
    bottom: -40vw;
    width: 86.2667vw;
  }
  .top_head header .link_btn {
    width: 70vw;
  }
  .top_head header .link_btn a, .top_head header .link_btn:before {
    width: 70vw;
  }
}
@media screen and (min-width: 768px) {
  .top_head {
    padding: 74px 0 0;
  }
  .top_head header {
    height: 900px;
  }
  .top_head header .left_bg {
    background: url("../img_new2022/main_bg01_2.png") no-repeat 0 0;
    background-size: 100%;
    height: 724px;
    position: absolute;
    top: 10px;
    left: 0;
    width: 425px;
  }
  .top_head header .left_bg img {
    animation: bg_anime 25s 3s ease-in-out infinite;
  }
}
@media screen and (min-width: 768px) and (max-width: 1300px) {
  .top_head header .left_bg {
    width: 33vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .top_head header .left_bg {
    top: 40px;
    width: 28vw;
  }
}
@media screen and (min-width: 768px) {
  .top_head header .right_bg {
    background: url("../img_new2022/main_bg02_2.png") no-repeat 0 0;
    background-size: 100%;
    height: 720px;
    position: absolute;
    top: 40px;
    right: 0;
    width: 436px;
  }
  .top_head header .right_bg img {
    animation: bg_anime 25s 5s ease-in-out infinite;
  }
}
@media screen and (min-width: 768px) and (max-width: 1300px) {
  .top_head header .right_bg {
    width: 33vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .top_head header .right_bg {
    top: 60px;
    width: 28vw;
  }
}
@media screen and (min-width: 768px) {
  .top_head header h1 {
    margin: 0 auto 35px;
  }
  .top_head header .main_lead {
    font-size: 22px;
    margin: 0 auto 265px;
    line-height: 190%;
    position: relative;
  }
  .top_head header .main_lead:after {
    background: url("../img_new2022/main_bg03.png") no-repeat 100% 0;
    content: "";
    height: 275px;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: -290px;
    width: 540px;
  }
  .top_head .link_btn {
    width: 290px;
  }
  .top_head .link_btn:before {
    width: 290px;
  }
  .top_head .link_btn a {
    width: 290px;
  }
}

@keyframes bg_anime {
  0% {
    opacity: 1;
  }
  10% {
    opacity: 1;
  }
  15% {
    opacity: 0;
  }
  25% {
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  40% {
    opacity: 1;
  }
  45% {
    opacity: 0;
  }
  55% {
    opacity: 0;
  }
  60% {
    opacity: 1;
  }
  65% {
    opacity: 1;
  }
  70% {
    opacity: 0;
  }
  75% {
    opacity: 0;
  }
  80% {
    opacity: 1;
  }
  95% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@media screen and (max-width: 767px) {
  .top_contents_area {
    padding-bottom: 14vw;
  }
}
@media screen and (min-width: 768px) {
  .top_contents_area {
    padding: 0 20px 80px;
  }
}

.contents_list .contents_list_detail {
  background-color: #fff;
  border-radius: 20px;
}
.contents_list a {
  border: 2px solid #000;
  border-radius: 20px;
  height: 100%;
  display: block;
  text-decoration: none;
}
.contents_list h3 {
  color: #000;
  font-weight: 700;
}
.contents_list .date {
  color: #bcbcbc;
}
.contents_list .link {
  color: #000;
  margin-left: auto;
  margin-right: 0;
  padding-top: 2px;
  padding-bottom: 6px;
  position: relative;
  overflow: hidden;
}
.contents_list .link:before {
  background: url("../img_new2022/icon01.png") no-repeat 0 0;
  background-size: 18px;
  content: "";
  position: absolute;
  right: 0;
}
.contents_list .link:after {
  background: linear-gradient(90deg, #0eb0cb 0%, #0eb0cb 50%, #000 50%, #000 100%);
  content: "";
  height: 2px;
  position: absolute;
  right: 0;
  bottom: 0;
  width: 200%;
}
.contents_list .cate_list {
  color: #000;
  display: flex;
  flex-wrap: wrap;
}
.contents_list .cate_list li {
  background: url("../img_new2022/icon02.png") no-repeat 0 0;
  font-weight: 700;
  padding: 1px 0 2px 30px;
}
@media screen and (max-width: 767px) {
  .contents_list {
    max-width: 85.6vw;
    margin: 0 auto;
  }
  .contents_list .contents_list_detail {
    margin-bottom: 8vw;
  }
  .contents_list .contents_list_detail a {
    padding: 5vw 5vw 1vw;
  }
  .contents_list .contents_list_detail .pict {
    margin-bottom: 3vw;
  }
  .contents_list .contents_list_detail h3 {
    font-size: 4vw;
    line-height: 150%;
    margin-bottom: 2vw;
  }
  .contents_list .contents_list_detail .date {
    font-size: 3.4vw;
    margin-bottom: 3px;
  }
  .contents_list .contents_list_detail .link {
    font-size: 3.6vw;
    font-weight: 700;
    padding-top: 0.5vw;
    margin-bottom: 4vw;
    width: 25vw;
  }
  .contents_list .contents_list_detail .link:before {
    background-size: 100%;
    height: 4.2vw;
    top: 0;
    width: 4vw;
  }
  .contents_list .contents_list_detail .cate_list li {
    background-size: 5.2vw;
    font-size: 3.6vw;
    margin: 0 4vw 4vw 0;
    padding: 0.5vw 0 2vw 7vw;
  }
}
@media screen and (min-width: 768px) {
  .contents_list {
    display: flex;
    flex-wrap: wrap;
    max-width: 1154px;
    margin: 0 auto;
  }
  .contents_list .contents_list_detail {
    margin: 0 3.2% 36px 0;
    width: 31.2%;
  }
  .contents_list .contents_list_detail:nth-of-type(3n) {
    margin-right: 0;
  }
  .contents_list .contents_list_detail a {
    padding: 30px 30px 20px;
    transition: border-color 0.4s ease-in-out;
  }
  .contents_list .contents_list_detail a:hover {
    border-color: #0eb0cb;
  }
  .contents_list .contents_list_detail a:hover .pict img {
    transform: scale(1.05);
  }
  .contents_list .contents_list_detail a:hover h3,
  .contents_list .contents_list_detail a:hover .date,
  .contents_list .contents_list_detail a:hover .link,
  .contents_list .contents_list_detail a:hover .cate_list li {
    color: #0eb0cb;
  }
  .contents_list .contents_list_detail a:hover .link:before {
    background-image: url("../img_new2022/icon03.png");
  }
  .contents_list .contents_list_detail a:hover .link:after {
    right: -100%;
  }
  .contents_list .contents_list_detail a:hover .cate_list li {
    background-image: url("../img_new2022/icon02_hover.png");
  }
  .contents_list .contents_list_detail .pict {
    margin-bottom: 20px;
  }
  .contents_list .contents_list_detail .pict img {
    transition: all 0.2s ease-in-out;
  }
  .contents_list .contents_list_detail h3 {
    font-size: 20px;
    margin-bottom: 10px;
    line-height: 140%;
    transition: color 0.2s ease-in-out;
  }
  .contents_list .contents_list_detail .date {
    font-size: 16px;
    margin: 0 0 2px;
    transition: color 0.2s ease-in-out;
  }
  .contents_list .contents_list_detail .link {
    font-weight: 700;
    margin-bottom: 35px;
    width: 104px;
    transition: color 0.2s ease-in-out;
  }
  .contents_list .contents_list_detail .link:before {
    height: 18px;
    top: 0;
    width: 18px;
  }
  .contents_list .contents_list_detail .link:after {
    transition: right 0.2s ease-in-out;
  }
  .contents_list .contents_list_detail .cate_list li {
    background-size: 23px;
    font-size: 14px;
    line-height: 140%;
    margin: 0 15px 10px 0;
    transition: color 0.2s ease-in-out;
  }
}

.top_news_area {
  background-color: #73bc59;
  position: relative;
}
.top_news_area:after {
  background: url("../img_new2022/news_bg.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
}
@media screen and (max-width: 767px) {
  .top_news_area {
    padding: 10vw 6vw 22vw;
  }
  .top_news_area:after {
    height: 24.1334vw;
    right: -3.5vw;
    bottom: -1.3vw;
    width: 52.2667vw;
  }
  .top_news_area .top_news {
    margin: 0 auto;
  }
  .top_news_area .top_news .sec_cont {
    margin-bottom: 3vw;
  }
  .top_news_area .top_news h2 {
    margin-bottom: 7vw;
    width: 39.2vw;
  }
  .top_news_area .top_news .top_news_detail dl {
    display: flex;
    margin-bottom: 6vw;
  }
  .top_news_area .top_news .top_news_detail dl dt {
    color: #000;
    font-size: 3.2vw;
    padding-top: 3px;
    width: 22%;
  }
  .top_news_area .top_news .top_news_detail dl dd {
    font-size: 3.7vw;
    line-height: 140%;
    font-weight: 700;
    width: 78%;
  }
  .top_news_area .top_news .top_news_detail dl dd a {
    color: #000;
    display: inline-block;
    padding-bottom: 4px;
    position: relative;
    text-decoration: none;
  }
}
@media screen and (min-width: 768px) {
  .top_news_area {
    padding: 75px 20px;
  }
  .top_news_area:after {
    height: 181px;
    bottom: -10px;
    right: 0;
    width: 392px;
  }
  .top_news_area .top_news {
    max-width: 992px;
    margin: 0 auto;
  }
  .top_news_area .top_news .sec_cont {
    display: flex;
    margin-bottom: 15px;
  }
  .top_news_area .top_news h2 {
    margin-right: 8%;
    width: 23.3%;
  }
  .top_news_area .top_news .top_news_detail {
    width: 65%;
  }
  .top_news_area .top_news .top_news_detail dl {
    display: flex;
    margin-bottom: 30px;
  }
  .top_news_area .top_news .top_news_detail dl dt {
    color: #000;
    font-size: 15px;
    padding-top: 5px;
    width: 16%;
  }
  .top_news_area .top_news .top_news_detail dl dd {
    font-size: 18px;
    line-height: 140%;
    font-weight: 700;
    width: 84%;
  }
  .top_news_area .top_news .top_news_detail dl dd a {
    color: #000;
    display: inline-block;
    padding-bottom: 4px;
    position: relative;
    text-decoration: none;
    transition: color 0.4s ease-in-out;
  }
  .top_news_area .top_news .top_news_detail dl dd a:after {
    background-color: #000;
    content: "";
    height: 2px;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    transition: width 0.4s ease-in-out;
  }
  .top_news_area .top_news .top_news_detail dl dd a:hover {
    color: #2f2f2f;
  }
  .top_news_area .top_news .top_news_detail dl dd a:hover:after {
    width: 100%;
  }
}

.top_sec_space {
  background: #fff;
  padding: 10vw 0;
}
@media screen and (min-width: 768px) {
  .top_sec_space {
    display: none;
  }
}

.top_factory_area {
  background-color: #a5dfea;
}
.top_factory_area .map_link li {
  position: absolute;
}
.top_factory_area .factory_link_area {
  background-color: #fff;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 25px;
}
.top_factory_area .factory_link_area .factory_link h3 {
  background-color: #e7a61c;
  border-radius: 20px;
  color: #fff;
  font-weight: 700;
  text-align: center;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li {
  margin-bottom: 10px;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a {
  color: #2f2f2f;
  font-weight: 700;
  display: block;
  line-height: 140%;
  position: relative;
  text-decoration: none;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a i {
  font-style: normal;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a span {
  color: #a7a7a7;
  display: block;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a img {
  position: absolute;
  top: 0;
  left: 0;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a:before {
  background: url("../img_new2022/icon01.png") no-repeat 0 0;
  background-size: 18px;
  content: "";
  height: 18px;
  position: absolute;
  top: 0;
  right: 0;
  width: 18px;
}
.top_factory_area .factory_link_area .factory_link .factory_link_list li a:after {
  background-color: #3d3d3d;
  content: "";
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
.top_factory_area .factory_link_area .factory_link.link_cate02 h3 {
  background-color: #893611;
}
.top_factory_area .factory_link_area .factory_link.link_cate03 h3 {
  background-color: #8f1d53;
}
.top_factory_area .factory_link_area .factory_link.link_cate04 h3 {
  background-color: #52b1d0;
}
.top_factory_area .qa_link {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .top_factory_area .top_factory {
    padding: 30vw 0 10vw;
    position: relative;
  }
  .top_factory_area h2 {
    position: absolute;
    top: 14vw;
    left: 5vw;
    width: 63vw;
  }
  .top_factory_area .map_area {
    min-height: 70vw;
    max-width: 96.3vw;
    margin: 0 auto;
    padding-bottom: 12vw;
    position: relative;
  }
  .top_factory_area .map_area:after {
    background: url("../img_new2022/factory_yoyaku_sp.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 23.334vw;
    position: absolute;
    bottom: 0;
    right: 2vw;
    width: 80.8vw;
  }
  .top_factory_area .map_link li {
    transition: all 0.3s ease-in-out;
    width: 6.2vw;
  }
  .top_factory_area .map_link li.map_pin01 {
    top: 42vw;
    left: 44vw;
    z-index: 11;
  }
  .top_factory_area .map_link li.map_pin02 {
    top: 41.2vw;
    left: 29.7vw;
    z-index: 10;
  }
  .top_factory_area .map_link li.map_pin03 {
    top: 47.2vw;
    left: 8.4vw;
    z-index: 9;
  }
  .top_factory_area .map_link li.map_pin04 {
    top: 41.2vw;
    left: 27.6vw;
    z-index: 8;
  }
  .top_factory_area .map_link li.map_pin05 {
    top: 40vw;
    left: 40vw;
    z-index: 6;
  }
  .top_factory_area .map_link li.map_pin06 {
    top: 40.4vw;
    left: 40.4vw;
    z-index: 7;
  }
  .top_factory_area .map_link li.map_pin07 {
    top: 39.8vw;
    left: 38.4vw;
    z-index: 5;
  }
  .top_factory_area .map_link li.map_pin08 {
    top: 36.2vw;
    left: 38.8vw;
    z-index: 4;
  }
  .top_factory_area .map_link li.map_pin09 {
    top: 38.2vw;
    left: 21.3vw;
    z-index: 3;
  }
  .top_factory_area .map_link li.map_pin10 {
    top: 47vw;
    left: 6.6vw;
    z-index: 2;
  }
  .top_factory_area .map_link li.big {
    transform: scale(1.3);
    z-index: 20;
  }
  .top_factory_area .factory_link_area {
    border-top: 2px solid #000;
    border-bottom: 2px solid #000;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 6vw 6vw 1vw;
  }
  .top_factory_area .factory_link_area .factory_link {
    margin-bottom: 5vw;
    width: 47.5%;
  }
  .top_factory_area .factory_link_area .factory_link .pict {
    margin-bottom: 2.6vw;
  }
  .top_factory_area .factory_link_area .factory_link h3 {
    font-size: 3.4vw;
    margin-bottom: 2vw;
    padding: 5px 0;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li {
    margin-bottom: 2vw;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a {
    font-size: 3.4vw;
    line-height: 140%;
    min-height: 45px;
    padding-right: 23px;
    padding-bottom: 12px;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a:before {
    background-size: 100%;
    height: 3.4vw;
    top: 1vw;
    width: 3.4vw;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a i {
    font-size: 3vw;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a span {
    font-size: 3vw;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover {
    color: #e7a61c;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover span {
    color: #e7a61c;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon04.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover {
    color: #893611;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover span {
    color: #893611;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon05.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover {
    color: #8f1d53;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover span {
    color: #8f1d53;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon06.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover {
    color: #52b1d0;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover span {
    color: #52b1d0;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon03.png");
  }
  .top_factory_area .qa_link {
    display: flex;
    justify-content: center;
  }
  .top_factory_area .qa_link a {
    display: block;
    height: 32.667vw;
    width: 46vw;
  }
}
@media screen and (min-width: 768px) {
  .top_factory_area .top_factory {
    padding: 90px 20px 30px;
  }
  .top_factory_area .sec_cont {
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
  }
  .top_factory_area h2 {
    position: absolute;
    top: 0;
    left: 0;
  }
  .top_factory_area .map_area {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 10px;
    position: relative;
  }
  .top_factory_area .map_area:after {
    background: url("../img_new2022/factory_yoyaku.png") no-repeat 0 0;
    content: "";
    height: 296px;
    position: absolute;
    bottom: 80px;
    right: 20px;
    width: 301px;
  }
  .top_factory_area .map_link {
    min-height: 650px;
  }
  .top_factory_area .map_link li {
    transition: all 0.3s ease-in-out;
  }
  .top_factory_area .map_link li.map_pin01 {
    top: 435px;
    left: 504px;
    z-index: 11;
  }
  .top_factory_area .map_link li.map_pin02 {
    top: 425px;
    left: 362px;
    z-index: 10;
  }
  .top_factory_area .map_link li.map_pin03 {
    top: 480px;
    left: 162px;
    z-index: 9;
  }
  .top_factory_area .map_link li.map_pin04 {
    top: 422px;
    left: 352px;
    z-index: 8;
  }
  .top_factory_area .map_link li.map_pin05 {
    top: 410px;
    left: 464px;
    z-index: 6;
  }
  .top_factory_area .map_link li.map_pin06 {
    top: 420px;
    left: 477px;
    z-index: 7;
  }
  .top_factory_area .map_link li.map_pin07 {
    top: 410px;
    left: 453px;
    z-index: 5;
  }
  .top_factory_area .map_link li.map_pin08 {
    top: 390px;
    left: 458px;
    z-index: 4;
  }
  .top_factory_area .map_link li.map_pin09 {
    top: 395px;
    left: 284px;
    z-index: 3;
  }
  .top_factory_area .map_link li.map_pin10 {
    top: 480px;
    left: 150px;
    z-index: 2;
  }
  .top_factory_area .map_link li.big {
    transform: scale(1.3);
    z-index: 20;
  }
  .top_factory_area .factory_link_area {
    border: 2px solid #000;
    border-radius: 20px;
    justify-content: space-between;
    padding: 30px;
  }
  .top_factory_area .factory_link_area .factory_link {
    max-width: 206px;
    width: 22%;
  }
  .top_factory_area .factory_link_area .factory_link .pict {
    margin-bottom: 20px;
  }
  .top_factory_area .factory_link_area .factory_link h3 {
    font-size: 16px;
    margin-bottom: 15px;
    padding: 5px 0;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li {
    margin-bottom: 10px;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a {
    font-size: 14px;
    line-height: 140%;
    min-height: 45px;
    padding-right: 23px;
    padding-bottom: 12px;
  }
  .top_factory_area .factory_link_area .factory_link .factory_link_list li a span {
    font-size: 12px;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover {
    color: #e7a61c;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover span {
    color: #e7a61c;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate01 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon04.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover {
    color: #893611;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover span {
    color: #893611;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate02 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon05.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover {
    color: #8f1d53;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover span {
    color: #8f1d53;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate03 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon06.png");
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover {
    color: #52b1d0;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover span {
    color: #52b1d0;
  }
  .top_factory_area .factory_link_area .factory_link.link_cate04 .factory_link_list li a:hover:before {
    background-image: url("../img_new2022/icon03.png");
  }
  .top_factory_area .qa_link {
    display: flex;
    justify-content: center;
  }
  .top_factory_area .qa_link a {
    display: block;
    height: 154px;
    width: 218px;
  }
  .top_factory_area .qa_link a:hover {
    background: url("../img_new2022/qa_link_hover.png") no-repeat 100% 100%;
  }
  .top_factory_area .qa_link a:hover img {
    opacity: 0;
  }
}

.mail_magazine_link_area {
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .mail_magazine_link_area {
    border-top: 3px solid #000;
    padding: 10vw 7vw 10vw;
  }
}
@media screen and (min-width: 768px) {
  .mail_magazine_link_area {
    padding: 80px 20px 80px;
  }
  .mail_magazine_link_area a {
    transition: opacity 0.4s ease-in-out;
  }
  .mail_magazine_link_area a:hover {
    opacity: 0.7;
  }
}

/****** concept *********/
.concept_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}
@media screen and (max-width: 767px) {
  .concept_wrap {
    border-top: 4px solid #000;
    border-bottom: 4px solid #000;
  }
}
@media screen and (min-width: 768px) {
  .concept_wrap {
    border: 4px solid #000;
    border-radius: 20px;
    max-width: 1310px;
    margin: 20px auto 0;
    position: relative;
  }
}

.concept_head {
  text-align: center;
}
.concept_head .headlogo {
  transform: scale(0.6);
  opacity: 0;
  animation: logo_anime 1s 1s ease-in-out forwards;
}
@media screen and (max-width: 767px) {
  .concept_head {
    padding: 18vw 0 0;
  }
  .concept_head .headlogo {
    max-width: 84.4vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  .concept_head {
    padding: 140px 20px 0;
  }
  .concept_head .headlogo {
    max-width: 685px;
    margin: 0 auto;
  }
}

@keyframes logo_anime {
  0% {
    opacity: 0;
    transform: scale(0.6);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.concept_contents .concept_detail {
  position: relative;
}
.concept_contents .concept_detail:before {
  content: "";
  position: absolute;
}
.concept_contents p {
  color: #2f2f2f;
  font-weight: 700;
  position: relative;
}
@media screen and (max-width: 767px) {
  .concept_contents {
    background: url("../img_new2022/concept_footbg_sp.png") no-repeat 0 100%;
    background-size: 100%;
    padding: 10vw 0 74vw;
  }
  .concept_contents .concept_detail {
    padding: 0 6vw;
  }
  .concept_contents .concept_detail:before {
    background: url("../img_new2022/concept_bg01_sp.png") no-repeat 0 0;
    background-size: 100%;
    height: 68.9334vw;
    top: 34vw;
    right: 2vw;
    width: 32vw;
  }
  .concept_contents p {
    font-size: 3.4vw;
    margin-top: 8vw;
    line-height: 200%;
  }
  .concept_contents p:first-of-type {
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .concept_contents {
    background: url("../img_new2022/concept_footbg.png") no-repeat 0 100%;
    background-size: 100%;
    padding: 70px 20px 500px;
    text-align: center;
  }
}
@media screen and (min-width: 768px) and (max-width: 1310px) {
  .concept_contents {
    padding-bottom: 35vw;
  }
}
@media screen and (min-width: 768px) {
  .concept_contents .concept_detail {
    margin: 0 auto;
    max-width: 1050px;
  }
  .concept_contents .concept_detail:before {
    background: url("../img_new2022/concept_bg01.png") no-repeat 0 0;
    height: 45px;
    top: 520px;
    left: 0;
    width: 142px;
  }
  .concept_contents .concept_detail:after {
    background: url("../img_new2022/concept_bg02.png") no-repeat 0 0;
    content: "";
    height: 437px;
    position: absolute;
    right: 0;
    top: 200px;
    width: 184px;
  }
  .concept_contents p {
    font-size: 22px;
    margin-top: 60px;
    line-height: 190%;
  }
  .concept_contents p:first-of-type {
    margin-top: 0;
  }
}

.scroll_fade {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .8s linear, transform .8s ease-in-out;
}
.scroll_fade.show {
  opacity: 1;
  transform: translateY(0px);
}

/****** news *********/
.news_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}
@media screen and (max-width: 767px) {
  .news_wrap {
    border-top: 4px solid #000;
    border-bottom: 4px solid #000;
  }
}
@media screen and (min-width: 768px) {
  .news_wrap {
    border: 4px solid #000;
    border-radius: 20px;
    max-width: 1310px;
    margin: 20px auto 0;
    position: relative;
  }
}

.news_head {
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .news_head {
    padding: 3vw 0;
  }
  .news_head .headlogo {
    max-width: 33.3vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  .news_head {
    border-radius: 20px 20px 0 0;
    padding: 25px 20px;
  }
  .news_head .headlogo {
    max-width: 271px;
    margin: 0 auto;
  }
}

.topicpath {
  display: flex;
}
@media screen and (max-width: 767px) {
  .topicpath {
    margin: 0 0 5vw;
    padding: 3.5vw 2.5vw 1vw;
  }
  .topicpath p {
    color: #2f2f2f;
    font-size: 2.8vw;
    line-height: 150%;
  }
  .topicpath p span:before {
    font-size: 2.5vw;
    content: "＞";
    margin: 0 1.5vw;
  }
  .topicpath p span:first-child:before {
    display: none;
  }
  .topicpath p span i {
    font-style: normal;
  }
  .topicpath p a {
    color: #2f2f2f;
  }
}
@media screen and (min-width: 768px) {
  .topicpath {
    justify-content: flex-end;
    max-width: 1200px;
    margin: 25px auto 65px;
    padding: 0 20px;
  }
  .topicpath p {
    color: #2f2f2f;
    font-size: 14px;
    font-weight: 700;
  }
  .topicpath p span {
    display: inline-block;
    vertical-align: top;
  }
  .topicpath p span:before {
    content: "＞";
    display: inline-block;
    vertical-align: top;
    margin: 1px 15px 0;
  }
  .topicpath p span:first-child:before {
    display: none;
  }
  .topicpath p span i {
    font-style: normal;
    display: inline-block;
    padding-bottom: 2px;
  }
  .topicpath p a {
    color: #2f2f2f;
    display: inline-block;
    padding-bottom: 2px;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    transition: color 0.2s ease-in-out;
  }
  .topicpath p a:after {
    background: linear-gradient(90deg, #0eb0cb 0%, #0eb0cb 50%, #000 50%, #000 100%);
    content: "";
    height: 1px;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 200%;
    transition: all 0.2s ease-in-out;
  }
  .topicpath p a:hover {
    color: #0eb0cb;
  }
  .topicpath p a:hover:after {
    right: -100%;
  }
}

.news_contents .news_detail {
  position: relative;
}
.news_contents .news_detail:after {
  background: url("../img_new2022/news_bg01.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
}
.news_contents .news_list {
  background-color: #fff;
}
.news_contents .news_detail_sec {
  position: relative;
}
.news_contents .news_detail_sec:after {
  background: url("../img_new2022/news_bg02.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
}
.news_contents .news_sec_contents {
  background-color: #fff;
}
.news_contents h2 {
  border-bottom: 2px dotted rgba(0, 0, 0, 0.3);
  font-weight: 700;
}
.news_contents h2 span {
  display: block;
}
@media screen and (max-width: 767px) {
  .news_contents {
    padding: 0 7vw 13vw;
  }
  .news_contents .news_detail:after {
    height: 21.6vw;
    top: 14.7vw;
    right: 2vw;
    width: 37.0667vw;
  }
  .news_contents .news_detail_sec {
    max-width: 956px;
    margin: 0 auto;
    position: relative;
  }
  .news_contents .news_detail_sec:after {
    height: 24.2667vw;
    top: 13vw;
    right: 2vw;
    width: 49.4667vw;
  }
  .news_contents h1 {
    margin-bottom: 16vw;
    width: 39.2vw;
  }
  .news_contents h2 {
    font-size: 5.3vw;
    line-height: 140%;
    padding-bottom: 3vw;
  }
  .news_contents h2 span {
    font-size: 3vw;
    font-weight: 500;
    margin-bottom: 1.5vw;
  }
  .news_contents .news_sec_contents {
    border-radius: 10px;
    border: 2px solid #000;
    margin-bottom: 6vw;
    padding: 8vw 5vw;
  }
  .news_contents .news_sec_contents .news_sec_detail p {
    font-size: 3.6vw;
    margin-top: 4vw;
    line-height: 200%;
  }
  .news_contents .news_sec_contents .news_sec_detail p a {
    color: #0eb0cb;
    text-decoration: none;
  }
  .news_contents .news_list {
    border-radius: 10px;
    border: 2px solid #000;
    padding: 8vw 5vw 2vw;
  }
  .news_contents .news_list dl {
    border-top: 2px dotted rgba(0, 0, 0, 0.3);
    margin: 0 auto 6vw;
    padding-top: 6vw;
  }
  .news_contents .news_list dl:first-of-type {
    border-top: none;
    padding-top: 0;
  }
  .news_contents .news_list dl dt {
    font-size: 3.6vw;
    margin-bottom: 3.8vw;
  }
  .news_contents .news_list dl dd {
    font-size: 4.2vw;
    line-height: 140%;
    font-weight: 700;
  }
  .news_contents .news_list dl dd a {
    color: #000;
    display: inline-block;
    position: relative;
    text-decoration: none;
  }
}
@media screen and (min-width: 768px) {
  .news_contents {
    padding: 0 20px 85px;
  }
  .news_contents .news_detail {
    max-width: 956px;
    margin: 0 auto;
    position: relative;
  }
  .news_contents .news_detail:after {
    height: 195px;
    top: 5px;
    right: 30px;
    width: 336px;
  }
  .news_contents .news_detail_sec {
    max-width: 956px;
    margin: 0 auto;
    position: relative;
  }
  .news_contents .news_detail_sec:after {
    height: 182px;
    top: 23px;
    right: 20px;
    width: 371px;
  }
  .news_contents h1 {
    margin-bottom: 80px;
    width: 231px;
  }
  .news_contents h2 {
    font-size: 30px;
    line-height: 140%;
    padding-bottom: 25px;
  }
  .news_contents h2 span {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 15px;
  }
  .news_contents .news_sec_contents {
    border-radius: 20px;
    border: 2px solid #000;
    margin-bottom: 30px;
    padding: 55px 20px;
  }
  .news_contents .news_sec_contents .news_sec_detail {
    max-width: 850px;
    margin: 0 auto;
  }
  .news_contents .news_sec_contents .news_sec_detail p {
    font-size: 18px;
    margin-top: 35px;
    line-height: 200%;
  }
  .news_contents .news_sec_contents .news_sec_detail p a {
    color: #0eb0cb;
    display: inline-block;
    padding-bottom: 4px;
    position: relative;
    text-decoration: none;
  }
  .news_contents .news_sec_contents .news_sec_detail p a:after {
    background-color: #0eb0cb;
    content: "";
    height: 2px;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    transition: width 0.4s ease-in-out;
  }
  .news_contents .news_sec_contents .news_sec_detail p a:hover:after {
    width: 100%;
  }
  .news_contents .news_list {
    border-radius: 20px;
    border: 2px solid #000;
    padding: 55px 20px 30px;
  }
  .news_contents .news_list dl {
    border-top: 2px dotted rgba(0, 0, 0, 0.3);
    display: flex;
    max-width: 850px;
    margin: 0 auto 25px;
    padding-top: 25px;
  }
  .news_contents .news_list dl:first-of-type {
    border-top: none;
    padding-top: 0;
  }
  .news_contents .news_list dl dt {
    font-weight: 600;
    margin-right: 2.35%;
    padding-top: 4px;
    width: 10%;
  }
  .news_contents .news_list dl dd {
    font-size: 18px;
    line-height: 140%;
    font-weight: 700;
    width: 87.65%;
  }
  .news_contents .news_list dl dd a {
    color: #000;
    display: inline-block;
    padding-bottom: 4px;
    position: relative;
    text-decoration: none;
    transition: color 0.4s ease-in-out;
  }
  .news_contents .news_list dl dd a:hover {
    color: #0eb0cb;
  }
}

/****** contents *********/
.contents_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}
@media screen and (max-width: 767px) {
  .contents_wrap {
    border-top: 4px solid #000;
    border-bottom: 4px solid #000;
  }
}
@media screen and (min-width: 768px) {
  .contents_wrap {
    border: 4px solid #000;
    border-radius: 20px;
    max-width: 1310px;
    margin: 20px auto 0;
    position: relative;
  }
}

.contents_head {
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contents_head {
    padding: 3vw 0;
  }
  .contents_head .headlogo {
    max-width: 33.3vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  .contents_head {
    border-radius: 20px 20px 0 0;
    padding: 25px 20px;
  }
  .contents_head .headlogo {
    max-width: 271px;
    margin: 0 auto;
  }
}

.contents_contents .contents_detail {
  position: relative;
}
.contents_contents .contents_detail:after {
  background: url("../img_new2022/contents_bg01.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
}
@media screen and (max-width: 767px) {
  .contents_contents {
    padding: 0 7vw 13vw;
  }
  .contents_contents .contents_detail:after {
    height: 24.534vw;
    top: 22vw;
    right: -3vw;
    width: 69.467vw;
  }
  .contents_contents h1 {
    margin-bottom: 28vw;
    width: 77.3vw;
  }
  .contents_contents .contents_catelist_area {
    margin-bottom: 8vw;
  }
  .contents_contents .contents_catelist_area .contents_catelist li {
    display: none;
  }
  .contents_contents .contents_catelist_area .contents_catelist li.c {
    display: block;
  }
  .contents_contents .contents_catelist_area .contents_catelist li a {
    background: url("../img_new2022/icon02.png") no-repeat 3vw 2.3vw #fbd94f;
    background-size: 5.2vw;
    border: 2px solid #000;
    border-radius: 40px;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    line-height: 140%;
    display: block;
    padding: 2vw 6vw 2vw 10vw;
    text-decoration: none;
    position: relative;
  }
  .contents_contents .contents_catelist_area .contents_catelist li a:after {
    background: url("../img_new2022/icon01.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 4.4vw;
    position: absolute;
    top: 2.5vw;
    right: 4vw;
    width: 4.4vw;
  }
  .contents_contents .contents_catelist_area.active {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 53px;
    left: 0;
    z-index: 10;
    width: 100%;
  }
  .contents_contents .contents_catelist_area.active .contents_catelist_area_bg {
    background-color: #fbd94f;
    height: 200%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 53px;
    left: 0;
    z-index: 10;
    width: 100%;
  }
  .contents_contents .contents_catelist_area.active .contents_catelist {
    display: flex;
    flex-wrap: wrap;
    width: 88vw;
    position: relative;
    z-index: 15;
  }
  .contents_contents .contents_catelist_area.active .contents_catelist li {
    display: block;
    margin: 0 8px 8px 0;
  }
  .contents_contents .contents_catelist_area.active .contents_catelist li a:after {
    display: none;
  }
  .contents_contents .contents_catelist_area.active .contents_catelist li.c a {
    background-color: #ef8602;
  }
}
@media screen and (min-width: 768px) {
  .contents_contents {
    padding: 0 20px 85px;
  }
  .contents_contents .contents_detail {
    max-width: 1154px;
    margin: 0 auto;
    position: relative;
  }
  .contents_contents .contents_detail:after {
    height: 167px;
    top: -45px;
    right: -20px;
    width: 535px;
  }
  .contents_contents h1 {
    margin-bottom: 35px;
    width: 471px;
  }
  .contents_contents .contents_catelist_area {
    margin-bottom: 80px;
  }
  .contents_contents .contents_catelist_area .contents_catelist {
    display: flex;
    flex-wrap: wrap;
  }
  .contents_contents .contents_catelist_area .contents_catelist li {
    margin: 0 14px 14px 0;
  }
  .contents_contents .contents_catelist_area .contents_catelist li a {
    background: url("../img_new2022/icon02.png") no-repeat 15px 10px #fbd94f;
    background-size: 23px;
    border: 2px solid #000;
    border-radius: 40px;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    line-height: 140%;
    display: block;
    padding: 10px 25px 8px 45px;
    text-decoration: none;
    position: relative;
  }
  .contents_contents .contents_catelist_area .contents_catelist li a:hover {
    background-color: #fff;
  }
  .contents_contents .contents_catelist_area .contents_catelist li.c a {
    background-color: #ef8602;
  }
}

@media screen and (max-width: 767px) {
  .contents_mv {
    margin: -8vw auto 10vw;
  }
}
@media screen and (min-width: 768px) {
  .contents_mv {
    margin: -45px auto 70px;
  }
}

@media screen and (max-width: 767px) {
  .contents_sec {
    margin: 0 auto;
  }
  .contents_sec h1 {
    color: #2f2f2f;
    font-size: 5vw;
    font-weight: 700;
    margin: 0 auto 5vw;
    line-height: 170%;
    text-align: center;
    width: auto;
  }
  .contents_sec .date {
    color: #2f2f2f;
    font-size: 2.8vw;
    margin: 0 auto 10vw;
    text-align: center;
  }
}
@media screen and (min-width: 768px) {
  .contents_sec {
    max-width: 960px;
    margin: 0 auto;
  }
  .contents_sec h1 {
    color: #2f2f2f;
    font-size: 30px;
    font-weight: 700;
    margin: 0 auto 20px;
    line-height: 120%;
    text-align: center;
    width: auto;
  }
  .contents_sec .date {
    color: #2f2f2f;
    font-size: 14px;
    margin: 0 auto 50px;
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .sec_infoarea .sec_catelist {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10vw;
  }
  .sec_infoarea .sec_catelist li {
    margin: 0 2vw 2vw 0;
  }
  .sec_infoarea .sec_catelist li a {
    background: url("../img_new2022/icon02.png") no-repeat 3vw 2.3vw #fbd94f;
    background-size: 5.2vw;
    border: 2px solid #000;
    border-radius: 40px;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    line-height: 140%;
    display: block;
    padding: 2vw 5vw 2vw 10vw;
    text-decoration: none;
    position: relative;
  }
  .sec_infoarea .lead_txt {
    font-size: 3.6vw;
    line-height: 220%;
  }
  .sec_infoarea .talk_area + .lead_txt {
    margin-top: 5vw;
  }
}
@media screen and (min-width: 768px) {
  .sec_infoarea {
    max-width: 750px;
    margin: 0 auto;
  }
  .sec_infoarea .sec_catelist {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 50px;
  }
  .sec_infoarea .sec_catelist li {
    margin: 0 13px 14px 0;
  }
  .sec_infoarea .sec_catelist li a {
    background: url("../img_new2022/icon02.png") no-repeat 15px 10px #fbd94f;
    background-size: 23px;
    border: 2px solid #000;
    border-radius: 40px;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    line-height: 140%;
    display: block;
    padding: 10px 25px 8px 45px;
    text-decoration: none;
    position: relative;
  }
  .sec_infoarea .sec_catelist li a:hover {
    background-color: #fff;
  }
  .sec_infoarea .lead_txt {
    font-size: 18px;
    line-height: 220%;
  }
  .sec_infoarea .talk_area + .lead_txt {
    margin-top: 40px;
  }
}

.talk_area .talk_cont {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.talk_area .talk_cont dd {
  color: #2f2f2f;
  line-height: 150%;
  position: relative;
}
.talk_area .talk_cont dd:after {
  background: url("../img_new2022/contents_talk_bg01.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
  height: 24px;
  left: -17px;
  width: 20px;
}
.talk_area .talk_cont dd div {
  background-color: #fff;
  border: 3px solid #333;
  border-radius: 10px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
}
.talk_area .talk_cont dd div:before {
  background: url("../img_new2022/contents_talk_bg02.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
  height: 3px;
  top: -3px;
  width: 48px;
}
.talk_area .talk_cont dd div:after {
  background: url("../img_new2022/contents_talk_bg03.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
  height: 3px;
  bottom: -3px;
  right: 20px;
  width: 53px;
}
.talk_area .talk_cont.reverse {
  flex-flow: row-reverse;
}
.talk_area .talk_cont.reverse dd:after {
  transform: scale(-1, 1);
}
.talk_area .talk_cont.reverse dd div:before {
  transform: scale(-1, 1);
}
.talk_area .talk_cont.reverse dd div:after {
  transform: scale(-1, 1);
}
@media screen and (max-width: 767px) {
  .talk_area .talk_cont {
    margin-top: 5vw;
  }
  .talk_area .talk_cont:first-of-type {
    margin-top: 0;
  }
  .talk_area .talk_cont dt {
    width: 16%;
  }
  .talk_area .talk_cont dd {
    font-size: 3.4vw;
    width: 78%;
  }
  .talk_area .talk_cont dd:after {
    height: 16px;
    top: 5vw;
    left: -11px;
    width: 14px;
  }
  .talk_area .talk_cont dd div {
    min-height: 13vw;
    padding: 4vw 5vw;
  }
  .talk_area .talk_cont dd div:before {
    background-image: url("../img_new2022/contents_talk_bg02_sp.png");
    left: 4.5vw;
    height: 0.8vw;
    width: 12.9334vw;
  }
  .talk_area .talk_cont dd div:after {
    background-image: url("../img_new2022/contents_talk_bg03_sp.png");
    height: 0.8vw;
    right: 4.5vw;
    width: 14.1334vw;
  }
  .talk_area .talk_cont.reverse dd:after {
    left: auto;
    right: -11px;
  }
  .talk_area .talk_cont.reverse dd div:before {
    left: auto;
    right: 4.5vw;
  }
  .talk_area .talk_cont.reverse dd div:after {
    right: auto;
    left: 4.5vw;
  }
}
@media screen and (min-width: 768px) {
  .talk_area .talk_cont {
    margin-top: 25px;
  }
  .talk_area .talk_cont:first-of-type {
    margin-top: 0;
  }
  .talk_area .talk_cont dt {
    width: 13.067%;
  }
  .talk_area .talk_cont dd {
    font-size: 18px;
    width: 82%;
  }
  .talk_area .talk_cont dd:after {
    top: 35px;
  }
  .talk_area .talk_cont dd div {
    border: 3px solid #333;
    border-radius: 10px;
    min-height: 100px;
    padding: 33px 40px;
  }
  .talk_area .talk_cont dd div:before {
    left: 20px;
  }
  .talk_area .talk_cont dd div:after {
    right: 20px;
  }
  .talk_area .talk_cont.reverse dd:after {
    left: auto;
    right: -17px;
  }
  .talk_area .talk_cont.reverse dd div:before {
    left: auto;
    right: 20px;
  }
  .talk_area .talk_cont.reverse dd div:after {
    right: auto;
    left: 20px;
  }
}

.character_bg {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .character_bg {
    margin: 10vw auto 0;
    max-width: 72vw;
  }
}
@media screen and (min-width: 768px) {
  .character_bg {
    margin: 50px auto 0;
  }
}

.sec_main_area {
  background-color: #fff;
  border: 2px solid #000;
  min-height: 1px;
  position: relative;
}
.sec_main_area a {
  color: #0eb0cb;
}
@media screen and (max-width: 767px) {
  .sec_main_area {
    border-radius: 10px;
    margin-top: -3px;
  }
  .sec_main_area + .sec_infoarea {
    margin-top: 10vw;
  }
  .sec_main_area .sec_main_mv {
    border-radius: 9px 9px 0 0;
    overflow: hidden;
  }
  .sec_main_area .sec_main_detail {
    padding: 8vw 4vw;
  }
  .sec_main_area h2 {
    color: #2f2f2f;
    font-size: 4.5vw;
    font-weight: 700;
    line-height: 130%;
  }
  .sec_main_area h2 + .sec_main_set {
    margin-top: 6vw;
  }
  .sec_main_area h3 {
    color: #2f2f2f;
    font-size: 4vw;
    font-weight: 700;
    margin-top: 8vw;
    margin-bottom: 5vw;
    line-height: 130%;
  }
  .sec_main_area h3:first-of-type {
    margin-top: 0;
  }
  .sec_main_area h3 span {
    color: #73bc59;
  }
  .sec_main_area p {
    color: #2f2f2f;
    font-size: 3.4vw;
    margin-top: 4.5vw;
    line-height: 220%;
  }
  .sec_main_area p span {
    color: #73bc59;
    font-weight: 700;
  }
  .sec_main_area .sec_main_set {
    color: #2f2f2f;
    font-size: 3.4vw;
    line-height: 170%;
  }
  .sec_main_area .sec_main_set strong {
    color: #73bc59;
    font-weight: 700;
  }
  .sec_main_area .sec_main_set .mt-image-center {
    margin: 0 auto 5vw;
  }
  .sec_main_area .pict {
    margin: 6vw auto 0;
    text-align: center;
  }
  .sec_main_area .pictarea {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 6vw auto 0;
    text-align: center;
  }
  .sec_main_area .pictarea .pict {
    margin: 0;
    max-width: 48%;
  }
  .sec_main_area .pictarea .pict:nth-child(2), .sec_main_area .pictarea .pict:nth-child(4) {
    margin-left: auto;
  }
  .sec_main_area .pictarea .pict:nth-child(3), .sec_main_area .pictarea .pict:nth-child(4) {
    margin-top: 4px;
  }
}
@media screen and (min-width: 768px) {
  .sec_main_area {
    border-radius: 20px;
    margin-top: -3px;
  }
  .sec_main_area + .sec_infoarea {
    margin-top: 60px;
  }
  .sec_main_area .sec_main_detail {
    max-width: 785px;
    margin: 0 auto;
    padding: 70px 20px 70px;
  }
  .sec_main_area .sec_main_mv {
    border-radius: 18px 18px 0 0;
    overflow: hidden;
  }
  .sec_main_area h2 {
    color: #2f2f2f;
    font-size: 30px;
    font-weight: 700;
    line-height: 130%;
  }
  .sec_main_area h2 + .sec_main_set {
    margin-top: 40px;
  }
  .sec_main_area h3 {
    color: #2f2f2f;
    font-size: 26px;
    font-weight: 700;
    margin-top: 40px;
    margin-bottom: 40px;
    line-height: 130%;
  }
  .sec_main_area h3:first-of-type {
    margin-top: 0;
  }
  .sec_main_area h3 span {
    color: #73bc59;
  }
  .sec_main_area p {
    color: #2f2f2f;
    font-size: 18px;
    margin-top: 40px;
    line-height: 220%;
  }
  .sec_main_area p span {
    color: #73bc59;
    font-weight: 700;
  }
  .sec_main_area .sec_main_set {
    color: #2f2f2f;
    font-size: 18px;
    line-height: 170%;
  }
  .sec_main_area .sec_main_set strong {
    color: #73bc59;
    font-weight: 700;
  }
  .sec_main_area .sec_main_set .mt-image-center {
    margin: 0 auto 40px;
  }
  .sec_main_area .pict {
    margin: 40px auto 0;
    max-width: 600px;
    text-align: center;
  }
  .sec_main_area .pictarea {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 40px auto 0;
    text-align: center;
    max-width: 600px;
  }
  .sec_main_area .pictarea .pict {
    margin: 0;
  }
  .sec_main_area .pictarea .pict:nth-child(2), .sec_main_area .pictarea .pict:nth-child(4) {
    margin-left: auto;
  }
  .sec_main_area .pictarea .pict:nth-child(3), .sec_main_area .pictarea .pict:nth-child(4) {
    margin-top: 7px;
  }
}

.sec_matome_area {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: relative;
}
.sec_matome_area .character {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .sec_matome_area {
    min-height: 41vw;
    margin: 15vw -4vw 0;
  }
  .sec_matome_area h2 {
    width: 34.5%;
  }
  .sec_matome_area .character {
    top: 2vw;
    left: 2vw;
    width: 58vw;
  }
  .sec_matome_area .character.character01 {
    top: -4vw;
  }
  .sec_matome_area .character.character02 {
    top: -1vw;
  }
  .sec_matome_area .character.character03 {
    top: 0;
  }
  .sec_matome_area .character.character04 {
    width: 50vw;
  }
  .sec_matome_area .character.character05 {
    width: 50vw;
  }
  .sec_matome_area .character.character06 {
    width: 50vw;
  }
  .sec_matome_area .character.character07 {
    top: 0;
    width: 50vw;
  }
  .sec_matome_area .character.character08 {
    top: 4vw;
    width: 50vw;
  }
  .sec_matome_area p {
    background: url("../img_new2022/contents_matome_bg.png") no-repeat 0 0;
    background-size: 100%;
    color: #2f2f2f;
    height: 41vw;
    font-size: 3.4vw;
    line-height: 170%;
    font-weight: 700;
    display: flex;
    align-items: center;
    padding: 0 4vw 0 8vw;
    width: 44%;
  }
}
@media screen and (min-width: 768px) {
  .sec_matome_area {
    min-height: 300px;
    max-width: 620px;
    margin: 60px auto 0;
  }
  .sec_matome_area h2 {
    width: 34.6%;
  }
  .sec_matome_area .character {
    top: 2px;
    left: -40px;
  }
  .sec_matome_area .character.character01 {
    top: -16px;
  }
  .sec_matome_area .character.character07 {
    top: -12px;
  }
  .sec_matome_area .character.character08 {
    top: 24px;
  }
  .sec_matome_area .character.character09 {
    top: 5px;
  }
  .sec_matome_area p {
    background: url("../img_new2022/contents_matome_bg.png") no-repeat 0 0;
    background-size: 100%;
    color: #2f2f2f;
    height: 260px;
    font-size: 24px;
    line-height: 150%;
    font-weight: 700;
    display: flex;
    align-items: center;
    padding: 0 20px 0 50px;
    width: 43.8%;
  }
}

.recommend_area .recommend_title {
  position: relative;
  text-align: center;
}
.recommend_area .recommend_title:after {
  background: url("../img_new2022/contents_recommend_bg.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
  position: absolute;
}
.recommend_area .recommend_title h2 {
  color: #000;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.recommend_area .recommend_title h2:after, .recommend_area .recommend_title h2:before {
  background: url("../img_new2022/contents_recommend_titlebg.png") no-repeat 0 0;
  background-size: 100%;
  content: "";
}
.recommend_area .recommend_title h2:before {
  transform: scale(-1, 1);
}
@media screen and (max-width: 767px) {
  .recommend_area {
    margin-top: 14vw;
    padding: 0;
  }
  .recommend_area .recommend_contents {
    margin: 0 auto;
  }
  .recommend_area .recommend_title:after {
    margin: 0 auto;
    height: 23.734vw;
    bottom: -1vw;
    right: 0;
    left: 0;
    width: 40.267vw;
  }
  .recommend_area .recommend_title h2 {
    font-size: 4.5vw;
    padding-bottom: 25vw;
  }
  .recommend_area .recommend_title h2:after, .recommend_area .recommend_title h2:before {
    height: 5.6vw;
    width: 4.4vw;
  }
  .recommend_area .recommend_title h2:after {
    margin-left: 3vw;
  }
  .recommend_area .recommend_title h2:before {
    margin-right: 3vw;
  }
  .recommend_area .contents_list .contents_list_detail:last-of-type {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .recommend_area {
    margin-top: 100px;
    padding: 0 20px;
  }
  .recommend_area .recommend_contents {
    max-width: 1154px;
    margin: 0 auto;
  }
  .recommend_area .recommend_title:after {
    height: 144px;
    top: -57px;
    right: 20px;
    width: 244px;
  }
  .recommend_area .recommend_title h2 {
    font-size: 28px;
    margin-bottom: 45px;
  }
  .recommend_area .recommend_title h2:after, .recommend_area .recommend_title h2:before {
    height: 36px;
    width: 28px;
  }
  .recommend_area .recommend_title h2:after {
    margin-left: 20px;
  }
  .recommend_area .recommend_title h2:before {
    margin-right: 20px;
  }
  .recommend_area .contents_list .contents_list_detail {
    margin-bottom: 0;
  }
}

.pager {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .pager {
    margin-top: 4vw;
  }
  .pager li {
    font-size: 4vw;
    font-weight: 700;
    margin: 0 4vw;
  }
  .pager li a {
    color: #000;
    text-decoration: none;
  }
  .pager li span {
    color: #5f5f5f;
  }
}
@media screen and (min-width: 768px) {
  .pager {
    margin-top: 50px;
  }
  .pager li {
    font-size: 26px;
    font-weight: 700;
    margin: 0 20px;
  }
  .pager li a {
    color: #000;
    text-decoration: none;
  }
  .pager li a:hover {
    color: #0eb0cb;
  }
  .pager li span {
    color: #5f5f5f;
  }
}

#factory_common_footer_wrap {
  box-sizing: content-box;
}
#factory_common_footer_wrap * {
  box-sizing: content-box;
}


/****** factoripmap *********/
.factoripmap_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}
@media screen and (max-width: 767px) {
  .factoripmap_wrap {
    border-top: 4px solid #000;
    border-bottom: 4px solid #000;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_wrap {
    border: 4px solid #000;
    border-radius: 20px;
    max-width: 1310px;
    margin: 20px auto 0;
    position: relative;
  }
}

.factoripmap_head {
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .factoripmap_head {
    padding: 3vw 0;
  }
  .factoripmap_head .headlogo {
    max-width: 33.3vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_head {
    border-radius: 20px 20px 0 0;
    padding: 25px 20px;
  }
  .factoripmap_head .headlogo {
    max-width: 271px;
    margin: 0 auto;
  }
}

.factoripmap_contents .factoripmap_detail {
  position: relative;
}
.factoripmap_contents .factoripmap_detail:after {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .factoripmap_contents {
    padding: 0 7vw 13vw;
  }
  .factoripmap_contents .factoripmap_detail:after {
    height: 24.534vw;
    top: 22vw;
    right: -3vw;
    width: 69.467vw;
  }
  .factoripmap_contents h1 {
    margin-bottom: 7vw;
    width: 77.3vw;
  }
  .factoripmap_contents .img_pc {
    display: none;
  }
  .factoripmap_contents .factoripmap_detail:after {
    background: url("../img_new2022/factoripmap_bg01_sp.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 30vw;
    max-height: 225px;
    top: 49vw;
    right: 15vw;
    width: 57.333333333333336vw;
    max-width: 430px;
  }
  .factoripmap_contents .main_lead .pc_item {
    display: none;
  }
  .factoripmap_contents .factoripmap_list ul li {
    margin-bottom: 4.666666666666667vw;
  }
  .factoripmap_contents .main_lead {
    font-size: 3.4vw;
    line-height: 160%;
    color: #333;
    font-weight: 700;
    margin-bottom: 32vw;
  }
  .factoripmap_contents .factoripmap_notice {
    font-size: 4vw;
    font-weight: bold;
    text-align: center;
    
  }
  .factoripmap_contents .factoripmap_notice p {
    padding-bottom: 1.3333333333333335vw;
    border-bottom: 2px solid #000;
    width: 80vw;
    margin: 0 auto;
  }
  .recommend_area {
    margin-bottom: 13.333333333333334vw;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_contents {
    padding: 0 180px 85px;
  }
  .factoripmap_contents .factoripmap_detail {
    max-width: 1154px;
    margin: 0 auto;
    position: relative;
  }
  .factoripmap_contents .factoripmap_detail:after {
    background: url("../img_new2022/factoripmap_bg01.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 14.275256222547583vw;
    max-height: 195px;
    top: -3.29429vw;
    right: -4.95022vw;
    width: 27.30600292825769vw;
    max-width: 373px;
  }
  .factoripmap_contents h1 {
    margin-bottom: 35px;
    width: 46.63250366032211vw;
    max-width: 637px;
  }
  .factoripmap_contents .img_sp {
    display: none;
  }
  .factoripmap_contents .factoripmap_list ul li {
    margin-bottom: 35px;
  }
  .factoripmap_contents .factoripmap_list ul li a{
    transition: opacity 0.4s ease-in-out;
  }
  .factoripmap_contents .factoripmap_list ul li a:hover{
    opacity: 0.7;
  }
  .factoripmap_contents .main_lead {
    font-size: 18px;
    line-height: 160%;
    color: #333;
    font-weight: 700;
    margin-bottom: 4.666666666666667vw;
  }
  .factoripmap_contents .factoripmap_notice {
    font-size: 26px;
    font-weight: bold;
    text-align: center;
    
  }
  .factoripmap_contents .factoripmap_notice p {
    padding-bottom: 10px;
    border-bottom: 2px solid #000;
    width: 517px;
    margin: 0 auto;
  }

  .recommend_area {
    margin-bottom: 100px;
  }
}

@media screen and (min-width:1080px) and ( max-width:1266px) {
  .factoripmap_contents .factoripmap_detail:after {
    height: 14.275256222547583vw;
    top: -3.29429vw;
    right: -11.95022vw;
    width: 27.30600292825769vw;
  }
}

@media screen and (min-width:768px) and ( max-width:1079px) {
  .factoripmap_contents .factoripmap_detail:after {
    height: 13.275256222547583vw;
    top: -3.29429vw;
    right: -16.95022vw;
    width: 24.30600292825769vw;
  }
}



/****** factoripmap_beer_beer *********/
.factoripmap_beer_wrap {
  background: url("../img_new2022/bg.png") repeat 50% 0;
}
@media screen and (max-width: 767px) {
  .factoripmap_beer_wrap {
    border-top: 4px solid #000;
    border-bottom: 4px solid #000;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_beer_wrap {
    border: 4px solid #000;
    border-radius: 20px;
    max-width: 1310px;
    margin: 20px auto 0;
    position: relative;
  }
}

.factoripmap_beer_head {
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .factoripmap_beer_head {
    padding: 3vw 0;
  }
  .factoripmap_beer_head .headlogo {
    max-width: 33.3vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_beer_head {
    border-radius: 20px 20px 0 0;
    padding: 25px 20px;
  }
  .factoripmap_beer_head .headlogo {
    max-width: 271px;
    margin: 0 auto;
  }
}

.factoripmap_beer_contents .factoripmap_beer_list {
  position: relative;
}
@media screen and (max-width: 767px) {
  .factoripmap_beer_contents {
    padding: 0;
  }
  .factoripmap_beer_contents h1 {
    width: 100%;
    line-height: 0;
  }
  .factoripmap_beer_contents .img_pc {
    display: none;
  }
  .factoripmap_beer_contents .factoripmap_beer_list {
    /* background: url("../img_new2022/factoripmap_beer_bg_sp.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 72.90076335877863vw;
    max-height: 1340px;
    width: 95.90043923865301vw;
    max-width: 750px; */
  }
  .factoripmap_beer_contents .factoripmap_beer_list .bg_box{
    display: grid;
  }
  .factoripmap_beer_contents .factoripmap_beer_list .bg_box img{
    width: 100%;
    border-radius: 0 0 15px 15px;
  }

  .factoripmap_beer_contents .factoripmap_beer_list ul li.kyoto_btn {
    position: absolute;
    max-width: 471px;
    width: 62.8vw;
    left: 26vw;
    top: 58vw;
  }
  .factoripmap_beer_contents .factoripmap_beer_list ul li.kyoto_btn .img_pc {
    display: none;
  }
  .factoripmap_beer_contents .factoripmap_beer_list ul li.yamazaki_btn {
    position: absolute;
    max-width: 340px;
    width: 45.333333333vw;
    left: 13vw;
    top: 120vw;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_beer_contents {
    padding: 0;
  }
  .factoripmap_beer_contents .factoripmap_beer_detail {
    max-width: 1310px;
    /* height: 80vw;
    max-height: 1088px; */
    margin: 0 auto;
  }
  .factoripmap_beer_contents h1 {
    width: 100%;
    line-height: 0;
  }
  .factoripmap_beer_contents .img_sp {
    display: none;
  }
  .factoripmap_beer_contents .factoripmap_beer_list {
    /* background: url("../img_new2022/factoripmap_beer_bg.png") no-repeat 0 0;
    background-size: 100%;
    content: "";
    height: 89.900763vw;
    max-height: 949px;
    margin-top: -3px;
    width: 100%; */
    /* max-width: 1340px; */
    margin-bottom: -3px;
  }

  .factoripmap_beer_contents .factoripmap_beer_list .bg_box img{
    width: 100%;
    border-radius: 0 0 15px 15px;
  }

  .factoripmap_beer_contents .factoripmap_beer_list ul li.kyoto_btn {
    position: absolute;
    max-width: 331px;
    width: 24vw;
    left: 394px;
    top: 332px;
  }
  .factoripmap_beer_contents .factoripmap_beer_list ul li.yamazaki_btn {
    position: absolute;
    max-width: 240px;
    width: 17vw;
    left: 330px;
    top: 653px;
    }
  .factoripmap_beer_contents .factoripmap_beer_list ul li a{
    transition: opacity 0.4s ease-in-out;
  }
  .factoripmap_beer_contents .factoripmap_beer_list ul li a:hover{
    opacity: 0.7;
  }
}

@media screen and (min-width:768px) and ( max-width:1366px) {
  .factoripmap_beer_contents .factoripmap_beer_list ul li.kyoto_btn {
    left: 29vw;
    top: 24vw;
  }
  .factoripmap_beer_contents .factoripmap_beer_list ul li.yamazaki_btn {
    left: 24vw;
    top: 48vw;
  }
}

/****** factoripmap_yamanashi_beer *********/

.factoripmap_yamanashi_contents .factoripmap_yamanashi_list {
  position: relative;
}
@media screen and (max-width: 767px) {
  .factoripmap_yamanashi_contents {
    padding: 0;
  }
  .factoripmap_yamanashi_contents h1 {
    width: 100%;
    line-height: 0;
  }
  .factoripmap_yamanashi_contents .img_pc {
    display: none;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list {

  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list .bg_box{
    display: grid;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list .bg_box img{
    width: 100%;
  }

  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.hakushu_btn {
    position: absolute;
    max-width: 546px;
    width: 67vw;
    left: 6.5vw;
    top: 7vw;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.hakushu_btn .img_pc {
    display: none;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.tomi_btn {
    position: absolute;
    max-width: 340px;
    width: 60vw;
    left: 35vw;
    top: 86vw;
  }
}
@media screen and (min-width: 768px) {
  .factoripmap_yamanashi_contents {
    padding: 0;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_detail {
    max-width: 1310px;
    margin: 0 auto;
  }
  .factoripmap_yamanashi_contents h1 {
    width: 100%;
    line-height: 0;
  }
  .factoripmap_yamanashi_contents .img_sp {
    display: none;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list {
    margin-bottom: -3px;
  }

  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list .bg_box img{
    width: 100%;
    border-radius: 0 0 15px 15px;
  }

  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.hakushu_btn {
    position: absolute;
    max-width: 357px;
    width: 22.9vw;
    left: 84px;
    top: 109px;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.tomi_btn {
    position: absolute;
    max-width: 331px;
    width: 23vw;
    left: 651px;
    top: 505px;
    }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li a{
    transition: opacity 0.4s ease-in-out;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li a:hover{
    opacity: 0.7;
  }
}

@media screen and (min-width:768px) and ( max-width:1366px) {
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.hakushu_btn {
    left: 7vw;
    top: 8vw;
  }
  .factoripmap_yamanashi_contents .factoripmap_yamanashi_list ul li.tomi_btn {
    left: 48vw;
    top: 37.5vw;
  }
}