﻿/*******************************************************************************
title
********************************************************************************/
#title{
    background: url("../img/title_bg.webp") no-repeat center top #801318;
    background-size: auto;
    overflow: hidden;
    padding-bottom: 1em;
    z-index: 0;
    position: relative;
}
#title::after{
    content: "";
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
    height: 5%;
    background: #801318;
    background: linear-gradient(0deg, rgba(128, 19, 24, 1) 0%, rgba(128, 19, 24, 0) 100%);
    
}

#topLogo{
    background-color: #f6ab00;
    font-weight: 800;
    font-size: 1.8em;
    line-height: 1;
    color: #FFF;
    text-align: center;
}
#topLogo span{
    display: inline-block;
    vertical-align: middle;
    margin: 0.3em;
    background-color: #FFF;
    padding: 0.2em;
}
#topLogo span img{
    height: 1em;
    width: auto;
    display: block;
}
#title h1{
    display: block;
    margin: 2em auto 0;
    width: 100%;
    padding-top: 24%;
    background: url("../img/title.webp") no-repeat center top;
    background-size: contain;
    white-space: nowrap;
    text-indent: 100%;
    overflow: hidden;
}
#titleContents{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: -3%;
}
.tc-left{
    flex-basis: 64%;
    max-width: 64%;
}
.tc-left img{
    width: 110%;
    margin-left: -10%;
}
.tc-right{
    flex-basis: 36%;
    max-width: 36%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-content: flex-start;
    align-items: center;
    position: relative;
}
#deptDay{
    background: url("../img/deptDay.webp") no-repeat left top;
    background-size: contain;
    flex-basis: 50%;
    padding-top: 44%;
    white-space: nowrap;
    text-indent: 100%;
    overflow: hidden;
    margin-bottom: 0.5em;
}
#term{
    background: url("../img/term.webp") no-repeat left top;
    background-size: contain;
    flex-basis: 38%;
    padding-top: 23%;
    white-space: nowrap;
    text-indent: 100%;
    overflow: hidden;
    margin-bottom:0.5em;
}
.orangeBox{
    font-size: 1.4em;
    color: #7d001a;
    background-color: #f5aa00;
    padding: 0 1em;
    border-radius: 2em;
    font-weight: 700;
    text-align: center;
    margin-bottom: 0.5em;
}
dl.price{
    text-align: center;
    line-height: 1.2;
}
dl.price dt{
    color: #FFF;
    font-size: 0.85em;
}
dl.price dd{
    font-size: 1.8em;
    font-weight: 700;
    color: #CC0000;
    text-shadow    : 
       2px  2px 1px #FFF,
      -2px  2px 1px #FFF,
       2px -2px 1px #FFF,
      -2px -2px 1px #FFF,
       2px  0px 1px #FFF,
       0px  2px 1px #FFF,
      -2px  0px 1px #FFF,
       0px -2px 1px #FFF; 
    
}
dl.price dd strong{
    font-size: 2em;
}
.mascot {
    width: 65%;
    margin-left: 22%;
}
.mascot img{
    width: 100%;
}

/*--1000px以下------------------------------------*/
@media only screen and (max-width: 1000px) {
.tc-right{
    font-size: 1.5vw;
}
}
/*--737px以下------------------------------------*/
@media screen and (max-width: 737px)  {
#topLogo{
    font-size: 5vw;
}
.tc-left{
    flex-basis: 100%;
    max-width: 100%;
    margin-top: -4%;
}
.tc-left img{
    width: 110%;
    margin-left: -6%;
}
.tc-right{
    display: inline-block;
    flex-basis: 100%;
    max-width: 100%;
    position: relative;
    font-size: 3vw;
}
.tc-right::after{
    content: "";
    display: inline-block;
    clear: both;
}
#deptDay{
    float: left;
    width: 33%;
    padding-top: 31%;
    margin-right: 2%;
}
#term{
    float: left;
    width: 24%;
    padding-top: 16%;
    margin-right: 2%;
}
.orangeBox{
    float: left;
    min-width: 8em;
}
dl.price{
    float: left;
    font-size: 2.2vw;
    text-align: left;
}
.mascot{
    float: right;
    width: 26%;
    margin-top: -20%;
    margin-right: -2%;
}
}

