/*
Theme Name:seeed_tcd105-child_test
Theme URI:
Description:WordPressテーマ「seeed_tcd105」の自作子テーマです。
Template:seeed_tcd105
Author:rush
Author URI:https://tcd-theme.com/
Version:0.0.1
*/
button,input,select{
/*font-family: "Noto Sans JP",Arial, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;*/
font-family:'Noto Sans JP',Arial,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro","Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
#header_logo a .logo_text {
    font-weight: 600;
}
h2.catch.rich_font,
.choose .ttl_tour{
/*
font-family: "toppan-bunkyu-midashi-go-std", sans-serif;
font-weight: 900;
*/
/*    font-family:"ruika", sans-serif;*/
/*    font-family: Helvetica, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
font-family:'Noto Sans JP',Arial,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",Arial, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
font-weight: 700 !important;
font-style: normal !important;
position: relative;
font-size: 34px !important;
}
.sp_content .main_content .catch{
/*    font-family:"ruika", sans-serif;*/
/*    font-family: Helvetica, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
font-family:'Noto Sans JP',Arial,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",Arial, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
font-weight: 500 !important;
font-style: normal !important;
}
#news_ticker h2.catch.rich_font{
    text-align: center;
    margin-bottom:35px
}
.sp_content .overlay {
    display: block;
}
section#cb_content_4 {
    margin-top: 60px;
}
/*
h2.catch.rich_font:before {
  content: '';
  position: absolute;
  bottom: -15px;
  display: inline-block;
  width: 60px;
  height: 5px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: var(--main_color_dark);
  border-radius: 2px;
}
*/
.header-w {
    max-width: 1030px;
    margin: 0 auto;
    position: relative;
    height: 80px;
}
#header_logo a .logo_text{
/*font-family: "logo-cut-std","ruika",sans-serif;*/
	font-family: "Noto Sans JP",Arial, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
font-weight: 100;
    font-style: normal;
}
#header {
    z-index: 2;
    position: sticky;
top: 0;
    left: 0;
    width: 100%;
    height: 80px;
/*    background: none;*/
    border-radius: 0px;
    transition: width 0.25s ease;
/*    color: #fff;*/
}
#header_slider {
    height: 100vh;
/*    height: 85vh;*/
/*    height: 32vh;*/
}
#container {
/*    全画面用*/
    margin-top: 0px;
}
#header_slider_wrap {
  width: 100%;
/*    height: 32vh;*/
    height: 100vh;
}
body.open_header #header {
    box-shadow: 0 0 10px 1px rgba(0,0,0,0.2);
    background: #fff;
    color: #565656;
  position: fixed !important;
}

body #header #global_menu > ul > li > a{
 color: #565656; 
    line-height: 120%;
    padding-top: 20px;
    font-size: 14px;
    padding: 20px 20px 0 5px;
 font-weight: normal;
/*    font-weight: bold;*/
}
body #header #global_menu > ul > li > a span{
    display: block;
    font-size: 12px;
}
body.open_header #header #global_menu > ul > li > a{
    color: #565656;
    font-size: 14px;
/*    font-weight: bold;*/
    font-weight: normal;
}
body #header #global_menu > ul > li > a span{
/*font-family: 'Material Symbols Rounded';*/
font-size: 24px;
    color: #565656;
    font-weight: normal;
        margin-bottom: 8px;

}
body #header #global_menu > ul > li > a:hover {
    opacity: 0.8;
}
body #header #global_menu > ul li.hd-tel {
    color: #565656;
    padding-bottom: 6px;
}
body #header #global_menu > ul li.hd-tel p.tel-number {
    font-size: 24px;
    font-weight: bold;
    vertical-align: top;
    letter-spacing: 0.01em;
}
body #header #global_menu > ul li.hd-tel p.tel-number span {
    vertical-align: text-bottom;
}
body #header #global_menu > ul li.hd-tel p.tel-number img {
    width: 18px;
}
body #header #global_menu > ul li.hd-tel p.tel-text{
    font-size: 11px;
    font-weight: 300;
            padding-top: 0.1825rem;
}
#header_logo a {
/*    color: #fff;*/
}
body.open_header #header #header_logo a {
    color:  var(--main_color);
}
.cb_image_slider a .image img {
    will-change: transform;
    transition: transform 0.5s ease;
  }
.cb_image_slider a:hover .image img {
    transform: scale(1.2);
  }
.case_study_list .title_area {
  padding: 0 50px;
    height: 100px;
}
.case_study_list .category {
    top: 100px;
}
.case_study_list .image_wrap {
  margin: 0 -1px;
  width: calc(100% + 2px);
  height: auto;
    max-height: 190px;}
.link-area a img {
    max-height: 60px;}

#footer_inner_link {
/*  background: #ebebeb;*/
  background:#fff;
  padding: 60px 0;
}
#footer_button_area .icon {
    border: 1px solid var(--main_color);
    background: #fff;
}
#footer_button_area .icon span {
    color: var(--main_color);}

