/*****共通*****/
@font-face {
    font-family: 'aoharu-marker-mini';
    src: url('https://www.tabione.com/assets/css/fonts/aoharu-marker-mini.ttf') format('woff');
}

@font-face {
    font-family: 'meiryo';
    src: url('https://www.tabione.com/assets/css/fonts/MEIRYO.woff') format('woff2');
}

@font-face {
    font-family: 'MeiryoUI';
    src: url('https://www.tabione.com/assets/css/fonts/MEIRYO.woff') format('woff2');
}

.pc_only {
    display: block;
}

.sp_only {
    display: none;
}

.aoharu {
    font-family: 'aoharu-marker-mini';
}

.meiryo {
    font-family: 'meiryo', sans-serif;
}

.meiryoui {
    font-family: 'MeiryoUI';
}

.hina {
    font-family: 'Hina Mincho', serif;
}

a {
    text-decoration: none;
    color: #000;
}

a:hover {
    opacity: 0.7;
}

body {
    font-family: "Zen Kaku Gothic New", sans-serif;
    box-sizing: border-box;
}

.inner {
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
}

.section-ttl {
    margin-bottom: 80px;
}

.section-ttl h2 {
    position: relative;
    font-size: 60px;
    line-height: 1;
    width: fit-content;
    margin: 0 auto;
}

.section-ttl h2::before {
    content: attr(data-en);
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(224, 66, 114, 0.2);
    font-size: 70px;
    font-style: italic;
    width: 100vw;
    text-align: center;
}

.section-ttl h2::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #000;
    margin-top: 15px;
}

.section-ttl img {
    width: 13vw;
}

.description {
    text-align: center;
    font-size: 25px;
    font-weight: bold;
    margin-bottom: 80px;
    line-height: 1.2;
}

.description span {
    font-size: 2.5vw;
    color: #FB6A6A;
    -webkit-text-stroke-width: 0;
    -webkit-text-stroke-color: #FB6A6A;
    margin: 0 10px;
}

#thema,
#recommend,
#area,
#feature,
#about,
#contact {
    padding: 100px 0;
}
/*****renew2024*******/
.renew2024 .custom-select label:before {
    width: 0;
}
.renew2024 .custom-select label:after {
    width: 10px;
    height: 10px;
    right: 25px;
}
.renew2024 .custom-select select {
    width: 100%;
    padding: 0 0 0 10px;
    box-sizing: border-box;
}
.renew2024 .btn-primary {
    background: #dd5355;
    font-weight: bold;
}
.renew2024 .btn-primary,
.renew2024 .btn-primary-border {
    border: 3px solid #DD5355;
    box-sizing: border-box
}
.renew2024 .btn-primary-border {
    color: #fff;
}
.renew2024 .btn-secondary {
    background: #DD5355;
    display: inline-block;
    border-radius: 5px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    border: 3px solid #DD5355;
    color: #fff;
    box-sizing: border-box
}
.renew2024 .main-search-head {
    padding: 0 0 20px 0;
}

.renew2024 .main-search-wh-title {
    text-align: center;
}
.renew2024 .main-search-body {
    border: none;
    border: 0;
}
.renew2024 .main-search-row {
    padding: 5px 0;
}
.renew2024 .main-search-group {
    width: 100%;
}
.renew2024 .main-search-select {
    width: 100%;
    border-radius: 5px;
}
.renew2024 .main-search-select select {
    display: flex;
    align-items: center;
}
.renew2024 .main-search-input {
    width: 100%;
    padding: 10px;
    border-radius: 5px;
    background-color: #fff;
    border: 1px solid #bcbcbc;
}
.renew2024 .main-search-date {
    position: relative;
    background: #fff;
    padding: 0 20px 0 0;
    width: 100%;
    border: 1px solid #bcbcbc;
    height: 45px;
}

.renew2024 .main-search-date::after {
    content: '';
    width: 20px;
    height: 22px;
    background-image: url(/assets/images/new_top/calendar.png);
    background-size: cover;
    position: absolute;
    top: 50%;
    right: 5%;
    transform: translateY(-50%);
}
.renew2024 .main-search-date input {
    height: 42px;
    width: 105%;
    padding: 0 10px;
    text-align: left;
}
.renew2024 .main-search-btn button {
    width: 100%;
}
.renew2024 .main-search-row+.main-search-row {
    border: none;
}
.renew2024 .main-search-wh {
    display: block;
    position: static;
    background-color: rgba(255, 255, 255, .85);
    border-radius: 10px;
    padding: 30px 40px;
    width: 100%;
}
.renew2024 .main-search-wh .main-search-body,
.renew2024 .main-search-wh .main-search-head {
    width: 100%;
}
/*****mv*****/
#mv {
    position: relative;
    background-color: #F5F5F5;
    height: 78vh;
}

