@charset "UTF-8";
@import url(https://fonts.googleapis.com/earlyaccess/hannari.css);
@import url(https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;600;700&display=swap);
@keyframes sway {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(15px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes loading_a {
  0% {
    translate: 0 0;
    rotate: 0;
  }
  50% {
    translate: 0 -15px;
    rotate: -3deg;
  }
  100% {
    translate: 0 0;
    rotate: 0;
  }
}
@keyframes loading_b {
  0% {
    translate: 0 0;
    rotate: 0;
  }
  50% {
    translate: 0 -15px;
    rotate: -7deg;
  }
  100% {
    translate: 0 0;
    rotate: 0;
  }
}
img {
  max-width: 100%;
  height: auto;
}
#chocolate_dessertfair2404 .inner {
  max-width: 1000px;
  margin: 0 auto;
}
#chocolate_dessertfair2404 {
  position: relative;
  background-color: #005a5a;
  background-image: linear-gradient(90deg, rgba(0,0,0,0.28) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,0.28) 100%), url(/chocolate_dessertfair2024/files/bg_green.png);
  background-repeat: no-repeat, repeat;
  background-position: center, left top;
  background-size: cover, 640px 640px;
  letter-spacing: normal;
}
#loading {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #005a5a;
  background-image: linear-gradient(90deg, rgba(0,0,0,0.28) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,0.28) 100%), url(/chocolate_dessertfair2024/files/bg_green.png);
  background-repeat: no-repeat, repeat;
  background-position: center, left top;
  background-size: cover, 640px 640px;
  z-index: 50;
  transition: all 1s;
}
#loading .loading_logo {
  position: relative;
  width: 312px;
  padding-top: 167px;
}
#loading .loading_logo::before {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  left: 93px;
  width: 98px;
  height: 96px;
  background-image: url(/chocolate_dessertfair2024/files/img_loading_cacao_a.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: top center;
  z-index: 5;
  animation: loading_a 6s ease-in-out infinite;
}
#loading .loading_logo::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 137px;
  width: 82px;
  height: 89px;
  background-image: url(/chocolate_dessertfair2024/files/img_loading_cacao_b.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: top center;
  z-index: 3;
  animation: loading_b 6s ease-in-out infinite;
}
#loading.loaded {
  opacity: 0;
  visibility: hidden;
}
#loading ~ * {
  opacity: 0;
  visibility: hidden;
}
#loading.loaded ~ * {
  opacity: 1;
  visibility: visible;
}
/* mv */
#mv {
  position: relative;
  width: 100%;
  height: 948px;
}
#mv::before {
  content: "";
  display: block;
  position: absolute;
  top: 220px;
  left: calc(50% - 640px);
  width: 200px;
  height: 764px;
  background-image: url(/chocolate_dessertfair2024/files/img_cacao_left.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100%;
  animation: sway 6s ease-in-out infinite;
}
#mv::after {
  content: "";
  display: block;
  position: absolute;
  top: 230px;
  left: calc(50% + 214px);
  width: 457px;
  height: 683px;
  background-image: url(/chocolate_dessertfair2024/files/img_cacao_right.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100%;
  animation: sway 6s ease-in-out infinite;
}
#mv .mv_ttl {
  position: absolute;
  top: 20px;
  left: calc(50% - 476px);
  width: 752px;
  z-index: 3;
}
#mv .mv_img {
  position: absolute;
  top: 129px;
  left: calc(50% - 533px);
  width: 1068px;
  z-index: 5;
}
/* lead */
#lead {
  position: relative;
  padding: 82px 0 120px;
}
#lead p {
  font-size: 1.8rem;
  line-height: 1.89;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#lead .introduction_movie {
  max-width: 726px;
  margin: 75px auto 0;
  background: url(/chocolate_dessertfair2024/files/bg_movie.png) no-repeat left top / 100% auto;
  padding: 50px 0 0 46px;
}
#lead .introduction_movie .movie_wrap {
  position: relative;
  width: 680px;
  aspect-ratio: 16 / 9;
}
#lead .introduction_movie .movie_wrap iframe {
  width: 100%;
  height: 100%;
}
.important_news {
  min-width: 660px;
  max-width: 960px;
  margin: 40px auto 0;
  text-align: center;
}
.important_news li {
  min-width: 660px;
  display: inline-block;
}
.important_news li + li {
  margin: 8px 0 0;
}
.important_news li a,
.important_news li span {
  padding: 20px 70px 20px 90px;
  display: block;
  color: #5c1511;
  font-size: 1.8rem;
  line-height: 1.3333333333;
  font-weight: bold;
  position: relative;
  border: 2px solid #f8ca0e;
  -webkit-box-shadow: 0 0 2px rgba(0, 0, 0, 0.16);
          box-shadow: 0 0 2px rgba(0, 0, 0, 0.16);
  background: #fff;
  border-radius: 6px;
}
.important_news li a::before {
  content: "\e931";
  font-family: "cocos";
  display: block;
  font-weight: normal;
  color: #f8ca0e;
  font-size: 1.4rem;
  line-height: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  right: 20px;
}
.important_news li a::after,
.important_news li span::after {
  content: "\e90e";
  font-family: "cocos";
  display: block;
  font-weight: normal;
  color: #f8ca0e;
  font-size: 3.2rem;
  line-height: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  left: 32px;
}

