#kv {
  position: relative;
  overflow: hidden;
  width: 100%;
  background: #fff; }

#kv_bg_img {
  position: relative;
  width: 100%; }

#kv_product {
  position: absolute;
  display: block; }
  @media screen and (min-width: 751px) {
    #kv_product {
      left: -0.5vw;
      bottom: -4vw;
      width: 23.7vw; } }
  @media screen and (max-width: 750px) {
    #kv_product {
      left: -3rem;
      bottom: -8.5rem;
      width: 45.45rem; } }

#kv h1 {
  position: absolute;
  display: block; }
  @media screen and (min-width: 751px) {
    #kv h1 {
      left: 74.609375vw;
      top: 12.109375vw;
      width: 8.203125vw; } }
  @media screen and (max-width: 750px) {
    #kv h1 {
      right: 3rem;
      top: 3rem;
      width: 19rem; } }

#kv h1 p {
  position: absolute;
  display: block;
  top: 0;
  overflow: hidden; }
  @media screen and (min-width: 751px) {
    #kv h1 p {
      width: 3.515625vw; } }
  @media screen and (max-width: 750px) {
    #kv h1 p {
      width: 8.1rem; } }

#kv h1 p#kv_txt1 {
  right: 0; }

#kv h1 p#kv_txt2 {
  left: 0; }

#kv a.to_read {
  position: absolute;
  text-align: center;
  display: block;
  bottom: 0;
  overflow: hidden; }
  @media screen and (min-width: 751px) {
    #kv a.to_read {
      right: 2rem;
      width: 1.5rem;
      height: 7rem; } }
  @media screen and (max-width: 750px) {
    #kv a.to_read {
      right: 2.3rem;
      width: 2.7rem;
      height: 14rem; } }

#kv a.to_read .bar {
  display: block;
  content: "";
  position: absolute;
  bottom: 0;
  width: 1px;
  left: 0;
  background: #FFFFFF;
  z-index: 10; }
  @media screen and (min-width: 751px) {
    #kv a.to_read .bar {
      height: 7rem; } }
  @media screen and (max-width: 750px) {
    #kv a.to_read .bar {
      height: 14rem; } }

#kv a.to_read .bar span {
  position: absolute;
  animation: bar_animation 1.8s ease-in-out infinite;
  display: block;
  content: "";
  position: absolute;
  bottom: 0;
  width: 1px;
  left: 0;
  background: #982235;
  z-index: 15; }
  @media screen and (min-width: 751px) {
    #kv a.to_read .bar span {
      height: 14rem; } }
  @media screen and (max-width: 750px) {
    #kv a.to_read .bar span {
      height: 28rem; } }

.scr_txt {
  position: absolute;
  top: 0;
  right: 0; }
  @media screen and (min-width: 751px) {
    .scr_txt {
      width: 0.9rem; } }
  @media screen and (max-width: 750px) {
    .scr_txt {
      width: 2rem; } }

@keyframes bar_animation {
  0% {
    top: -200%; }
  10% {
    top: -200%; }
  100% {
    top: 100%; } }
/**/
#kv #kv_bg_img {
  opacity: 0; }

#kv.start #kv_bg_img {
  transition: all 900ms cubic-bezier(0.63, 0.355, 0.155, 0.905);
  transition-timing-function: cubic-bezier(0.63, 0.355, 0.155, 0.905);
  opacity: 1; }

#kv #kv_product {
  opacity: 0;
  transform: translateY(10%); }

#kv #kv_product.start {
  transition: all 1200ms cubic-bezier(0.63, 0.355, 0.155, 0.905);
  transition-timing-function: cubic-bezier(0.63, 0.355, 0.155, 0.905);
  opacity: 1;
  transform: translateY(0); }

#kv h1 p#kv_txt1 img,
#kv h1 p#kv_txt2 img {
  mask-image: linear-gradient(135deg, black 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-image: linear-gradient(135deg, black 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
  mask-size: 100% 0%;
  -webkit-mask-size: 100% 0%;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: 0 0;
  -webkit-mask-position: 0 0; }

#kv p#kv_txt1.start img {
  transition: ease-out 2.4s all;
  mask-size: 100% 350%;
  -webkit-mask-size: 100% 350%; }

