@charset "UTF-8";
/* CSS Document */
@import url("reset.css");
@import url("fonts.css");

html {
    box-sizing: border-box;
}

*,
*:before,
*:after {
    box-sizing: inherit;
}

body {
    text-align: center;
    font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    font-size: 18px;
    line-height: 180%;
    color: #333333;
    background: #fff;
}

a:hover img {
    opacity: 0.8;
    filter: alpha(opacity=60);
    -ms-filter: "alpha( opacity=60 )";
}

input:hover {
    opacity: 0.8;

    /* IE */
    filter: alpha(opacity=8);
}

.clear {
    clear: both;
}

.timer {
    margin: 0px auto 0px auto;
    padding: 10px 0px 20px 0px;
    font-size: 24px;
    color: #ff2f56;
    text-align: center;
}

.timer2 {
    margin: 0px auto 10px auto;
    padding: 0px;
    font-size: 30px;
    color: #fb0000;
    text-align: center;
    font-weight: bold;
}

/* button start  */
.anihv button {
    width: 558px;
    padding: 13px 5px 10px;
    border: 3px double #fff;
    color: #fff;
    font-size: 160%;
    cursor: pointer;
    border-radius: 2em;
    animation: regbtngreen2 0.8s infinite alternate;
}

.anihv button {
    font-size: 28px;
    font-weight: bold;
    margin-top: 10px;
}

.fa {
    display: inline-block;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@-webkit-keyframes regbtngreen2 {
    from {
        color: #fff;
        background-image: linear-gradient(#298A08, #04d339);
        box-shadow: 0 0 2px 2px #74DF00;
        /*
        box-shadow:0 0 2px 2px #74DF00;
        text-shadow:0 0 2px #fff;*/
    }

    99%,
    to {
        color: #fff;
        background-image: linear-gradient(#04d339, #298A08);
        box-shadow: 0 0 4px 8px #cfc;
        /*
        box-shadow:0 0 4px 8px #cfc;
        text-shadow:0 0 2px #fff;*/
    }
}

/*
.fa-youtube-play:before{
content:"\f16a";
box-sizing: border-box;
}
*/
/*  button end */
/*s
@-webkit-keyframes regbtngreen2{
from{
color:#fcc;
background-image:linear-gradient(#090,#0f0);
box-shadow:0 0 2px 2px olive;
text-shadow:0 0 2px #999;
}
99%,to{
color:#fff;
background-image:linear-gradient(#0f0,#0c0);
box-shadow:0 0 4px 8px #cfc;
text-shadow:0 0 3px #fcc;
}}
*/
.padding40 {
    padding: 40px 0px 40px 0px !important;
}

.padding50 {
    padding: 50px 0px 10px 0px !important;
}

.margin0 {
    margin: 0px auto 0px auto;
}

.margintop0 {
    margin: 0px auto 40px auto !important;
    padding: 40px 0px 20px 0px !important;
}

.margin40 {
    margin: 0px auto 60px auto !important;
}

.backgroundnone {
    background: none !important;
}

div#headline .padding15 {
    padding: 15px 0px 15px 0px;
}

/*******  button end *******/

/*******  headline *******/
div#headline {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 20px 0px 0px 0px;
    text-align: center;
    background: #fff url(../image/bg.jpg) no-repeat top center;

}

div#headline .headline01 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;

    text-align: center;
}

div#headline .headline02 {
    margin: -26px auto 0px auto;
    padding: 80px 0px 35px 0px;
    background: #fff url(../image/bg2.jpg) no-repeat top center;

    text-align: center;
}

div#headline .headline03 {
    margin: 0px auto 0px auto;
    padding: 45px 0px 45px 0px;
    /*
    background: linear-gradient(to right, #2d3ca0, #1e2a7a);
    */
    background: linear-gradient(to right, #00b5d6, #1e2a7a);
    text-align: center;
    line-height: 0;
}

div#headline h1 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
    font-size: 0;
    line-height: 0;
}

div#headline h2 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 30px 0px;
    text-align: center;

}

div#headline h3 {
    margin: 0px auto 30px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
    font-size: 0;
    line-height: 0;
}


.form01 {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 35px 0px 35px 0px;
    background: #004885 url(../image/form01_bg.jpg) no-repeat top center;

}

#headline .form01 {
    margin: 0 auto;
}

.form01 p {
    margin: 0px auto 12px auto;
    padding: 0px;
    text-align: center;
}

