/* ---------------------------------------------------------
animation
----------------------------------------------------------*/

.animeBefore {
  visibility: hidden;
}

.fadeAnime {
  visibility: visible;
  animation-name: fadeAnime;
  animation-duration: 600ms;
}
@keyframes fadeAnime {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0px);
  }
}

.pic-main {
  display: flex;
  flex-direction: column-reverse;
}

@media screen and (max-width: 450px){
  .pic-main {
    flex-direction: column;
  }
}

.tullys {
  font-family: '游ゴシック体', 'Yu Gothic', sans-serif;
  font-feature-settings: initial;
}

.tullys_mv {
  position: relative;
  max-width: 1280px;
  margin: 0 auto 128px;
}

@media screen and (max-width: 450px){
  .tullys_mv {
    padding-top: 108px;
    margin-bottom: 80px;
  }
}

.tullys_mv .mv-caption {
  display: block;
  line-height: 1.5;
  font-size: 14px;
  text-align: right;
  padding: 0 0 8px 0;
}

@media screen and (max-width: 450px){
  .tullys_mv .mv-caption {
    padding: 8px 20px 0 0;
    font-size: 10px;
  }
}

.tullys_mv ul {
  margin-top: 10px;
  text-align: right;
  font-size: 11px;
  line-height: 1.45;
}

.mv-title {
  position: absolute;
  left: 0;
  top: clamp(-50px, -4vw, 50px);
  color: #fff;
}

@media screen and (max-width: 450px){
  .mv-title {
    font-size: 16px;
    left: 20px;
    top: 49.5px;
  }
}

.mv-title span {
  display: inline-block;
  padding: 10px 20px;
  font-size: clamp(16px, 2.5vw, 36px);
  font-weight: bold;
  background: #012c0e;
  line-height: 1.38;
}

.mv-list-pc {
  display: block;
}

.mv-list-sp {
  display: none;
}

@media screen and (max-width: 450px){
  .mv-title span {
    padding: 10px 10px 8px;
    font-size: 16px;
  }

  .mv-list-pc {
    display: none;
  }

  .mv-list-sp {
    display: block;
  }
}

.mv-lead {
  max-width: 840px;
  margin: 40px auto 0;
  padding: 0 20px;
  line-height: 2;
  font-size: 16px;
}

@media screen and (max-width: 450px){
  .mv-lead {
    margin: 16px 0 20px;
    font-size: 14px;
  }
}

.tullys_mv-sub {
  position: relative;
  max-width: 1280px;
  margin: 0 auto 128px;
}

@media screen and (max-width: 450px){
  .tullys_mv-sub {
    margin-bottom: 80px;
  }
}

.mv-sub-title {
  margin-block-start: 80px;
  font-size: 24px;
  line-height: 2;
  text-align: center;
  padding: 0 20px;
  font-weight: bold;
  margin-block-end: 24px;
}

@media screen and (max-width: 450px){
  .mv-sub-title {
    margin-block-start: 40px;
    left: 30px;
    text-align: left;
    font-size: 18px;
    line-height: 1.8;
    margin-block-end: 16px;
  }

  .mv-sub-title span {
    padding: 10px 10px 8px;
    font-size: 15px;
  }
}

.mv-sub-description {
  max-width: 840px;
  margin: 0 auto;
  padding: 0 20px;
  font-size: 16px;
  line-height: 2;
}

@media screen and (max-width: 450px){
  .mv-sub-description {
    font-size: 14px;
  }
}

.tullys_mv-sub ul {
  margin-top: 10px;
  font-size: 11px;
  line-height: 1.45;
  text-align: right;
}

@media screen and (max-width: 450px){
  .tullys_mv-sub ul {
    margin: 10px 20px 0;
    text-align: right;
  }
}

.tullys_profile {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 40px;
  margin-bottom: 100px;
}

@media screen and (max-width: 450px){
  .tullys_profile {
    flex-direction: column-reverse;
    align-items: flex-start;
    padding: 0 20px;
    margin-bottom: 40px;
  }
}