.link-area {
    text-align: center;
}
#footer_inner_link .catch.rich_font{
    text-align: center;
    margin-bottom: 50px;
        color: #fff;
}
#return_top a {
  background: #fff !important;
    color: var(--main_color);
    border: 1px solid var(--main_color);
}
#return_top a::before {
    color: var(--main_color);
}
.home .choose .ttl_tour{
    color: var(--main_color);
/*    margin-bottom: 45px;*/
    margin-bottom: 5px;
}
.home .choose .ttl_tour:before {
/*
    content: '';
    position: absolute;
    bottom: -15px;
    display: inline-block;
    display: inline-block;
    width: 60px;
    height: 5px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: var(--main_color_dark);
    border-radius: 2px;
*/
}
#news_ticker {
    background: #fff;
    width: 750px;
    height: 80px;
    border-radius: 0;
     box-shadow: 0; 
    position: relative;
    /* top: -40px; */
    margin-bottom: -40px;
    z-index: 10;
    margin: 50px auto;
}
#cb_content_city {
    padding-top: 60px;
}
section#cb_content_city h2.catch.rich_font,
section#cb_content_theme h2.catch.rich_font {
    text-align: center;
    margin-bottom: 35px;
/*        color: #fff;*/
}

section#cb_content_city ul,
section#cb_content_theme ul {
    display: flex;
    flex-wrap: wrap;
    max-width: 1000px;
    margin: 0 auto;
}
section#cb_content_city ul li,
section#cb_content_theme ul li {
    width: 23%;
    margin: 0.5%;
    text-align: center;
}

section#cb_content_city ul li a p,
section#cb_content_theme ul li a p {
    padding-top: 15px;
/*        color: #fff;*/
}

#cb_content_city,
#cb_content_theme,
section#cb_content_00{
    padding-top: 60px;
/*    border-top: #ddd solid 1px;*/
        margin-bottom: 60px;
}
section#cb_content_city h2.catch.rich_font,
section#cb_content_theme h2.catch.rich_font {
    text-align:left;
    margin-bottom: 15px;
}
section#cb_content_1,
section#cb_content_4{
    /* background: var(--main_color); */
    padding-top: 60px;
/*    border-top: #ddd solid 1px;*/
}
.cb_white_bg {
    padding: 60px 0;
}
.cb_free_space {
    padding: 80px 0;
    position: relative;
}
section#cb_content_city ul,
section#cb_content_theme ul {
    display: flex;
    flex-wrap: wrap;
    max-width: 800px;
    margin: 0 auto;
}
section#cb_content_city ul li,
section#cb_content_theme ul li {
width: 30%;
    margin: 1.5%;
    text-align: center;
}
section#cb_content_city ul li img,
section#cb_content_theme ul li img {
    border-radius: 10px;
}
section#cb_content_city ul li a p,
section#cb_content_theme ul li a p {
    padding-top: 15px;
}
section#cb_content_city ul li a img,
section#cb_content_theme ul li a img,
section#cb_content_city ul li .box,
section#cb_content_theme ul li .box{
  will-change: transform;
  transition: transform 0.5s ease;
}
section#cb_content_city ul li a:hover {
}
section#cb_content_city ul li .box:hover,
section#cb_content_theme ul li .box:hover {
/*    box-shadow: 3px 3px 7px rgba(0, 0, 0, 0.1);*/
    transform: scale(1.1);
}
#service_icon_list_type1 li a:hover {
/*    box-shadow: 3px 3px 7px rgba(0, 0, 0, 0.1);*/
}

.footer_inner_link_inner {
  display: flex;
  flex-wrap: wrap;
/*  justify-content: center;*/
justify-content: space-evenly;
max-width: 1000px;
  margin: 0 auto;
}
.top-fot-link {
  min-width: 25%;
}
.top-fot-link-iner {
  display: flex;
}
.top-fot-link p {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 12px;
}
#cb_content_6 .design_header.cb_design_header {
  padding-top: 30px;
    color: #fff;
}
.top-fot-link li {
  margin: 5px 16px 11px 0;
}
/* モーダルCSS */
.inner-box {
    color: var(--main_color);
}
.modalContents p.telnum {
    font-size: 39px;
    font-weight: bold;
}
.modalContents p.time {
    font-weight: normal;
      color: var(--main_color);
}
.modalContents-inner {
    margin-bottom: 10px;
    border-bottom: 1px solid #ccc;
    padding-bottom: 15px;
}
.modalContents-inner {
    margin-bottom: 10px;
}
.modalContents {
    text-align: center;
}
.modalContents a {
    background: var(--main_color);
    color: #fff;
    display: block;
    text-align: center;
    padding: 12px;
}
p.md-title {
    color: #666;
    font-size: 18px;
    padding: 5px;
    font-weight: normal;
}
.modalArea {
  display: none;
  position: fixed;
  z-index: 10; /*サイトによってここの数値は調整 */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.modalBg {
  width: 100%;
  height: 100%;
  background-color: rgba(30,30,30,0.9);
}

.modalWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform:translate(-50%,-50%);
  width: 70%;
  max-width: 500px;
  padding: 30px 30px;
  background-color: #fff;
}