/* end */
.important_news .end span {
  padding: 20px 30px 20px 80px;
  color: #e64135;
  border: 2px solid #e64135;
}
.important_news .end span::after {
  color: #e64135;
}
/*-- Hover --*/
.important_news a {
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
/* item_list */
#item_list {
  position: relative;
}
#item_list::before,
#item_list::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center;
  animation: sway 6s ease-in-out infinite;
  z-index: 2;
}
#item_list::before {
  top: 836px;
  left: -30px;
  width: 125px;
  height: 166px;
  background-image: url(/chocolate_dessertfair2024/files/img_cacao_list_left.png);
}
#item_list::after {
  top: 1666px;
  right: 0;
  width: 98px;
  height: 96px;
  background-image: url(/chocolate_dessertfair2024/files/img_cacao_list_right.png);
}
#item_list > li {
  display: flex;
  gap: calc(60 / 1000 * 100%);
  position: relative;
}
#item_list > li::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: calc(50% - 50vw);
  width: 100vw;
  height: 215px;
  background-image: url(/chocolate_dessertfair2024/files/bg_wave.png);
  background-position: center top;
  background-repeat: repeat-x;
  background-size: 1366px auto;
}
#item_list > li:nth-of-type(2) {
  padding-top: 84px;
  margin-top: 100px;
}
#item_list > li:nth-of-type(3) {
  padding-top: 116px;
  margin-top: 100px;
}
#item_list > li:nth-of-type(4) {
  padding-top: 114px;
  margin-top: 100px;
}
#item_list > li:nth-of-type(2n) {
  flex-direction: row-reverse;
}
#item_list > li .item_img {
  width: calc(520 / 1000 * 100%);
}
#item_list > li:nth-of-type(2n - 1) .item_img {
  margin-left: -40px;
}
#item_list > li:nth-of-type(2n) .item_img {
  margin-right: -40px;
}
#item_list > li .item_info {
  position: relative;
  width: calc(460 / 1000 * 100%);
}
#item_list > li .item_name {
  font-size: 3.6rem;
  line-height: 1.19;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#item_list > li:nth-of-type(2) .item_name {
  font-size: 3.5rem;
}
#item_list > li .item_name_en {
  margin-top: 16px;
}
#item_list > li:first-of-type .item_name_en {
  width: 194px;
}
#item_list > li:nth-of-type(2) .item_name_en {
  width: 243px;
}
#item_list > li:nth-of-type(3) .item_name_en {
  width: 488px;
}
#item_list > li:nth-of-type(4) .item_name_en {
  width: 285px;
}
#item_list > li .item_txt {
  margin-top: 56px;
  font-size: 1.8rem;
  line-height: 1.89;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#item_list > li .item_price {
  margin-top: 32px;
}
#item_list > li .item_price .yen {
  padding-right: 0.25em;
  font-size: 2.2rem;
  line-height: 44px;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#item_list > li .item_price .price {
  font-size: 3.7rem;
  line-height: 44px;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#item_list > li .item_price .tax {
  padding-left: 0.8em;
  font-size: 2.0rem;
  line-height: 44px;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#item_list > li .item_price .tax_s {
  padding-right: 0.25em;
  font-size: 0.8em;
}
#item_list > li .item_note {
  margin-top: 20px;
}
#item_list > li .item_note > li {
  font-size: 1.4rem;
  line-height: 1.21;
  color: #fff;
}
#item_list > li .item_note > li::before {
  content: "※";
  padding-right: 0.25em;
}
#item_list > li .item_note > li:not(:last-of-type) {
  margin-bottom: 0.5em;
}
#item_list > li:first-of-type .item_info {
  padding-top: 231px;
}
#item_list > li:nth-of-type(2) .item_info {
  padding-top: 30px;
}
#item_list > li:nth-of-type(3) .item_info {
  padding-top: 42px;
}
#item_list > li:nth-of-type(4) .item_info {
  padding-top: 45px;
}
#item_list > li .btn_wrap {
  margin-top: 40px;
}
/* set */
#set {
  position: relative;
  padding: 100px 0;
  margin-top: 140px;
  background-image: url(/chocolate_dessertfair2024/files/bg_set.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}