.tullys_profile-text {
  max-width: 450px;
}

@media screen and (max-width: 450px){
  .tullys_profile-text {
  }
}

.tullys_profile-image {
  max-width: 580px;
}

@media screen and (max-width: 450px){
  .tullys_profile-image {
    margin-left: auto;
  }
}

.tullys_profile-text_desc {
  padding: 50px;
  background: #000;
  color: #fff;
  font-family: "Libre Baskerville", sans-serif;
}

@media screen and (max-width: 450px){
  .tullys_profile-text_desc {
    padding: 40px;
  }
}

.tullys_profile-text_title {
  margin-bottom: 12px;
  border-bottom: 1px solid #000;
  font-size: 16px;
  font-style: italic;
  font-family: "Libre Baskerville", sans-serif;
}

.tullys_profile-text_desc h3 {
  margin-bottom: 30px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.74;
}

@media screen and (max-width: 450px){
  .tullys_profile-text_desc h3 {
    font-size: 18px;
  }
}

.tullys_profile-text_desc div {
  margin-bottom: 30px;
  font-size: 20px;
  font-weight: bold;
}

@media screen and (max-width: 450px){
  .tullys_profile-text_desc div {
    font-size: 16px;
  }
}

.tullys_profile-text_desc div span {
  display: block;
  font-size: 14px;
  font-style: italic;
  color: #c1c1c1;
  padding-block-start: 16px;
}

@media screen and (max-width: 450px){
  .tullys_profile-text_desc div span {
    font-size: 11px;
  }
}

.tullys_profile-text_desc p {
  font-size: 14px;
  line-height: 2;
}

.label-title {
  position: absolute;
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  z-index: 2;
  white-space: nowrap;
}

.label-title:before {
  position: absolute;
  display: block;
  content: '';
}

.label-title span {
  display: inline-block;
  padding: 20px 20px 15px;
  background: #000;
}

@media screen and (max-width: 450px){
  .label-title {
    font-size: 15px;
  }

  .label-title span {
    padding: 10px 10px 8px;
  }
}

.tullys_q1 .label-title {
  top: 100px;
  right: 380px;
}

@media screen and (max-width: 450px){
  .tullys_q1 .label-title {
    top: 93vw;
    left: 20px;
    right: 0;
  }
}

.tullys_q1 .label-title:before {
  top: -40px;
  width: 56px;
  height: 58px;
  background: url('../images/q-1.svg') no-repeat center center/cover;
}

@media screen and (max-width: 450px){
  .tullys_q1 .label-title:before {
    top: -45px;
    width: 46px;
    height: 50px;
  }
}

.tullys_q2 .label-title:before {
  top: -36px;
  width: 56px;
  height: 53px;
  background: url('../images/q-2.svg') no-repeat center center/cover;
}

@media screen and (max-width: 450px){
  .tullys_q2 .label-title:before {
    top: -48px;
    width: 45px;
    height: 44px;
  }
}

.tullys_q3 .label-title:before {
  top: -34px;
  width: 48px;
  height: 42px;
  background: url('../images/q-3.svg') no-repeat center center/cover;
}

@media screen and (max-width: 450px){
  .tullys_q3 .label-title:before {
    top: -43px;
    width: 44px;
    height: 38px;
  }
}

.tullys_q4 .label-title:before {
  top: -34px;
  width: 49px;
  height: 42px;
  background: url('../images/q-4.svg') no-repeat center center/cover;
}


@media screen and (max-width: 450px){
  .tullys_q4 .label-title:before {
    top: -38px;
    width: 38px;
    height: 33px;
  }
}

.tullys_q2 .label-title {
  top: -130px;
  left: 0;
}

.tullys_q2 .label-title br:nth-of-type(2) {
  display: none;
}

.tullys_q2 .label-title span:nth-of-type(2){
  padding-right: 0;
}