#kv p#kv_txt2.start img {
  transition: ease-out 2.4s all;
  mask-size: 100% 350%;
  -webkit-mask-size: 100% 350%; }

/*read*/
#read {
  position: relative;
  margin: 0;
  width: 100%;
  overflow: hidden; }
  @media screen and (min-width: 751px) {
    #read {
      padding: 11rem 0 7.5rem; } }
  @media screen and (max-width: 750px) {
    #read {
      padding: 12.5rem 0 9rem; } }

#read .inner {
  position: relative;
  margin: 0 auto;
  display: flex; }
  @media screen and (min-width: 751px) {
    #read .inner {
      justify-content: space-between;
      width: 90rem; } }
  @media screen and (max-width: 750px) {
    #read .inner {
      flex-direction: column;
      width: 65rem;
      gap: 6rem;
      padding: 0 0 43rem; } }

#read .inner_btm {
  position: relative;
  margin: 0 auto; }
  @media screen and (min-width: 751px) {
    #read .inner_btm {
      width: 69rem; } }
  @media screen and (max-width: 750px) {
    #read .inner_btm {
      width: 65rem; } }

.under_cap {
  position: relative;
  font-weight: 400;
  color: #333333;
  letter-spacing: 0.0em; }
  @media screen and (min-width: 751px) {
    .under_cap {
      line-height: 1.5em;
      font-size: 1.2rem;
      /*padding-left:divceil(13, 10, rem); 
      text-indent:divceil(-13, 10, rem);*/
      margin-top: 6rem;
      white-space: nowrap; } }
  @media screen and (max-width: 750px) {
    .under_cap {
      line-height: 1.5em;
      font-size: 2rem;
      /*padding-left:divceil(27, 10, rem); 
      text-indent:divceil(-27, 10, rem);*/
      margin-top: 8rem; } }

#read_ttl {
  position: relative; }
  @media screen and (min-width: 751px) {
    #read_ttl {
      width: 37.8rem; } }
  @media screen and (max-width: 750px) {
    #read_ttl {
      width: 64.5rem; } }

#read_txt_block {
  position: relative;
  display: flex;
  flex-direction: column; }
  @media screen and (min-width: 751px) {
    #read_txt_block {
      width: 39rem;
      gap: 2.4rem; } }
  @media screen and (max-width: 750px) {
    #read_txt_block {
      width: 65rem;
      gap: 3.6rem; } }

.read_txt {
  position: relative;
  font-weight: 400;
  font-weight: 400;
  color: #000000;
  letter-spacing: 0.0em;
  white-space: nowrap; }
  @media screen and (min-width: 751px) {
    .read_txt {
      line-height: 2em;
      font-size: 1.6rem; } }
  @media screen and (max-width: 750px) {
    .read_txt {
      line-height: 2em;
      font-size: 2.8rem; } }

#read_txt_block .logo {
  position: relative; }
  @media screen and (min-width: 751px) {
    #read_txt_block .logo {
      width: 22.8rem;
      margin-top: 1rem; } }
  @media screen and (max-width: 750px) {
    #read_txt_block .logo {
      width: 40.8rem;
      margin: 3rem auto 0; } }

#read_product {
  position: absolute;
  display: block; }
  @media screen and (min-width: 751px) {
    #read_product {
      left: -3.5rem;
      bottom: -11.5rem;
      width: 42.7rem; } }
  @media screen and (max-width: 750px) {
    #read_product {
      left: -4.5rem;
      bottom: -18rem;
      width: 72rem; } }

section hgroup {
  position: relative;
  text-align: center; }

section hgroup h2 {
  position: relative;
  font-family: "Montserrat", sans-serif !important;
  font-weight: 700;
  color: #000000;
  letter-spacing: 0.0em; }
  @media screen and (min-width: 751px) {
    section hgroup h2 {
      line-height: 1em;
      font-size: 5rem;
      padding: 0 0 3rem; } }
  @media screen and (max-width: 750px) {
    section hgroup h2 {
      line-height: 1em;
      font-size: 9rem;
      padding: 0 0 7rem; } }

section hgroup h2::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #982235; }
  @media screen and (min-width: 751px) {
    section hgroup h2::after {
      width: 5rem;
      height: 0.6rem; } }
  @media screen and (max-width: 750px) {
    section hgroup h2::after {
      width: 9rem;
      height: 1rem; } }