input.formtxt01 {
    background: #fff url(../image/mail_bg.png) no-repeat 16px 18px;
    width: 560px;
    padding: 18px 25px 18px 25px;
    border: 5px solid #b4b4b4;
    font-size: 18px;
    font-weight: bold;
    box-sizing: border-box;
    text-align: center;
}

.submit_btnarea {
    width: 550px;
    margin: 0 auto 15px;
}

.form_btn {
    width: 100%;
    background: #f39800;
    color: #fff;
    padding: 15px 0;
    font-size: 30px;
    border-radius: 40px;
    cursor: pointer;
    transition: all .5s ease-out;
    position: relative;
    font-weight: bold;
    border: none;
}

.chk {
    cursor: pointer
}

button[type="submit"][disabled] {
    background-color: #848484;
    color: #fff;
    cursor: default;
}


button[type="submit"][disabled]:hover {
    opacity: 1;
}

div#wrapper .banner02 .kiyaku p {
    margin: 0 auto;
    text-align: left;
}

div#wrapper .banner02 .kiyaku {
    max-width: 550px;
    margin: 0 auto;
    color: #fff;
    font-size: 12px;
    line-height: 150%;
}

.white {
    max-width: 560px;
    margin: 0 auto;
    color: #ffffff;
}



/*******  banner *******/

.brown {
    background: #59493f;
}



div#wrapper {
    margin: 0px auto 0px auto;
    padding: 0px 0px 40px 0px;
    text-align: center;
    background: #ffffff;
}

div#wrapper .padding0 {
    padding: 0px;
}

div#wrapper h2 {
    position: relative;
    margin: 0px auto 40px auto;
    padding: 20px 0px 10px 0px;
    text-align: center;
    position: relative;
    font-weight: bold;
    background-image: linear-gradient(135deg, #00b5d6 10%, #1e2a7a 100%);
    background-repeat: no-repeat;
    background-size: 140px 3px;
    background-position: bottom;
    line-height: 140%;
    font-size: 36px;

}

/*
div#wrapper h2::before {
position: absolute;
border-bottom: 2px solid #353535;
top: 100%;
left: 50%;
transform: translateX(-50%);
width: 70px;
content: '';
}
*/
div#wrapper h3 {
    margin: 0px auto 30px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;

}

div#wrapper h4 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
    font-size: 0;
    line-height: 0;
}

div#wrapper h5 {
    margin: 0px auto 40px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
    font-size: 0;
    line-height: 0;
}

div#wrapper h6 {
    width: 100%;
    margin: 6px auto 40px auto;
    padding: 25px 0px 25px 0px;
    text-align: center;
    line-height: 0;
    background: linear-gradient(to right, #00b5d6, #1e2a7a);
}

div#wrapper .subttl01 {
    margin: 0px auto 20px auto;
    padding: 20px 0px 0px 0px;
    font-size: 20px;
    font-weight: bold;
    text-align: left;
    border-bottom: 1px solid #00b5d6;
}

div#wrapper .subttl02 {
    margin: 0px auto 30px auto;
    padding: 0px 0px 30px 0px;
    text-align: center;
    line-height: 0;
    background: #000000;
}

div#wrapper .subttl03 {
    margin: 0px auto 20px auto;
    padding: 0px;
    text-align: center;
    line-height: 0;

}


div#wrapper .banner02 {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 55px 0px 10px;
    background: #faf8e3;
}

div#wrapper .banner03 {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 55px 0px 30px;
    background: #552378 url(../image/banner03_bg.jpg) no-repeat top center;
    /*
    background-size: contain;
    */
}

div#wrapper .banner04 {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 55px 0px 40px;
    background: url(../image/banner04_bg.jpg) no-repeat top center;
    background-size: cover;
}

div#wrapper .grid2 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;
    display: grid;
    gap: 30px;
    grid-template-columns: 330px 1fr;
}

div#wrapper .grid2_860 {
    max-width: 860px;
    width: 90%;
    margin: 0px auto 40px auto;
    padding: 0px 0px 0px 0px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 26px;
}

.grid2_860in {
    margin: 0px auto 30px auto;
    padding: 0px 0px 0px 0px;
    background: #f8f3ec;
}

div#wrapper .profile_wrap {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 55px 0px 20px;
    background: #ece8dd;
}

div#wrapper .profile {
    width: 860px;
    margin: 0px auto 40px auto;
    padding: 55px 0px 30px;
    background: linear-gradient(90deg, #dad5c7 0%, #dad5c7 80%, #ece8dd 100%);
}

div#wrapper .profile_left {
    background: linear-gradient(90deg, #ece8dd 0%, #dad5c7 80%, #dad5c7 100%);
}

