@charset "utf-8";

/* common */
main {
    max-width: none;
    padding: 0;
}
#aroundtrip .inner {
    width: 100%;
    padding: 0 3%;
    margin: auto;
    position: relative;
}
#aroundtrip .midashi {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin-bottom: 36px;
    font-size: 24px;
    color: #000 !important;
    text-align: center;
    line-height: 30px;
    font-family: ten-mincho, serif;
}
#aroundtrip .midashi::before,
#aroundtrip .midashi::after {
    content: '';
    display: inline-block;
    width: 1.3em;
    height: 1.3em;
    margin-right: .7em;
}
#aroundtrip .midashi::after {
    margin-right: 0;
    margin-left: .7em;
    transform: scale(-1,1);
}
#aroundtrip .midashi.blue::before,
#aroundtrip .midashi.blue::after {
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/deco_txt_blue.png') no-repeat center/contain;
}
#aroundtrip .midashi.red::before,
#aroundtrip .midashi.red::after {
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/deco_txt_red.png') no-repeat center/contain;
}
#aroundtrip .midashi.pink::before,
#aroundtrip .midashi.pink::after {
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/deco_txt_pink.png') no-repeat center/contain;
}
#aroundtrip .midashi.yellow::before,
#aroundtrip .midashi.yellow::after {
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/deco_txt_yellow.png') no-repeat center/contain;
}
#aroundtrip .aroundtrip_content__bnr {
    width: 100%;
    margin: 40px auto 0;
}
/* aroundtrip_mv */
#aroundtrip .aroundtrip_mv img {
    width: 100%;
}

/* aroundtrip_nav */
#aroundtrip .aroundtrip_nav {
    padding: 200px 0 60px;
    background-color: #E7F6F9;
}
#aroundtrip .aroundtrip_nav .inner {
    position: relative;
}
#aroundtrip .aroundtrip_nav .ttl {
    position: absolute;
    top: -135px;
    left: 3%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 160px;
    height: 160px;
}
#aroundtrip .aroundtrip_nav .ttl::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 160px;
    height: 160px;
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/nav_circle.png') no-repeat center/cover;;
    animation: 15s linear infinite rotation;
}
@keyframes rotation {
    0% {
      transform: rotate(0);
    }
  
    100% {
      transform: rotate(360deg);
    }
}
#aroundtrip .aroundtrip_nav .ttl img {
    max-width: 94px;
}
#aroundtrip .aroundtrip_nav .nav {
    display: flex;
    flex-wrap: wrap;
    padding: 30px 25px;
    background-color: #FFF;
}
#aroundtrip .aroundtrip_nav .nav li {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    width: 50%;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(1) {
    padding-right: 12px;
    padding-bottom: 25px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(2) {
    padding-left: 12px;
    padding-bottom: 25px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(3) {
    padding-right: 12px;
    padding-top: 25px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(4) {
    padding-left: 12px;
    padding-top: 25px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(1)::before,
#aroundtrip .aroundtrip_nav .nav li:nth-child(1)::after,
#aroundtrip .aroundtrip_nav .nav li:nth-child(4)::before,
#aroundtrip .aroundtrip_nav .nav li:nth-child(4)::after {
    content: '';
    position: absolute;
    display: block;
    background: url('https://osaka-info.jp/information/around-trip/common/img/entrance_2023/deco_nav.png') repeat;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(1)::before {
    bottom: -2px;
    right: 1%;
    width: 100%;
    height: 4px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(1)::after {
    bottom: 1%;
    right: -2px;
    width: 4px;
    height: 100%;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(4)::before {
    top: -2px;
    left: 1%;
    width: 100%;
    height: 4px;
}
#aroundtrip .aroundtrip_nav .nav li:nth-child(4)::after {
    top: 1%;
    left: -2px;
    width: 4px;
    height: 100%;
}
#aroundtrip .aroundtrip_nav .nav li img {
    max-height: 144px;
}

/* aroundtrip_pickup */
#aroundtrip .aroundtrip_pickup {
    padding: 90px 0 60px;
    .banner-list{
        .banner-item +.banner-item {
            margin-top:15px;
        }
        & a {
            display: block;
            width: 100%;
        }
        & img {
            width: 100%;
        }
    }
}
/* aroundtrip_content */
#aroundtrip .aroundtrip_content {
    padding: 100px 0;
}
#aroundtrip .aroundtrip_content#kanto {
    background: #FAF1F1;
}
#aroundtrip .aroundtrip_content#chubu_hokuriku {
    background: #EFF6FB;
}
#aroundtrip .aroundtrip_content#kansai {
    background: #F7ECEC;
}
#aroundtrip .aroundtrip_content#chugoku_shikoku {
    background: #FBF8EF;
}

/* aroundtrip_content__head */
#aroundtrip .aroundtrip_content__head {
    position: relative;
    margin-bottom: 100px;
    padding-top: 70%;
}
#aroundtrip .aroundtrip_content__head .txt h2 {
    position: absolute;
    top: 10%;
    right: 0;
    display: block;
    width: 40%;
}
#aroundtrip .aroundtrip_content__head .txt h2 img {
    max-width: 100%;
}
#aroundtrip .aroundtrip_content__head .txt p {
    font-size: 16px;
    line-height: 30px;
}
#aroundtrip .aroundtrip_content__head .img {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 55%;
}