section hgroup p {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.0em;
  color: #000000; }
  @media screen and (min-width: 751px) {
    section hgroup p {
      padding: 3rem 0 0;
      line-height: 1.5em;
      font-size: 1.8rem; } }
  @media screen and (max-width: 750px) {
    section hgroup p {
      padding: 5rem 0 0;
      line-height: 1.5em;
      font-size: 3.2rem;
      white-space: nowrap; } }

#lineup {
  position: relative;
  margin: 0;
  width: 100%; }
  @media screen and (min-width: 751px) {
    #lineup {
      padding: 7.5rem 0 7.5rem; } }
  @media screen and (max-width: 750px) {
    #lineup {
      padding: 9rem 0 9rem; } }

#lineup .inner {
  position: relative; }
  @media screen and (min-width: 751px) {
    #lineup .inner {
      width: 100%; } }
  @media screen and (max-width: 750px) {
    #lineup .inner {
      width: 65rem;
      margin: 0 auto; } }

#lineup ul {
  position: relative;
  width: 100%;
  display: flex; }
  @media screen and (min-width: 751px) {
    #lineup ul {
      justify-content: center;
      align-items: stretch;
      margin-top: 2rem; } }
  @media screen and (max-width: 750px) {
    #lineup ul {
      flex-direction: column;
      margin-top: 3rem;
      gap: 4rem; } }

#lineup ul li {
  position: relative;
  display: block;
  text-align: center;
  transition: ease-out .6s all; }
  @media screen and (min-width: 751px) {
    #lineup ul li {
      width: 42rem;
      margin: 0 -1.5rem; } }
  @media screen and (max-width: 750px) {
    #lineup ul li {
      width: 64rem;
      margin: 0 auto; } }

#lineup ul li figure {
  position: relative;
  width: 100%; }

#lineup ul li figure p {
  position: absolute;
  font-weight: 400;
  font-weight: 400;
  color: #000000;
  letter-spacing: 0.0em;
  bottom: 0;
  left: 0;
  width: 100%; }
  @media screen and (min-width: 751px) {
    #lineup ul li figure p {
      line-height: 1em;
      font-size: 1.6rem;
      bottom: 4rem; } }
  @media screen and (max-width: 750px) {
    #lineup ul li figure p {
      line-height: 1em;
      font-size: 2.4rem;
      bottom: 6rem; } }

#lineup ul li h3 {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.0em;
  color: #000000; }
  @media screen and (min-width: 751px) {
    #lineup ul li h3 {
      margin-top: -1rem;
      line-height: 1.4em;
      font-size: 2.6rem; } }
  @media screen and (max-width: 750px) {
    #lineup ul li h3 {
      margin-top: -0.5rem;
      line-height: 1.4em;
      font-size: 4.6rem; } }

@media screen and (min-width: 751px) {
  #lineup ul li:nth-of-type(1) h3,
  #lineup ul li:nth-of-type(2) h3 {
    margin-top: 2.6rem; } }

#lineup ul li .ml_txt {
  position: relative;
  font-weight: 400;
  font-weight: 400;
  color: #000000;
  letter-spacing: 0.0em;
  white-space: nowrap; }
  @media screen and (min-width: 751px) {
    #lineup ul li .ml_txt {
      line-height: 1em;
      font-size: 1.6rem;
      padding: 1.6rem 0 2.4rem; } }
  @media screen and (max-width: 750px) {
    #lineup ul li .ml_txt {
      line-height: 1em;
      font-size: 2.8rem;
      padding: 2.8rem 0 3.6rem; } }