.box01 {
    width: 700px;
    margin: 0px auto 40px auto;
    padding: 0px;
    text-align: left;
}

.box01 p {
    margin: 0px 0px 18px 0px;
    padding: 0px;
}

.center {
    text-align: center;
}

.frame01 .box01 {
    margin: 0px auto 20px auto;
    padding: 0px;
    text-align: center;
}

div#wrapper .box01in {
    height: 200px;
    overflow-y: scroll;
}

div#wrapper .box02 {
    max-width: 620px;
    width: 90%;
    margin: 0px auto 0px auto;
    padding: 0px;
    text-align: left;
}

div#wrapper .box02 p {
    margin: 0px 0px 18px 0px;
    padding: 0px;
}

div#wrapper .box02 img {
    max-width: 100%;
}

div#wrapper .box03 {
    width: 680px;
    margin: 0px auto 10px auto;
    padding: 0px;
    text-align: left;
}

div#wrapper .box03 p {
    margin: 0px 0px 18px 0px;
    padding: 0px;
}

div#wrapper .box04 {
    width: 90%;
    margin: 0px auto 40px auto;
    padding: 30px 0px 0px 0px;
    background: url("../image/blackout.png") no-repeat top center;
    z-index: 100;
}

div#wrapper .box05 {
    width: 730px;
    margin: 0px auto 40px auto;
    padding: 0px;
    text-align: left;
    z-index: 1;
    filter: alpha(opacity=30);
    -moz-opacity: 0.30;
    opacity: 0.30;
}

div#wrapper .box05 p {
    margin: 0px 0px 18px 0px;
    padding: 0px;
}

div#wrapper .img_left {
    float: left;
    margin: 0px 20px 10px 0px;
    padding: 0px;
}

div#wrapper .img_left2 {
    float: left;
    margin: 0px 0px 10px 0px;
    padding: 0px;
}

div#wrapper .img_left3 {
    float: left;
    margin: 0px 20px 10px 0px;
    padding: 0px;
}

div#wrapper .img_right {
    float: right;
    margin: 0px 0px 0px 10px;
    padding: 0px;
}

div#wrapper .img_right p {
    margin: 0px 0px 10px 0px;
    padding: 0px;
}

div#wrapper .img_right2 {
    width: 490px;
    float: right;
    margin: 0px 0px 0px 0px;
    padding: 0px;
}

div#wrapper .frame01 {
    width: 860px;
    margin: 0px auto 40px auto;
    padding: 50px 0px 30px;
    background: #fff;
    box-sizing: border-box;
}

div#wrapper .frame02 {
    width: 860px;
    margin: 0px auto 20px auto;
    padding: 30px 0px 20px;
    background-color: rgba(255, 255, 255, 0.9);
    box-sizing: border-box;
}

div#wrapper .frame03 {
    margin: 0px auto 20px auto;
    padding: 30px 0px 10px;
    background: #efe7db;
    box-sizing: border-box;
    font-size: 18px;
    text-align: left;
    font-weight: bold;
}

div#wrapper .frame04 {
    max-width: 860px;
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 30px 0px 1px;
    background: #f8f3ec;
    box-sizing: border-box;
}

div#wrapper .frame05 {
    max-width: 860px;
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 30px 0px 20px;
    background: url("../image/frame05_bg.jpg") repeat top center;
    box-sizing: border-box;
}

.frame03_ttl01 {
    margin: 0px auto 20px auto;
    padding: 8px 15px 8px;
    background: #efe7db;
    font-size: 19px;
    font-weight: bold;
    border-bottom: 2px solid #404040;
}

div#wrapper .frame06 {
    max-width: 860px;
    width: 100%;
    margin: 0px auto 60px auto;
    padding: 65px 0px 20px;
    background: linear-gradient(135deg, #e9e0d3 0%, #e9e0d3 12%, #efe7db 12%, #efe7db 100%);
    box-sizing: border-box;
}

div#wrapper .frame07 {
    max-width: 860px;
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 50px 0px 10px;
    background: #e2455d;
    color: #fff;
    box-sizing: border-box;
}

div#wrapper .frame07_ttl {
    margin: 0px auto 10px auto;
    padding: 0px;

}

div#wrapper .voice01 {
    width: 860px;
    margin: 0px auto 30px auto;
    padding: 50px 0px 20px;
    border-left: 10px solid #eeeeee;
    border-right: 10px solid #eeeeee;
    border-bottom: 10px solid #eeeeee;
    background: #fffef4;
    box-sizing: border-box;
}