#mv .mv-slider {
    position: relative;
    width: 100%;
    margin-left: auto;
    height: 100%;
}

#mv .mv-slider img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#mv .mv-slider .slick-list,
#mv .mv-slider .slick-list .slick-track {
    height: 100% !important;
}

#mv .mv-slider .slide .tour-txt {
    width: 50%;
    position: absolute;
    top: 55%;
    right: 5%;
    padding: 15px 30px;
    background: rgba(0, 0, 0, .25);
    border-radius: 10px;
}

#mv .mv-slider .slide .tour-txt .place {
    display: flex;
    display: none;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    column-gap: 5px;
}

#mv .mv-slider .slide .tour-txt .place p {
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.5);
}

#mv .mv-slider .slide .tour-txt .tour-ttl h2 {
    font-size: 1.2vw;
    color: #fff;
    font-weight: 500;
    margin-bottom: 10px;
    line-height: 1.5;
    text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.5);
}

#mv .mv-slider .slide .tour-txt .tour-ttl h2 span {
    font-size: 2.5vw;
    font-weight: bold;
}

#mv .mv-slider .slide .tour-txt .tour-btn {
    width: fit-content;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    column-gap: 15px;
    margin-left: auto;
    text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.5);
    border-bottom: 2px solid #fff;
    padding: 7px 10px;
}

#mv .mv-slider .slide .tour-txt .tour-btn p {
    color: #fff;
    font-size: 18px;
    font-weight: 500;
}

#mv .mv-slider .slide .tour-txt svg {
    filter: drop-shadow(0 4px 4px rgba(0, 0, 0, .5));
}

/*ページネーション*/
#mv .mv-slider .slick-dots {
    width: fit-content;
    bottom: 3% !important;
    right: 22%;
}

#mv .mv-slider .slick-dots li {
    width: 70px;
}

#mv .mv-slider .slick-dots li button {
    width: 100%;
}

#mv .mv-slider .slick-dots li button:before {
    content: '' !important;
    width: 100%;
    height: 5px;
    background-color: #CCCCCC;
    opacity: 0.8;
}

#mv .mv-slider .slick-dots li.slick-active button:before {
    background-color: #fff;
    opacity: 1;
}

#mv .mv-slider .slick-next:before,
#mv .mv-slider .slick-prev:before {
    font-size: 30px !important;
    opacity: 1 !important;
}

/*arrowボタン*/
#mv .mv-slider .prev-arrow,
#mv .mv-slider .next-arrow {
    width: 1.5vw;
    height: auto;
    position: absolute;
    bottom: 5%;
    transform: translateY(-50%);
}

#mv .mv-slider .prev-arrow {
    right: 40%;
    z-index: 1;
}

#mv .mv-slider .next-arrow {
    right: 15%;
}

#mv .txt-area {
    width: fit-content;
    position: absolute;
    top: 50%;
    left: 3%;
    transform: translateY(-50%);
    z-index: 3;
    background-color: rgba(188, 188, 188, .75);
    padding: 30px;
    border-radius: 20px;
}

#mv .txt-area h1 {
    font-size: 1.5vw;
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1;
    color: #fff;
    margin-bottom: 25px;
    width: fit-content;
}

#mv .txt-area h1 .subttl {
    font-size: 16px;
    display: block;
    margin: 0.5em 0 1em;
}

#mv .txt-area h1 .hina {
    font-family: "Hina Mincho", serif;
    font-size: 3.1vw;
    line-height: 1;
}

#mv .txt-area .search-box {
    width: 65%;
    padding: 20px 30px;
    background-color: rgba(255, 255, 255, 0.85);
    text-align: center;
    font-size: 20px;
    font-weight: 500;
    border-radius: 10px;
}

/*****テーマ*****/

#thema .thema-inner {
    padding: 0 30px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 30px;
    margin-bottom: 80px;
}

#thema .thema-inner .thema-item {
    width: calc((100% - 60px) / 3);
    position: relative;
}