.detail_btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #982235;
  transition: .6s ease-out;
  overflow: hidden;
  margin: 0 auto; }
  @media screen and (min-width: 751px) {
    .detail_btn {
      width: 21.4rem;
      height: 4.5rem;
      border-radius: 2.7rem;
      border: #982235 4px solid; } }
  @media screen and (max-width: 750px) {
    .detail_btn {
      width: 39rem;
      height: 10rem;
      border-radius: 5rem; } }

.detail_btn p {
  position: relative;
  /*@include fw(Bold);*/
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  color: #FFFFFF;
  letter-spacing: 0.0em; }
  @media screen and (min-width: 751px) {
    .detail_btn p {
      line-height: 1em;
      font-size: 1.4rem;
      transition: .6s ease-out; } }
  @media screen and (max-width: 750px) {
    .detail_btn p {
      line-height: 1em;
      font-size: 2.5rem; } }

@media screen and (min-width: 751px) {
  .detail_btn::before {
    content: "";
    display: block;
    position: absolute;
    transition: ease-out .4s all;
    top: 50%;
    left: 0;
    width: 100%;
    height: 100%;
    background: #FFFFFF;
    opacity: 0; } }

@media screen and (min-width: 751px) {
  .detail_btn:hover::before {
    top: 0;
    opacity: 1; } }

@media screen and (min-width: 751px) {
  .detail_btn:hover p {
    color: #982235; } }

#interview {
  position: relative;
  margin: 0;
  width: 100%;
  overflow: hidden; }
  @media screen and (min-width: 751px) {
    #interview {
      padding: 7.5rem 0 0; } }
  @media screen and (max-width: 750px) {
    #interview {
      padding: 9rem 0 15rem; } }

#interview .inner {
  position: relative; }
  @media screen and (min-width: 751px) {
    #interview .inner {
      width: 100%; } }
  @media screen and (max-width: 750px) {
    #interview .inner {
      width: 100%; } }

#interview ul {
  position: relative; }
  @media screen and (min-width: 751px) {
    #interview ul {
      width: 128rem;
      height: 110rem;
      margin: 0 auto; } }
  @media screen and (max-width: 750px) {
    #interview ul {
      width: 75rem;
      display: flex;
      flex-direction: column;
      margin-top: 3rem;
      gap: 0rem; } }

#interview ul li {
  text-align: center;
  overflow: visible;
  display: flex;
  align-items: center;
  background: url("../../img/interview_bg.png") center center no-repeat;
  transition: ease-out .6s all; }
  @media screen and (min-width: 751px) {
    #interview ul li {
      position: absolute;
      width: 50rem;
      height: 50rem;
      background-size: 50rem 50rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li {
      position: relative;
      width: 75rem;
      height: 75rem;
      background-size: 75rem 75rem; } }

#interview ul li div {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center; }
  @media screen and (min-width: 751px) {
    #interview ul li div {
      gap: 0.7rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li div {
      gap: 1.2rem; } }

@media screen and (min-width: 751px) {
  #interview1 {
    top: 0rem;
    left: 10.5rem; } }

@media screen and (min-width: 751px) {
  #interview2 {
    top: 10.5rem;
    left: 64.5rem; } }

@media screen and (min-width: 751px) {
  #interview3 {
    top: 46.5rem;
    left: 26.5rem; } }

#interview1 figure {
  position: absolute; }
  @media screen and (min-width: 751px) {
    #interview1 figure {
      bottom: 3.5rem;
      left: -8.5rem;
      width: 18rem; } }
  @media screen and (max-width: 750px) {
    #interview1 figure {
      bottom: 0rem;
      left: -1.5rem;
      width: 23rem; } }

#interview2 figure {
  position: absolute; }
  @media screen and (min-width: 751px) {
    #interview2 figure {
      bottom: 0rem;
      left: 41.5rem;
      width: 18rem; } }
  @media screen and (max-width: 750px) {
    #interview2 figure {
      bottom: 3.5rem;
      left: 53.5rem;
      width: 23rem; } }

#interview3 figure {
  position: absolute; }
  @media screen and (min-width: 751px) {
    #interview3 figure {
      bottom: 1.5rem;
      left: 40rem;
      width: 18rem; } }
  @media screen and (max-width: 750px) {
    #interview3 figure {
      bottom: 3.5rem;
      left: -2.5rem;
      width: 23rem; } }

#interview ul li span {
  position: relative;
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Montserrat", sans-serif !important;
  font-weight: 600;
  color: #982235;
  border: #982235 1px solid;
  letter-spacing: 0.0em;
  white-space: nowrap;
  margin: 0 auto; }
  @media screen and (min-width: 751px) {
    #interview ul li span {
      line-height: 1.667em;
      font-size: 1.2rem;
      width: 13rem;
      height: 2rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li span {
      line-height: 1.637em;
      font-size: 2.2rem;
      width: 23.4rem;
      height: 3.6rem; } }