.closeModal {
  position: absolute;
  top: 0.5rem;
  right: 1rem;
  cursor: pointer;
}
a#openModal {
    cursor: pointer;
}
#service_icon_list_type1 li {
    width: calc(24% + 1px);
}
#service_icon_list_type1 a {
    padding: 0 0px;
}
#news_ticker {
    height: auto;
    box-shadow: none;
    border-radius: 0px;
    top: 0px;
    padding-top: 60px;
    width: 100%;
/*    border-top: #ddd solid 1px;*/
/*    margin: 15px;*/
}
#footer_button_area {
    overflow: hidden;
}
.top-fot-link {
    min-width: 25%;
    font-size: 14px;
    font-weight: normal;
}
.top-fot-link li span {
    font-size: 10px;
    padding: 5px;
    display: inline-block;
    /* margin-top: -62px; */
    vertical-align: 1px;
    color:  var(--main_color);
}

.home .choose .bt_search button[type=button] {
    background-color:  var(--main_color);
}
#content_builder .case_study_list {
    display: flex;
    flex-wrap: wrap;
}
#content_builder .case_study_list .item {
    margin-bottom: 15px;
}
.cb_case_study_slider{
    border-bottom: none;
}
.cb_case_study_slider_wrap:before,
.cb_case_study_slider_wrap:after{
    display: none;
}
/*
section#cb_content_2 {
    background: var(--main_color_dark);
    padding: 60px 0;
    margin: 60px auto;
}
*/
.home .choose .bt_add {
    color:var(--main_color);}
.home .choose {
    width: 100%;
    background-color: transparent;
    margin-bottom: 20px;
    padding: 20px;
    position: static;
    z-index: 100;
    top: 0;
    margin-top: 100px;
}
#header_slider .overlay {
    display: block;
}


.cb_image_slider {
    animation: none !important;
        flex-wrap: wrap !important;
}
.cb_image_slider .image{
    position: static;
    height: auto;
    width: auto;
}

.cb_image_slider .item {
    width: calc((100vw - 46px) / 3);
    height: auto;
    position: relative;
    overflow: hidden;
    flex: auto;
    margin: 6px;
}
section#cb_content_city ul li a p,
section#cb_content_theme ul li a p,
.cb_image_slider .title{
        position: static;
    overflow: hidden;
    white-space: wrap;
/*    text-overflow: ellipsis;*/
    font-size: 10px;
    color: #565656;
        text-align: left;
}
.home .choose .add_box ul li .input_box:after{
    display: none;
}

@media (min-width: 1200px) {
#header_button {
    height: 42px;
    line-height: 44px;
    text-align: center;
    padding: 0 19px;
    min-width: 170px;
    position: absolute;
    right: 10px;
    top: 10px;
    z-index: 3;
    background: var(--main_color);
    color: #fff;
    border-radius: 0px;
}
#global_menu > ul {
    position: relative;
    text-align: right;
    font-size: 0;
    /* padding-left: 40vw; */
    padding-right: 200px;
}
    #global_menu > ul#menu-c {
        position: relative;
        text-align: right;
        font-size: 0;
        padding-right: 10px;
        display: flex;
        align-items: flex-start;
/*        align-items: center;*/
        justify-content: flex-end;
    }
}
@media screen and (max-width: 1250px) {
  #drawer_menu {
      display: block;}
#news_ticker {
    background: #fff;
    width: auto;}
#content_builder .design_header {
    width: auto;}
}
@media (min-width: 800px) {
     .pc-none{
         display: none
     }
 #global_menu > ul#menu-c {
    position: relative;
    text-align: center;
    font-size: 0;
    display: flex;
    align-items: flex-start;
}
body #header #global_menu > ul li.hd-tel{
    padding-top: 17px;
    padding-bottom: 23px;
        }
/*SEEED変更*/
.cb_image_slider .item {
    width: 200px;
    height: 300px;
    flex: 0 0 200px;
    margin: 0 30px 0 0;
}
.cb_image_slider .image {
    width: 100%;
    height: 215px;
}

.cb_image_slider .title {
    position: absolute;
    top: 230px;}
.cb_image_slider .item:nth-child(even) .title {
    top: auto;
    bottom: 215px;
}
        #service_icon_list_type1 .icon {
            font-size: 85px
        }

#footer_nav ul#menu-bottom {
    display: flex;
}
.footer_bottom {
    border-top: 1px solid #ccc;
    padding: 10px;
    text-align: center;
}


}
 @media screen and (max-width: 800px) {

      .sp-none{
         display: none
     }   
     .home .choose .ttl_tour{
         margin-left: 10px;
         text-align: left;
     }
     .home .choose {
         margin-top: 15px;
padding: 20px 5px 0;
     }
     #header{
         height: 65px
     }
     #container{
         margin-top: 0px;
     }
#header_slider_wrap {
    overflow: hidden;
}
#header_slider {
/*    height: 85vh;*/
height: calc(100svh - 65px);
/*    max-height: 550px;*/
/*    max-height: 550px;*/
}

#header_slider_wrap {
  width: 100%;
height: calc(100svh - 65px);
    max-height: 100svh;
/*max-height: 550px;*/
}
.cb_image_slider a .image img {
    width: calc((100vw - 36px) / 3);
    height: calc((100vw - 36px) / 3);
    position: static;
}
    }