/*******************************************************************************
points
********************************************************************************/
#points{
    background-color: #801318;
    background: url("../img/point_bg.webp") center top no-repeat #ffc100;
    background-size: auto;
    padding-top: 5%;
    padding-bottom: 3%;
}
.pointWrap{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    counter-reset: number 0;
}
.pointBox{
    flex-basis: calc(100% / 3 - 2%);
    max-width:  calc(100% / 3 - 2%);
    position: relative;
    z-index: 0;
    display: flex;
}
/*.pointBox::after{
    content: "";
    display: block;
    width: 100%;
    padding-top: 100%;
    background-color: #faf8db;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
}*/

.pointBox dt{
    position: absolute;
    width: 40%;
    padding-top: 39%;
    border-radius: 50%;
    overflow: hidden;
    margin-left: -8%;
    margin-bottom: -10%;
    background-color: #FFF;
    z-index: 1;
    border: 2px solid #FFF;

}
.pointBox dt img{
    width: 100%;
    position: absolute;
    top: 0;

}
.pointBox dd{
padding: 5.5em 2em 3em 2em;
    margin-top: 7%;
    background-color: #FFF;
    border-radius: 10em;
    position: relative;
    font-size: 1.2em;
    font-weight: 700;
    line-height: 1.5;
    border: 3px solid #a8002b;
}
.pointBox dd h3{
    display: flex;
    align-items: center;
    height: 4em;
    position: absolute;
    top: -3%;
    left: 30%;
    z-index: 1;
    font-size: 1.3em;
    line-height: 1.3;
    color: #ffde00;
    text-shadow    : 
       2px  2px 1px #79001f,
      -2px  2px 1px #79001f,
       2px -2px 1px #79001f,
      -2px -2px 1px #79001f,
       2px  0px 1px #79001f,
       0px  2px 1px #79001f,
      -2px  0px 1px #79001f,
       0px -2px 1px #79001f; 
}
.pointBox dd h3::before{
    content: "";
    display: inline-block;
    width: 1.6em;
    height: 1.6em;
    background: url(../img/icon_ball.webp) no-repeat left top;
    background-size: contain;
    position: absolute;
    left: -1em;
    top: -1.4em;
    z-index: 1;
}
.pointBox dd h3::after{
    display: inline-block;
    background-color: #faa61a;
    color: #FFF;
    position: absolute;
    left: -0.4em;
    top: -1.5em;
    text-align: left;
    padding: 0 0.7em 0 1.3em;
    counter-increment: number 1;
    content: "Point " counter(number);
    text-shadow: none;
    transform: rotate(-6deg);
}

.pointBox dd .note{
    display: inline-block;
    line-height: 1.4;
    font-size: 0.8em;
}
/*--1000px以下------------------------------------*/
@media only screen and (max-width: 1000px) {
#points{
    background-size: cover;
}
.pointBox{
    font-size: 1.4vw;
}

}
/*--737px以下------------------------------------*/
@media screen and (max-width: 737px)  {
.pointBox{
    flex-basis: 100%;
    max-width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    align-content: flex-start;
    font-size: 2.9vw;
    margin: 1em 0;
}
.pointBox dt{
    flex-basis: 20%;
    max-width: 20%;
    padding-top: 20%;
    margin: 0;
    position: relative;
}
.pointBox dd{
    flex-basis: 84%;
    max-width: 84%;
    border-radius: 2em;
    padding: 1em 1em 1em 1.5em;
    margin: 0 0 0 -4%;
}
.pointBox dd h3{
    position: relative;
    height: auto;
    left: 0;
    top:0;
    margin-bottom: 0.5em;
}
}