#thema .thema-inner .thema-item::after {
    content: '';
    width: 40%;
    height: 100%;
    background-color: #CFE4ED;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

#thema .thema-inner .thema-item:nth-child(2)::after {
    content: '';
    width: 40%;
    height: 100%;
    background-color: #FDEFCD;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

#thema .thema-inner .thema-item:last-of-type::after {
    content: '';
    width: 40%;
    height: 100%;
    background-color: #D4EBD0;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

#thema .thema-inner .thema-item .comment {
    padding: 20px 0 10px 0;
    font-size: 18px;
    font-weight: bold;
    color: #4B4B4B;
}

#thema .thema-inner .thema-item .img-wrap {
    width: 85%;
    position: relative;
}

#thema .thema-inner .thema-item .img-wrap img {
    width: 100%;
    height: auto;
}

#thema .thema-inner .thema-item .img-wrap .thema-name {
    font-size: 2vw;
    padding: 10px;
    background-color: #fff;
    position: absolute;
    top: 20%;
    right: 0;
    transform: translate(20%, -50%);
    line-height: 1;
}

#thema .thema-inner .thema-item .img-wrap .sub-ttl {
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translate(-5%, -20%);
}

#thema .thema-inner .thema-item .img-wrap .sub-ttl p {
    font-size: 18px;
    font-weight: 500;
    padding: 2px 15px;
    background-color: #fff;
    width: fit-content;
    margin-bottom: 10px;
}

#thema .thema-inner .thema-item .img-wrap .sub-ttl p:last-of-type {
    margin-bottom: 0;
}

#thema .keyword .key-ttl {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    column-gap: 10px;
    margin-bottom: 20px;
}

#thema .keyword .key-ttl h4 {
    font-size: 25px;
    font-weight: 500;
}

#thema .keyword .keyword-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

#thema .keyword .keyword-inner .keyword-item {
    width: fit-content;
    font-size: 18px;
    font-weight: bold;
    padding: 5px 15px;
    border: 2px solid #828282;
    box-sizing: border-box;
    border-radius: 25px;
    text-align: center;
}

#thema .keyword .keyword-inner .keyword-item:hover {
    border: 2px solid #FB6A6A;
    opacity: 0.7;
}

#thema .keyword .keyword-inner .keyword-item:hover a {
    color: #FB6A6A;
}

#thema .keyword .keyword-inner .keyword-item a {
    color: #828282;
}

/*****おすすめ*****/
#recommend {
    background-color: #CFE4ED;
}

#recommend .recommend-slider .slide {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    column-gap: 15px;
}

#recommend .recommend-slider .slick-list {
    overflow: visible !important;
}

#recommend .recommend-slider .slide .img-wrap,
#recommend .recommend-slider .slide .txt-wrap {
    position: relative;
    width: calc((100% - 15px) / 2);
}

#recommend .recommend-slider .slide .img-wrap {
    position: relative;
}

#recommend .recommend-slider .slide .img-wrap .thumbnail {
    position: absolute;
    top: 5%;
    left: 0;
    z-index: 1;
}

#recommend .recommend-slider .slide .img-wrap .thumbnail h3 {
    width: fit-content;
    font-size: 30px;
    padding: 5px;
    background-color: #fff;
    margin-bottom: 10px;
    line-height: 1.3;
}

#recommend .recommend-slider .slide .txt-wrap .recom-ttl {
    position: relative;
    width: fit-content;
    margin-bottom: 20px;
}

#recommend .recommend-slider .slide .txt-wrap .recom-ttl h2 {
    font-family: "Bonheur Royale", cursive;
    font-family: "Hina Mincho", serif;
    font-family: "Meiryo";
    font-size: 3vw;
    z-index: 5;
    line-height: 1;
}

#recommend .recommend-slider .slide .txt-wrap .recom-ttl .flag {
    position: absolute;
    top: -30%;
    right: -20%;
    width: 5vw;
    z-index: -1;
    object-fit: contain;
}

#recommend .recommend-slider .slide .txt-wrap .letter {
    position: relative;
    padding: 30px;
    background-color: #FFF9DA;
    margin-bottom: 15px;
}

#recommend .recommend-slider .slide .txt-wrap .letter:before {
    content: '';
    background-image: url(/assets/images/new_top/letter-tape.png);
    background-size: cover;
    width: 150px;
    height: 40px;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
}