#set::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 242px;
  height: 313px;
  background-image: url(/chocolate_dessertfair2024/files/img_chocolate.png);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center top;
}
#set h2 {
  font-weight: 600;
  font-size: 2.6rem;
  font-style: normal;
  font-family: "Noto Serif JP", serif;
  line-height: 1.38;
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
}
#set .cafe_side {
  margin-top: 35px;
  padding: 32px 0;
  border: 2px solid #906250;
  background: #351E10 url(/chocolate_dessertfair2024/files/bg_cafe_repeat.png) left top;
  text-align: center;
}
#set .cafe_side h3 {
  width: 526px;
  margin: 0 auto;
}
#set .cafe_side .cafe_side_inner {
  margin-top: 32px;
  padding: 0 60px;
}
#set .cafe_side .zensho {
  margin-top: 15px;
  color: #9BA285;
  font-weight: bold;
  text-align: left;
  padding: 10px 10px 10px 70px;
  background: url(/chocolate_dessertfair2024/files/img_cafe_logo.png) no-repeat left center /55px auto;
  line-height: 1.75;
  font-size: 1.4rem;
}
#set .notice_box {
  padding: 25px;
  margin-top: 40px;
  font-size: 1.3rem;
  line-height: 1.5;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}
#set .notice_box ul li {
  position: relative;
  margin-top: 5px;
  padding-left: 20px;
}
#set .notice_box ul li:before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 4px;
  left: 0;
  width: 11px;
  height: 11px;
  border-radius: 100px;
  background: #D95F2E;
}
#set .notice_box ul li:first-child {
  margin-top: 0;
}
#set .notice_box ul li a {
  display: inline-block;
  color: #fff;
  position: relative;
  background: linear-gradient(#fff, #fff) 0 100%/100% 1px no-repeat;
}
#set .notice_box ul li a img {
  vertical-align: baseline;
}
/* campaign */
#campaign {
  padding-top: 100px;
  text-align: center;
}
#campaign h2 {
  width: 228px;
  margin: 0 auto;
}
#campaign .txt {
  margin-top: 20px;
  font-size: 2.8rem;
  line-height: 1.65;
  font-family: "Hannari", "Noto Serif JP", serif;
  color: #fff;
}
#campaign .col_wrap {
  display: flex;
  gap: 40px;
  margin-top: 60px;
}
#campaign .col_wrap .col {
  width: 480px;
}
#campaign .col_wrap .col .video_wrap {
  position: relative;
  width: 100%;
  background-color: #fff;
  aspect-ratio: 1 / 1;
}
#campaign .col_wrap .col video {
  width: 100%;
  height: 100%;
  font-size: 0;
  line-height: 1;
  vertical-align: middle;
}
#campaign .col_wrap .col .img_wrap {
  background-color: #fff;
  aspect-ratio: 16 / 9;
}
#campaign .col .btn_wrap {
  margin-top: 20px;
}
#campaign .col:last-of-type .btn_wrap {
  display: flex;
  gap: 16px;
}
#campaign .col:last-of-type .btn_wrap .btn {
  width: 100%;
  min-width: auto;
}
/* owner */
#owner {
  padding: 100px 0;
  margin-top: 100px;
  background: url(/chocolate_dessertfair2024/files/bg_owner.png) no-repeat center / cover;
  color: #fff;
}
#owner .inner {
  max-width: 805px;
  margin: 0 auto;
}
#owner .intro {
  display: flex;
  gap: calc(70 / 805 * 100%);
  position: relative;
}
#owner .intro > figure {
  width: calc(303 / 805 * 100%);
}
#owner .intro h2 {
  position: absolute;
  top: 48px;
  right: 12px;
  width: 518px;
}
#owner .intro .txt_wrap {
  width: calc(431 / 805 * 100%);
  padding-top: 192px;
}
#owner .intro .txt_wrap .pos {
  font-size: 1.8rem;
  line-height: 1.33;
}
#owner .intro .txt_wrap .name {
  margin-top: 6px;
}
#owner .intro .txt_wrap .name .txt01 {
  font-weight: bold;
  font-size: 3.4rem;
  line-height: 50px;
  letter-spacing: 0.16em;
}
#owner .intro .txt_wrap .name .txt02 {
  font-weight: bold;
  padding-left: 0.6em;
  font-size: 1.8rem;
  line-height: 50px;
}
#owner .intro .txt_wrap .lead {
  margin-top: 16px;
  font-size: 1.4rem;
  line-height: 1.71;
}
#owner .box {
  margin-top: 64px;
  border: 1px solid rgba(255,255,255,0.4);
  padding: 40px 37px 32px;
  background: rgba(36, 18, 8, 0.4);
}
#owner .box h2 {
  text-align: center;
}
#owner .box .article_wrap {
  display: flex;
  gap: 25px;
  margin-top: 40px;
  line-height: 1.75;
  letter-spacing: 0.1em;
}
#owner .box .article_wrap .txt_wrap {
  flex: 1;
}
#owner .box .article_wrap .ttl {
  font-weight: bold;
  font-size: 1.6rem;
}
#owner .box .article_wrap .txt {
  margin-top: 10px;
  font-size: 1.3rem;
}
#owner .box .article_wrap .link {
  text-align: right;
  margin-top: 10px;
}
#owner .box .article_wrap .link a {
  display: inline-block;
  position: relative;
  border-bottom: 1px solid #fff;
  font-size: 1.4rem;
  color: #fff;
}
#owner .box .article_wrap .link a:before {
  content: "";
  background: url(/chocolate_dessertfair2024/files/icon_blank.svg) no-repeat center /cover;
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: middle;
  margin-top: -4px;
  margin-right: 4px;
}
/* btn_footer */
#btn_footer {
  padding: 80px 20px;
  background: #351E10;
}
#btn_footer .inner {
  max-width: 1000px;
  margin: 0 auto;
}
#btn_footer .btn_col_wrap {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  text-align: center;
}
#btn_footer .btn_col_wrap li {
  flex: 1;
}
/* sns_fixed_list */
.sns_fixed_list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: fixed;
  top: 50%;
  right: 16px;
  z-index: 5;
}
@media (min-width: 1366px) {
  #mv::before {
    left: calc(50% - 710px);
  }
  #mv::after {
    left: calc(50% + 230px);
  }
}
@media (max-width: 1032px) {
  #chocolate_dessertfair2404 .inner {
    padding: 0 16px;
  }
  /* mv */
  #mv {
    height: calc(948 / 1366 * 100vw);
  }
  #mv::before {
    top: calc(232 / 1366 * 100vw);
    left: calc(50% - (640 / 1366 * 100vw));
    width: calc(200 / 1366 * 100vw);
    height: calc(764 / 1366 * 100vw);
  }
  #mv::after {
    top: calc(241 / 1366 * 100vw);
    left: calc(50% + (214 / 1366 * 100vw));
    width: calc(457 / 1366 * 100vw);
    height: calc(683 / 1366 * 100vw);
  }
  #mv .mv_ttl {
    top: calc(20 / 1366 * 100vw);
    left: calc(50% - (476 / 1366 * 100vw));
    width: calc(752 / 1366 * 100vw);
  }
  #mv .mv_img {
    top: calc(148 / 1366 * 100vw);
    left: calc(50% - (533 / 1366 * 100vw));
    width: calc(1066 / 1366 * 100vw);
  }
  /* item_list */
  #item_list::before {
    top: calc(1008 / 1366 * 100vw);
    left: calc(-30 / 1366 * 100vw);
    width: calc(125 / 1366 * 100vw);
    height: calc(166 / 1366 * 100vw);
  }
  #item_list::after {
    top: calc(2060 / 1366 *100vw);
    width: calc(98 / 1366 * 100vw);
    height: calc(96 / 1366 * 100vw);
  }
  #item_list > li::before {
    height: calc(215 / 1366 * 100vw);
    background-size: calc(1366 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(2) {
    padding-top: calc(84 / 1366 * 100vw);
    margin-top: calc(100 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(3) {
    padding-top: calc(116 / 1366 * 100vw);
    margin-top: calc(100 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(4) {
    padding-top: calc(114 / 1366 * 100vw);
    margin-top: calc(100 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(2n - 1) .item_img {
    margin-left: calc(-40 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(2n) .item_img {
    margin-right: calc(-40 / 1366 * 100vw);
  }
  #item_list > li .item_name {
    font-size: calc(36 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(2) .item_name {
    font-size: calc(35 / 1366 * 100vw);
  }
  #item_list > li .item_name_en {
    margin-top: calc(16 / 1366 * 100vw);
  }
  #item_list > li:first-of-type .item_name_en {
    width: calc(194 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(2) .item_name_en {
    width: calc(243 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(3) .item_name_en {
    width: calc(488 / 1366 * 100vw);
  }
  #item_list > li:nth-of-type(4) .item_name_en {
    width: calc(285 / 1366 * 100vw);
  }
  #item_list > li .item_txt {
    margin-top: calc(56 / 1366 * 100vw);
    font-size: calc(18 / 1366 * 100vw);
  }
  #item_list > li .item_price {
    margin-top: calc(32 / 1366 * 100vw);
  }
  #item_list > li .item_price .yen {
    font-size: calc(22 / 1366 * 100vw);
    line-height: calc(44 / 1366 * 100vw);
  }
  #item_list > li .item_price .price {
    font-size: calc(37 / 1366 * 100vw);
    line-height: calc(44 / 1366 * 100vw);
  }
  #item_list > li .item_price .tax {
    font-size: calc(20 / 1366 * 100vw);
    line-height: calc(44 / 1366 * 100vw);
  }
  #item_list > li .item_note {
    margin-top: calc(20 / 1366 * 100vw);
  }
  #item_list > li .item_note > li {
    font-size: calc(14 / 1366 * 100vw);
  }
  #item_list > li .btn_wrap {
    margin-top: calc(40 / 1366 * 100vw);
  }
  /* set */
  #set::before {
    width: calc(242 / 1366 * 100vw);
    height: calc(313 / 1266 * 100vw);
  }
  /* campaign */
  #campaign .btn {
    padding: calc(16 / 1366 * 100vw) calc(48 / 1366 * 100vw);
  }
}
@media (max-width: 979.98px) {
  .important_news {
    min-width: auto;
    max-width: none;
    width: 90%;
  }
  .important_news li {
    min-width: auto;
  }
}
@media (min-width: 768px) {
  .sns_fixed_list a {
    transition: all 0.3s ease;
  }
  body:not(.tab_view) .sns_fixed_list a:hover {
    opacity: 0.8;
  }
  body:not(.tab_view) .important_news a:hover {
    opacity: 0.7;
  }
}
@media (max-width: 767.98px) {
  #chocolate_dessertfair2404 .inner {
    max-width: calc(358 / 390 * 100vw);
    padding: 0;
    margin: 0 auto;
  }
  /* mv */
  #mv {
    height: calc(576 / 390 * 100vw);
  }
  #mv::before {
    top: calc(182 / 390 * 100vw);
    left: calc(12 / 390 * 100vw);
    width: calc(424 / 390 * 100vw);
    height: calc(207 / 390 * 100vw);
    background-image: url(/chocolate_dessertfair2024/files/img_cacao_sp.png);
  }
  #mv::after {
    content: none;
  }
  #mv .mv_ttl {
    top: calc(22 / 390 * 100vw);
    left: calc(5 / 390 * 100vw);
    width: calc(340 / 390 * 100vw);
  }
  #mv .mv_img {
    top: calc(297 / 390 * 100vw);
    left: 0;
    width: 100%;
  }
  /* lead */
  #lead {
    padding: calc(56 / 390 * 100vw) 0 calc(106 / 390 * 100vw);
  }
  #lead p {
    font-size: calc(15 / 390 * 100vw);
    line-height: 2.27;
  }
  #lead .introduction_movie {
    max-width: none;
    margin: calc(55 / 390 * 100vw) auto 0;
    background: url(/chocolate_dessertfair2024/files/bg_movie_sp.png) no-repeat left top / 100% auto;
    padding: calc(37 / 390 * 100vw) 0 0 calc(23 / 390 * 100vw);
    translate: calc(-7 / 390 * 100vw) 0;
  }
  #lead .introduction_movie .movie_wrap {
    width: 100%;
  }
  .important_news {
    width: 100%;
    margin: 24px auto 0;
  }
  .important_news li a {
    padding: 14px 40px 14px 60px;
    font-size: 1.3rem;
    line-height: 1.4615384615;
    -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.16);
            box-shadow: 0 0 4px rgba(0, 0, 0, 0.16);
  }
  .important_news li a::before {
    right: 14px;
  }
  .important_news li a::after {
    left: 16px;
  }
  /* item_list */
  #item_list::before,
  #item_list::after {
    content: none;
  }
  #item_list > li {
    display: block;
    gap: unset;
  }
  #item_list > li:first-of-type {
    padding-top: calc(29 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2) {
    padding-top: calc(40 / 390 * 100vw);
    margin-top: calc(40 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(3) {
    padding-top: calc(34 / 390 * 100vw);
    margin-top: calc(40 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(4) {
    padding-top: calc(34 / 390 * 100vw);
    margin-top: calc(18 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2n) {
    flex-direction: unset;
  }
  #item_list > li .item_img {
    width: calc(374 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2n - 1) .item_img {
    margin-left: calc(-16 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2n) .item_img {
    margin-right: calc(-16 / 390 * 100vw);
  }
  #item_list > li .item_info {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  #item_list > li .item_name,
  #item_list > li:nth-of-type(2) .item_name {
    order: 1;
    font-size: calc(28 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2) .item_name {
    letter-spacing: -0.04em;
  }
  #item_list > li .item_name_en {
    order: 2;
    margin-top: calc(16 / 390 * 100vw);
  }
  #item_list > li:first-of-type .item_name_en {
    width: calc(155 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2) .item_name_en {
    width: calc(194 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(3) .item_name_en {
    width: calc(279 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(4) .item_name_en {
    width: calc(228 / 390 * 100vw);
  }
  #item_list > li .item_txt {
    order: 4;
    margin-top: calc(30 / 390 * 100vw);
    font-size: calc(16 / 390 * 100vw);
    line-height: 1.75;
  }
  #item_list > li .item_price {
    order: 3;
    margin-top: calc(24 / 390 * 100vw);
  }
  #item_list > li .item_price .yen {
    font-size: calc(18 / 390 * 100vw);
    line-height: calc(36 / 390 * 100vw);
  }
  #item_list > li .item_price .price {
    font-size: calc(30 / 390 * 100vw);
    line-height: calc(36 / 390 * 100vw);
  }
  #item_list > li .item_price .tax {
    padding-left: calc(8 / 390 * 100vw);
    font-size: calc(13 / 390 * 100vw);
    line-height: calc(36 / 390 * 100vw);
  }
  #item_list > li .item_note {
    order: 5;
    margin-top: calc(30 / 390 * 100vw);
  }
  #item_list > li .item_note > li {
    font-size: calc(14 / 390 * 100vw);
  }
  #item_list > li:first-of-type .item_info {
    padding-top: calc(24 / 390 * 100vw);
  }
  #item_list > li:nth-of-type(2) .item_info,
  #item_list > li:nth-of-type(3) .item_info,
  #item_list > li:nth-of-type(4) .item_info {
    padding-top: calc(29 / 390 * 100vw);
  }
  #item_list > li .btn_wrap {
    order: 6;
    margin-top: calc(40 / 390 * 100vw);
    text-align: center;
  }
  /* set */
  #set {
    padding: calc(60 / 390 * 100vw) 0;
    margin-top: calc(80 / 390 * 100vw);
    background-image: url(/chocolate_dessertfair2024/files/bg_set_sp.png);
  }
  #set::before {
    width: calc(242 / 390 * 100vw);
    height: calc(313 / 390 * 100vw);
    background-image: url(/chocolate_dessertfair2024/files/img_chocolate_sp.png);
  }
  #set h2 {
    font-size: calc(24 / 390 * 100vw);
    line-height: 1.5;
  }
  #set .cafe_side {
    margin-top: calc(35 / 390 * 100vw);
    padding: calc(35 / 390 * 100vw) 0 calc(40 / 390 * 100vw);
  }
  #set .cafe_side h3 {
    width: calc(244 / 390 * 100vw);
  }
  #set .cafe_side .cafe_side_inner {
    margin-top: calc(35 / 390 * 100vw);
    padding: 0 calc(20 / 390 * 100vw);
  }
  #set .cafe_side .zensho {
    padding-top: 0;
    padding-bottom: 0;
    margin-top: calc(24 / 390 * 100vw);
    font-size: calc(13 / 390 * 100vw);
    background-position: top 4px left;
  }
  #set .notice_box {
    padding: calc(16 / 390 * 100vw);
    margin: calc(30 / 390 * 100vw) calc(-16 / 390 * 100vw) 0;
    font-size: calc(13 / 390 * 100vw);
  }
  #set .notice_box ul li {
    margin-top: calc(5 / 390 * 100vw);
    padding-left: calc(19 / 390 * 100vw);
  }
  #set .notice_box ul li:before {
    top: calc(4 / 390 * 100vw);
    width: calc(11 / 390 * 100vw);
    height: calc(11 / 390 * 100vw);
  }
  /* campaign */
  #campaign {
    padding-top: calc(80 / 390 * 100vw);
  }
  #campaign h2 {
    width: calc(228 / 390 * 100vw);
  }
  #campaign .txt {
    margin-top: calc(20 / 390 * 100vw);
    font-size: calc(23 / 390 * 100vw);
    line-height: 1.5;
    letter-spacing: -0.06em;
  }
  #campaign .col_wrap {
    display: flex;
    flex-direction: column;
    gap: calc(40 / 390 * 100vw);
    margin-top: calc(60 / 390 * 100vw);
  }
  #campaign .col_wrap .col {
    width: 100%;
  }
  #campaign .col .btn_wrap {
    margin-top: calc(16 / 390 * 100vw);
  }
  #campaign .col:last-of-type .btn_wrap {
    gap: calc(16 / 390 * 100vw);
  }
  #campaign .btn {
    padding: calc(14 / 390 * 100vw) calc(36 / 390 * 100vw);
    font-size: calc(14 / 390 * 100vw);
  }
  /* owner */
  #owner {
    padding: calc(60 / 390 * 100vw) 0;
    margin-top: calc(80 / 390 * 100vw);
    background: url(/chocolate_dessertfair2024/files/bg_owner.png) no-repeat center / cover;
  }
  #owner .inner {
    max-width: calc(358 / 390 * 100vw);
  }
  #owner .intro {
    display: flex;
    gap: calc(37 / 390 * 100vw);
    position: relative;
  }
  #owner .intro > figure {
    width: calc(157 / 390 * 100vw);
  }
  #owner .intro h2 {
    top: calc(47 / 390 * 100vw);
    right: 0;
    width: calc(215 / 390 * 100vw)  ;
  }
  #owner .intro .txt_wrap {
    width: calc(100 / 390 * 100vW);
    padding-top: calc(122 / 390 * 100vw);
  }
  #owner .intro .txt_wrap .pos {
    font-size: calc(9 / 390 * 100vw);
  }
  #owner .intro .txt_wrap .name {
    margin-top: calc(4 / 390 * 100vw);
  }
  #owner .intro .txt_wrap .name .txt01 {
    font-size: calc(17 / 390 * 100vw);
    line-height: calc(25 / 390 * 100vw);
  }
  #owner .intro .txt_wrap .name .txt02 {
    font-size: calc(9 / 390 * 100vw);
    line-height: calc(25 / 390 * 100vw);
  }
  #owner .intro .txt_wrap .lead {
    position: absolute;
    left: 0;
    top: calc(232 / 390 * 100vw);
    width: 100%;
    margin-top: 0;
    font-size: calc(14 / 390 * 100vw);
  }
  #owner .box {
    padding: calc(32 / 390 * 100vw) calc(16 / 390 * 100vw) calc(40 / 390 * 100vw);
    border-color: #fff;
    margin-top: calc(174 / 390 * 100vw);
    background: #241208;
  }
  #owner .box .article_wrap {
    flex-direction: column;
    gap: calc(24 / 390 * 100vw);
    margin-top: calc(33 / 390 * 100vw);
  }
  #owner .box .article_wrap .img img {
    width: 100%;
  }
  #owner .box .article_wrap .ttl {
    font-size: calc(16 / 390 * 100vw);
  }
  #owner .box .article_wrap .txt {
    margin-top: calc(10 / 390 * 100vw);
    font-size: calc(13 / 390 * 100vw);
  }
  #owner .box .article_wrap .link {
    text-align: center;
    margin-top: calc(25 / 390 * 100vw);
  }
  #owner .box .article_wrap .link a {
    font-size: calc(14 / 390 * 100vw);
  }
  #owner .box .article_wrap .link a:before {
    width: calc(20 / 390 * 100vw);
    height: calc(20 / 390 * 100vw);
    margin-top: calc(-4 / 390 * 100vw);
    margin-right: calc(4 / 390 * 100vw);
  }
  /* btn_footer */
  #btn_footer {
    padding: 60px 40px;
  }
  #btn_footer .btn_col_wrap {
    flex-direction: column;
    gap: 16px;
  }
  #btn_footer .btn_col_wrap .btn {
    width: 100%;
  }
}