/*******************************************************************************
summary
********************************************************************************/
#summary{
    padding-top: 7%;
    padding-bottom: 1%;
    background: url("../img/summary_bg.webp");
}
#summary h3{
    text-align: center;
    background-color: #8e2326;
    color: #FFF;
    padding: 0.2em;
    font-size:1.6em;
    margin-bottom: 1em;
}
#summary h4{
    color: #8e2326;
    font-size: 1.4em;
    margin-bottom: 0.3em;
}
#summary h4::before{
    content: "■";
    display: inline-block;
    font-size: 0.8em;
}
#schedule{
    background: #FFF;
    width: 100%;
    border: 1px solid #999;
}
#schedule thead th,
#schedule thead td{
    padding:0.5em 1em;
    background-color: #f1d9df;
    border: 1px solid #999;
    border-collapse: collapse;
}
#schedule tbody th,
#schedule tbody td{
    padding: 1em;
    border: 1px solid #999;
    border-collapse: collapse;
}
#schedule th{
    background-color: #f1d9df;
    text-align: center;
    padding: 0.5em;
    font-weight: 500;
    min-width: 5em;
}
#schedule td:nth-of-type(2){
    min-width: 3.5em;
    padding: 1em 0.5em;
    text-align: center;
}

.aboutIcons{
    display: inline-block;
    text-align: right;
    float: right;
}
[class^=si-]{
    display: inline-block;
    vertical-align: middle;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    height: 1.2em;
    width: 1.8em;
    margin-top: -4px;
    position: relative;
}
.si-air{
    background: url("../img/si-air.webp") no-repeat center;
    background-size: contain;
}
.si-bus{
    background: url("../img/si-bus.webp") no-repeat center;
    background-size: contain;
}
.si-walk{
    background: url("../img/si-walk.webp") no-repeat center;
    background-size: contain;
}
.itinerary li{
    position: relative;
    display: inline-block;
    margin-right: 0.5em;
    margin-bottom: 0.5em;
    padding-left: 3.6em;
}
.itinerary li:first-of-type{
    padding-left: 0;
}
.itinerary li::before{
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 1.2em;
    height: 1px;
    margin-top: 0.7em;
    background-color: #999;
    position: absolute;
    left: 0;
}
.itinerary li:first-of-type::before{
    display: none;
}
.itinerary [class^="icon-"]::after{
    content: "";
    display: inline-block;
    width: 1.8em;
    height: 1.5em;
    position: absolute;
    left: 1.6em;
    top: 0;
}
.icon-air::after{
    background: url("../img/si-air.webp") no-repeat center;
    background-size: contain;
}
.icon-bus::after{
    background: url("../img/si-bus.webp") no-repeat center;
    background-size: contain;
}
.icon-walk::after{
    background: url("../img/si-walk.webp") no-repeat center;
    background-size: contain;
}
.YellowBox {
    display: inline-block;
    background-color: #f9e082;
    color: #333;
    border-radius: 5px;
    padding: 0.1em 0.3em 0.2em 0.3em;
    margin: 0 0.5em;
    font-weight: 600;
    line-height: 1.2;
}
.brownBox {
    display: inline-block;
    background-color: #8e2326;
    color: #FFF;
    border-radius: 5px;
    padding: 0.1em 0.3em 0.2em 0.3em;
    margin: 0 0.5em;
    font-weight: 600;
    line-height: 1.2;
}
.termday{
    display: inline-block;
    margin-bottom: 0.2em;
    background-color: #8e2326;
    color: #FFF;
    width: 4em;
    text-align: center;
    padding: 2px;
}
.note{
    font-size: 0.8em;
    margin: 0.5em 0;
}
.hotelWrap{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.hotelBox{
    position: relative;
    border: 1px solid #999;
    flex-basis: calc(100% / 2 - 1.6%);
    background-color: #FFF;
}
.hotelBox dt img{
    width: 50%;
}
.hotelBox dt .haku{
    background-color: #8e2326;
    color: #FFF;
    padding: 0.3em 0.5em;
    line-height: 1;
    position: absolute;
    left: 0;
    top: 0;
}
.hotelBox dd{
    padding: 1em 1em 2em;
}
.hotelBox dd h5{
    font-size: 1.2em;
    margin-bottom: 0.3em;
}
.detail{
    display: flex;
    flex-wrap: wrap;
    background-color: #FFF;
    border: 1px solid #999;
    border-bottom: 0;
}
.detail dt{
    flex-basis: 9em;
    max-width: 9em;
    background-color: #f1d9df;
    padding: 0.5em 1em;
    border-bottom: 1px solid #999;
    border-right:  1px solid #999;
}
.detail dd{
    flex-basis: calc(100% - 9em);
    max-width:  calc(100% - 9em);
    padding: 0.5em 1em;
    border-bottom: 1px solid #999;
}
.detail dd span{
    display: inline-block;
    margin-right: 1em;
}
.entry{
    margin: 8% auto 13%;
    text-align: center;
}
.entry a {
    min-width: 50%;
    font-size: 1.6em;
    line-height: 1.2;
    font-weight: 500;
    background-color: #cc0033;
    color: #FFF;
    display: inline-block;
    padding: 0.8em 2em;
    border-radius: 2em;
    border-bottom: 6px solid #8d0000;
}
.entry a:hover{
    background-color: #ED0003;
    color: #FFF;
    border-bottom: 0;
    border-top: 6px solid #FFF;
}
/*--737px以下------------------------------------*/
@media screen and (max-width: 737px)  {
#summary h3{
    font-size:4.4vw;
}
#schedule{
    font-size: 3vw;
}
#schedule thead th{
    display: none;
}
#schedule tbody td{
    padding-right: 0;
}
#schedule tr{
    display: flex;
    flex-wrap: wrap;
}
#schedule tbody th{
    display: block;
    flex-basis: 100%;
    padding: 0.3em;
}
#schedule td:nth-of-type(1){
    flex-basis: calc(100% - 3.5em);
    max-width: calc(100% - 3.5em);
}