div#wrapper .voice01_ttl {
    margin: 0px auto 10px auto;
    padding: 10px 5px 10px 5px;
    background: #59493f;
    color: #fff;
    text-align: center;
    box-sizing: border-box;
    font-size: 20px;
    font-weight: bold;
}

div#wrapper .voice01_box01 {
    width: 700px;
    margin: 0px auto 0px auto;
    padding: 0px;
    text-align: left;
}

div#wrapper .voice01_box01 p {
    margin: 0px 0px 18px 0px;
    padding: 0px;
}

div#wrapper .cart {
    width: 100%;
    margin: 0px auto 40px auto;
    padding: 45px 0px 15px 0px;
    border: 10px solid #000;
    background: #000 url(../image/cart_bg.jpg) no-repeat top center;
}

div#wrapper .cart_ttl {
    margin: 0px auto 30px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
    font-size: 0;
    line-height: 0;
}

div#wrapper .cart_in {
    width: 860px;
    margin: 0px auto 30px auto;
    padding: 30px 0px 10px 0px;
    background: #ffffff;
    border: 10px solid #f2efdd;
    box-sizing: border-box;
}

div#wrapper .cart_in .box01 {
    width: 790px;
    margin: 0px auto 20px auto;

}

div#wrapper .profile_ttl {
    margin: 0px auto 18px auto;
    padding: 0px 0px 0px 0px;
    text-align: center;
}

div#wrapper .profile .box01 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;
    text-align: left;
}

div#wrapper .frame01in {
    margin: 0px auto 30px auto;
    padding: 0px;
    background: #ffffff;
    box-sizing: border-box;
}

div#wrapper .frame01in2 {
    width: 730px;
    margin: 0px auto 30px auto;
    padding: 25px 0px 10px 0px;
    border: 10px solid #e8e1be;
    background: #ffffff;
    box-sizing: border-box;
}

div#wrapper .frame01_ttl {
    margin: 0px auto 18px auto;
    padding: 0px 0px 3px 0px;
    border-bottom: 1px solid #313131;
    box-sizing: border-box;
    font-size: 18px;
    font-weight: bold;
}

div#wrapper .frame01_ttl02 {
    margin: 0px auto 25px auto;
    padding: 12px 0px 12px 20px;
    border-left: 10px solid #7d7d7d;
    text-align: left;
    background: #eeeeee;
    font-size: 0;
    line-height: 0;
    box-sizing: border-box;
}

div#wrapper .frame01 .box01 {
    margin: 0px auto 0px auto;
    padding: 0px 0px 0px 0px;
    text-align: left;
}

div#wrapper .endin {
    position: relative;
    padding: 0px 0px 1px 0px;
}

div#wrapper .endin:after {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    top: 0;
    left: 0;
}

div#wrapper .end {
    position: relative;
    padding: 0;
}

div#wrapper .end:before {
    content: "";
    width: 457px;
    height: 203px;
    display: inline-block;
    background-image: url(../image/soldout.png);
    background-size: cover;
    vertical-align: middle;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    z-index: 1;
}

/*
div#wrapper .end:before {
content: "";
display: inline-block;
width: 457px;
height: 203px;
background-image: url(../image/soldout.png);
background-size: cover;
vertical-align: middle;
}
*/


div#wrapper .ul01 {
    margin: 0px auto 18px auto;
    padding: 0px;
    line-height: 150%;
}

div#wrapper .ul01 li {
    margin: 0px auto 5px 1em;
    padding: 0px;
    list-style-type: disc;
    list-style-position: outside;
    text-align: left;
}

div#wrapper .ol01 {
    margin: 0px auto 18px auto;
    padding: 0px;
}

div#wrapper .ol01 li {
    margin: 0px auto 5px 0;
    padding: 0px;
    list-style-type: decimal;
    list-style-position: inside;
    text-align: left;
}

div#wrapper .ul02 {
    margin: 0px auto 20px auto;
    padding: 0px;
    text-align: left;

}

div#wrapper .ul02 li {
    margin: 5px auto 10px;
    padding: 0px 0px 0px 45px;
    background: url(../image/icon01.png) no-repeat left 2px;

}

div#wrapper .ul03 {
    margin: 0px auto 18px auto;
    padding: 0px;
}

div#wrapper .ul03 li {
    margin: 0px auto 5px 1em;
    padding: 0px;
    list-style-type: disc;
    list-style-position: outside;
    text-align: left;
}

div#wrapper .img_change01 {
    display: none;
}