@media screen and (max-width: 800px) {
        .cb_selling_point:first-of-type {
            margin-top:-75px
        }

        .cb_selling_point:first-of-type .cb_design_header {
            padding-top: 70px !important
        }

        #header_slider_wrap.no_header_news+#content_builder .cb_selling_point:first-of-type .cb_design_header {
            padding-top: 40px !important
        }

        .sp_content_inner {
            padding: 40px 20px 40px
        }

        .sp_content_wrap:not(.display_two_content) .sp_content_inner {
            padding-bottom: 60px
        }

        .sp_content .main_content .catch {
            font-size: 18px
        }

        .sp_content .main_content .desc {
            font-size: 16px;
            line-height: 2
        }

        .sp_content .main_content+.sub_content {
            margin-top: 35px
        }

        .sp_content .sub_content img {
            max-width: 80%
        }

        .sp_content .bg_image.mobile {
            display: block
        }

        .sp_content .bg_image.pc {
            display: none
        }

        .sp_content .chart {
            width: 100%
        }
#news_ticker h2.catch.rich_font {
  text-align: left;
  margin-bottom: 0;
  margin-left: 10px;
}
#news_ticker .post_list li a {
    width: 100%;
    padding: 5px 10px;}
#news_ticker .post_list {
    padding: 0px 10px 12px;
    width: 100%;
}
#news_ticker {
    margin: 15px 0;
}
    }

    @media screen and (max-width: 1200px) {
        #service_category_list .desc {
            font-size:16px
        }
    }

    @media screen and (max-width: 1000px) {
        #service_category_list {
            padding:100px 0
        }

        #service_category_list.service_list_type3 {
            padding-bottom: 100px
        }

        #service_category_list .desc {
            padding: 0 50px
        }

        body.no_header_image #service_category_list {
            margin-top: 100px
        }
    }

    @media screen and (max-width: 800px) {
        #service_category_list {
            padding:40px 0
        }

        #service_category_list.service_list_type3 {
            padding-bottom: 40px
        }

        #service_category_list .desc {
            font-size: 16px;
            line-height: 2;
            margin: -7px 0 -4px;
            padding: 0 20px
        }

        #service_category_list .desc.mobile {
            display: block
        }

        #service_category_list .desc.pc {
            display: none
        }

        #service_category_list .desc+#service_icon_list_type1 {
            margin-top: 35px
        }

        #service_category_list .desc+#service_icon_list_type2 {
            margin-top: 35px
        }
    }

    @media screen and (max-width: 1200px) {
        #service_icon_list_type1 {
            margin:0 100px;
            width: auto
        }

        #service_icon_list_type1.short_size {
            justify-content: start
        }

        #service_icon_list_type1 li {
            width: calc(25% + 1px)
        }

        #service_icon_list_type1 a {
            padding: 0 20px
        }

        #service_icon_list_type1 li a:after {
            bottom: 25px
        }
    }

    @media screen and (max-width: 1000px) {
        #service_icon_list_type1 {
            margin:0 50px
        }

        #service_icon_list_type1 li a:after {
            display: none
        }

        #service_icon_list_type1 .catch {
            font-size: 14px
        }

        #service_icon_list_type1 .icon {
            font-size: 50px
        }

        @media(hover: hover) {
            #service_icon_list_type1 li a:hover {
                transform:none;
                box-shadow: none
            }
        }
    }

    @media screen and (max-width: 800px) {
        #service_icon_list_type1 {
            margin:0 20px
        }

        #service_icon_list_type1 li {
            width: calc(100%/3 + 1px)
        }
    }

    @media screen and (max-width: 600px) {
        #service_icon_list_type1 li {
            width:calc(50% + 1px)
        }
    }

    @media screen and (max-width: 1100px) {
        #service_icon_list_type2 {
            width:auto;
            margin: 0 100px
        }

        #service_icon_list_type2.short_size {
            justify-content: start
        }

        #service_icon_list_type2 li {
            width: calc(100%/5 + 1px)
        }

        #service_icon_list_type2 li a:after {
            bottom: 10px
        }
    }

    @media screen and (max-width: 1000px) {
        #service_icon_list_type2 {
            margin:0 50px
        }

        #service_icon_list_type2 li a:after {
            display: none
        }

        @media(hover: hover) {
            #service_icon_list_type2 li a:hover {
                transform:none;
                box-shadow: none
            }
        }
    }

    @media screen and (max-width: 900px) {
        #service_icon_list_type2 li {
            width:calc(100%/4 + 1px)
        }
    }

    @media screen and (max-width: 800px) {
        #service_icon_list_type2 {
            margin:0 20px
        }
.home .add_box {
    padding: 12px 0;}
        #service_icon_list_type2 li {
            width: calc(100%/3 + 1px)
        }
    }

    @media screen and (max-width: 600px) {
        #service_icon_list_type2 li {
            width:calc(100%/2 + 1px)
        }
    }
