/*common*/
.item_name{
    text-align: center;
    font-size: 1.6rem;
    font-family: "Zen Old Mincho", serif;
}
.item_price{
    text-align: center;
    font-size: 2.4rem;
    line-height: 1;
    font-family: "Zen Old Mincho", serif;
}
.item_price .s_01{
    font-size: 1.5rem;
}
.item_price .normal_price{
    font-size: 1.5rem;
    font-weight: normal;
    margin-right: 0.3em;
    color: #000;
}
.order a {
    position: relative;
    display: block;
    text-align: center;
    width: 100%;
    max-width: 24rem;
    background: linear-gradient(125deg, rgba(180, 118, 30, 1) 0%, rgba(237, 202, 111, 1) 50%, rgba(180, 118, 30, 1) 100%);
    background-size: 200% 100%;
    background-position: right center;
    color: #fff;
    border-radius: 1rem;
    padding: 0.6em;
    font-weight: bold;
    transition: background-position 0.5s ease;
    font-size: 1.4rem;
    margin: auto;
    z-index: 1;
    overflow: hidden;
}
.order a:hover{
    opacity: 1;
    background-position: left center;
}
.order a::after{
    content:'';
    display: block;
    position: absolute;
    top: 50%;
    right: 7%;
    margin: auto;
    width: 6px;
    height: 6px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: translate(0, -50%) rotate(45deg);
    transition: 0.2s;
}
.order a:hover:after{
    right: 6%;
}
.contents{
    display: table;
    margin: 0.5em auto;
}
/*****only*****/
.bg_area{
    background: #2c4b7d;
    position: relative;
}

.toph2{
    font-family: "Zen Old Mincho", serif;
    font-weight: normal;
    font-size: 2rem;
    position: relative;
    padding-bottom: 0.5em;
    margin-bottom: 1em;
}
.toph2::before{
    content: '';
    background: linear-gradient(125deg, rgba(180, 118, 30, 1) 0%, rgba(237, 202, 111, 1) 50%, rgba(180, 118, 30, 1) 100%);
    width: 20rem;
    height: 0.2rem;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
.color_w{
    color: #fff;
}
/*sec_title*/
.sec_title{
    padding: 0;
}
.sec_title .container{
    max-width: none;
    padding: 0;
}
/*sec_01*/
.sec_01{
    color: #fff;
    padding-top: 2rem;
}
.sec_01 .container{
    max-width: 1120px;
}
.circle{
    position: relative;
    z-index: 10;
}
.circle::before{
    content: '';
    background: #fff;
    width: 30rem;
    height: 30rem;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50% , -50%);
    border-radius: 50%;
    z-index: -1;
    box-shadow: 5px 5px 15px rgba(0,0,0 , 0.5);
}
@media (max-width : 520px) {
    .circle::before{
        width: 25rem;
        height: 25rem;
    }
}
.circle a{
    transition: 0.2s;
}
.circle a:hover{
    opacity: 1;
    filter: contrast(0.8);
}
/*sec_02*/
.sec_02{
    position: relative;
    z-index: 10;
}

.sec_02 .container{
    background: #fff;
    max-width: 1300px;
    padding: 4rem 1rem;
    box-shadow: 5px 5px 15px rgba(0,0,0 , 0.5);
}
@media (max-width : 1323px) {
    .sec_02 .container{
        margin: 0 10px;
    }
}
.sec_02 h2{
    letter-spacing: -0.1em;
}
.sec_02 .item_area{
    max-width: calc(940px + 3rem);
    margin: 0 auto;
}
.sec_02 .title_desc{
    font-size: 1.5rem;
}
.sec_02 .desc_area{
    max-width: calc(940px + 3rem);
    margin: 0 auto 2rem;
}
.sec_02 .flex{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.sec_02 figure{
    max-width: 320px;
    margin: auto;
}
.sec_02  .item_area figure img{
    border: 1px solid rgba(43, 60, 90, 0.8);
    border-radius: 1rem;
}
/*sesc_03*/
.sec_03 h2{
    color: #ca3a28;
    font-size: 1.8rem;
}
.sec_03 h2 span{
    font-size: 2.2rem;
}
.sec_03 .container{
    background: #fff;
    max-width: 1300px;
    padding: 4rem 1rem;
    box-shadow: 5px 5px 15px rgba(0,0,0 , 0.5);
}
@media (max-width : 1323px) {
    .sec_03 .container{
        margin: 0 10px;
    }
}
.sec_03 .line{
    max-width: 1200px;
    margin: 0 auto;
}
.sec_03 figure{
    max-width: 320px;
    margin: auto;
}
.sec_03 figure img{
    border: 1px solid rgba(43, 60, 90, 0.8);
    border-radius: 1rem;
}
.sec_03 .contents{
    text-align: center;
}
/*sec_04*/
.sec_04{
    padding: 4rem 0 8rem;
    margin-bottom: -10rem;
}
.sec_04 .container{
    max-width: 1200px;
}
.sec_04 figure{
    position: relative;
    z-index: 10;
}
.sec_04 figure a{
    display: block;
}
@media (max-width : 1223px) {
    .sec_04 .container{
        padding: 0 10px;
    }
}
.smb{
    margin-bottom: 3rem !important;
}
.top_desc{
    font-size: 1.8rem;
    font-family: "Zen Old Mincho", serif;
    color: #fff;
    text-align: center;
    margin: 1em 0 0;
}