.termday {
    margin-right: 1em;
}
.hotelBox{
    flex-basis: 100%;
    max-width: 100%;
    margin-bottom: 1em;
}
.hotelBox dd {
    padding: 0.5em 1em 1.4em;
}
.entry a{
    font-size: 4.2vw;
    padding: 0.8em;
    display: block;
}
}
/*******************************************************************************
site-footer
********************************************************************************/
#site-footer{
    background-color:#e6e6e6;
    padding-top: 1.5em;
    padding-bottom: 2em;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: flex-start;
}
#site-footer h3{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: #AAA;
    color: #8e2326;
    color: #FFF;
    flex-basis: 8em;
    height: 8em;
    text-align: center;
    margin-right: 1em;
}

#site-footer ul{
    flex-basis: calc(100% - 10em);
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
}
#site-footer ul li{
    line-height: 1.2;
    margin:0.2em 1rem 0.2em 0;
}

.f-shiten h4{
    color: #004ea2;
    font-size: 2em;
}
.f-shiten h4 a:hover{
    color: #004ea2;  
}
.f-shiten h4 img{
    display: inline-block;
    vertical-align: bottom;
    height: 1.1em;
    margin-right: 0.2em;
}
.f-tel a,.f-tel a:hover{
    display: block;
    font-size: 1.8em;
    color: #333;
    font-weight: 600;
}
.f-tel a::before{
    content: "";
    display: inline-block;
    vertical-align: middle;
    background: url("../img/icon_tel.webp") no-repeat left top;
    background-size: contain;
    width: 0.9em;
    height: 0.9em;
    margin-right: 0.2em;
    margin-top: -0.2em;
}
.bottom-note{
    font-size: 0.8em;
    color: #666;
}

/*--737px以下------------------------------------*/
@media screen and (max-width: 737px)  {
#site-footer h3{
    flex-basis: 100%;
    max-width: 100%;
    height: auto;
    border-radius: 0;
    padding: 0.3em;
    margin:0 0 0.5em;
}
#site-footer ul{
    flex-basis: 100%;
    max-width: 100%;
}
.f-shiten h4{
    font-size: 7vw;
}


}