@media screen and (max-width: 1000px) {
        #footer_button_area {
            width:100%;
            height: auto;
            position: relative;
            bottom: auto;
            left: auto;
            transform: translateX(0%)
        }

        #footer_contact.one_item #footer_button_area {
            width: 100%
        }

        #footer_button_area .item {
            padding: 30px 20px
        }

        #footer_button_area .icon {
            width: 70px;
            height: 70px
        }

        #footer_button_area .icon span {
            font-size: 32px
        }

        #footer_button_area .icon img {
            max-width: 26px
        }

        #footer_button_area .content {
            width: calc(100% - 70px)
        }

        #footer_button_area .icon+.content {
            padding-left: 20px
        }

        #footer_button_area .title {
            font-size: 16px;
            margin-top: -5px
        }

        #footer_button_area .desc {
            font-size: 14px;
            line-height: 2;
            margin-bottom: -7px
        }
    }

    @media screen and (max-width: 800px) {
        #footer_button_area {
            display:block
        }

        #footer_button_area .item:last-of-type {
            border-left: none;
            border-top: 1px solid #ddd
        }

        #footer_button_area .item:only-of-type {
            border-top: none
        }

    }
div#pagelink.sp-none ul {
    display: flex;
    flex-wrap: wrap;
    border: 1px solid #ccc;
    align-items: center;
}

div#pagelink.sp-none ul li a{
    border: 1px solid #ccc;
}

div#pagelink.pc-none {
    border: 1px solid #ccc;
    border-radius: 10px;
    border-collapse: collapse;
    overflow: hidden;
    margin: 8px;
}
div#pagelink.pc-none td {
    border: 1px solid #ccc;
    padding: 5px;
    font-size: 12px;
    vertical-align: middle;
}
div#pagelink.pc-none table tr.pagelink-top td {
    border-top: none !important;
    border-left: none;
}
div#pagelink.pc-none table tr.pagelink-top td:nth-child(3n){
      border-right: none;  
}
div#pagelink.pc-none table tr.pagelink-bottom td {
    border-bottom:none !important;
    border-left: none;
}
div#pagelink.pc-none table tr.pagelink-bottom td:nth-child(3n) {
       border-right: none;     
}
div#pagelink.pc-none a{
    display: block;
    text-align: center;
    line-height: 150%;
font-weight: 400;
}

footer#footer {
padding-top: 25px;
    background: #212129;
    color: #fff;
}
div#footer_tour_area {
    /* padding: 0 100px; */
    max-width: 1064px;
    margin: 0 auto;
}
div#footer_tour_area p.toggle-btn {
    margin-top: 30px;
    padding-bottom: 10px;
    font-size: 16px;
    position: relative;
    cursor: pointer;
}
.fot_trip{
    border-top: 1px solid #dadada;
}

div#footer_tour_area p.toggle-btn:after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    color: #333;
    line-height: 1;
    width: 10px;
    height: 10px;
    border: 0.15em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    position: absolute;
    transform: translateY(-25%) rotate(135deg);
    right: 10px;
}
footer div#footer_tour_area p.toggle-btn:after{
      color: #fff;  
}
div#footer_tour_area p.toggle-btn.active:after {
    transform: translateY(-25%) rotate(315deg);
}
div#footer_tour_area .fot_trip_box {
    display: flex;

/*    border-bottom: 1px solid #dadada;*/
    padding: 10px 0;
    line-height: 151%;
}
div#footer_tour_area .fot_trip_box ul {
    width: 880px;
}
div#footer_tour_area .fot_trip_box ul li {
    display: inline-block;
    margin: 0 10px;
    font-size: 12px;
}

div#footer_tour_area .fot_trip_box ul li a{
color: #565656;
font-weight: 400;
}

.fot_trip_box p {
    width: 170px;
    font-size: 12px;
    font-weight: bold;
}
#footer_nav {
    padding: 10px 100px;
    border-top: 1px solid #ddd;
    margin-top: 30px;
}
div#footer_logo {
    text-align: center;
    padding: 10px;
    line-height: 150%;
    font-weight: normal;
}
div#footer_logo p.text_s {
    font-size: 11px;
    line-height: 140%;
    margin-top: 10px;
    margin-bottom: 10px;
}
div#drawer_menu_box.disp_on #mobile_menu #footer_nav{
    margin: 15px 50px;
}
div#drawer_menu_box.disp_on #mobile_menu div#footer_logo p.text_s {
    font-size: 11px;
    line-height: 140%;
    margin-top: 10px;
    margin-bottom: 10px;
    font-weight: 300;
    color: #8b8b8b;
}
div#drawer_menu_box.disp_on #mobile_menu .footer_bottom p {
        display: flex;
        font-size: 11px;
        justify-content: center;
        color: #8b8b8b;
        font-weight: 300;
    }
div#drawer_menu_box.disp_on #mobile_menu #footer_logo p.tel-number,
div#drawer_menu_box.disp_on #mobile_menu #footer_logo p.tel-number a{
        color: #8b8b8b !important;    
    font-weight: bold;
}
div#drawer_menu_box.disp_on #mobile_menu #footer_logo p.tel-number img {
    width: 15px;
    display: inline-block;
    vertical-align: -2px;
    opacity: 0.6;
}
div#drawer_menu_box.disp_on .footer_bottom {
/*        padding: 5px 10px 100px;*/
    border-top: none;
    padding: 5px 10px 20px !important;
    }
