@charset "UTF-8";

/*----------------------------------
フィジーツアー2026　メイン画像
---------------------------------- */
html,body {overflow-x: hidden;}

.swiper-wrap {
  margin: 0 calc(50% - 50vw);
  max-width: 100vw;
  position: fixed;
  overflow: hidden;
  z-index: -10;
  outline: 1px solid transparent;
}

@keyframes zoom-in {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img{
  animation: zoom-in 10s linear 0s 1 normal both;  
}
.slide-img img {
  object-fit: cover;
  height: 100vh;
  width: 100vw;
}

.copy_shadow {
  filter: drop-shadow(0 10px 20px rgba(0, 0, 0, .9));
}

/*----------------------------------
世界大会
---------------------------------- */
.conference {
  text-align: center;
}

.conference h1 {
  color: #fff;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
  font-size: 27px;
  line-height: 1.35;
  padding-top: calc(50vh - 15px);
  padding-bottom: 10px;
}
.conference h1 span {font-size: 22px;}

.conference_date {
  display: inline-block;
  background: #000;
  border-radius: 20px;
  color: #fff;
  font-size: 17px;
  padding: 5px 15px;
  border: 2px #ccc solid;
}

.conference_info {
  width: 90%;
  max-width: 640px;
  margin: 30px auto 70px;
  background: #fff;
  opacity: 0.85;
}

.conference_info p {
  padding: 60px 50px;
  font-size: 14px;
  text-align: justify;
  line-height: 2;
  opacity: 1.0;
  color: #000;
}

.loop01 {
  padding: 0;
  display: flex;
  overflow: hidden;
}
.loop01_box {
  padding: 0;
  display: flex;
  align-items: center;
  animation: loop-list 50s linear infinite;
}
.loop01_item img {padding: 0;}

@keyframes loop-list {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

.conference_area {
  width: 90%;
  margin: 50px auto;
  background: #fff;
  padding: 25px 5%;
}

.conference_area h2 {
  font-size: 13px;
  letter-spacing: -0.05em;
  line-height: 1.2;
  padding-bottom: 8px;
  margin: 60px 0 8px 0;
  border-bottom: 1px #ccc solid;
}
.conference_area h2 span {
  font-family: Roboto, "Helvetica Neue", HelveticaNeue, Verdana, Meiryo, sans-serif;
  font-size: 25px;
}

.conference_area table {
  font-size: 0.85rem;
  margin: 30px auto 0;
}

.conference_area th {font-size: 20px; padding: 15px 10px;}
.conference_area td {padding: 15px 15px;}
.conference_area .table_mark {font-size: 16px; text-align: center;}
.conference_area .table_bg {border-top: 1px #ccc solid; border-bottom: 1px #ccc solid;}

.speaker {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 0;
}
.speaker li {
  width: 31.5%;
  font-size: 0.8rem;
  line-height: 1.3;
  margin: 5px 0 15px 0;
}
.speaker li h3 {font-size: 13px; line-height: 1.25; letter-spacing: -0.02em; margin-bottom: 12px;}
.speaker li h3 span {
  font-family: Roboto, "Helvetica Neue", HelveticaNeue, Verdana, Meiryo, sans-serif;
  font-size: 18px;
}
.speaker li .speaker_photo {background: #399; text-align: right; margin-bottom: 10px;}
.speaker li .speaker_photo img {margin-right: 10%;}
.speaker li .speaker_title {font-size: 0.83rem; font-weight: bold; padding-top: 5px;}

.youtube {
  width: 100%;
  max-width: 800px;
  height: auto;
  max-height: 450px;
  margin: 50px auto 30px;
}

.youtube_mov {
  width: 100%;
  max-width: 800px;
  height: auto;
  max-height: 450px;
  aspect-ratio: 16 / 9;
}

@media (min-width: 769px) {
  .conference h1 {font-size: 30px;}
  .conference h1 span {font-size: 23.5px;}
  .conference_area {width: 85%; padding: 25px 6.5% 50px 6.5%;}
}

@media (max-width: 768px) {
  .conference_area table {width: 90%; margin: 15px auto 0;}
  .conference_area th, .conference_area td {
    display: inline-block;
    width: 100%;
    float: left;
  }
  .conference_area th {padding: 15px 0 0 0;}
  .conference_area td {padding: 15px 0;}
  .conference_area .table_mark {padding: 0;}
  
  .speaker li {width: 48%;}
}

/*----------------------------------
フィジーツアー
---------------------------------- */
.tour {
  width: 92%;
  margin-left: 8%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  height: 90vh;
}

.tour_info {
  width: 515px;
  margin: 350px auto auto 0;
}
.tour_copy {
  background: #fff;
  opacity: 0.85;
  font-size: 14px;
}

.tour_copy .tour_copy_text {
  padding: 50px 35px 25px 35px;
  text-align: justify;
  line-height: 2;
  opacity: 1.0;
  color: #000;
}

.tour_copy dl {
  padding: 0 35px 30px 35px;
  display: flex;
  flex-wrap: wrap;
  opacity: 1.0;
  color: #000;
  font-size: 15px;
  font-weight: bold;
}
.tour_copy dt {width: 45%;}
.tour_copy dd {width: 55%;}
.tour_copy dt, .tour_copy dd {padding: 10px 0; border-bottom: 1px #999 dotted;}
.tour_copy_cap {font-size: 13px; padding: 10px 0 0 0;}

.tour_photo {
  position: relative;
  width: 700px;
  max-width: 700px;
  height: auto;
  max-height: 500px;
  margin: auto 0 0 auto;
}
.tour_photo img {width: 100%; height: auto;}

/*------ swiper ナビゲーション ------ */
.swiper .swiper-button-next,.swiper .swiper-button-prev {
  background-color: #3cf;
  width: 35px;
  height: 35px;
  opacity: 0.9;
}
.swiper .swiper-button-next {
  right: 0;/* ボタンを右端にくっつける */
}
.swiper .swiper-button-prev {
  left: 0;/* ボタンを左端にくっつける */
}
.swiper .swiper-button-next::after {
  content: '→';/* ボタンの矢印変更 */
  color: #fff;
  font-size: 1.5rem;
}
.swiper .swiper-button-prev::after {
  content: '←';/* ボタンの矢印変更 */
  color: #fff;
  font-size: 1.5rem;
}

.swiper .swiper-pagination {
  position: absolute;
  bottom: -50px;
}
.swiper .swiper-pagination-bullet-active {background-color: #666;}

.swiper .swiper-pagination-bullet {
  height: 16px;
  width: 16px;
  border: 1px #fff solid;
  background-color: #ccc;
  opacity: 1.0;
}
.swiper .swiper-pagination-bullet-active {background-color: #3cf; border: 2px #3cf solid;}


.tour_photo h2 {font-size: 1.0rem; text-align: center; line-height: 1.5;}


.tour h1 {
  color: #fff;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
  font-size: 27px;
  line-height: 1.35;
  padding-bottom: 10px;
}

.tour_area {
  width: 90%;
  max-width: 1240px;
  margin: 80px auto 50px;
  background: #fff;
  padding: 25px 5%;
  font-size: 15px;
}

.tour_area h2 {
  font-size: 16px;
  letter-spacing: -0.05em;
  line-height: 1.2;
  padding: 25px 0 20px 0;
  text-align: center;
}

.tour_date {
  width: 90%;
  border: 1px #ccc solid;
  font-size: 16px;
  padding: 15px 8%;
  margin: 0 auto 10px;
  box-sizing: border-box;
}

.tour_date > h3 {
  font-size: 21px;
  display: inline-block;
  padding-right: 50px;
}

.tour_area .tour_date_txt {width: 90%; margin: 15px auto;}

.tour_area > h3 {font-size: 17px; padding: 50px 0 20px 0;}

.hotel {
  display: flex;
  justify-content: space-between;
}

.hotel_photo {
  width: 55%;
  max-width: 530px;
}
.hotel_photo h4 {font-size: 20px; padding-bottom: 8px;}
.hotel_photo img {width: 100%; height: auto;}

.swiper-photo {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  outline: 1px solid transparent;
}

.hotel_info {
  width: 42%;
  font-size: 0.9rem;
  padding: 25px 0 0 0;
  color: #000;
}
.hotel_price {font-size: 0.95rem; font-weight: bold; line-height: 1.3; padding-top: 7px; color: #164A8E;}
.hotel_cap {font-size: 0.8rem; padding: 10px 0 25px 0;}

.option {
  width: 100%;
  border: 1px #ccc solid;
  font-size: 0.9rem;
  padding: 25px 5%;
  margin: 0 auto 10px;
  box-sizing: border-box;
}
.option > h3 {font-size: 20px; padding-bottom: 15px;}
.option_txt {width: 65%; margin-left: 35%;}
.option_txt p {font-size: 0.97rem; padding-bottom: 10px;}

.btn_entry {
  width: 480px;
  margin: 35px auto 15px;
  background: #1aadcf;
  border-radius: 27px;
  font-size: 20px;
  padding: 13px 0;
  text-align: center;
  color: #fff;
}
.btn_faq {
  width: 480px;
  margin: 60px auto 35px;
  background: #666;
  border-radius: 27px;
  font-size: 14px;
  padding: 13px 0;
  text-align: center;
  color: #fff;
}
.btn_entry:hover, .btn_faq:hover {opacity: 0.8;}

.faq_wrap {
  display: flex;
  justify-content: space-between;
  line-height: 1.6;
}
.faq h4 {font-size: 18px; padding: 40px 0 15px 0;}
.faq span {padding-right: 7px;}
.faq {width: 48%;}
.faq dt {font-size: 1.0rem; font-weight: bold; color: #164A8E; padding: 14px 0 7px 0; border-top: 1px #999 dotted;}
.faq dd {font-size: 0.88rem; padding: 0 0 14px 0; color: #000;}


@media (max-width: 768px) {
  .tour {
    width: 100%;
    margin: 0 auto;
    display: block;
    height: auto;
  }
  .tour_info {width: 90%; max-width: 515px; margin: 0 auto 50px;}
  .tour_info h1 {text-align: center; padding-top: 50vh;}
  .tour_photo {width: 100%;}
  
  .hotel {display: block;}
  .hotel_photo {width: 100%;}
  .hotel_info {width: 100%;}
  
  .option > h3 {font-size: 18px;}
  .option_txt {width: 90%; margin-left: 10%;}
  
  .btn_entry {width: 90%;}
  .btn_faq {width: 90%;}
  
  .faq_wrap {display: block;}
  .faq {width: 100%;}
  .faq dt {font-size: 0.97rem;}
}

@media (max-width: 1080px) {
  .tour {
    width: 100%;
    margin: 0 auto;
    display: block;
    height: auto;
  }
  .tour_info {width: 90%; max-width: 515px; margin: 0 auto 50px;}
  .tour_info h1 {text-align: center; padding-top: 50vh;}
  .tour_photo {width: 100%; max-width: 700px; margin: 0 auto;}
}


/*----------------------------------
スケジュール部分
---------------------------------- */
:root {
            --blue-accent: #00add8;
            --green-accent: #8bc34a;
            --pink-accent: #e96fa4;
            --bg-dark: #4d4d4d;
            --border-color: #ccc;
        }

.schedule_wrap {overflow-x: auto; white-space: nowrap;}

.schedule-container {
            display: flex;
            max-width: 980px;
   min-width: 630px;
            margin: 50px auto 0;
            background: #fff;
            border-bottom: 1px #999 dotted;
  overflow: auto;
    width: 100%;
  border-collapse: inherit;
        }

        /* 左側：日付カラム */
        .dates-column {
            width: 80px;
            flex-shrink: 0;
        }

        /* 中央：会議内容カラム */
        .content-column {
            flex-grow: 1;
            position: relative;
        }
.content-column .row {border-left: 1px #999 solid;}

        .column-header {
            height: 50px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
          font-size: 1.1rem;
        }

        /* 旅行プランカラム共通 */
        .plan-column {
            width: 180px;
            margin-left: 10px;
            border-radius: 10px 10px 0 0;
            overflow: hidden;
            color: #fff;
            font-size: 0.85rem;
            line-height: 1.3;
        }

        .plan-header {
            height: 50px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            font-size: 1rem;
        }

        .plan-body {
            background-color: #555;
            flex-grow: 1;
            padding: 0;
        }
.plan-body-blue {border-left: 3px #1aadcf solid; border-right: 3px #1aadcf solid;}
.plan-body-green {border-left: 3px #86c044 solid; border-right: 3px #86c044 solid;}

        /* 各行の高さ設定 */
        .row {
            display: flex;
            align-items: center;
            border-top: 1px #999 dotted;
            box-sizing: border-box;
        }
        .row {height: 80px;}

        .date-cell {
            width: 100%;
            text-align: center;
            font-size: 1.05rem;
          font-weight: bold;
        }

        /* 会議詳細の枠 */
        .event-box {
            margin: 10px 0 10px 10px;
            padding: 10px 10px;
            border: 2px solid #ccc;
            background: #fff;
            font-size: 0.83rem;
            line-height: 1.4;
            width: 100%;
            z-index: 2;
          box-sizing: border-box;
        }
.event-box dl {display: flex; flex-wrap: wrap;}
.event-box dt {width: 25%;}
.event-box dd {width: 75%;}

        /* 旅行プラン内の各セル */
        .plan-cell {
            height: 80px;
            padding: 5px 10px;
            box-sizing: border-box;
            border-top: 1px #ccc dotted;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }
.row02 {height: 95px;}

        .time-text { font-weight: bold; margin-bottom: 1px; }
        
        /* ピンクのフリータイム */
        .free-time {
            background-color: #e96ea4;
            margin: 2px 0;
            height: 60px;
        }

        /* 凡例 */
        .legend {
            max-width: 980px;
            margin: 20px auto;
            display: flex;
            justify-content: flex-end;
            align-items: center;
            font-size: 0.85rem;
        }
        .legend-color {
            width: 60px;
            height: 20px;
            background-color: #e96ea4;
            margin-right: 10px;
        }

.br_hyo {display: none;}

@media (max-width: 768px) {
  .content-column {width: 60%;}
  .event-box {width: 100%;}
  .plan-column {width: 130px;}
  .row, .plan-cell {height: 65px;}
  .row02 {height: 110px;}
}

@media (max-width: 965px) {
  .schedule-container {width: 630px;}
  .dates-column {width: auto; padding-right: 10px;}
  .date-cell {font-size: 0.98rem;}
  .br_hyo {display: block;}
  .event-box dt {width: 30%;}
  .event-box dd {width: 70%;}
}