/* aroundtrip_content__map */
#aroundtrip .aroundtrip_content__map {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
    margin-bottom: 70px;
}
#aroundtrip .aroundtrip_content__map .txt img {
    display: block;
    width: 80%;
    margin: 0 auto 22px;
}
#aroundtrip .aroundtrip_content__map .txt p {
    margin-bottom: 40px;
    font-size: 16px;
    line-height: 30px;
}

/* aroundtrip_content__list */
#aroundtrip .aroundtrip_content__list.mt {
    margin-top: 60px;
}
#aroundtrip .aroundtrip_content__list ul li {
    border-radius: 5px;
    box-shadow: 5px 5px 0 rgba(70, 70, 70, .1);
    overflow: hidden;
    cursor: pointer;
}
#aroundtrip .aroundtrip_content__list ul.col1 {
    margin-left:auto;
    margin-right:auto;
}
#aroundtrip .aroundtrip_content__list ul.col1 li {
    width: 100%;
}
#aroundtrip .aroundtrip_content__list ul.col2 li,
#aroundtrip .aroundtrip_content__list ul.col3 li {
    background-color: #FFF;
}
#aroundtrip .aroundtrip_content__list ul li {
    margin-bottom: 35px;
}
#aroundtrip .aroundtrip_content__list ul.col2 + .col2 {
    margin-top: 35px;
}
#aroundtrip .aroundtrip_content__list ul.pickup {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#aroundtrip .aroundtrip_content__list ul.pickup li {
    width: 49%;
    margin-right: 2%;
    box-shadow: none;
}
#aroundtrip .aroundtrip_content__list ul.pickup li:nth-child(2n) {
    margin-right: 0;
}
#aroundtrip .aroundtrip_content__list ul.pickup li .img {
    border-radius: 5px;
    overflow: hidden;
}
#aroundtrip .aroundtrip_content__list ul li .img {
    overflow: hidden;
}
#aroundtrip .aroundtrip_content__list ul.col1 li .txt,
#aroundtrip .aroundtrip_content__list ul.col2 li .txt,
#aroundtrip .aroundtrip_content__list ul.col3 li .txt {
    min-height: 112px;
    padding: 20px 38px;
    background-color: #FFF;
    font-size: 17px;
    line-height: 24px;
    font-family: ten-mincho, serif;
}
#aroundtrip .aroundtrip_content__list ul.pickup li .txt {
    font-size: 13px;
    line-height: 20px;
}
#aroundtrip .aroundtrip_content__list ul.pickup li .ttl {
    display: inline-block;
    width: auto;
    margin: 15px 0 5px;
    padding: 5px 15px;
    border-radius: 5px;
}
#aroundtrip .aroundtrip_content__list ul.pickup li .name {
    display: block;
    margin-bottom: 5px;
    font-size: 15px;
}
#aroundtrip #kanto .aroundtrip_content__list ul.pickup li .ttl {
    background-color: #F7CBCB;
    color: #EC3434;
}
#aroundtrip #chubu_hokuriku .aroundtrip_content__list ul.pickup li .ttl,
#aroundtrip #chugoku_shikoku .aroundtrip_content__list ul.pickup li .ttl {
    background-color: #CDE7F1;
    color: #47A9C9;
}

/* aroundtrip_content__pref */
#aroundtrip .aroundtrip_content__pref {
    margin: 140px 0 50px;
    padding: 60px 20px 70px;
    background: #FFF;
    border-radius: 5px;
}
#aroundtrip .aroundtrip_content__pref .txt p {
    margin-top: 25px;
    font-size: 16px;
    line-height: 30px;
}

/* aroundtrip_content__pref */
#aroundtrip .aroundtrip_side_nav {
    visibility: hidden;
    display: none;
    position: fixed;
    bottom: 80px;
    left: 0;
    right: 0;
    display: flex;
    width: 96%;
    margin: 0 auto;
    background-color: #FFF;
    border-radius: 5px;
    border: 1px solid #999;
}
#aroundtrip .aroundtrip_side_nav li {
    width: 25%;
}
#aroundtrip .aroundtrip_side_nav li:not(:last-child) {
    border-right: 1px solid #999;
}
#aroundtrip .aroundtrip_side_nav li a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    padding: 15px 0;
    color: #9B9696;
    font-size: 14px;
    font-family: ten-mincho, serif;
    line-height: 1em;
}
#aroundtrip .aroundtrip_side_nav li.active a {
    color: #FFF;
}
#aroundtrip .aroundtrip_side_nav li.active.red a {
    background-color: #EC3434;
}
#aroundtrip .aroundtrip_side_nav li.active.blue a {
    background-color: #47A9C9;
}
#aroundtrip .aroundtrip_side_nav li.active.pink a {
    background-color: #EC7D7D;
}
#aroundtrip .aroundtrip_side_nav li.active.yellow a {
    background-color: #FFAA00;
}

/* notes */
.notes {
    padding-bottom: 45px;
    background: #FBF8EF;
}
.notes p {
    padding: 20px;
    background: #E8E8E8;
    border-radius: 5px;
}