@charset "utf-8";

.floating {position: fixed; right: 20px; bottom: 100px; z-index: 16; transform: scale(0.8);}
.right_icon {margin-top: 10px; text-align: center; display: flex; justify-content: end;}
.right_icon a {position: relative; color: #fff; width: 100px; height: 100px; display: flex; align-items: center; justify-content: center; border-radius: 40%; box-shadow: 1px 1px 15px rgba(0, 0, 0, 0.1);}
.right_icon a > i {font-size: 30px; color:#fff;}
.right_icon a > span {font-size: 22px; font-weight:500; line-height:26px; color: #fff; display: none;}
.floating .icon .right_icon:last-child a > span {color:#3e2723; text-shadow:initial;}
.right_icon a:hover i, .right_icon a:hover img {display: none;}
.right_icon a:hover span {display: block;}
.right_icon a > img {width: 42px; height: 42px;}
.pc-tel a:hover {width: 220px !important; border-radius: 100px !important;}
.red-point {color:#c83a2a;}

#wrap-body {overflow: hidden; width: 100%;}
.header-wrap {width: clamp(1600px, 83.33%, 1800px); margin: 0 auto; display: grid; align-items: center;}
.logo {width: 270px; height: 46px; background-size: contain; background-repeat: no-repeat; background-image: url('../../images/header-logo.png');}
#header.follow-top .logo {background-image: url('../../images/header-logo2.png');}
.mobile-menu-icon {width: 32px; height: 32px; background-size: contain; background-repeat: no-repeat; background-image: url('../../images/m-menu-icon02.png');}
#header.follow-top .mobile-menu-icon {width: 32px; height: 32px; background-size: contain; background-repeat: no-repeat; background-image: url('../../images/m-menu-icon02_on.png');}
.right-top-menu {display: flex; align-items: center; gap: 20px;}
.mobile-menu-view {display: none;}
.header-wrap nav {width: 100%;}
.menu-body {/*position: absolute; transform: translate(-50%, -50%); left: 50%; top: 50%;*/ width: 100%; text-align: left; margin-top: 20px;}
.menu-body ul {/*display:flex;*/ margin-bottom:0;}
.menu-body ul li {margin-right: 4vw; display: inline-block;}
.menu-body a {font-size: clamp(20px, 1vw, 24px); color:#fff;}
.reg-button a > img {width: 24px; height: 24px;}
.reg-button {}
.reg-button a {display:flex; justify-content: center; gap:10px; font-size: clamp(15px, 0.6vw, 18px); color:#312125; align-items: center; background: #fff; padding: 12px 0; border-radius: 6px; width: clamp(125px, 6vw, 150px);}
.all-sitemap {width: 94px; height: 94px; background-color: #c53a28e3; display: flex; justify-content: center; align-items: center;}
.main-wrap {position: relative; width: 100%; height: 100vh; overflow: hidden;}
.visual-area {height: 100vh; width: 100%; position: relative;}
.main-wrap ul li::before {content:''; position: absolute; width: 100%; height: 100%; background: #000; opacity: 0.4; z-index: 2;}
.main-visual p {position: absolute; transform: translate(-50%, -50%); top: 40%; left: 50%; color: #fff; font-size: 70px; z-index: 2; text-align: center; width:100%;}
.main-visual p span {color: #fff; font-weight:500;}
.main-visual.img-01 {background-image: url('../../images/main-visual01.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.main-visual.img-02 {background-image: url('../../images/main-visual02.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.main-visual.img-03 {background-image: url('../../images/main-visual03.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.main-title .show1 {display: inline-block;}
.main-title .show2 {display: none;}
.down-scroll {position: absolute; transform: translateX(-50%); bottom: clamp(50px, 5vh, 100px); left: 50%; z-index: 2; animation: balloon 2.5s ease-in-out infinite;}
@keyframes balloon {
  0%, 100% {
    transform: translate(-50%, 0);
  }
  50% {
    transform: translate(-50%, 20px);
  }
 }
.text-dots {display: inline-flex; font-size: clamp(26px, 1vw, 32px); font-weight:700; color:#fff;}
.text-dots span {position: relative; display: inline-block; font-size: clamp(26px, 1vw, 32px); font-weight:700; color:#fff;}
.text-dots span::before {content: ""; position: absolute; top: -8px; left: 50%; transform: translateX(-50%); width: 5px; height: 5px; background-color: #fff; border-radius: 100%;}
.main-title-wrap {width: 100%; position: absolute; z-index: 10; transform: translate(-50%, -50%); left: 50%; top: 48%; display: flex; align-items: center; justify-content: space-between;}
.main-title-wrap .swiper-slide { display: flex; align-items: center; justify-content: space-between; --content-width: clamp(1360px, 64vw, 1920px); padding-left: max(0px, calc((100vw - var(--content-width)) / 2)); padding-right: max(0px, calc((100vw - var(--content-width)) / 2)); }
.main-title .small { font-size: clamp(22px, 1vw, 28px); font-weight:800; color:#fff; letter-spacing: 2px; }
.main-title .big {font-size: clamp(52px, 2.6vw, 76px); font-weight:700; color:#fff; line-height: clamp(72px, 3vw, 100px);}
.main-title .normal {font-size: clamp(22px, 1vw, 28px); font-weight:600; color:#fff; margin-top: clamp(10px, 3vw, 30px);}
.main-title-wrap .youtube {width: clamp(692px, 30vw, 900px); height: clamp(432px, 40vh, 500px); border-radius: 15px; overflow: hidden;}
.main-title .button {display: flex; gap: 10px; margin-top: clamp(25px, 4.5vw, 45px);}
.main-title .button a {display:flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight:600; color:#fff; border: 2px solid #ffff; padding: 12px 0; width: clamp(185px, 8vw, 220px);}
.main-contents-etc {width: clamp(1360px, 64vw, 1920px); margin: 150px auto 70px; position: relative; overflow: hidden; height: 100%;}
.common-head-wrap {display: flex; justify-content: space-between; align-items: end;}
.common-head-wrap .more {position: relative; margin-bottom: 20px;}
.head-text {}
.head-text h2 {font-size: clamp(40px, 2vw, 50px); font-weight:800;}
.head-text p {font-size: clamp(22px, 1vw, 28px); font-weight:600; margin-top: clamp(10px, 3vw, 30px);}
.common-head-wrap .more a {display:flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight:600; color:#fff; background: #518871; padding: 10px 0; width: clamp(180px, 8vw, 220px);}
.tour-list-wrap {position: relative; width: 100%; overflow: hidden;}
.tour-lst-left {position: absolute; top: 0; left: 270px; width: 1640px; overflow: hidden;}
.tour-list-hidden {position: relative; clip-path: inset(0 -9999px 0 -28px); width: clamp(1360px, 64vw, 1920px); margin: 0 auto;}
.tour-list-thum {width: clamp(360px, 15vw, 480px); height: clamp(320px, 14vw, 480px); border-radius: 15px; overflow: hidden; display:block;}
.tour-list-thum a {background-repeat: no-repeat; background-size: cover; background-position: 100% 100%; display: block; height: 100%; width: 100%;}
.tour-list-thum a::before {content:''; position: absolute; width: 100%; height: 100%; background: #000; opacity: 0.15; z-index: 2;}
.tour-list-thum a > span {font-size: 26px; font-weight: 600; color: #fff; position: absolute; bottom: 40px; left: 30px; z-index: 3; white-space: nowrap; overflow: hidden;text-overflow: ellipsis; width: clamp(250px, 12vw, 330px);}
.swiper-button-prev {background-image: url(../../images/prev-button.png); width: 64px; height: 64px; text-indent: -99999px; left: -30px !important;}
.swiper-button-next {background-image: url(../../images/next-button.png); width: 64px; height: 64px; text-indent: -99999px; right: -30px !important;}
.main-contents-banner {width: clamp(1600px, 83.33%, 1800px); margin: 180px auto; position: relative; overflow: hidden; height: 100%;}
.best-tour-wrap {background-image: url(../../images/best-tour-img.png); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%; width:100%; height: clamp(540px, 50vh, 720px); border-radius: 15px; overflow: hidden; position: relative;}
.best-ment {text-align: center; position: absolute; transform: translate(-50%, -50%); top: 50%; left: 50%; width: 100%;}
.best-ment .big {font-size: clamp(60px, 3vw, 80px); font-weight: 700; color: #fff;}
.best-ment .normal {font-size: clamp(40px, 2vw, 50px); font-weight:600; color:#fff; line-height: 30px;}
.best-ment .small {font-size: clamp(26px, 1vw, 30px); font-weight:600; color:#fff; padding: 25px 0 40px;}
.best-ment .small br {display:none;}
.best-ment a {display:flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight:600; background: #fff; color:#10182b; padding: 10px 0; width: clamp(180px, 8vw, 220px); margin:0 auto;}
.main-contents-etctour {position: relative; width: 100%; background-color: #f7f7f7; overflow: hidden; margin-top: 170px;}
.etc-tour-wrap { width: 100%;}
.etc-tour-list {position: relative; width: clamp(1360px, 64vw, 1920px); margin: 0 auto; display: flex; justify-content: space-between;}
.etc-tour-list.reverse {flex-direction: row-reverse;}
.etc-tour-ment-lay {width: 50%; height: clamp(440px, 40vh, 640px); position: relative;}
.etc-tour-bg {position: absolute; top: 0; background-repeat: no-repeat; background-size: cover; background-position: center center; width: 100%; height: clamp(440px, 40vh, 640px);}
.etc-tour-bg.bg-01 {right: -50%; background-image: url(../../images/etc_tour_img01.png);}
.etc-tour-bg.bg-02 {left: -50%; background-image: url(../../images/etc_tour_img02.png);}
.etc-tour-bg.bg-03 {right: -50%; background-image: url(../../images/etc_tour_img03.png);}
.etc-tour-bg.bg-04 {left: -50%; background-image: url(../../images/etc_tour_img04.png);}
.etc-tour-ment {position: absolute; transform: translateY(-50%); top: 50%;}
.etc-tour-ment.left {padding-left: 80px;}
.etc-tour-ment .big {font-size: clamp(40px, 2vw, 50px); font-weight:800;}
.etc-tour-ment .small {font-size: clamp(22px, 1vw, 28px); font-weight:600; margin-top: clamp(25px, 1.2vw, 45px);}
.etc-tour-ment a {display:flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight:600; border: 2px solid #10182b; color:#10182b; padding: 6px 0; width: clamp(185px, 8vw, 220px); margin-top: clamp(35px, 1.5vw, 45px);}
.main-contents-review {position: relative; width: 100%; overflow: hidden;}
.review-background {position: absolute; top: clamp(546px, 45vh, 720px); left: 0; width: 100%; height: 100%; background-image: url("../../images/review-bg.jpg"); background-position: center bottom; background-repeat: no-repeat; background-size: cover; background-attachment: fixed; z-index: -1;}
.review-wrap {width: clamp(1360px, 64vw, 1920px); margin: 180px auto; position: relative; z-index: 1; height: 100%;}
.review-head {font-size: clamp(40px, 2vw, 50px); font-weight: 800; color: #10182b; text-align:center; margin-bottom: 85px;}
.review-thumnail {background-position: center bottom; background-repeat: no-repeat; background-size: cover; width: 100%; height: clamp(186px, 15vh, 300px);}
.review-box {width: clamp(320px, 16vw, 480px); height: auto; background: #fff; box-sizing: border-box; border-radius: 15px; overflow: hidden;}
.review-info {padding:25px 25px 30px;}
.review-info .tour-list {background: #e8edf1; padding: 4px 15px; width: fit-content; border-radius: 100px; font-size: clamp(14px, 1vw, 16px); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: clamp(260px, 12vw, 330px);}
.review-info .customer-info {font-size: clamp(16px, 1vw, 20px); font-weight: 600; padding: 16px 0; margin: 0;}
.review-info .customer-info span {font-size: clamp(13px, 1vw, 15px); font-weight: 400; margin-left: 12px;}
.review-info .review-text {font-size: clamp(14px, 1vw, 17px); font-weight: 500; line-height:24px; white-space: normal; height: 75px; text-align: left; word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;}
.review-info a {font-size: clamp(12px, 1vw, 15px); font-weight: 500; color: #10182b; display: flex; gap: 10px; align-items: baseline;}
.review-more {margin-top:60px;}
.review-more a {display: flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight: 600; color: #fff; border: 2px solid #fff; padding: 6px 0; width: clamp(185px, 8vw, 220px); margin: 0 auto;}
.main-contents-map {position: relative; width: 100%; overflow: hidden;}
.contact-us-wrap {}
.contact-us-map {}
.contact-us-lay {width: 50%; height: clamp(440px, 40vh, 640px); position: relative;}
.google-map {width:50%; height: clamp(760px, 50vh, 960px);}
.google-map iframe {width: 100%; height: 100%;}
.office-info-wrap {width: clamp(1360px, 64vw, 1920px); margin: 0 auto; position: absolute; transform: translate(-50%, -50%); top: 50%; left: 50%; display: flex; flex-direction: row-reverse;}
.office-info-lay {width: clamp(680px, 35vw, 960px); padding-left: clamp(80px, 5vw, 120px);}
.booking-info-title {font-size: clamp(40px, 2vw, 50px); font-weight:800; display: flex; align-items: center; gap: 15px; margin-bottom: 20px;}
.booking-info-detail {background: #f7f7f7; border-radius: 15px; padding: 20px 15px; margin-bottom: 35px;}
.booking-info-detail p {font-size: clamp(18px, 1vw, 20px); letter-spacing: -0.5px; position: relative; padding-left: 20px; }
.booking-info-detail p > a > img {width: 110px;}
.booking-info-detail p::before {content: "ㆍ"; position: absolute; color: #000; font-size: 26px; top: -7px; left: 0;}
.booking-info-detail .another::before {top: -2px;}
.office-info-info {display: grid; margin: 0; gap: 15px;}
.office-info-info li { font-size: clamp(20px, 1vw, 22px); font-weight:700; display: flex; align-items: center; gap: 10px;}
.sns-list {display: flex; align-items: center; gap: 40px; margin-top:18px;}
.sns-list li {position: relative;}
.sns-list li::before {content: ""; position: absolute; top: 0; left: -20px; height: 100%; width: 1px; background-color: #ddd;}
.sns-list li:first-child::before {content: initial;}
.sns-list li > a > img {width: 85px;}
.copy-warp {width: clamp(1600px, 83.33%, 1800px); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; height: 85px;}
.copy-warp .company-info {font-size: clamp(13px, 1vw, 15px); font-weight: 400; color:#fff;}
.copy-warp .copyright a {font-size: clamp(13px, 1vw, 15px); font-weight: 400; color:#fff;}
.copy-logo {position: absolute; transform: translate(-50%, -50%); top: 50%; left: 50%; display: flex; gap: 20px; align-items: center;}
.copy-logo img:nth-child(3) { width: 170px; }
.copy-logo img:nth-child(1) { width: 200px; }
.follow-top {background-color: #fff; position: fixed !important; top: 0 !important; padding: 15px 0; z-index: 3000 !important; border-bottom: 1px solid rgb(0 0 0 / 20%) !important;}
.follow-top .menu-body a {color: #10182b;}
.follow-top .reg-button a {border: 1px solid #c9c9c9;}
.logo-body { display: flex; gap: 30px; align-items: center; }
.logo-body a img {content: url('../../images/header-logo.png'); transition: content 0.3s;}
#header.follow-top .logo-body a img {content: url('../../images/header-logo2.png');}
.sub-visual-area {height: clamp(500px, 50vh, 800px); width: 100%; position: relative;}
.sub-visual-area::before {content:''; position: absolute; width: 100%; height: 100%; background: #000; opacity: 0.4; z-index: 2;}
.sub-visual.img-01 {background-image: url('../../images/sub-visual01.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.sub-title-wrap {width: clamp(1360px, 64vw, 1920px); position: absolute; z-index: 10; transform: translate(-50%, -50%); left: 50%; top: 57%; text-align: center;}
.sub-title .small {font-size: clamp(22px, 1vw, 28px); font-weight:600; color:#fff;}
.sub-title .big {font-size: clamp(60px, 3vw, 80px); font-weight:700; color:#fff; line-height: clamp(75px, 4vw, 100px);}
.tour-info-wrap {margin-top: clamp(50px, 5vh, 100px); position: relative; width: 100%; display: flex; gap: clamp(60px, 3vw, 100px);}
.sub-content-wrap {width: clamp(1360px, 64vw, 1920px); position: relative; margin:100px auto;}
.sub-head-text {font-size: clamp(40px, 2vw, 50px); font-weight:800; margin: 0;}
.tour-thumnail-wrap {width: clamp(670px, 30vw, 1000px); height: clamp(670px, 30vw, 1000px); position: relative;}
.tour-thumnail {overflow:hidden; border-radius: 15px; height:100%;}
.tour-thumnail ul > li {background-repeat: no-repeat; background-size: cover; background-position: 100% 100%; height: 100%;}
.tour-info-layout {width: 100%; position: relative;}
.tour-icons {display: flex; gap: 5px; align-items: center;}
.tour-sub-info-title {font-size: clamp(20px, 1vw, 22px); font-weight:700; letter-spacing:-0.5px; position: relative; padding-left: 18px; margin-top: 20px;}
.tour-sub-info-title::before {content: ""; position: absolute; width: 8px; height: 8px; background-color: #c0c5c9; border-radius: 100%; top: 7px; left: 0;}
.tour-detail-box {margin: 0 0 30px; border-bottom: 1px solid #ddd;}
.tour-detail-info {border-top: 1px solid #ddd; padding-top: 20px; margin-top:15px;}
.tour-detail-info li > dl {display: flex; gap: 5px; }
.tour-detail-info li > dl > dd {display: flex; align-items: start; gap: 8px; line-height: 24px; font-size: clamp(16px, 1vw, 18px); word-break: break-all;}
.tour-detail-info li > dl > dd:nth-child(1) {width: 160px;}
.tour-detail-info li > dl > dd:nth-child(2) {width: calc(100% - 160px);}
.tour-detail-info li > dl > dd > img {width: 24px; height: 24px; object-fit: contain;}
.people-price {}
.people-price .people {font-size: clamp(20px, 1vw, 22px); font-weight:600; margin-right: 10px;}
.people-price .price {font-size: clamp(40px, 2vw, 50px); font-weight:800;}
.etc-price-info {background: #f7f7f7; border-radius: 15px; margin-top:20px; padding: 20px; font-size: clamp(20px, 1vw, 22px); font-weight:600;}
.tour-detail-wrap {width: 100%; position: relative;}
.detail-info-layout h2 {margin: 80px 0 50px; font-size: clamp(34px, 1vw, 40px); font-weight:800; border-bottom: 2px solid #10182b; padding-bottom: 24px;}
.detail-info-youtube {border-radius: 15px; position: relative; width: 100%; padding-bottom: 56.25%; height: 0; margin-bottom:65px; overflow: hidden;}
.detail-info-youtube iframe {position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; border: 0;}
.general-text-style {font-size: clamp(20px, 1vw, 26px); font-weight:500; width: calc(100% - clamp(320px, 10vw, 480px)); width: calc(100% - clamp(320px, 10vw, 480px)); line-height: clamp(32px, 2vw, 48px);}
.general-text-style.another {width:100% !important;}
.info-half-box {display: flex; align-items: start; border-bottom: 1px solid #ddd; padding-bottom:60px;}
.info-half-box:nth-child(n+2) {margin-top:60px;}
.info-half-title {font-size: clamp(28px, 1vw, 34px); font-weight:800; display: flex; align-items: center; gap: 10px; width: clamp(320px, 10vw, 480px);}
.go-to-list a {display:flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight:600; border: 2px solid #10182b; color:#10182b; padding: 6px 0; width: clamp(185px, 8vw, 220px); margin: 90px auto 100px;}
.select-custom {position: relative; width: 180px; height: 40px;}
.select-custom select {appearance: none; -webkit-appearance: none; -moz-appearance: none; background: transparent; border: 1px solid #000; border-radius: 6px; padding: 8px 15px; width: 100%; cursor: pointer; font-size: clamp(15px, 1vw, 18px); font-weight:400;}
.select-custom::after {content: ''; position: absolute; right: 15px; top: 54%; transform: translateY(-50%); width: 18px; height: 18px; background: url('../../images/up-down-icon.png') no-repeat center center; background-size: contain; pointer-events: none;}
.tour-list-option {display: flex; justify-content: space-between; align-items: baseline;}
.tour-list-option ul {display: flex; gap:50px; margin: 50px 0;}
.tour-list-option ul > li {font-size: clamp(22px, 1vw, 26px); font-weight:500;}
.tour-list-option ul > li > a {color: #6d7782;}
.tour-list-option ul > li > a.on {color: #ff000a; font-weight:600;}
.tour-list-option ul > li > a:hover {color: #ff000a;}
.tour-list-thumnail {background-position: center center; background-repeat: no-repeat; background-size: cover; width: clamp(320px, 15vw, 480px); height: clamp(186px, 15vh, 300px); margin: 0; border-top-right-radius: 15px; border-top-left-radius: 15px;}
.tour-list-box {width: clamp(320px, 15vw, 480px); height: auto; background: #fff; box-sizing: border-box; overflow: hidden;}
.tour-list-page-wrap {display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(30px, 2vw, 50px) clamp(26px, 1.3vw, 40px);}
.tour-shorts-info {border: 1px solid #ddd; border-bottom-right-radius: 15px; border-bottom-left-radius: 15px; padding: 25px 25px 30px;}
.tour-shorts-info div, .tour-shorts-info p {white-space: nowrap; overflow: hidden;text-overflow: ellipsis; width: clamp(270px, 14vw, 400px);}
.tour-shorts-region  {font-size: clamp(13px, 1vw, 16px); font-weight:500; }
.tour-shorts-subject {font-size: clamp(24px, 1vw, 28px); font-weight:700; margin-bottom: 12px;}
.tour-shorts-text {font-size: clamp(14px, 1vw, 17px); font-weight:400; margin: 0;}
.tour-shorts-price {font-size: clamp(20px, 1vw, 24px); font-weight:700; margin: 25px 0 5px; height: 30px;}
.paging-wrap {text-align: center; margin-top: 60px;}
.sub-visual.img-02 {background-image: url('../../images/sub-visual02.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.sub-head-text span {font-weight:800; color:#518871;}
.sub-head-text.border-line {border-bottom: 2px solid #10182b; padding-bottom: 35px; margin: 0;}
.review-list-wrap {position: relative; margin: 60px 0;}
.review-list-lay {display: flex; gap: clamp(50px, 2vw, 80px); border-bottom: 1px solid #ddd; padding-bottom: 60px;}
.review-list-thum {width: clamp(350px, 18vw, 500px); height: clamp(270px, 14vw, 400px); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%; border-radius: 15px; overflow: hidden;}
.review-list-shorts {width: calc(100% - (clamp(50px, 2vw, 80px) + clamp(350px, 18vw, 500px))); position: relative;}
.how-review-write {font-size: clamp(24px, 1vw, 28px); font-weight:700; margin-bottom: 25px;}
.how-review-write span {font-size: clamp(18px, 1vw, 20px); padding-left: 20px; color:#515151;}
.play-tour-list {display: flex;}
.play-tour-list li {width:25%; display: flex; align-items: center;}
.play-tour-list li > a > img {width: clamp(50px, 3vw, 60px); height: clamp(50px, 3vw, 60px); margin-right: 10px; border-radius: 6px;}
.play-tour-list li a {color:#10182b; font-size: clamp(18px, 1vw, 20px); font-weight: 600; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; width: 95%; display: block;}
.play-tour-last {font-size: clamp(28px, 1vw, 34px); font-weight:800;}
.how-trip {font-size: clamp(16px, 1vw, 20px); line-height: clamp(28px, 1.6vw, 40px); white-space: normal; height: clamp(85px, 5vw, 150px); text-align: left; word-wrap: break-word; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;}
.learn-more {font-size: clamp(12px, 1vw, 18px); font-weight: 500; color: #10182b; display: flex; gap: 10px; align-items: center; position: absolute; bottom: 0; left: 0;}
.learn-more:hover {color:#ff000a;}
.writer-info {display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid #ddd; height: 60px;}
.writer-name {font-size: clamp(24px, 1vw, 28px); font-weight:700;  padding-left: 20px;}
.count-icon {padding-right:20px;}
.count-icon ul li {font-size: clamp(15px, 1vw, 17px); padding-left: 8px;}
.count-icon ul {display: flex; gap: 30px; margin:0;}
.review-prev-warp {width: clamp(816px, 42vw, 1000px); position: relative; margin: 0 auto;}
.review-prev-wrap {width: 100%; position: relative; margin-top: 60px;}
.review-prev-photo {overflow: hidden; border-radius: 15px; height: clamp(670px, 30vw, 900px);}
.review-prev-photo ul > li {background-repeat: no-repeat; background-size: cover; background-position: 100% 100%; height: 100%;}
.play-tour-layout {border-bottom: 1px solid #ddd; padding-bottom: 40px;}
.tour-head-tit {font-size: clamp(16px, 1vw, 18px); font-weight:500; margin: 30px 0 20px;}
.tour-head-tit img {padding-right: 10px;}
.play-tour-list.views {display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 1vw, 30px);}
.play-tour-list.views li {width: 100%; display: flex; align-items: center;}
.how-trip-story {margin-top:40px; border-bottom: 1px solid #ddd; padding-bottom: 100px;}
.general-text-style2 {font-size: clamp(15px, 1vw, 18px); font-weight: 400; line-height: 30px;}
.review-go-to-list a {display: flex; justify-content: center; align-items: center; border-radius: 6px; font-size: clamp(22px, 1vw, 28px); font-weight: 600; border: 2px solid #10182b; color: #10182b; padding: 6px 0; width: clamp(185px, 8vw, 220px); margin: 60px auto 100px;}
.sub-visual.img-03 {background-image: url('../../images/sub-visual03.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.hello-text {font-size: clamp(16px, 1vw, 19px); font-weight: 400; line-height: clamp(34px, 1.6vw, 50px); width: clamp(730px, 40vw, 830px);}
.company-wrap {display: flex; justify-content: space-between;}
.company-img img {margin-top: 60px; border-radius: 15px; overflow: hidden; width: 100%;}
.three-promise {display: flex; justify-content: space-between; margin: 60px 0 0;}
.three-promise li {width: 30%;}
.promise-wrap {border-bottom: 1px solid #ddd; padding-bottom: 100px;}
.three-promise .title {margin: 35px 0 30px; font-size: clamp(28px, 1vw, 34px); font-weight:800;}
.three-promise .ment {font-size: clamp(20px, 1vw, 26px); font-weight: 500;}
.three-promise .icon img {height: 80px; object-fit: contain;}
.contact-us-contents {display: flex; justify-content: space-between; align-items: center; margin-top: 100px; border-bottom: 1px solid #ddd; padding-bottom: 100px; gap: clamp(50px, 2vw, 80px);}
.contact-us-body {width:40%;}
.contact-us-info {display: grid; gap: 20px; margin-bottom: 35px;}
.contact-us-info li {display: flex; align-items: baseline;}
.contact-us-info li > h2 > img {position: relative; top: 3px;}
.contact-us-info li > p {font-size: clamp(16px, 1vw, 19px); font-weight: 400; padding-left:12px;}
.contact-tit {font-size: clamp(28px, 1vw, 34px); font-weight:800; margin-bottom: 40px;}
.contact-ment {font-size: clamp(16px, 1vw, 19px); font-weight: 400; margin-bottom: 30px;}
.company-map-info {width: calc(100% - 40%); height: clamp(435px, 17vw, 800px); border-radius: 15px; overflow: hidden;}
.company-map-info iframe {width: 100%; height: 100%;}
.activity-booking-wrap {margin-top: 100px;}
.activity-booking-wrap {letter-spacing: 0;}

.ellipsis {
  white-space: nowrap;      /* 줄바꿈 없이 한 줄로 표시 */
  overflow: hidden;         /* 초과 내용 숨기기 */
  text-overflow: ellipsis;  /* 오버플로우된 텍스트를 말줄임표로 표시 */
}

.menuwrap {position: fixed; top: 0; right: -400px; width: 340px; height: 100%; background-color: #fff; transition: right 0.3s ease; z-index: 3004;}
.menu-logo img {width: 200px;}
.menuwrap.on {right: 0;}
.overlay {position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); z-index: 3002; display: none;}
.overlay.on {display: block;}
.menu-style {display: grid; gap: 40px; z-index: 2; position: relative;}
.menu-style li > a {font-size: 20px; color: #10182b; font-weight: 500; display: flex; align-items: center; justify-content: space-between; transition: color 0.6s ease}
.menu-style li > a:hover {color:#fe5d5d;}
.closed {position: absolute; top: 50%; left: -45px; height: 90px; width: 90px; background: #fff; border-radius: 100%; display: flex; align-items: center; justify-content: center; transform: translateY(-50%);}
.closed i {color: #10182b; font-size: 32px;}
.left-copyright {text-align: center; position: absolute; bottom: 10px; transform: translateX(-50%); left: 50%; width: 100%;}
.left-copyright a {color: #7d7d7d; }
.m-menu-height {position: relative; height: 700px; overflow: auto;}
.m-menu-wrap {width: 100%; height: 100%; overflow: auto;}
.menu-logo {position: absolute; top: 90px; left: 50px;}
.menu-style {position: absolute; transform: translateY(-50%); top: 55%; left: 50px;}

.tour-guide-wrap {width: clamp(1360px, 64vw, 1920px); margin: 180px auto 0; position: relative; height: 100%;}
.tip-title {font-size: clamp(40px, 2vw, 50px); font-weight: 800; text-align: center; margin-bottom: 80px;}
.guide-box {}
.guide-box-wrap {display: flex; justify-content: space-between; gap:30px;}
.guide-box-icon {background: #518871; width: 60px; height: 60px; display: flex; border-radius: 6px; justify-content: center; align-items: center; margin-left: 30px; position: relative; z-index: 2;}
.guide-box-icon img {width:46px; height:46px;}
.guide-ment-box {background: #ffffff; border-radius: 15px; padding: 70px 30px 40px; box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.05); position: relative; top: -30px; z-index: 1;}
.guide-ment-box h3 {font-size: clamp(20px, 1vw, 24px); font-weight: 700; margin-bottom: 25px; height: 30px;}
.guide-ment-box p {font-size: clamp(16px, 1vw, 19px); font-weight: 500; line-height: 28px; margin-bottom: 40px; height:90px;}
.guide-ment-box a {font-size: 16px; color: #10182b; align-items: center; gap: 15px;  display: flex; align-items: center; font-weight: 600;}
.guide-ment-box a .arrow {width: 30px; height: 30px; border: 1px solid #626278; border-radius: 100%; display: flex; align-items: center; justify-content: center;}

.main-contents-rhb {position: relative; width: 100%; overflow: hidden; background: #fff; z-index: 4;}
.collabo-wrap {width: clamp(1360px, 64vw, 1920px); margin: 180px auto 0; position: relative; z-index: 1; height: 100%;}
.collabo-info {display: flex; justify-content: space-between; margin-bottom: 80px;}
.collabo-logo {width: 50%; display: flex; justify-content: center; text-align: center; align-items: center; gap: 0;}
.collabo-logo ul {margin-bottom: 0; display: grid; gap: 20px;}
.collabo-ment {width: 50%; border-left: 1px solid #ebebeb; padding-left: 40px;}
.collabo-ment a {font-size: clamp(20px, 1vw, 24px); color: #10182b; font-weight: 500; display: inline-block; border-bottom: 1px solid #10182b; padding-bottom: 0px;}
.collabo-ment h2 {font-size: clamp(40px, 2vw, 50px); font-weight: 800;}
.collabo-ment h2 span {font-weight: 800; background: #518871; color:#fff;}
.collabo-ment p {font-size: clamp(22px, 1vw, 28px); font-weight: 600;}
.collabo-ment ul li {font-size: clamp(22px, 1vw, 28px); font-weight: 600; line-height:40px;}
.collabo-ment ul li span {background: #518871; width: 26px; height: 26px; display: inline-block; text-align: center; line-height: 26px; border-radius: 100%; margin-right: 10px; color: #fff; font-weight: 600;}
.collabo-photo a {display: block; position: relative;}
.collabo-photo {display: flex; justify-content: space-between; gap: 26px;}
.photos-lay {width: 50%; height: 590px; display: grid; gap: 26px;}
.photos-another01 {height: 284px;}
.photos-another02 {display: flex; gap: 26px;}
.photos-another02 div {width:50%; height: 280px;}
.photos-lay a h2 {font-size: clamp(26px, 1vw, 32px); font-weight:700; color:#fff; text-transform: uppercase; position: absolute; bottom: 70px; left: 40px;}
.photos-lay a p {font-size: clamp(16px, 1vw, 18px); font-weight:500; color:#fff; position: absolute; bottom: 30px; left: 40px;}
.sub-nav {display: flex; align-items: end; gap: 50px;}
.sub-nav a {text-align:center; font-size: clamp(20px, 1vw, 24px); color:#10182b; font-weight:700; line-height:32px; padding-bottom: 8px;}
.sub-nav a.on {color:#518871; display: inline-block; border-bottom: 3px solid #518871; padding-bottom: 5px;}
.step-info-wrap {display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(80px, 5.33vw, 100px) clamp(80px, 5.33vw, 100px); margin-top: 80px;}
.step-info-lay {}
.step-photo {margin-bottom: 30px; width: 100%;}
.step-photo img {border-radius: 15px; overflow: hidden; object-fit: cover; width: 100%;}
.step-tit {font-size: 26px; font-weight:800; margin-bottom: 20px;}
.step-tit span {color:#518871; font-weight:800;}
.step-ment {font-size: 20px; font-weight:600; letter-spacing:-0.5px;}
.step-ment .more-text {font-size: 20px; font-weight: 600; letter-spacing: -0.5px;}
.step-ment .more-text span:nth-child(1) {display: inline-block; width: 6%; vertical-align: top;}
.step-ment .more-text span:nth-child(2) {display: inline-block; width: 94%; vertical-align: top;}

.sub-visual.img-04 {background-image: url('../../images/sub-visual04.jpg'); background-repeat: no-repeat; background-size: cover; background-position: 100% 100%;}
.common-tip-wrap { margin-top: 80px; }
.common-tip-lay { display: flex; justify-content: space-between; }
.common-tip-tit { width: 32%; font-size: clamp(30px, 1.1vw, 36px); font-weight:800; line-height: 42px; }
.common-tip-info { width: 68%; }
.common-tip-img { border-radius: 15px; overflow: hidden; margin-bottom: 60px; }
.common-tip-img img { width: 100%; }
.common-tip-ment .subject { font-size: clamp(26px, 1vw, 30px); font-weight:700; margin-bottom: 25px; line-height: 36px; }
.common-tip-ment .subject span { font-weight:700; color:#518871; }
.common-tip-ment .tip { font-size: clamp(22px, 1vw, 28px); font-weight:600; line-height: 36px; margin-bottom: 60px; }
.common-tip-ment .tip span { font-weight:600; color:#518871; }

.pc-none {display: none;}
.copy-banner-wrap {background-size: cover; background-repeat: no-repeat; background-position: center bottom; background-image: url(../../images/copy-banner-img.jpg); width: 100%;}
.copy-banner-img {text-align: center; padding: 80px 0 70px;}

.youtube-play-btn {display: flex; justify-content: center; margin-top: 80px; color: #10182b;}
.youtube-play-btn a {font-size: 20px; font-weight: 600; display: flex; gap: 10px; align-items: center; justify-content: center; border: 2px solid #141414; width: 250px; border-radius: 10px; padding: 10px 0; color: #10182b;}
.youtube-play-btn img {width:50px;}

.layer-pop {display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.9); justify-content: center; align-items: center; z-index: 9999;}
.layer-pop-content {position: fixed; transform: translate(-50%, -50%); top: 50%; left: 50%; width: 90%; height: auto;}
.close-layer-pop {margin: 15px 0; width: 100px; padding: 5px 10px; background-color: #333; color: white; border: none; border-radius: 3px; cursor: pointer;}
.close-layer-pop.etc-style {background-color: #fff; border: 1px solid #000; color: #000;}
.privacy-box {margin: 60px; text-align: center;}
.privacy-contents iframe {height: 85vh;}

.int-pagination { display: flex; position: absolute; z-index: 14; align-items: center; gap: 20px; transform: translate(-50%, -50%); bottom: clamp(135px, 16vh, 260px); left: 50%; }
.int-button-prev { display: flex; align-items: center; gap: 20px; }
.int-button-next { display: flex; align-items: center; gap: 20px; }
.int-button-prev.swiper-button-disabled, .int-button-next.swiper-button-disabled { opacity: 0.6; }
.int-button-prev span, .int-button-next span { font-size: clamp(20px, 1vw, 24px); font-weight: 700; color: #fff; }
.int-swiper-pagination { width: 90px; text-align: center; }
.int-swiper-pagination, .int-swiper-pagination span { font-size: clamp(20px, 1vw, 24px); font-weight: 700; color: #fff; }

.int-hmr-mtit .text-dots span { position: relative; display: inline-block; font-size: clamp(30px, 1vw, 32px); font-weight:700; color:#fff; }
.int-hmr-mtit .text-dots span::before { content: initial; position: absolute; top: -3px; left: 50%; transform: translateX(-50%); width: 5px; height: 5px; background-color: #fff; border-radius: 100%; }
.int-hmr-mtit.main-title .big { font-size: clamp(56px, 3vw, 80px); font-weight:700; color:#fff; line-height: clamp(75px, 4vw, 100px); letter-spacing: -1px; }
.int-hmr-mtit.main-title .big span { font-size: clamp(50px, 2.6vw, 76px); font-weight: 700; color: #fff; }
.int-hmr-mtit .main-tit-dots { display: inline-flex; font-size: clamp(56px, 3vw, 80px); font-weight:700; color:#fff; line-height: clamp(75px, 4vw, 100px); letter-spacing: -1px; }
.int-hmr-mtit .main-tit-dots span { position: relative; display: inline-block; font-size: clamp(56px, 3vw, 80px); font-weight:700; color: #ffbaba !important; }
.int-hmr-mtit .main-tit-dots span::before { content: ''; position: absolute; top: -5px; left: 50%; transform: translateX(-50%); width: 7px; height: 7px; background-color: #ffbaba !important; border-radius: 100%; }
.int-hmr-mtit.main-title .normal { font-size: clamp(25px, 1vw, 28px); font-weight:600; color:#fff; margin-top: clamp(10px, 3vw, 30px); line-height: 36px; }
.collabo-logo li:nth-child(1) { display: flex; gap: 30px; align-items: center; justify-content: center; }
.int-rhb-logo1 { width: 250px; }
.int-rhb-logo2 { width: 210px; }

.int-sns-pop.layer-pop-content { position: fixed; transform: translate(-50%, -50%); top: 50%; left: 50%; width: 644px; height: auto; }
.int-sns-pop.close-layer-pop { background-color: #fff; border: none; color: #000; margin: 0; border-radius: 0; width: 60px; height: 60px; padding: 0; position: absolute; top: 14px; right: 20px; }

.int-sns-icon { margin-bottom: 45px; }
.int-sns-icon img { width: 108px; }
.int-sns-box h2 { font-size: 30px; font-weight: 500; text-align: center; margin-bottom: 18px; }
.int-sns-box p { font-size: 24px; font-weight: 500; margin-bottom: 52px; }
.int-sns-box { background: #fff; padding: 50px 0 90px; border-radius: 15px; height: 450px; text-align: center; position: relative; }
.int-sns-go { display: flex; justify-content: center; }
.int-sns-go a { width: 130px; height: 50px; display: flex; justify-content: center; align-items: center; font-size: 20px; font-weight: 600; border-radius: 10px; color: #fff; }
.int-sns-go a:nth-child(1) { background: #ec8c8c; }
.int-sns-go a:nth-child(2) { background: #518871; }

.integration-header { display: flex;  align-items: center; justify-content: space-between; width: 100%; }
.int-logo01 { width: 228px; height: 39px; background-size: contain; background-repeat: no-repeat; background-image: url('../../images/header-logo.png'); }
#header.follow-top .int-logo01 { width: 170px;  height: 30px; background-image: url('../../images/header-logo2.png'); }
.int-logo02 { width: 264px; height: 34px; background-size: contain; background-repeat: no-repeat; background-image: url('../../images/hmr-logo.png'); }
#header.follow-top .int-logo02 { width: 200px; height: 26px; }
#header.follow-top .menu-body { margin-top: 6px; }

.int-left-logo { top: 50px; left: 50px; }
.int-left-logo img { width: 220px; }