.tullys_q2 .label-title span:nth-of-type(3){
  padding-left: 0;
}

@media screen and (max-width: 450px){
  .tullys_q2 .label-title {
    top: -90px;
  }

  .tullys_q2 .label-title br:nth-of-type(2) {
    display: block;
  }

  .tullys_q2 .label-title span:nth-of-type(2){
    padding-right: 10px;
  }

  .tullys_q2 .label-title span:nth-of-type(3){
    padding-left: 10px;
  }
}

.tullys_q3 .label-title {
  top: -230px;
  left: 0;
  white-space: nowrap;
}

.tullys_q3 .label-title br:nth-of-type(1) {
  display: none;
}

.tullys_q3 .label-title span:nth-of-type(1){
  padding-right: 0;
}

.tullys_q3 .label-title span:nth-of-type(2){
  padding-left: 0;
}

@media screen and (max-width: 450px){
  .tullys_q3 .label-title {
    top: -150px;
  }

  .tullys_q3 .label-title br:nth-of-type(1) {
    display: block;
  }

  .tullys_q3 .label-title span:nth-of-type(1){
    padding-right: 10px;
  }

  .tullys_q3 .label-title span:nth-of-type(2){
    padding-left: 10px;
  }
}

.tullys_q4 .label-title {
  top: -70px;
  left: 80px;
}

.tullys_q4 .label-title br:nth-of-type(1) {
  display: none;
}

.tullys_q4 .label-title br:nth-of-type(3) {
  display: none;
}

.tullys_q4 .label-title span:nth-of-type(1){
  padding-right: 0;
}

.tullys_q4 .label-title span:nth-of-type(2){
  padding-left: 0;
}

.tullys_q4 .label-title span:nth-of-type(3){
  padding-right: 0;
}

.tullys_q4 .label-title span:nth-of-type(4){
  padding-left: 0;
}

@media screen and (max-width: 450px){
  .tullys_q4 .label-title {
    top: -150px;
    left: 20px;
  }

  .tullys_q4 .label-title br:nth-of-type(1) {
    display: block;
  }

  .tullys_q4 .label-title br:nth-of-type(3) {
    display: block;
  }

  .tullys_q4 .label-title span:nth-of-type(1){
    padding-right: 10px;
  }

  .tullys_q4 .label-title span:nth-of-type(2){
    padding-left: 10px;
  }

  .tullys_q4 .label-title span:nth-of-type(3){
    padding-right: 10px;
  }

  .tullys_q4 .label-title span:nth-of-type(4){
    padding-left: 10px;
  }
}

.tullys_q1 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 40px;
  margin-bottom: 100px;
}

@media screen and (max-width: 450px){
  .tullys_q1 {
    padding: 0 20px;
    flex-direction: column;
    gap: 70px;
    margin-bottom: 220px;
  }
}

.tullys_q1-image {
  max-width: 640px;
}

.tullys_q1-text {
  max-width: 440px;
}

.tullys_q1-text h3 {
  margin-bottom: 40px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.74;
}


@media screen and (max-width: 450px){
  .tullys_q1-text h3 {
    margin-bottom: 20px;
    font-size: 18px;
    line-height: 1.83;
  }
}

.tullys_q1-text p {
  font-size: 16px;
  line-height: 1.94;
}

.tullys_q2 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  margin-bottom: 100px;
}

@media screen and (max-width: 450px){
  .tullys_q2 {
    margin-bottom: 240px;
    flex-direction: column;
    padding: 0 20px;
  }
}

.tullys_q2-image {
  position: relative;
  max-width: 640px;
}

.tullys_q2-image p {
  margin-top: 10px;
  font-size: 11px;
  text-align: right;
  line-height: 1.91;
}

.tullys_q2-text {
  position: relative;
  max-width: 440px;
  padding-top: 40px;
}

.tullys_q2-text h3 {
  margin-bottom: 40px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.74;
}