#recommend .recommend-slider .slide .txt-wrap .ema {
    position: absolute;
    top: -3%;
    right: 0;
    z-index: -1;
}

#recommend .recommend-slider .slide .txt-wrap .ema img {
    width: 6vw;
    height: auto;
}

#recommend .recommend-slider .slide .txt-wrap .letter p {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
}

#recommend .recommend-slider .slide .txt-wrap .letter p span {
    color: #DC143C;
}

#recommend .recommend-slider .slide .txt-wrap .detail {
    padding: 20px;
    background-color: #fff;
}

#recommend .recommend-slider .slide .txt-wrap .detail .ttl {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px;
    line-height: 1.2;
}

#recommend .recommend-slider .slide .txt-wrap .detail .label {
    margin-bottom: 10px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    column-gap: 25px;
}

#recommend .recommend-slider .slide .txt-wrap .detail .label li {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    column-gap: 10px;
}

#recommend .recommend-slider .slide .txt-wrap .detail .label li span {
    font-size: 16px;
    font-weight: bold;
    line-height: 1;
}

#recommend .recommend-slider .slide .txt-wrap .detail .price {
    margin-bottom: 10px;
}

#recommend .recommend-slider .slide .txt-wrap .detail .price p {
    font-size: 30px;
    font-weight: bold;
    color: #DD5355;
    line-height: 1.2;
}

#recommend .recommend-slider .slide .txt-wrap .detail .price p span {
    font-size: 16px;
}

#recommend .recommend-slider .slide .txt-wrap .detail .hashtag {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

#recommend .recommend-slider .slide .txt-wrap .detail .hashtag li {
    font-size: 14px;
    font-weight: bold;
    line-height: 1;
}

#recommend .recommend-slider .slick-dots {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    column-gap: 30px;
    bottom: -5%;
}

#recommend .recommend-slider .slick-dots li.slick-active button:before {
    background-color: #fff;
    opacity: 1;
}

#recommend .recommend-slider .slick-dots li button:before {
    font-size: 18px;
    opacity: 1;
    border: 2px solid #fff;
    border-radius: 50%;
    color: rgba(0, 0, 0, 0);
}

#recommend .recommend-slider .prev-arrow,
#recommend .recommend-slider .next-arrow {
    width: 2vw;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 99;
}

#recommend .recommend-slider .prev-arrow {
    left: -5%;
}

#recommend .recommend-slider .next-arrow {
    right: -5%;
}

#recommend .recommend-slider .inner-slider.slick-slider {
    margin: 0;
}

#recommend .recommend-slider .inner-slider .inner-slide {
    position: relative;
    margin: 0;
}

#recommend .recommend-slider .inner-slider .slick-list {
    overflow: hidden !important;
}

#recommend .recommend-slider .inner-slider .slick-dots {
    display: block;
    width: fit-content;
    bottom: 1%;
    left: 1%;

}

#recommend .recommend-slider .inner-slider .slick-dots li {
    display: block;
    margin-bottom: 5px;
}

#recommend .recommend-slider .inner-slide .place {
    position: absolute;
    bottom: 5%;
    right: 0;
    padding: 0 20px;
    background-color: rgba(255, 255, 255, .7);
}

#recommend .recommend-slider .inner-slide .place p {
    font-size: 20px;
    line-height: 1.3;
}

/*****エリア*****/
#area .area-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 20px;
}

#area .area-inner .area-item {
    width: calc((100% - 40px) / 3);
    position: relative;
}

#area .area-inner .area-item .img-wrap {
    position: relative;
	overflow: visible;
}
.area-item .main-img {
    width: 100%;
    height: auto;
    display: block;
    -webkit-mask-image: url(https://www.tabione.com/assets/images/new_top/area_black.png);
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url(https://www.tabione.com/assets/images/new_top/area_black.png);
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
}
#area .area-inner .area-item .img-wrap .main-img {}

#area .area-inner .area-item .img-wrap .cover-img {
    content: '';
    width: 100%;
    height: auto;
    background-image: url(/assets/images/new_top/area_black.png);
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    opacity: 0.1;
}

#area .area-inner .area-item .over-txt {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    column-gap: 5px;
    position: absolute;
    top: 8%;
    left: 5%;
    z-index: 2;
	text-shadow: 1px 1px 4px #000000;
}

#area .area-inner .area-item .over-txt2 {
    display: flex;
    column-gap: 5px;
    position: absolute;
    top: 30%;
    left: 5%;
    z-index: 2;
}

