@charset "utf-8";

/*-------------------------------------------------------------------------------------------------------------------------------
* TOP
-------------------------------------------------------------------------------------------------------------------------------*/
.sec-intro {
  padding-top: 70px;
  position: relative;
}

.sec-intro::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/bg-img01.png) no-repeat center center;
  width: 679px;
  height: 404px;
  z-index: -1;
}

.sec-intro .intro h2 {
  width: 475px;
  margin: auto;
}

.sec-intro .intro .intro-text {
  font-size: 28px;
  line-height: 1.8;
  text-align: center;
  padding-block: 40px 90px;
}

.intro-wrap {
  max-width: 610px;
  margin: auto;
}


.intro-wrap .intro-movie .intro-inner {
  max-width: 536px;
  margin: 0 auto;
}

.intro-wrap .intro-movie h4,
.intro-wrap .intro-map h4 {
  width: 510px;
  margin-inline: auto;
  transform: translateY(-45px);
}

.intro-wrap .intro-movie,
.intro-wrap .intro-map {
  background: linear-gradient(135deg,
      #e7daa4 0%,
      #bbaf3c 20%,
      #e0d08c 40%,
      #baad3c 60%,
      #f7efdc 80%,
      #bbaf3c 100%);
}

.intro-wrap .intro-movie video {
  width: 100%;
}

.intro-wrap .intro-movie p {
  font-size: 20px;
  line-height: 1.6;
  padding: 20px 50.5px;
  color: #cf112c;
}

.intro-wrap .intro-map {
  margin-top: 50px;
  padding-bottom: 35px;
}

.intro-wrap .intro-map .intro-map-img {
  width: 560px;
  margin: -20px auto 0;
}

.sec-event {
  background-color: #cf112c;
}

.event {
  max-width: 608px;
  margin: 0 auto;
  padding-top: 50px;
}

.event .accordion-wrapper button {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  position: relative;
}

.event .accordion-wrapper button::before {
  content: "";
  position: absolute;
  width: 35px;
  height: 35px;
  background-color: black;
  bottom: 10px;
  right: 10px;
}

.event .accordion-wrapper button::after {
  content: "";
  position: absolute;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  width: 17px;
  height: 14px;
  background-color: #cf112c;
  bottom: 20px;
  right: 19px;
  transform: rotate(180deg);
  transition: all 0.3s;
}

.event .accordion-contents {
  background-color: white;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.5s ease-out;
}

.event .accordion-contents.goods-color {
  background-color: #5bc2dc;
}

.event .accordion-wrapper.is-open button::after {
  transform: rotate(0deg);
}

.event .accordion-wrapper.is-open .accordion-contents {
  grid-template-rows: 1fr;
}



.event .accordion-inner {
  padding-left: 30px;
  padding-right: 30px;
  overflow: hidden;
}

.event .accordion-wrapper.is-open .accordion-inner {
  overflow: visible;
}

.event .accordion-contents .event-title {
  font-size: 40px;
  font-weight: bold;
  letter-spacing: -0.02em;
  text-align: center;
  line-height: 1.3;
  color: #cf112c;
  margin-top: 40px;
  margin-bottom: 20px;
}

.event .accordion-contents .event-text {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #cf112c;
  padding-block: 20px;
  border-top: 1px solid #cf112c;
  border-bottom: 1px solid #cf112c;
  font-weight: 500;
}

.event .accordion-contents .event-text span {
  font-size: 19px;
}

.event .accordion-contents .event-text span.letter {
  /* letter-spacing: -0.02em; */
  padding-top: 5px;
  font-size: 19px;
  display: block;


}

.event .event-list {
  display: flex;
  gap: 20px;
  margin-top: 30px;
}

.event .event-list .event-list-text {
  font-size: 24px;
  letter-spacing: 0.02em;
  line-height: 1.5;
  font-weight: 500;
}

.event .accordion-contents .event-text02 {
  font-size: 30px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #cf112c;
  font-weight: bold;
}

.event .accordion-contents .event-text02 span {
  font-size: 24px;
  font-weight: 500;
}

.event .accordion-contents .event-text02 span i {
  font-style: normal;
  margin-top: 15px;
  display: block;
  font-weight: 500;
}

.event .accordion-contents .event-text02 span i b {
  font-weight: 800;
}

.event .accordion-contents .event-text03 {
  font-size: 18px;
  line-height: 1.5;
  font-weight: 500;
}

.event .accordion-contents .event-text04 {
  font-size: 24px;
  line-height: 1.5;
  font-weight: 500;
}

.event .event-list .event-list-text span {
  font-size: 21px;
}

.event .event-list .event-list-icon {
  width: 168px;
  flex-shrink: 0;
}

.event .event-talk .event-talk-note {
  text-align: right;
  font-size: 15px;
  margin-top: 5px;
}

.event .event-img.w641 {
  width: 117%;
  transform: translateX(-64px);
}

.event .event-times-text {
  font-size: 24px;
  line-height: 1.6;
  font-weight: 500;
}

.event.goods .accordion-inner {
  padding-left: 0;
  padding-right: 0;
}

.event.goods .accordion-inner.active {
  overflow: visible;
}

.event.goods .accordion-inner h4 {
  max-width: 548px;
}

.chocomoo {
  padding-left: 25px;
  padding-right: 25px;


}

.chocomoo-box {
  border-radius: 15px;
  border: 1px solid black;
  padding: 20px 30px;
}

.chocomoo-title {
  font-size: 32px;
  padding-left: 80px;
  font-weight: bold;

}

.chocomoo-title .span-01 {
  font-size: 18px;
  font-weight: 500;
}

.chocomoo-title .span-02 {
  font-size: 20px;
  font-weight: 500;
}

.chocomoo p {
  font-size: 19px;
  line-height: 1.5;
  font-weight: 500;
}

.goods-list {
  padding-top: 175px;
  position: relative;

}

.goods-list {
  padding-top: 190px;
  position: relative;

}

.goods-list::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 522px;
  height: 290px;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/icon-birds04.png) no-repeat center center;
  background-size: cover;

}