@media screen and (max-width: 450px){
  .tullys_q2-text h3 {
    margin-bottom: 20px;
    font-size: 18px;
  }
}

.tullys_q2-text p {
  font-size: 16px;
  line-height: 1.94;
}

.tullys_q3 {
  position: relative;
  max-width: 1120px;
  margin: 0 auto 210px;
}

@media screen and (max-width: 450px){
  .tullys_q3 {
    padding: 0 20px;
    margin-bottom: 220px;
  }
}

.tullys_q3-text {
  position: relative;
}

.tullys_q3-text h3 {
  margin-bottom: 40px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.74;
}

@media screen and (max-width: 450px){
  .tullys_q3-text h3 {
    margin-bottom: 20px;
    font-size: 18px;
  }
}

.tullys_q3-text p {
  font-size: 16px;
  line-height: 1.94;
}

.tullys_q4 {
  position: relative;
  max-width: 1280px;
  margin: 0 auto 100px;
}

.tullys_q4-desc {
  display: flex;
  justify-content: center;
  gap: 40px;
  margin-top: 50px;
}

@media screen and (max-width: 450px){
  .tullys_q4-desc {
    flex-direction: column;
    padding: 0 20px;
    gap: 20px;
  }
}

.tullys_q4-text {
  margin-top: -90px;
}

@media screen and (max-width: 450px){

  .tullys_q4-text {
    margin-top: -80px;
  }
}

.tullys_q4-area {
  display: grid;
  grid-template-columns: minmax(100px, 440px) minmax(200px, 640px);
  gap: 40px;
}

.tullys_q4-image {
  max-width: 640px;
  grid-column: 2 / 3;
  grid-row: 1 / 3;
}

.tullys_q4-area p:nth-of-type(1) {
  padding-top: 20px;
}

@media screen and (max-width: 450px){
  .tullys_q4-area {
    grid-template-columns: auto;
    grid-template-rows: auto;
  }

  .tullys_q4-image {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
  }
}

.tullys_q4-text h3 {
  margin-bottom: 10px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.74;
}

@media screen and (max-width: 450px){
  .tullys_q4-text h3 {
    margin-bottom: 20px;
    font-size: 18px;
  }
}

.tullys_q4-text p {
  font-size: 16px;
  line-height: 1.94;
}

.item-pickup {
  position: relative;
  max-width: 1280px;
  margin-inline: auto;
  padding: 60px 70px 100px;
  background: #000;
  box-sizing: border-box;
}

@media screen and (max-width: 450px){
  .item-pickup {
    padding: 40px 20px 80px;
  }
}

.item-pickup h2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 40px;
  margin-bottom: 60px;
  font-family: BerninoSans, sans-serif;
  font-size: 70px;
  font-weight: bold;
  font-style: italic;
  color: #555555;
  text-align: center;
}

@media screen and (max-width: 450px){
  .item-pickup h2 {
    margin-bottom: 40px;
    font-size: 31px;
    line-height: 0.68;
    letter-spacing: -0.62px;
  }
}

.item-pickup h2 span {
  display: block;
  font-family: '游ゴシック体', 'Yu Gothic', sans-serif;
  font-size: 23px;
  font-style: normal;
  color: #fff;
}

@media screen and (max-width: 450px){
  .item-pickup h2 span {
    font-size: 16px;
  }
}

.item-pickup ul {
  display: grid;
  grid-template-columns: repeat(3, 350px);
  gap: 45px;
  margin-bottom: 125px;
}

@media screen and (max-width: 450px){
  .item-pickup ul {
    grid-template-columns: auto;
    gap: 40px;
    margin-bottom: 100px;
  }
}

.item-pickup li span {
  display: block;
  margin-bottom: 40px;
  padding: 10px;
  background: #555;
  font-family: BerninoSans, sans-serif;
  font-size: 20px;
  font-weight: bold;
  font-style: italic;
  text-align: center;
  line-height: 1.05;
  letter-spacing: -0.4px;
  color: #fff;
}