#area .area-inner .area-item .over-txt h3,
#area .area-inner .area-item .over-txt2 h3 {
    font-size: 30px;
    font-weight: 500;
    color: #fff;
    line-height: 1.2;
}

#area .area-inner .area-item .over-txt p {
    font-size: 16px;
    font-weight: 500;
    color: #fff;
    line-height: 1.2;
}

/*****特集記事*****/
#feature {
    background-color: #FFF9DA;
}

#feature .feature-inner {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    column-gap: 26px;
    margin-bottom: 50px;
}

#feature .feature-inner .feature-item {
    width: calc((100% - 52px) / 3);
    position: relative;
}

#feature .feature-inner .feature-item img {
    width: 100%;
    margin-bottom: 5px;
}

#feature .feature-inner .feature-item .over-txt {
    border: 1px solid #fff;
    padding: 5px 10px;
    position: absolute;
    top: 5%;
    left: 5%;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
}

#feature .feature-inner .feature-item .txt-wrap {
    padding: 0 20px;
}

#feature .feature-inner .feature-item .txt-wrap .date {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.1em;
}

#feature .feature-inner .feature-item .txt-wrap .ttl {
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
}

.btn-wrap {
    display: flex;
    justify-content: flex-end;
}

.next-btn a {
    background: #DD5355;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-left: auto;
    max-width: 200px;
    padding: 10px 25px;
    color: #fff;
    transition: 0.3s ease-in-out;
    font-weight: 500;
    z-index: 0;
    border-radius: 5px;
    gap: 10px;
}

.next-btn a:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 0;
    display: block;
    background: #eee;
    transition: .3s;
    left: 0;
}

.next-btn a:hover {
    color: #313131;
}

.next-btn a:hover svg path {
    stroke: #313131 !important;
}

.next-btn a:hover:before {
    width: 100%;
    z-index: -1;
}

/*****about*****/
#about {
    text-align: center;
    position: relative;
}

#about .about-inner {
    padding: 100px 0 200px 0;
}

#about .about-inner h2 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 50px;
}

#about .about-inner h2 span {
    font-size: 40px;
    color: #FB6A6A;
}

#about .about-inner .txt {
    margin-bottom: 50px;
}

#about .about-inner .txt p {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
}

#about .bg {
    position: absolute;
    opacity: 0.5;
    z-index: -1;
}

#about .bg1 {
    top: 14%;
    left: 33%;
    width: 12vw;
}

#about .bg2 {
    top: 10%;
    left: 60%;
    width: 7vw;
}

#about .bg3 {
    top: 30%;
    left: 55%;
    width: 30vw;
}

#about .bg4 {
    top: 35%;
    left: 15%;
    width: 10vw;
}

#about .bg5 {
    top: 50%;
    left: 25%;
    width: 20vw;
}

#about .bg6 {
    top: 78%;
    right: 16%;
    width: 5vw;
}

/*****お問い合わせ*****/
#contact {
    background-color: #f5f5f5;
}

#contact .contact-item {
    position: relative;
    width: 100%;
    padding: 6rem 8rem 5rem 27rem;
    z-index: 1;
}

#contact .contact-item::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: 0;
    right: 0;
    background-color: #fff;
    border: 2px solid #000;
    border-radius: 15px;
    z-index: -1;
}

#contact .contact-item::after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: -9%;
    right: -3%;
    background-color: #d4ebd0;
    border: 2px solid #000;
    border-radius: 15px;
    z-index: -2;
}

#contact .contact-item .txt {
    width: 100%;
}

#contact .contact-item .txt .hina {
    font-size: 55px;
    line-height: 1.5;
}

#contact .contact-item .txt .sub {
    text-align: right;
    font-size: 18px;
    font-weight: 500;
}

#contact .contact-item .contact-btn {
    width: 100%;
    background: url(https://www.tabione.com/assets/images/new_top/sumaho.png);
    border-radius: 10px;
}

.contact-btn a {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    padding: 30px;
    background: rgba(221, 83, 85, .6);
    gap: 10px;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    margin: 20px 0 5px 0;
    border-radius: 10px;
}

#contact .contact-item .business-hour {
    color: #000;
    text-align: center;
}

#contact .contact-item .contact-img1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 15vw;
    transform: translate(0%, 30%) rotate(5deg);
}