_::-webkit-full-page-media, _:future, :root div#drawer_menu_box.disp_on .footer_bottom  {
        padding: 5px 10px 100px !important;
}
div#drawer_menu_box.disp_on #footer_logo .logo_text {
        font-size: 16px;
        font-weight: 400;
color: #464646;
    }
    div#drawer_menu_box.disp_on #footer_logo p.tel-number {
        font-size: 15px;
    }
div#drawer_menu_box.disp_on #mobile_menu .footer_bottom p span {
    display: inline-block;
    line-height: 160%;
    font-weight: 300;
    font-weight: 300;
    color: #8b8b8b;
}
#footer_logo p.tel-number img {
    width: 15px;
    display: inline-block;
    vertical-align: -2px;
}

#footer_logo p.tel-number {
    font-size: 16px;
    vertical-align: top;
    font-weight: bold;
}
#footer_nav li a {
    color: #565656;
    font-weight: 400
}
#footer_logo p.tel-number a{
    color: #fff
}
#footer_nav .sns-logo img {
    width: 30px;
    padding: 10px 5px 10px;
}
.footer_bottom p span{
    display: inline-block;
    line-height: 160%;
}
#copyright {
    font-size: 12px;
    font-weight: 400;
}
    @media screen and (max-width: 1000px) {
        .footer_image_carousel .item {
            width:180px;
            height: 200px;
            position: relative;
            overflow: hidden;
            flex: 0 0 180px
        }

        #footer_video {
            height: 200px
        }

        #footer_contact.fixed_image {
            height: auto;
            padding-top: 200px
        }

        #footer_contact .bg_image {
            width: 100%;
            max-height: 200px
        }
    }

    @media screen and (max-width: 1200px) {
        #footer_catch {
            padding:12px 30px
        }

        #footer_catch p {
            width: auto;
            max-width: 1030px
        }

        #footer_inner {
            width: auto;
            max-width: 1030px
        }
    }

    @media screen and (max-width: 1000px) {
        #footer_catch {
            padding:12px 20px;
            font-size: 14px
        }

        #footer_inner {
            padding: 50px 100px
        }

        #footer_logo img.pc {
            display: none
        }

        #footer_logo img.mobile {
            display: block
        }

        #footer_sns {
            margin-top: 20px
        }
    }

    @media screen and (max-width: 1000px) {
        #footer_inner {
            padding:40px 20px
        }
    }

    #footer_nav {
        padding: 0 100px
    }

    @media screen and (max-width: 1200px) {
        #footer_nav {
            padding:0 50px
        }

        #footer_nav li {
            font-size: 14px
        }

        #footer_nav li a {
            height: 50px;
            line-height: 50px
        }
    }

    @media screen and (max-width: 800px) {
        #footer_nav {
            padding:0 20px
        }

        #footer_nav ul {
            justify-content: start
        }

        #footer_nav li {
            margin-right: 20px
        }

        #footer_nav li:last-of-type {
            margin-right: 0
        }
    }

    @media screen and (max-width: 1200px) {
        #copyright {
            top:calc(100vh - 50px)
        }
    }

    @media screen and (max-width: 800px) {
#copyright {
        padding: 19px 20px;
        background: #212129;
        color: #fff;
    }
    }

    @media screen and (max-width: 1100px) {
        body.show_footer_bar #return_top.active {
            bottom:68px
        }

        #return_top a {
            height: 50px;
            width: 50px;
            line-height: 50px
        }

        #return_top a:before {
            font-size: 12px;
            width: 12px
        }

        #return_top.active {
            transform: translate3d(0,0,0);
            bottom: 25px
        }
    }

    @media screen and (max-width: 800px) {
    .cb_free_space .post_content {
        width: auto;}
        .p-footer-bar+#return_top {
            bottom:0
        }

        .p-footer-bar+#return_top.active {
            bottom: 68px
        }
div#footer_logo {
    text-align: center;
        padding: 30px 10px;
        }
.link-area a img {
    max-height: auto;
}
.footer_inner_link_inner,
.top-fot-link-iner{
        display: block;}
.top-fot-link {
    min-width: 25%;
    padding: 15px;
}
    }
@media screen and (max-width: 1000px) {
        .cb_selling_point:first-of-type {
            margin-top:-70px
        }

        .cb_selling_point:first-of-type .cb_design_header {
            padding-top: 100px !important
        }

        .cb_selling_point:first-of-type.no_header .sp_content_wrap:nth-child(1) .sp_content_inner {
            padding-top: 75px
        }

        #header_slider_wrap.no_header_news+#content_builder .cb_selling_point:first-of-type .cb_design_header {
            padding-top: 70px !important
        }

        #header_slider_wrap.no_header_news+#content_builder .cb_selling_point:first-of-type.no_header .sp_content_wrap:nth-child(1) .sp_content_inner {
            padding-top: 40px
        }

        .sp_content {
            align-self: stretch;
            display: flex;
            flex-direction: column;
            justify-content: center
        }

        .sp_content_inner {
            width: auto;
            margin: 0;
            display: block;
            height: auto;
            padding: 40px 50px;
            min-height: inherit
        }

        .sp_content .main_content {
            width: auto;
            max-width: 500px;
            margin: 0 auto
        }

        .sp_content .main_content+.sub_content {
            margin-top: 40px
        }

        .sp_content .sub_content {
            width: auto
        }

        .sp_content .sub_content {
            text-align: center !important
        }

        .sp_content .main_content .design_button {
            margin-top: 30px;
            margin-left: auto;
            margin-right: auto;
            display: table
        }

        .sp_content .sub_content img {
            max-width: 80%
        }

        .sp_content .switch {
            position: relative;
            top: auto;
            right: auto;
            left: 50%;
            transform: translateX(-50%);
            margin-top: 20px;
            margin-bottom: -15px
        }

        .sp_content:nth-child(2) .switch {
            left: 50%
        }

        .sp_content .switch:before {
            font-size: 25px
        }
    }