@media screen and (max-width: 450px){
  .item-pickup li span {
    margin-bottom: 20px;
  }
}

.item-pickup li h3 {
  margin-bottom: 30px;
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  line-height: 1.75;
}

@media screen and (max-width: 450px){
  .item-pickup li h3 {
    margin-bottom: 20px;
  }
}

.item-pickup li p {
  font-size: 14px;
  line-height: 2.07;
  color: #fff;
}

.item-pickup li p small {
  font-size: 12px;
}

.brand {
  position: relative;
  max-width: 720px;
  margin-inline: auto;
  padding: 40px 50px;
  background: #555;
  box-sizing: border-box;
}

@media screen and (max-width: 450px){
  .brand {
    padding: 60px 20px 40px;
  }
}

@media screen and (max-width: 450px){
  .brand:before {
    top: 40px;
  }
}

.brand div {
  margin-bottom: 20px;
}

.brand p {
  font-size: 14px;
  line-height: 2.07;
  color: #fff;
}

.item-detail a {
  position: absolute;
  bottom: 260px;
  right: 0;
  display: flex;
  align-items: center;
  width: 336px;
  height: 80px;
  padding: 30px;
  background: #fff;
  box-sizing: border-box;
  font-size: 18px;
  font-weight: bold;
}

@media screen and (max-width: 450px){
  .item-detail a {
    bottom: 400px;
  }
}

.item-detail a:after {
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 80px;
  height: 16px;
  background: url('../images/arrow.svg') no-repeat center center/cover;
  content: '';
  transform: translateY(-50%);
}

.mv-sub-caption {
  font-size: 14px;
  text-align: right;
  line-height: 2;
  margin-block-start: 8px;
}

@media screen and (max-width: 450px){
  .mv-sub-caption {
    font-size: 10px;
    line-height: 1.6;
    padding: 0 20px;
  }
}

.tullys-section {
  padding: 0 20px;
}

.tullys-section-title {
  font-size: 24px;
  line-height: 2;
  font-weight: bold;
  text-align: center;
  margin-block-end: 40px;
}

@media screen and (max-width: 450px){
  .tullys-section-title {
    font-size: 18px;
    margin-block-end: 16px;
    line-height: 1.8;
    text-align: left;
  }
}

.tullys-section-content {
  max-width: 1280px;
  margin: 0 auto 40px;
  display: flex;
  align-items: flex-end;
  gap: 20px;
}

@media screen and (max-width: 450px){
  .tullys-section-content {
    flex-direction: column;
    gap: 8px;
  }
}

.tullys-section-content:nth-child(2) {
  flex-direction: row-reverse;
  margin: 0 auto 128px;
}

@media screen and (max-width: 450px){
  .tullys-section-content:nth-child(2) {
    flex-direction: column;
    margin-bottom: 80px;
  }
}

.tullys-section-content picture {
  max-width: 948px;
}

.tullys-section-content p {
  min-width: 200px;
  width: 200px;
  font-size: 14px;
  line-height: 2;
}

@media screen and (max-width: 450px){
  .tullys-section-content p {
    width: 100%;
    font-size: 10px;
  }
}

.tullys-section-02 {
  max-width: 1320px;
  margin: 0 auto 128px;
  display: flex;
  gap: 40px;
  padding: 0 20px;
}

@media screen and (max-width: 450px){
  .tullys-section-02 {
    flex-direction: column-reverse;
    margin-bottom: 80px;
  }
}

.tullys-section-02 picture {
  max-width: 640px;
  margin-block-end: 16px;
  display: block;
}

@media screen and (max-width: 450px){
  .tullys-section-02 picture {
    margin-block-end: 8px;
  }
}

.tullys-section-02 > p {
  max-width: 600px;
  line-height: 2;
  font-weight: 500;
}

@media screen and (max-width: 450px){
  .tullys-section-02 > p {
    margin-block-start: 0;
    font-size: 14px;
  }
}