div#wrapper .table01 {
    width: 100%;
    margin: 0px auto 30px auto;
    line-height: 140%;
    text-align: center;
    border-top: 1px solid #dddddd;
    border-left: 1px solid #dddddd;
    background: #FFFFFF;

}

div#wrapper .table01 p {
    padding: 0px;
    margin: 0px auto 10px auto;
}

div#wrapper .table01 th {
    width: 25%;
    padding: 8px 15px;
    vertical-align: middle;
    border-right: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
    background: #ece8dd;
    text-align: center;
}

div#wrapper .table01 td {
    padding: 8px 15px;
    text-align: left;
    border-right: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
}


div#footer_links {
    width: 100%;
    margin: 0px auto 0px auto;
    padding: 20px 0px 10px 0px;
    border-bottom: 1px solid #eeeeee;
    text-align: center;
    font-size: 12px;
    color: #535353;
    background: #e5e5e5;
}

div#footer_links a {
    color: #535353;
    text-decoration: none;
}

div#footer {
    width: 100%;
    margin: 0px auto 0px auto;
    padding: 15px 0px;
    text-align: center;
    font-size: 12px;
    color: #535353;
    background: #bfbfbf;
}

.iframe_wrap {
    margin: 0px auto 30px auto;
    padding: 0px;
    text-align: center;
}

.pconly {
    display: block;
}

.sponly {
    display: none;
}




.reflection-img {
    width: 550px;
    height: 80px;
    margin: 0px auto;
    text-align: center;
    position: relative;
    overflow: hidden;
    border-radius: 40px;
}

.reflection {
    height: 100%;

    width: 30px;

    position: absolute;
    top: -180px;
    left: 0;
    background-color: #fff;
    opacity: 0;
    transform: rotate(45deg);
    animation: reflection 5s ease-in-out infinite;
    -webkit-transform: rotate(45deg);
    -webkit-animation: reflection 5s ease-in-out infinite;
    -moz-transform: rotate(45deg);
    -moz-animation: reflection 5s ease-in-out infinite;
    -ms-transform: rotate(45deg);
    -ms-animation: reflection 5s ease-in-out infinite;
    -o-transform: rotate(45deg);
    -o-animation: reflection 5s ease-in-out infinite;
}

@keyframes reflection {
    0% {
        transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}

@-webkit-keyframes reflection {
    0% {
        -webkit-transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        -webkit-transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        -webkit-transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        -webkit-transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}

@-moz-keyframes reflection {
    0% {
        -moz-transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        -moz-transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        -moz-transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        -moz-transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}

@-ms-keyframes reflection {
    0% {
        -ms-transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        -ms-transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        -ms-transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        -ms-transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}

@-o-keyframes reflection {
    0% {
        -o-transform: scale(0) rotate(45deg);
        opacity: 0;
    }

    80% {
        -o-transform: scale(0) rotate(45deg);
        opacity: 0.5;
    }

    81% {
        -o-transform: scale(4) rotate(45deg);
        opacity: 1;
    }

    100% {
        -o-transform: scale(50) rotate(45deg);
        opacity: 0;
    }
}

@-webkit-keyframes pulse {
    from {
        opacity: 1.0;
        /*透明度100%*/
    }

    to {
        opacity: 0.6;
        /*透明度80%*/
    }
}

.btn {
    -webkit-animation-name: pulse;
    /* 実行する名前 */
    -webkit-animation-duration: 0.5s;
    /* 0.5秒かけて実行 */
    -webkit-animation-iteration-count: infinite;
    /* 何回実行するか。infiniteで無限 */
    -webkit-animation-timing-function: ease-in-out;
    /* イーズインアウト */
    -webkit-animation-direction: alternate;
    /* alternateにするとアニメーションが反復 */
    -webkit-animation-delay: 0s;
    /* 実行までの待ち時間 */
}

@media screen and (min-width: 1800px) {

    /* PC用のスタイル記述 */
    div#wrap {
        width: 1800px;
        margin: 0px auto;
        padding: 0px;
    }

    div#headline .headline02 {
        background-size: cover;
    }
}

@media screen and (min-width: 769px) and (max-width: 950px) {
    img.miniimg {
        display: block;
    }

    img.bigimg {
        display: none;
    }

    img.frame01tab {
        display: block;
    }

    img {
        max-width: 100%;
        width
        /**************/
        : auto;
        height: auto;
        vertical-align: bottom;
    }

    div#headline {
        width: 100%;
    }

    div#wrapper {
        width: 100%;
    }
}