#contact .contact-item .contact-img2 {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 15vw;
    transform: translate(-5%, -15%) rotate(-5deg);
}

@media screen and (max-width: 767px) {

    /*****共通*****/
    @font-face {
        font-family: 'aoharu-marker-mini';
        src: url('../fonts/aoharu-marker-mini.ttf') format('woff');
    }

    .pc_only {
        display: none;
    }

    .sp_only {
        display: block;
    }

    .search-box {
        display: none;
    }

    .inner {
        padding: 0 15px;
    }

    .section-ttl {
        margin-bottom: 50px;
    }

    .section-ttl h2 {
        font-size: 40px;
        line-height: 0.5;
    }

    .section-ttl h2::before {
        top: -20px;
        font-size: 40px;
    }

    .description {
        font-size: 18px;
        margin-bottom: 50px;
    }

    .description span {
        font-size: 35px;
    }

    #thema,
    #recommend,
    #area,
    #feature,
    #about,
    #contact {
        padding: 50px 0;
    }

    body {
        overflow: hidden;
    }
    /*****renew2024*****/
    .renew2024 .custom-select label:after {
        right: 20px;
    }
    .renew2024 {
        width: 90%;
        position: absolute;
        top: calc(80vh - 30px);
        left: 50%;
        transform: translateX(-50%);
    }

    .renew2024 .main-search-wh {
        padding: 10px;
        border: 1px solid #ccc;
        position: absolute;
        top: 600%;
        width: 100%;
    }
    .renew2024 .main-search-wh .main-search-body,
    .renew2024 .main-search-wh .main-search-head {
        padding: 10px;
    }
    .renew2024 .main-search-date input {
        font-size: 14px;
    }
    /*****mv*****/
    #mv {
        background-color: #F5F5F5;
        height: 80vh;
    }

    #mv .mv-slider {
        position: relative;
        width: 100%;
        /*padding-top: 80px;*/
    }

    #mv .mv-slider img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    #mv .mv-slider .slick-list,
    #mv .mv-slider .slick-list .slick-track {
        height: 100% !important;
    }

    #mv .mv-slider .slide .tour-txt {
        width: 100%;
        top: 40%;
        right: 0;
        padding: 20px;
        background-color: rgba(251, 106, 106, .7);
        border-radius: 0;
    }

    #mv .mv-slider .slide .tour-txt .place {
        margin-bottom: 5px;
    }

    #mv .mv-slider .slide .tour-txt .place p {
        font-size: 14px;
    }

    #mv .mv-slider .slide .tour-txt .tour-ttl h2 {
        font-size: 16px;
        text-shadow: none;
    }

    #mv .mv-slider .slide .tour-txt .tour-ttl h2 span {
        font-size: 18px;
        text-shadow: none;
    }

    #mv .mv-slider .slide .tour-txt .tour-btn {
        padding: 5px 10px;
        border-bottom: 1px solid #fff;
        text-shadow: none;
    }

    #mv .mv-slider .slide .tour-txt .tour-btn p {
        font-size: 14px;
    }

    /*ページネーション*/
    #mv .mv-slider .slick-dots {
        bottom: 10% !important;
        right: 50%;
        transform: translateX(50%);
    }

    #mv .mv-slider .slick-dots li {
        width: 50px;
    }

    #mv .mv-slider .slick-dots li button:before {
        height: 3px;
    }

    /*arrowボタン*/
    #mv .mv-slider .prev-arrow,
    #mv .mv-slider .next-arrow {
        width: 5vw;
        bottom: 13%;
    }

    #mv .mv-slider .prev-arrow {
        left: 15%;
    }

    #mv .mv-slider .next-arrow {
        right: 15%;
    }

    #mv .txt-area {
        top: 3%;
        left: 50%;
        transform: translateX(-50%);
        width: 100%;
        padding: 0 15px;
        background: none;
    }

    #mv .txt-area h1 {
        font-size: 20px;
        text-shadow: 0 0 5px #444444;
    }

    #mv .txt-area h1 .subttl {
        font-size: 14px;
    }

    #mv .txt-area h1 .hina {
        font-size: 30px;
        line-height: 1;
        -webkit-text-stroke-color: #fff;
        color: #fff;
        text-shadow: 0 3px 10px rgba(0, 0, 0, .5);
    }

    #mv .txt-area .search-box {
        width: 65%;
        padding: 20px 30px;
        background-color: rgba(255, 255, 255, 0.85);
        text-align: center;
        font-size: 20px;
        font-weight: 500;
        border-radius: 10px;
    }

    /*****テーマ*****/
    #thema {
        margin-top: 230px;
    }

    #thema .thema-inner {
        padding: 0 15px;
        display: block;
        margin-bottom: 50px;
    }

    #thema .thema-inner .thema-item {
        width: 100%;
        margin-bottom: 20px;
    }

    #thema .thema-inner .thema-item .comment {
        padding: 0;
        font-size: 14px;
    }

    #thema .thema-inner .thema-item .img-wrap {
        width: 85%;
        position: relative;
    }

    #thema .thema-inner .thema-item .img-wrap img {
        width: 100%;
        height: auto;
    }

    #thema .thema-inner .thema-item .img-wrap .thema-name {
        font-size: 25px;
        padding: 10px 20px;
        background-color: #fff;
        position: absolute;
        top: 15%;
        right: 0;
        transform: translate(20%, -50%);
    }

    #thema .thema-inner .thema-item .img-wrap .sub-ttl {
        position: absolute;
        left: 0;
        bottom: 0;
        transform: translate(-5%, -20%);
    }

    #thema .thema-inner .thema-item .img-wrap .sub-ttl p {
        font-size: 14px;
    }

    #thema .keyword .key-ttl {
        display: flex;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        column-gap: 10px;
        margin-bottom: 20px;
    }

    #thema .keyword .key-ttl h4 {
        font-size: 25px;
        font-weight: 500;
    }

    #thema .keyword .keyword-inner {
        justify-content: flex-start;
        column-gap: 5px;
        row-gap: 10px;
    }

    #thema .keyword .keyword-inner .keyword-item {
        font-size: 15px;
        padding: 5px 6px;
        border: 1px solid #828282;
        border-radius: 20px;
        line-height: 1.3;
    }

    /*****おすすめ*****/
    #recommend .recommend-slider .slide {
        display: block;
    }

    #recommend .recommend-slider .slide .img-wrap,
    #recommend .recommend-slider .slide .txt-wrap {
        width: 100%;
        margin-bottom: 20px;
    }

    #recommend .recommend-slider .slide .img-wrap img {
        aspect-ratio: 4 / 3;
        object-fit: cover;
    }

    #recommend .recommend-slider .slide .img-wrap .thumbnail {
        position: absolute;
        top: 5%;
        left: -1px;
        z-index: 1;
    }

    #recommend .recommend-slider .slide .img-wrap .thumbnail h3 {
        font-size: 22px;
    }

    #recommend .recommend-slider .slide .txt-wrap .recom-ttl {
        margin-bottom: 10px;
    }

    #recommend .recommend-slider .slide .txt-wrap .recom-ttl h2 {
        font-size: 11vw;
    }

    #recommend .recommend-slider .slide .txt-wrap .recom-ttl .flag {
        width: 15vw;
    }

    #recommend .recommend-slider .slide .txt-wrap .letter {
        padding: 15px 20px;
        display: none;
    }

    #recommend .recommend-slider .slide .txt-wrap .letter:before {
        width: 140px;
        height: 30px;
    }

    #recommend .recommend-slider .slide .txt-wrap .letter p {
        font-size: 16px;
    }

    #recommend .recommend-slider .slide .txt-wrap .ema {
        position: absolute;
        top: -2%;
    }

    #recommend .recommend-slider .slide .txt-wrap .ema img {
        width: 19vw;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail {
        padding: 20px 15px;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail .ttl {
        font-size: 16px;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail .label {
        flex-wrap: wrap;
        column-gap: 15px;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail .label li {
        column-gap: 5px;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail .label li span {
        font-size: 14px;
    }

    #recommend .recommend-slider .slide .txt-wrap .detail .price p {
        font-size: 25px;
    }

    #recommend .recommend-slider .slick-dots {
        column-gap: 15px;
        bottom: -3%;
    }

    #recommend .recommend-slider .slick-dots li button:before {
        font-size: 14px;
        width: 14px;
        height: 14px;
    }

    #recommend .recommend-slider .prev-arrow,
    #recommend .recommend-slider .next-arrow {
        width: 5vw;
        top: 100%;
        transform: translate(0%);
    }

    #recommend .recommend-slider .prev-arrow {
        left: 5%;
    }

    #recommend .recommend-slider .next-arrow {
        right: 5%;
    }

    #recommend .recommend-slider .inner-slider .inner-slide {
        position: relative;
        margin: 0;
    }

    #recommend .recommend-slider .inner-slider .slick-list {
        overflow: hidden !important;
    }

    #recommend .recommend-slider .inner-slider .slick-dots {
        display: flex;
        left: 50%;
        transform: translateX(-50%);
    }

    #recommend .recommend-slider .inner-slider .slick-dots li {
        display: block;
        margin: 0;
    }

    #recommend .recommend-slider .inner-slide .place {
        position: absolute;
        bottom: 15%;
        right: 0;
        background-color: rgba(255, 255, 255, .7);
    }

    #recommend .recommend-slider .inner-slide .place p {
        font-size: 16px;
    }

    /*****エリア*****/
    #area .area-inner {
        gap: 10px;
    }

    #area .area-inner .area-item {
        width: 100%;
    }

    #area .area-inner .area-item .over-txt2 {
        top: 25%;
    }

    #area .area-inner .area-item .over-txt h3,
    #area .area-inner .area-item .over-txt2 h3 {
        font-size: 25px;
    }

    #area .area-inner .area-item .over-txt p {
        font-size: 14px;
    }

    /*****特集記事*****/
    #feature {
        background-color: #FFF9DA;
    }

    #feature .feature-inner {
        display: block;
        margin-bottom: 30px;
    }

    #feature .feature-inner .feature-item {
        width: 100%;
        margin-bottom: 25px;
    }

    #feature .feature-inner .feature-item .over-txt {
        border: 1px solid #fff;
        padding: 5px 10px;
        position: absolute;
        top: 5%;
        left: 5%;
        color: #fff;
        font-size: 16px;
        font-weight: 500;
    }

    #feature .feature-inner .feature-item .txt-wrap {
        padding: 0 20px;
    }

    #feature .feature-inner .feature-item .txt-wrap .date {
        font-size: 15px;
        font-weight: 500;
        letter-spacing: 0.1em;
    }

    #feature .feature-inner .feature-item .txt-wrap .ttl {
        font-size: 16px;
        font-weight: 600;
    }

    .next-btn a {
        background: #DD5355;
        position: relative;
        display: flex;
        justify-content: space-around;
        align-items: center;
        margin-left: auto;
        max-width: 200px;
        font-size: 14px;
        padding: 5px 25px;
        color: #fff;
        transition: 0.3s ease-in-out;
        font-weight: 500;
        z-index: 0;
        border-radius: 5px;
    }

    .next-btn a:before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        width: 0;
        display: block;
        background: #eee;
        transition: .3s;
        left: 0;
    }

    .next-btn a:hover {
        color: #313131;
    }

    .next-btn a:hover svg path {
        stroke: #313131 !important;
    }

    .next-btn a:hover:before {
        width: 100%;
        z-index: -1;
    }

    /*****about*****/
    #about .about-inner {
        padding: 0;
    }

    #about .about-inner h2 {
        font-size: 18px;
    }

    #about .about-inner h2 span {
        font-size: 35px;
    }

    #about .about-inner .txt {
        margin-bottom: 30px;
    }

    #about .about-inner .txt p {
        font-size: 16px;
        margin-bottom: 0;
    }

    #about .bg {
        opacity: 0.3;
    }

    #about .bg1 {
        top: 10%;
        left: -25%;
        width: 50vw;
    }

    #about .bg2 {
        top: 12%;
        left: 55%;
        width: 15vw;
    }

    #about .bg3 {
        top: 27%;
        left: 70%;
        width: 25vw;
    }

    #about .bg4 {
        top: 35%;
        left: 15%;
        width: 35vw;
    }

    #about .bg5 {
        top: 60%;
        left: 5%;
        width: 15vw;
    }

    #about .bg6 {
        top: 55%;
        right: 0%;
        width: 50vw;
    }

    /*****お問合せ*****/
    #contact .contact-item {
        padding: 20px;
    }

    #contact .contact-item::after {
        bottom: -3%;
        right: -2%;
    }

    #contact .contact-item .txt .hina {
        font-size: 25px;
        text-align: center;
    }

    #contact .contact-item .txt .sub {
        font-size: 16px;
    }

    .contact-btn a {
        padding: 20px;
    }

    #contact .contact-item .business-hour {
        font-size: 16px;
    }
}