#interview ul li h3 {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.01em;
  color: #000000; }
  @media screen and (min-width: 751px) {
    #interview ul li h3 {
      padding: 0.8rem 0 0;
      line-height: 1.5em;
      font-size: 2.8rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li h3 {
      padding: 1.2rem 0 0;
      line-height: 1.5em;
      font-size: 5rem; } }

#interview ul li .general_txt {
  position: relative; }
  @media screen and (min-width: 751px) {
    #interview ul li .general_txt {
      padding: 0 0 1.6rem;
      line-height: 1.5em;
      font-size: 1.6rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li .general_txt {
      line-height: 1.5em;
      font-size: 2.8rem;
      padding: 0 0 2rem; } }

#interview .cap {
  position: relative;
  width: auto !important;
  height: auto !important;
  background: none !important;
  list-style: none;
  font-weight: 400;
  color: #000000;
  letter-spacing: 0.0em; }
  @media screen and (min-width: 751px) {
    #interview .cap {
      line-height: 1.601em;
      font-size: 1.2rem;
      margin-top: 1rem; } }
  @media screen and (max-width: 750px) {
    #interview .cap {
      line-height: 1.6em;
      font-size: 2rem;
      margin-top: 1.6rem; } }

#interview ul li .detail_btn {
  cursor: pointer; }
  @media screen and (min-width: 751px) {
    #interview ul li .detail_btn {
      width: 20rem;
      height: 4.5rem;
      border-radius: 2.7rem; } }
  @media screen and (max-width: 750px) {
    #interview ul li .detail_btn {
      width: 36rem;
      height: 10rem; } }

.link_none {
  pointer-events: none;
  background: #aaaaaa;
  border: none; }

#recipe {
  position: relative;
  margin: 0;
  width: 100%;
  background: #fff; }
  @media screen and (min-width: 751px) {
    #recipe {
      padding: 14rem 0 14rem; } }
  @media screen and (max-width: 750px) {
    #recipe {
      padding: 18rem 0 18rem; } }

#recipe .inner {
  position: relative;
  margin: 0 auto; }
  @media screen and (min-width: 751px) {
    #recipe .inner {
      width: 107rem; } }
  @media screen and (max-width: 750px) {
    #recipe .inner {
      width: 65rem; } }

#recipe ul {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column; }
  @media screen and (min-width: 751px) {
    #recipe ul {
      margin-top: 5rem;
      gap: 3rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul {
      margin-top: 7rem;
      gap: 9rem; } }

#recipe ul li {
  position: relative;
  display: flex;
  transition: ease-out .6s all; }
  @media screen and (min-width: 751px) {
    #recipe ul li {
      justify-content: space-between;
      align-items: center;
      width: 100%; } }
  @media screen and (max-width: 750px) {
    #recipe ul li {
      flex-direction: column;
      width: 100%;
      gap: 5rem; } }

#recipe ul li figure {
  position: relative; }
  @media screen and (min-width: 751px) {
    #recipe ul li figure {
      width: 50rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li figure {
      width: 64rem; } }

#recipe ul li figure img {
  position: relative;
  display: block;
  overflow: hidden;
  height: auto; }
  @media screen and (min-width: 751px) {
    #recipe ul li figure img {
      width: 50rem !important;
      border-radius: 1.6rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li figure img {
      width: 64rem !important;
      border-radius: 1.6rem; } }

@media screen and (min-width: 751px) {
  #recipe ul li:nth-of-type(even) figure {
    order: 2; } }

#recipe ul li figure::before {
  content: "";
  display: block;
  position: absolute;
  transition: ease-out .4s all;
  top: 1rem;
  left: 1rem;
  width: 100%;
  height: 100%;
  border: #000000 1px solid;
  border-radius: 1.6rem; }

#recipe ul li > div {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start; }
  @media screen and (min-width: 751px) {
    #recipe ul li > div {
      width: 40rem;
      gap: 1.2rem;
      margin-right: 5rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li > div {
      width: 65rem;
      gap: 1rem; } }