@media screen and (max-width: 768px) {

    body {
        text-align: center;
        font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
        font-size: 16px;
        line-height: 170%;
        background: #fff;
    }

    img.miniimg {
        display: block;
    }

    /* mini\ */
    img.bigimg {
        display: none;
    }

    /* big\ */
    img.frame01tab {
        display: block;
    }

    /* frame01tab\ */
    img {
        max-width: 100%;
        width
        /***/
        : auto;
        height: auto;
        vertical-align: bottom;
    }

    .btn1 {
        width: 100%;
    }

    .btn2 {
        max-width: 55%;
    }

    .timer {
        margin: 0px auto 0px auto;
        padding: 0px;
        font-size: 16px;
        background: #000000;
    }

    .timer2 {
        margin: 0px auto 0px auto;
        font-size: 16px;
    }

    .padding40 {
        padding: 15px 0px !important;
    }

    .padding50 {
        padding: 10px 0px 1px 0px !important;
    }

    .margin40 {
        margin: 0px auto 40px auto !important;
    }

    .backgroundnone {
        background: none !important;
        margin: 0px auto 10px auto !important;
        padding: 10px 0 0px 0 !important;
    }

    div#headline {
        margin: 0px auto 20px auto;
        padding: 0px;
        background: #fff url(../image/bg2_sp.jpg) no-repeat top center;
        background-size: 100% auto;
    }

    div#headline .headline01 {
        margin: 0px auto 0px auto;
        padding: 0px;

    }

    div#headline .headline01 img {
        width: 100%;
    }

    div#headline .headline02 {
        margin: 0px auto 0px auto;
        padding: 25px 0px 15px 0px;

    }

    div#headline .headline02 .box01 {
        margin: 0px auto 0px auto;

    }

    div#headline .headline02 img {
        max-width: 95%;

    }

    div#headline .headline03 {
        padding: 25px 0px 25px 0px;

    }

    div#headline h1 {
        margin: 0px auto;
        padding: 0px 0px 0px 0px;
        text-align: center;
    }

    div#headline h1 img {
        width: 100%;
    }

    div#headline h2 {
        margin: 0px auto 10px auto;
        padding: 0px;
        text-align: center;
    }

    div#headline h3 {
        margin: 0px auto 20px auto;
    }

    div#headline .banner01 {
        height: 15px;
        margin: 0px auto;
    }

    div#headline .banner01 img {
        width: 95%;
    }

    .banner02 {
        width: 100%;
        margin: 0px auto 40px;
        padding: 20px 0 1px 0;
    }

    .banner02 img {
        width: 100%;
        margin: 0px;
    }

    h5 img {
        width: 90%;

    }

    .form01 {
        width: 100%;
        margin: 0px auto 40px auto;
        padding: 20px 0px 10px 0px;
        background: #004885 url(../image/form01_bg_sp.jpg) no-repeat top center;
        background-size: 100% auto;
    }

    input.formtxt01 {
        width: 100%;
        padding: 10px 3px 10px 3px;
        font-size: 16px;
        font-weight: bold;
        box-sizing: border-box;
        text-align: center;
        background-image: none;
        border: 3px solid #b4b4b4;
    }

    .submit_btnarea {
        width: 100%;
        margin: 0 auto 15px;
    }

    .form_btn {
        width: 100%;
        padding: 15px 0;
        font-size: 20px;
    }

    div#wrapper .kiyaku {
        max-width: 550px;
        margin: 0 auto;
        font-size: 12px;
        line-height: 150%;
        overflow: scroll;
        height: 65px;
    }

    div#wrapper {
        padding: 0px 0px 30px 0px;
    }

    div#wrapper h2 {
        margin: 0px auto 30px auto;
        padding: 15px 0 15px 0;
        text-align: center;
    }

    div#wrapper h2 {
        width: 95%;
        position: relative;
        margin: 0px auto 40px auto;
        padding: 20px 0px 10px 0px;
        text-align: center;
        position: relative;
        font-weight: bold;
        font-size: 24px;
        width: 95%;
        background-repeat: no-repeat;
        background-size: 70px 3px;
        background-position: bottom;
        line-height: 140%;
    }

    div#wrapper h2 img,
    div#wrapper h6 img {
        width: 90%;
    }

    div#wrapper h3 {
        margin: 0px auto 20px auto;
        padding: 10px 0 0 0;
        font-size: 18px;
    }

    div#wrapper .banner02 h3 img {
        width: 90%;
    }

    div#wrapper h4 {
        width: 100%;
    }

    div#wrapper h5 {

        margin: 0px auto 20px auto;
        padding: 0px 0px 0px 0px;
        text-align: center;
    }

    div#wrapper h6 {
        width: 100%;
        margin: 6px auto 30px auto;
        padding: 12px 0px 12px 0px;

    }

    div#wrapper .subttl01 {
        margin: 0px auto 20px auto;
        padding: 10px 0px 5px 0px;
        line-height: 140%;
        font-size: 16px;
    }


    div#wrapper .banner01 {
        width: 100%;
        margin: 0px auto 40px auto;
        padding: 20px 0px 1px;
        background: url(../image/banner01_bg.jpg) repeat top center;
    }

    div#wrapper .banner02 {
        padding: 20px 0px 1px;
    }

    div#wrapper .banner03 {
        width: 100%;
        margin: 0px auto 0px auto;
        padding: 20px 0px 1px;
    }

    div#wrapper .banner04 {
        width: 100%;
        margin: 0px auto 40px auto;
        padding: 20px 0px 1px;
    }

    div#wrapper .profile_wrap {
        width: 100%;
        margin: 0px auto 40px auto;
        padding: 20px 0px 1px;
    }

    .box01 {
        width: 90%;
        margin: 0px auto 40px auto;
        padding: 0px;
        text-align: left;
    }

    .w90 {
        width: 90% !important;
    }

    .margin15 {
        margin: 0px 0px 15px 0px !important;

    }

    .box01 p {
        margin: 0px 0px 18px 0px;
        padding: 0px;
    }

    div#wrapper .profile .box01 {
        width: 90%;
    }

    .banner04 .box01 {
        width: 90%;
    }

    .banner02 .box01 {
        margin: 0px auto 20px auto;
    }

    div#wrapper .frame03 {
        padding: 15px 0px 1px;
        font-size: 16px;
    }

    div#wrapper .frame07 .box01,
    div#wrapper .frame06 .box01,
    div#wrapper .frame05 .box01,
    div#wrapper .frame03 .box01 {
        margin: 0px auto 1px auto;
    }

    div#wrapper .frame07 {
        margin: 0px auto 40px auto;
        padding: 15px 0px 1px;
        background: #e2455d;

    }

    div#wrapper .frame07_ttl {
        margin: -25px auto 10px auto;
        padding: 0px;

    }

    .frame03_ttl01 {
        margin: 0px auto 20px auto;
        padding: 7px 10px 7px;
        font-size: 17px;
        border-bottom: 1px solid #404040;
    }

    div#wrapper .frame04 {
        width: 100%;
        margin: 0px auto 30px auto;
        padding: 20px 0px 1px;

    }

    div#wrapper .frame04 .box01 {
        margin: 0px auto 10px auto;
    }

    div#wrapper .frame05 {
        width: 100%;
        margin: 0px auto 40px auto;
        padding: 20px 0px 1px;
        background: url("../image/frame05_bg_sp.jpg") repeat top center;
        background-size: 100% auto;
    }

    div#wrapper .frame06 {
        margin: 0px auto 40px auto;
        padding: 20px 0px 1px;
        background: linear-gradient(135deg, #e9e0d3 0%, #e9e0d3 6%, #efe7db 6%, #efe7db 100%);

    }

    div#wrapper .grid2 {
        margin: 0px auto 10px auto;
        padding: 0px 0px 0px 0px;
        display: block;
        gap: 30px;

    }

    div#wrapper .grid2_860 {

        margin: 0px auto 30px auto;
        padding: 0px 0px 0px 0px;
        display: block;
        grid-template-columns: 1fr 1fr;
        gap: 26px;
    }

    .grid2_860in {
        margin: 0px auto 30px auto;
        padding: 0px 0px 1px 0px;
        background: #f8f3ec;
    }

    div#wrapper .ol01,
    div#wrapper .ul01 {
        width: 95%;
    }

    div#wrapper .voice01 {
        width: 100%;
        margin: 0px auto 15px auto;
        padding: 10px 0px 1px 0px;
        border: none;
    }

    div#wrapper .voice01_box01 {
        width: 93%;
        margin: 0px auto 1px auto;
    }

    div#wrapper .voice01_box01 p {
        margin: 0px 0px 10px 0px;
        padding: 0px;
    }

    div#wrapper .voice01 .box01 img {
        width: 100%;
    }

    div#wrapper .voice01_ttl {
        margin: 0px auto 10px auto;
        padding: 5px;
        font-size: 16px;
    }

    div#wrapper .cart {
        width: 100%;
        margin: 0px auto 20px auto;
        padding: 20px 0px 1px 0px;
        border: 5px solid #000;
        background: #000 url(../image/cart_bg_sp.jpg) no-repeat top center;
        background-size: 100% auto;
    }

    div#wrapper .cart_in {
        width: 95%;
        margin: 0px auto 20px auto;
        padding: 10px 0px 1px 0px;
        background: #ffffff;
        border: 5px solid #f2efdd;
        box-sizing: border-box;
    }

    div#wrapper .cart_ttl {
        width: 95%;
        margin: 0px auto 15px auto;
        padding: 0px 0px 0px 0px;
        text-align: center;
        font-size: 0;
        line-height: 0;
    }

    div#wrapper .cart_in .box01 {
        width: 95%;
        margin: 0px auto 0px auto;
        padding: 0px;
    }

    div#wrapper .cart_in .box01 p {
        margin: 0px 0px 10px 0px;
        padding: 0px;
    }

    div#wrapper .profile {
        width: 95%;
        margin: 0px auto 15px auto;
        padding: 25px 0px 1px 0px;
        box-sizing: border-box;
    }

    div#wrapper .profile_ttl {
        width: 95%;
        margin: 0px auto 18px auto;
        padding: 0px 0px 0px 0px;
        text-align: center;
    }

    .margintop0 {
        width: 100%;
        padding: 20px 0px 10px !important;
    }

    div#wrapper .end:before {
        content: "";
        width: 90%;
        height: 30%;
        display: inline-block;
        background-size: 100% auto;
        background-repeat: no-repeat;
    }

    div#wrapper .frame01 {
        width: 95%;
        margin: 0px auto 15px auto;
        padding: 25px 0px 10px;
    }

    div#wrapper .frame02 {
        width: 95%;
        margin: 0px auto 15px auto;
        padding: 25px 0px 10px;
    }

    div#wrapper .frame02 .box01 {
        margin: 0px auto;
    }

    div#wrapper .img_left,
    div#wrapper .img_left2 {
        width: 100%;
        float: none;
        margin: 0px auto 18px auto;
        padding: 0px;
        text-align: center;
    }

    div#wrapper .img_left3 {
        display: none;
    }

    div#wrapper .img_right {
        width: 100%;
        float: none;
        margin: 0px auto 18px auto;
        padding: 0px;
        text-align: center;
    }

    div#wrapper .img_right2 {
        width: 100%;
        float: none;
        margin: 0px auto 18px auto;
        padding: 0px;
    }

    div#wrapper .frame01 .box01 {
        width: 90%;
        margin: 0px auto 0px auto;
    }


    div#wrapper .ul02 {
        width: 100%;
        margin: 0px auto 10px auto;
        padding: 0px;
        font-size: 16px;
        text-align: left;
    }

    div#wrapper .ul02 li {
        margin: 0px 0px 0px 0px;
        padding: 0px 0px 5px 25px;
        background: url(../image/icon01_sp.png) no-repeat left 5px;
    }

    div#wrapper .img_change01 {
        display: block;
        width: 100%;
        margin: 0px auto 18px auto;
        padding: 20px 0px 0px 0px;
        text-align: center;
    }

    div#wrapper .table01 td {
        display: block;
    }

    div#wrapper .tablesp th,
    div#wrapper .tablesp td {
        display: block;
        text-align: left;
    }

    .sponly {
        display: block;
    }

    .pconly {
        display: none;
    }

    div#footer_links {
        width: 100%;
        margin: 0px auto 0px auto;
        padding: 7px 0px 5px 0px;
        text-align: center;
        font-size: 12px;
    }

    div#footer_links a {
        text-decoration: none;
    }

    div#footer {
        width: 100%;
        margin: 0px auto 0px auto;
        padding: 15px 0px;
        text-align: center;
        font-size: 12px;
    }

    .iframe_wrap {
        margin: 0px auto 15px auto;
        position: relative;
        width: 100%;
        padding: calc(360 / 640 * 100%) 0 0;
    }

    iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    .anihv button {
        width: 90%;
        font-size: 20px;
    }

    .reflection-img {
        width: 90%;
        height: 12%;
        margin: 0px auto 10px auto;
        position: relative;
        overflow: hidden;
        line-height: 0;
    }

    .reflection {
        height: 90%;
        width: 30px;
        position: absolute;
        top: -180px;
    }

    div#wrapper .table01 th {
        width: auto;
        padding: 5px 10px;
    }

    div#wrapper .table01 td {
        padding: 5px 10px;
    }
}