@media (max-width: 800px) {
  .choose {
    top: 9vh !important;
  }
h2.catch.rich_font, .choose .ttl_tour {
  font-size: 15px !important;
        text-align: left;
}
section#cb_content_city h2.catch.rich_font,
section#cb_content_theme h2.catch.rich_font {
    margin-left: 10px;
}
    section#cb_content_theme .design_header h2.catch.rich_font{
    margin-left: 0px;  
    }
.design_header .desc p{
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
/*    text-overflow: ellipsis;*/
    word-wrap: break-word;
    color: #969696;
    font-size: 10px;
    text-align: left;
    line-height: 150%;
}
.design_header .catch + .desc {
    margin-top: -10px;
}
#content_builder .design_header {
    margin: 10px auto 15px;
            padding: 0 10px;
}
section#cb_content_city ul li a img, section#cb_content_city ul li .box,
section#cb_content_theme ul li a img, section#cb_content_theme ul li .box {
  will-change: transform;
  transition: transform 0.5s ease;
  height: 100%;
  width: 100%;
  object-fit: cover;
  aspect-ratio: 1;
}
section#cb_content_city ul li a,
section#cb_content_theme ul li a {
  display: block;
}
section#cb_content_city ul li,
section#cb_content_theme ul li {
  min-height: 140px;
padding-bottom: 5px;
        margin-bottom: 5px;
}
#cb_content_city, section#cb_content_00,
#cb_content_theme{
    padding-top: 30px;
    margin-bottom: 30px;
    padding-bottom: 0px;
        padding-left: 5px;
        padding-right: 5px;
}
/*
section#cb_content_city ul li a p {
  font-size: 12px;
}
*/
/*
.design_header .desc p {
  font-size: 15px;
  line-height: 1.4;
  padding-top: 10px;
}
*/

.home .choose .bt_add {
color:var(--main_color);
  text-align: right;
  max-width: 960px;
  margin: 0 auto;
  text-decoration: underline;
  cursor: pointer;
  padding: 9px 0 0;
  font-size: 13px;
/*  pointer-events: none;*/
}
section#cb_content_city ul li a p, section#cb_content_theme ul li a p {
    padding-top: 5px;
    margin-top: 5px;
}
.sp_content_inner{
    padding: 40px 30px;
    width:auto;}
.design_button {
  width: 255px;
  height: 40px;
  border-radius: 70px;
    line-height: 2.5;}

.top-fot-link p {
    font-size: 14px;
font-weight: 500 !important;
  font-style: normal !important;
}
.top-fot-link li {
    font-size: 11px;
}
.top-fot-link li span {
    font-size: 8px;}
    .top-fot-link li a{
        color: #565656;
    }
.add .top-fot-link{
     display: flex;
    }
.top-fot-link.flex-none {
  display: block;
}
.add .top-fot-link-iner {
  display: flex;
}
    #footer_contact.no_background{
        height: auto;
    }
/*
.swiper-wrapper {
  display: block;
}
*/
#footer_nav li a {
    height: 30px;
    line-height: 150%;
    font-size: 12px;
    color: #565656;
            display: inline-block;
  }
#footer_nav ul {
/*
    display: flex;
    flex-wrap: wrap;
*/
  }
#footer_nav ul li{
        width: 48%
    }
#footer_nav nav#menu-bottom {
    inline-size: fit-content;
    display: flex;
    margin-inline: auto;
}
    #footer_nav ul {
        display: block;
/*
        column-count: 2;
        inline-size: fit-content;
        margin-inline: auto;
*/
        vertical-align: top;
        margin-bottom: 25px;
    }
.footer_bottom {
    text-align: left;
    line-height: 160%;
    border-top: 1px solid #ccc;
    padding: 10px;
}
.footer_bottom p {
    display: flex;
    font-size: 12px;
    justify-content: center;
}
.footer_bottom p img {
    width: 45px;
    padding: 5px;
}
div#footer_tour_area .fot_trip_box ul {
    width: auto;
    list-style: none;
    padding: 0;
}
.fot_trip_box p {
    width: auto;
    padding: 0px 9px;
}
div#footer_tour_area {
    padding: 0 7px;
}
div#footer_tour_area .fot_trip_box {
    display: block;
    }
    div#footer_tour_area p.toggle-btn{
        font-size: 14px;
        font-weight: bold;
    }
    
#mobile_menu li.menu-title {
    background: #565656;
    color: #fff;
    padding: 10px 20px;
}
}