.goods-item.goods-flex {
  display: flex;
  align-items: center;
}

.goods-item .item-01 {
  transform: scale(1.055);
}

.goods-item .item-02 {
  transform: scale(1.07);
}

.goods-item .item-03 {
  max-width: 310px;
}

.goods-item .item-04 {
  transform: scale(1.16);
}

.goods-item .item-05 {
  transform: scale(1.07);
}

.goods-item .item-text {
  font-size: 24px;
  line-height: 1.5;
}

.goods-item .item-text span {
  font-weight: bold;
}

.goods-item.icon-birds04 {
  position: relative;
}

.goods-item.icon-birds04::after {
  position: absolute;
  content: "";
  width: 160px;
  height: 210px;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/icon-birds05.png) no-repeat center center;
  background-size: cover;
  right: -45px;
  top: -67px;
}

.text-more {
  text-align: center;
  font-size: 24px;
}

.note-text {
  font-size: 21px;
  padding-left: 100px;
  margin-bottom: 70px;
  line-height: 1.5;
  font-weight: 500;
}

.present02 {
  position: relative;
  padding-bottom: 80px;

}

.present02-box {
  position: relative;

}

.present02-title {
  max-width: 506px;
}

.present02-box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 486px;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/border01.png) no-repeat top center;
  background-size: contain;
  z-index: 0;

}

.present02-content {
  position: relative;
  z-index: 1;
}

.present02-text {
  font-size: 22px;
  line-height: 1.5;
  font-weight: 500;
}

.slider-container {
  max-width: 540px;
  margin: 0 auto;
}

.slider .gallery-slider {
  width: 100%;
  height: 500px;
  object-fit: cover;
  display: block;
}

/* Tùy chỉnh nút */
.slick-prev,
.slick-next {
  width: 25px;
  height: 40px;
  z-index: 1;
  filter: brightness(0) saturate(100%) invert(99%) sepia(1%) saturate(891%) hue-rotate(208deg) brightness(116%) contrast(100%);
}

.slick-prev {
  left: 25px;
  top: 50%;
}

.slick-next {
  right: 25px;
  top: 50%;
}

.icon-birds02,
.icon-birds03 {
  position: relative;

}

.icon-birds02::before {
  content: "";
  position: absolute;
  bottom: -130px;
  left: -80px;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/icon-birds02.png) no-repeat center center;
  background-size: cover;
  width: 135px;
  height: 184px;
}

.icon-birds03::before {
  content: "";
  position: absolute;
  bottom: -30px;
  right: -90px;
  background: url(/base/osaka/special/suntorysunbirds/img/251212/top/icon-birds03.png) no-repeat center center;
  background-size: cover;
  width: 209px;
  height: 160px;
}

.btn a {
  display: grid;
  position: relative;
  align-items: center;
  padding: 0px 70px 0px 30px;
  color: white;
  font-size: 24px;
  font-weight: bold;
  background-color: #cf112c;
  line-height: 1.3;
  height: 82px;

}

.btn a::before {
  content: "";
  position: absolute;
  width: 35px;
  height: 35px;
  background-color: white;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}

.btn a::after {
  content: "";
  position: absolute;
  clip-path: polygon(0% 0, 100% 50%, 0 100%);
  width: 14px;
  height: 17px;
  background-color: #cf112c;
  top: 50%;
  right: 29px;
  transform: translateY(-50%);
}

.btn a.btn-02 {
  background-color: black;
}

.btn a.btn-02::after {
  background-color: black;
}


.present {

  border-radius: 40px;
  background-color: white;
  position: relative;
  margin-left: -30px;
  margin-right: -30px;
}

.present::after {
  content: "";
  position: absolute;
  top: 0;
  left: -35px;
  width: 115%;
  height: 100%;
  background-color: #cf112c;
}

.present-box {
  position: relative;
  z-index: 1;
  background-color: white;
  border-radius: 30px;
  padding-top: 30px;
}

.present h2 {
  max-width: 600px;
  padding-left: 30px;
}

.present-text {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.5;
}

.present-note {
  border-radius: 15px;
  border: 1px solid #cf112c;
  padding: 10px 20px;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 500;

}

.present-note .span-01 {
  color: #00a0ca;
}

.present-note .span-02 {
  color: #cf112c;
}

.remarks {
  padding-bottom: 80px;
  background-color: #cf112c;
  color: white;
}

.remarks-list {
  margin-inline: auto;
  max-width: 640px;
  font-size: 24px;
  line-height: 1.5;
}

.remarks-list>li {
  padding-left: 1em;
  text-indent: -1em;
}

.remarks-list>li+li {
  margin-top: 4px;
}