@media screen and (min-width: 751px) {
  #recipe ul li:nth-of-type(even) > div {
    order: 1; } }

/*
#recipe ul li span{
    position: relative;
	display: block;
	font-weight:400;
	font-family: "IwaUDGoHonPro-Md" !important;
    letter-spacing: 0.01em;
	color: $key_color;
    @include mq(pc) {
    @include tbmag(14, 14*1.5, pc);
        }
    @include mq(sp) {
    @include tbmag(24, 24*1.5, sp);
    }
}
*/
#recipe ul li h3 {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.01em;
  color: #000000;
  width: 100%; }
  @media screen and (min-width: 751px) {
    #recipe ul li h3 {
      line-height: 1.5em;
      font-size: 2.8rem;
      padding: 0 0 1rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li h3 {
      line-height: 1.5em;
      font-size: 5rem;
      padding: 0 0 2rem; } }

#recipe ul li h3::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #aaaaaa; }

#recipe ul li > div div {
  position: relative; }
  @media screen and (min-width: 751px) {
    #recipe ul li > div div {
      padding: 0 0 1.5rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li > div div {
      padding: 1.6rem 0 2.4rem; } }

#recipe ul li > div div .general_txt {
  position: relative; }
  @media screen and (min-width: 751px) {
    #recipe ul li > div div .general_txt {
      letter-spacing: 0.0em;
      padding-left: 1.6rem;
      text-indent: -1.6rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li > div div .general_txt {
      letter-spacing: -0.03em;
      padding-left: 2.8rem;
      text-indent: -2.8rem; } }

#recipe ul li > div div .general_txt span,
#recipe ul li > div div .cap {
  position: relative;
  font-weight: 400;
  color: #333333;
  letter-spacing: 0.0em; }
  @media screen and (min-width: 751px) {
    #recipe ul li > div div .general_txt span,
    #recipe ul li > div div .cap {
      line-height: 2em;
      font-size: 1.2rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li > div div .general_txt span,
    #recipe ul li > div div .cap {
      line-height: 2em;
      font-size: 2rem; } }

#recipe ul li > div div .cap {
  position: relative;
  display: block; }
  @media screen and (min-width: 751px) {
    #recipe ul li > div div .cap {
      padding-top: 0.5rem; } }
  @media screen and (max-width: 750px) {
    #recipe ul li > div div .cap {
      padding-top: 1rem; } }

#recipe ul li .detail_btn {
  background: #000000;
  margin: 0; }
  @media screen and (min-width: 751px) {
    #recipe ul li .detail_btn {
      width: 20rem;
      height: 4.5rem;
      border: #000000 4px solid; } }
  @media screen and (max-width: 750px) {
    #recipe ul li .detail_btn {
      width: 29rem;
      height: 9rem; } }

#recipe ul li .detail_btn p {
  color: #FFFFFF; }

@media screen and (min-width: 751px) {
  #recipe ul li .detail_btn::before {
    background: #FFFFFF; } }

@media screen and (min-width: 751px) {
  #recipe ul li .detail_btn:hover p {
    color: #000000; } }

/*modal*/
#modal_bg {
  position: fixed;
  inset: 0;
  margin: 0;
  width: 100%;
  height: 100lvh;
  z-index: 9990;
  background: #F8F4EA;
  opacity: 0;
  pointer-events: none;
  transition: ease-out .6s all; }

.close_bg {
  position: absolute;
  inset: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0; }

#movie_set.open .close_bg,
#modal_set.open .close_bg {
  pointer-events: auto !important; }

#modal_bg.open {
  opacity: 0.95;
  pointer-events: auto !important; }

.modal_outer {
  position: relative;
  margin: 0;
  width: 100%;
  min-height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 7rem 0;
  pointer-events: none; }

#movie_set {
  position: fixed;
  inset: 0;
  margin: 0;
  width: 100%;
  min-height: 100vh;
  z-index: 9998;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  transition: ease-out .6s all; }

#movie_set.open {
  opacity: 1;
  pointer-events: auto !important; }

#movie_modal {
  position: relative;
  margin: 0 auto;
  pointer-events: none;
  width: 100%; }
  @media screen and (min-width: 751px) {
    #movie_modal {
      max-width: 96rem; } }

#movie_set.open #movie_modal {
  pointer-events: auto !important; }