@media screen and (max-width:1250px) {
    #drawer_menu {
        background: #fff
    }
    #mobile_menu a {
        color: #565656 !important;
        border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    }
#mobile_menu a span {
/*    font-family: 'Material Symbols Rounded';*/
    font-size: 22px;
    vertical-align: top;
    margin-right: 6px;
}
    #drawer_mneu_close_button:before{
        color: #565656 !important;  
    }
}
section#toursearch {
    padding-top: 15px;
    margin-top: 15px;
}
#header_slider .scroll-box {
    position: absolute;
    text-align: center;
    width: 100%;
    display: flex;
    justify-items: center;
    flex-wrap: nowrap;
    justify-content: center;
    bottom: 0;
    z-index: 100;
}
#header_slider .scroll-box span.sc-text {
    /* font-weight: bold; */
    letter-spacing: 0.1rem;
    display: block;
    border-left: none;
    border-bottom: none;
    width: auto;
    position: absolute;
    z-index: 2;
    width: 100px;
    text-align: center;
    margin: 0 auto;
    bottom: 70px;
    color: #fff;
    bottom: 4em;
}
#header_slider .scroll-box > a{
    width: 100px;
    display: block;
}
#header_slider .scroll-box .scroll {
    position: relative;
    bottom: 2em;
    width: 3em;
    height: 3em;
    margin: 0 auto;
    /* text-align: -webkit-match-parent; */
    display: block;
}
#header_slider .scroll-box .scroll span {
  width: 1em;
  height: 1em;
  position: absolute;
  top: 25%;
  left: 33%;
  transform: translateY(0) rotate(-45deg);
  border-left: 1px solid #F5F5F5;
  border-bottom: 1px solid #F5F5F5;
  z-index: 2;
/*  animation: popping-arrow 2s infinite ease-out;*/
}
#header_slider .scroll-box .scroll:hover span {
  transform: translateY(0.5em) rotate(-45deg);
/*  animation: paused;*/
}

/*
@keyframes popping-arrow {
  0% {
    transform: translateY(0) rotate(-45deg);
  }
  30% {
    transform: translateY(0.5em) rotate(-45deg);
  }
  60% {
    transform: translateY(0) rotate(-45deg);
  }
}*/
@media (min-width: 800px) {
    #header_logo{
        left: 0;
    }
#global_menu > ul#menu-c li.menu-item{
    opacity: 1;
    transition: opacity .3s cubic-bezier(.25,.46,.45,.94);
        }
#global_menu > ul#menu-c:hover li.menu-item {
    opacity: 0.3;
    transition: opacity .3s cubic-bezier(.25,.46,.45,.94);
}
body #header #global_menu > ul#menu-c:has(.hd-tel.active):hover li.menu-item {
    opacity: 1;
        }
#global_menu > ul#menu-c:hover li.menu-item:hover {
    opacity: 1;
    transition: opacity .6s cubic-bezier(.25,.46,.45,.94);
}
section#cb_content_city ul, section#cb_content_theme ul {
    display: flex;
    flex-wrap: wrap;
        max-width: 1064px;
    margin: 0 auto;
}
section#cb_content_city ul li,
section#cb_content_theme ul li{
    width: auto;
}
section#cb_content_city ul li a img,
section#cb_content_theme ul li a img{
    width: 108px;
    height: 108px;
    object-fit: cover;
}
#footer_nav {
        display: flex;
        justify-content: space-between;
        max-width: 1064px;
        margin: 15px auto 0;
        padding: 0;
        padding-top: 15px;
    }
div#footer_logo{
    padding: 10px 0;
    text-align: left;
    }
div#footer_logo .logo_text {
    font-size: 20px;
}
#footer_logo p.tel-number {
    font-size: 16px;
    }
#footer_logo p.tel-number img {
    width: 15px;
    vertical-align: middle;
}
#footer_nav nav#menu-bottom  {
    display: flex;
}
#footer_nav nav#menu-bottom li {
    font-size: 12px;
    }
#footer_nav nav#menu-bottom li a {
    height: 28px;
    line-height: 28px;
    display: block;
    font-size: 13px;
}
#footer_nav nav#menu-bottom .footer_bottom.sp-none{
    font-size: 11px;
    border: 1px solid #ddd;
        font-weight: 400;
    }
#footer_nav nav#menu-bottom .footer_bottom.sp-none p{
    display: flex;
    text-align: left;
    margin-bottom: 5px;
}
div#footer_logo p.text_s {
    margin-bottom: 5px;
    font-size: 12px;
}
#footer_nav nav#menu-bottom .footer_bottom.sp-none p img{
    width: 42px;
    padding: 5px;
}
#footer_nav .sns-logo {
    display: inline-block;
}
#footer_nav .sns-logo img {
    width: 25px;
    padding: 10px 5px 10px;
}
}

.symbols-fill {
  font-variation-settings: 'FILL' 0
}

.loading {
  width: 65px;
  height: 65px;
  margin: 50px auto;
  border-radius: 50%;
  border: 6px solid #ddd;
  border-top-color: #999;
  animation: spin 1s infinite linear;
}

@keyframes spin {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(360deg);
  }
}