.tullys-section-02_caption {
  font-size: 14px;
  font-weight: 500;
  line-height: 2;
}

span.tullys-section-02_caption {
  font-size: 12px;
  padding-top: 8px;
}

@media screen and (max-width: 450px){
  .tullys-section-02_caption {
    font-size: 10px;
    line-height: 1.6;
  }
}

.tullys-section-03 {
  max-width: 840px;
  padding: 0 20px;
  margin: 0 auto 128px;
  line-height: 2;
}

@media screen and (max-width: 450px){
  .tullys-section-03 {
    margin-bottom: 80px;
    font-size: 14px;
  }
}

.tullys_item {
  max-width: 1280px;
  margin: 0 auto 128px;
  padding: 112px 0;
  background-image: linear-gradient(to bottom, #004314, #00270c);
}

@media screen and (max-width: 450px){
  .tullys_item {
    padding: 80px 0;
    margin-bottom: 80px;
  }
}

.tullys_item h2 {
  color: #fff;
  text-align: center;
  font-size: 48px;
  line-height: 1.6;
  margin-bottom: 40px;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
}

.tullys_item h2 br {
  display: none;
}

@media screen and (max-width: 450px){
  .tullys_item h2 {
    font-size: 30px;
    margin-bottom: 24px;
  }
  .tullys_item h2 br {
    display: block;
  }
}

.tullys_item-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  padding: 0 clamp(10px ,7vw, 112px);
  gap: 40px;
  margin-bottom: 64px;
}

@media screen and (max-width: 450px){
  .tullys_item-list {
    grid-template-columns: auto;
    gap: 80px;
    padding: 0 20px;
    margin-bottom: 80px;
  }
}

.tullys_item-list li {
  display: grid;
  grid-template-rows: subgrid;
  align-content: flex-start;
  grid-row: span 5;
  color: #fff;
  gap: 0;
}

@media screen and (max-width: 450px){
  .tullys_item-list li {
    grid-template-rows: auto;
  }
}

.tullys_item-list li h3 {
  text-align: center;
  font-size: 22px;
  line-height: 1.6;
  font-weight: bold;
  margin-bottom: 8px;
}

@media screen and (max-width: 450px){
  .tullys_item-list li h3 {
    font-size: 16px;
    letter-spacing: -0.8px;
  }
}


.tullys_item-list li span {
  display: block;
  text-align: center;
  line-height: 1.6;
  margin-bottom: 24px;
  font-weight: bold;
}

.tullys_item-list li p {
  font-size: 16px;
  line-height: 2;
  margin-bottom: 24px;
}

@media screen and (max-width: 450px){
  .tullys_item-list li p {
    font-size: 14px;
  }
}

.tullys_item-list li a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 52px;
  background: #000;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}

@media screen and (max-width: 450px){
  .tullys_item-list li a {
    font-size: 14px;
  }
}

.tullys_item-list li a:hover {
  background: #fff;
  color: #000;
}

.tullys_item-logo {
  background: #000;
  margin: 0 clamp(10px ,7vw, 112px) 40px;
  text-align: center;
  padding: 32px 0;
}

@media screen and (max-width: 450px){
  .tullys_item-logo {
    margin-bottom: 24px;
  }
}

.tullys_item-logo ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
  margin-bottom: 16px;
}

@media screen and (max-width: 450px){
  .tullys_item-logo ul {
    gap: 16px;
  }

  .tullys_item-logo ul li {
    width: 76px;
  }

  .tullys_item-logo ul li:nth-of-type(3) {
    width: 103px;
  }
}

.tullys_item-logo .logo-link {
  display: inline-block;
  text-align: center;
  color: #fff;
  font-family: "poppins", sans-serif;
  font-style: italic;
  font-size: 14px;
  font-weight: 300;
}

.tullys_social-list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

@media screen and (max-width: 450px){
  .tullys_social-list {
    gap: 20px;
  }
}