.youtube-wrap {
  position: relative;
  width: 100%;
  margin: 0 auto; }

.youtube-wrap .youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  z-index: 3; }

.youtube-wrap .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important; }

#movie_set.open #movie_modal .btn_close {
  position: absolute;
  display: block;
  cursor: pointer;
  transition: .3s;
  background: url("../img/close.svg") center center no-repeat;
  background-size: contain;
  border: none;
  transition: ease-out .6s all; }
  @media screen and (min-width: 751px) {
    #movie_set.open #movie_modal .btn_close {
      top: 0;
      right: -8rem;
      width: 6rem;
      height: 6rem; } }
  @media screen and (max-width: 750px) {
    #movie_set.open #movie_modal .btn_close {
      bottom: -12.8rem;
      left: 50%;
      transform: translateX(-50%);
      width: 10.8rem;
      height: 10.8rem; } }

@media screen and (min-width: 751px) {
  #movie_modal .btn_close:hover {
    opacity: .7; } }

#modal_set {
  position: fixed;
  inset: 0;
  margin: 0;
  width: 100%;
  min-height: 100vh;
  z-index: 9999;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  transition: ease-out .6s all; }

#modal_set.open {
  opacity: 1;
  pointer-events: auto !important; }

#interview_modal_set {
  position: relative;
  margin: 0 auto;
  pointer-events: none;
  width: 100%;
  background: #fff;
  border-radius: 3rem; }
  @media screen and (min-width: 751px) {
    #interview_modal_set {
      max-width: 120rem;
      padding: 7rem 0; } }
  @media screen and (max-width: 750px) {
    #interview_modal_set {
      max-width: 67rem;
      padding: 5rem 0; } }

#modal_set.open #interview_modal_set {
  pointer-events: auto !important; }

.interview_modal {
  position: relative;
  margin: 0 auto;
  display: none; }
  @media screen and (min-width: 751px) {
    .interview_modal {
      width: 105rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal {
      width: 57rem; } }

.interview_modal .interview_modal_head {
  position: relative;
  display: flex; }
  @media screen and (min-width: 751px) {
    .interview_modal .interview_modal_head {
      justify-content: center;
      align-items: center;
      gap: 3.5rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal .interview_modal_head {
      flex-direction: column;
      justify-content: center;
      text-align: center;
      gap: 5rem; } }

.interview_modal figure {
  position: relative; }
  @media screen and (min-width: 751px) {
    .interview_modal figure {
      width: 50rem; } }

.interview_modal figure img {
  display: block; }
  @media screen and (min-width: 751px) {
    .interview_modal figure img {
      width: 16rem !important;
      height: auto;
      margin: 0 0 0 auto; } }
  @media screen and (max-width: 750px) {
    .interview_modal figure img {
      width: 28.8rem !important;
      height: auto;
      margin: 0 auto; } }

.interview_modal hgroup {
  position: relative;
  display: flex; }
  @media screen and (min-width: 751px) {
    .interview_modal hgroup {
      flex-direction: column;
      width: 50rem;
      gap: 1rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal hgroup {
      flex-direction: column;
      justify-content: center;
      gap: 1rem; } }

.interview_modal hgroup span {
  position: relative;
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Montserrat", sans-serif !important;
  font-weight: 600;
  color: #982235;
  border: #982235 1px solid;
  letter-spacing: 0.0em;
  white-space: nowrap; }
  @media screen and (min-width: 751px) {
    .interview_modal hgroup span {
      margin: 0;
      line-height: 1.667em;
      font-size: 1.2rem;
      width: 13rem;
      height: 2rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal hgroup span {
      margin: 0 auto;
      line-height: 1.637em;
      font-size: 2.2rem;
      width: 23.4rem;
      height: 3.6rem; } }

.interview_modal hgroup h2 {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.01em;
  color: #000000; }
  @media screen and (min-width: 751px) {
    .interview_modal hgroup h2 {
      padding: 0.8rem 0 0;
      line-height: 1em;
      font-size: 2.8rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal hgroup h2 {
      padding: 1rem 0 0;
      line-height: 1.3em;
      font-size: 5rem; } }

.interview_modal hgroup .general_txt {
  position: relative; }

.interview_modal_cont {
  position: relative;
  display: flex;
  width: 100%; }
  @media screen and (min-width: 751px) {
    .interview_modal_cont {
      justify-content: space-around;
      align-items: stretch;
      flex-wrap: wrap;
      gap: 4rem;
      margin-top: 4rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal_cont {
      flex-direction: column;
      gap: 8rem;
      margin-top: 8rem; } }

.interview_modal_cont div {
  position: relative;
  display: flex;
  width: 100%; }
  @media screen and (min-width: 751px) {
    .interview_modal_cont div {
      flex-direction: column;
      width: 50rem;
      gap: 2rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal_cont div {
      flex-direction: column;
      width: 100%;
      gap: 3rem; } }

.interview_modal_cont h3 {
  position: relative;
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  letter-spacing: 0.01em;
  color: #000000;
  width: 100%; }
  @media screen and (min-width: 751px) {
    .interview_modal_cont h3 {
      line-height: 1.5em;
      font-size: 2.4rem;
      padding: 0 0 2rem; } }
  @media screen and (max-width: 750px) {
    .interview_modal_cont h3 {
      line-height: 1.5em;
      font-size: 4.2rem;
      padding: 0 0 3rem; } }

.interview_modal_cont h3::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #aaaaaa; }

.interview_modal_btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #982235;
  transition: .6s ease-out;
  overflow: hidden; }
  @media screen and (min-width: 751px) {
    .interview_modal_btn {
      width: 22rem;
      height: 5.5rem;
      border-radius: 3rem;
      border: #982235 4px solid;
      margin: 1rem auto 0; } }
  @media screen and (max-width: 750px) {
    .interview_modal_btn {
      width: 44rem;
      height: 10rem;
      border-radius: 5rem;
      margin: 2rem auto 0; } }

.interview_modal_btn p {
  position: relative;
  /*@include fw(Bold);*/
  font-weight: 400;
  font-family: "IwaUDGoHonPro-Md" !important;
  color: #FFFFFF;
  letter-spacing: 0.0em;
  text-align: center; }
  @media screen and (min-width: 751px) {
    .interview_modal_btn p {
      line-height: 1.3em;
      font-size: 1.4rem;
      transition: .6s ease-out; } }
  @media screen and (max-width: 750px) {
    .interview_modal_btn p {
      line-height: 1.3em;
      font-size: 2.5rem; } }

@media screen and (min-width: 751px) {
  .interview_modal_btn::before {
    content: "";
    display: block;
    position: absolute;
    transition: ease-out .4s all;
    top: 50%;
    left: 0;
    width: 100%;
    height: 100%;
    background: #FFFFFF;
    opacity: 0; } }

@media screen and (min-width: 751px) {
  .interview_modal_btn:hover::before {
    top: 0;
    opacity: 1; } }

@media screen and (min-width: 751px) {
  .interview_modal_btn:hover p {
    color: #982235; } }

#modal_set.open #interview_modal_set .btn_close {
  position: absolute;
  display: block;
  cursor: pointer;
  transition: .3s;
  background: url("../img/close.svg") center center no-repeat;
  background-size: contain;
  border: none;
  transition: ease-out .6s all; }
  @media screen and (min-width: 751px) {
    #modal_set.open #interview_modal_set .btn_close {
      top: -1rem;
      right: -1rem;
      width: 6rem;
      height: 6rem; } }
  @media screen and (max-width: 750px) {
    #modal_set.open #interview_modal_set .btn_close {
      top: 0;
      right: 0;
      width: 10.8rem;
      height: 10.8rem; } }

@media screen and (min-width: 751px) {
  #modal_set.open #interview_modal_set .btn_close:hover {
    opacity: .7; } }

/**/
/*
.msk_in{
  mask-image: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .5) 70%, rgba(0, 0, 0, 1));
  -webkit-mask-image: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .5) 70%, rgba(0, 0, 0, 1));
  mask-size: 100% 0;
  -webkit-mask-size: 100% 0;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: 0 0;
  -webkit-mask-position: 0 0;
}
.msk_in.active{
	transition:ease-out 2.4s all;
	animation-delay: 0.3s;
	mask-size: 100% 180%;
	-webkit-mask-size: 100% 180%;
}
*/
