/* CSS Document */
@charset "utf-8";
/*-------------------------------------
    common　CSS
--------------------------------------*/
@media screen and (max-width:1024px) {
    html {
        font-size: 1.5vw;
    }
}
html {
    scroll-behavior: smooth;
}
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}
body, html, div, p, span, li, ul, a, h1, h2, h3, h4, h5, h6, input, button {
    font-family: "Helvetica", "Century Gothic", "Avenir", sans-serif, "Hiragino Sans", "Hiragino Kaku Gothic ProN";
    line-height: 1.5;
    /*color: #333;*/
}
body.IE, .IE div, .IE p, .IE span, .IE li, .IE ul, .IE a, .IE h1, .IE h2, .IE h3, .IE h4, .IE h5, .IE h6, .IE input, .IE button {
    font-family: "Helvetica", "Century Gothic", "Avenir", sans-serif, "Hiragino Sans", "Hiragino Kaku Gothic ProN";
}
p {
    font-family: "Helvetica", "Arial", "museo-sans", "sans-serif";
    font-size: 1rem;
}
.secInner {
    max-width: 1920px;
    margin: 0 auto;
}
h1, p {
    margin: 0px;
}
ul, li {
    list-style-type: none;
    padding: 0px;
    margin: 0px;
}
a {
    text-decoration: none;
}
* {
    box-sizing: border-box;
}
/*-------------------------------------
    first view
--------------------------------------*/
.firstView h1 {
    margin-top: 80px;
}
.contentWidth > .secInner {
    max-width: 1024px;
    margin: 0 auto;
    padding: 0px 1rem;
}
.background {
    background-color: #fff;
    border-radius: 16px;
    overflow: hidden;
    padding: 3rem 2rem;
    box-sizing: border-box;
    text-align: center;
}
.contentWidth > .secInner {
    max-width: 1024px;
    margin: 0 auto;
    padding: 0px 1rem;
}
.secInner {
    max-width: 1920px;
    margin: 0 auto;
}
.img-responsive {
    max-width: 100%;
}
/*h1 img {
    width: 100%;
	max-width: 1920px;
}*/
/* youtube */
.youtube_wrap {
    width: 100%;
    height: 0;
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
    margin-bottom: 50px;
}
.youtube_wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
/*-------------------------------------
    SEO
--------------------------------------*/
.product-copy-wrap {
    width: 50%;
    max-width: 900px;
    margin: 0 auto;
    padding: 100px 0;
}
.product-copy-title {
    font-size: calc(17px + 10 * (100vw - 320px)/1020) !important;
    font-weight: 600;
    text-align: center;
    color: #fff !important;
    display: block;
}
.product-copy-text {
    text-align: center;
    margin: 10px auto;
    font-size: calc(15px + 4 * (100vw - 320px)/1020);
    background: #fff;
    padding: 2rem;
    border-radius: 10px;
}
@media screen and (max-width: 416px) {
    .product-copy-wrap {
        width: 90%;
        margin: 0 auto;
        padding: 30px 0;
    }
    .product-copy-text {
        text-align: center;
        margin: 10px auto;
        font-size: calc(15px + 4 * (100vw - 320px)/1020);
        background: #fff;
        padding: 2rem;
        border-radius: 10px;
    }
}
/*-------------------------------------
    pkg
--------------------------------------*/
.number-title {
    font-size: 50px;
    font-weight: 700;
    font-family: "Arial Black", "museo-sans", -apple-system, BlinkMacSystemFont, "Helvetica", sans-serif;
}
.package-img {
    width: 40%;
    margin: 0 auto;
}
.package-img img {
    width: 100%;
    padding: 30px 0;
}
/*-------------------------------------
    contents
--------------------------------------*/
.section-title.contents {
    background: #f5e82a;
    color: #333333;
}
.section-title {
    display: block;
    font-family: "Arial Black", "museo-sans", -apple-system, BlinkMacSystemFont, "Helvetica", sans-serif;
    font-size: calc(27px + 10 * (100vw - 320px)/448);
    font-weight: 600;
    height: 2%;
    width: 100%;
    margin: 0;
    border-radius: 16px 16px 0 0;
    text-align: center;
}
.background_b {
    background-color: #fff;
    /*  border: 6px solid #f5e82a;*/
    border-radius: 16px;
    overflow: hidden;
    padding: 1rem;
    box-sizing: border-box;
    text-align: center;
    margin: 20px auto;
}
.flat-head {
    border-radius: 0 0 16px 16px;
}
.m-0 {
    margin: 0;
}
/*-------------------------------------
    Explanation
--------------------------------------*/
.contentGrid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    /*  grid-column-gap: 30px;*/
    grid-row-gap: 0px;
    padding: 30px 0;
}
.item-left {
    grid-row: 1/2;
    grid-column: 1/2;
    align-self: baseline;
    text-align: left;
}
.item-right {
    grid-row: 1/2;
    grid-column: 2/3;
    align-self: center;
}
.asset-list {
    text-align: left;
}
.asset-list ol {
    padding-left: 1em;
}
.asset-list ol > li {
    text-indent: -25px;
    padding-left: 1em;
    font-size: calc(16px + 2 * (100vw - 320px)/1020);
    margin-bottom: 0.5em;
}
.background_a h4, .background_b h4, .background_c h4, .background_d h4 {
    padding: 0.3em 0.3em 0.3em 0.4em;
    color: #fafafa;
    border-radius: 10px;
    text-align: left;
    font-size: calc(16px + 5 * (100vw - 320px)/1020);
    margin: 20px 0;
}
.background_e h4 {
    border-radius: 100px;
    padding: 0.3em 0 0.3em 0.4em;
    color: #fafafa;
    text-align: left;
    font-size: calc(16px + 5 * (100vw - 320px)/1020);
    margin: 20px 0;
}
.background_a h4::before, .background_b h4::before, .background_c h4::before, .background_d h4::before, .background_e h4::before {
    height: 1.3em;
    width: 1.3em;
    color: #fafafa;
    background: #000;
    display: inline-flex;
    justify-content: center;
    align-self: center;
    align-items: center;
    border-radius: 1em;
    font-size: 90%;
    box-shadow: 0 0 0 1px #fff, 0 0 0 2px #000000;
    margin-right: 0.3em;
}
/*		yellow      */
.background_a {
    background-color: #fff;
    border: 6px solid #FFCC00;
    border-radius: 16px;
    overflow: hidden;
    padding: 1rem;
    box-sizing: border-box;
    text-align: center;
    margin: 20px auto;
}
.background_a h4 {
    background: #fabe00;
}
.background_a h4::before {
    content: "1";
}
/*		blue      */
.background_b h4 {
    background: #00a8f4;
}
.background_b h4::before {
    content: "2";
}
.copyright-text {
    text-align: center;
    padding: 60px 0 0;
}
.background_c {
    background-color: #fff;
    border: 6px solid #E51C24;
    border-radius: 16px;
    overflow: hidden;
    padding: 1rem;
    box-sizing: border-box;
    text-align: center;
    margin: 20px auto;
}
.background_c h4 {
    background: #e60012;
}
.background_c h4::before {
    content: "3";
}
@media screen and (max-width: 820px) {
    #recommended {
        width: 85%;
    }
    .enjoytoy h2 {
        width: 85%;
        padding: 1em;
        line-height: 1.4;
    }
}
@media screen and (max-width: 758px) {
    .contentWidth > .secInner {
        padding: 0px 1rem;
    }
    .item-left {
        grid-row: 1/2;
        grid-column: 1/3;
    }
    .item-right {
        grid-row: 2/3;
        grid-column: 1/3;
    }
}
@media screen and (max-width: 480px) {
    .firstView h1 {
        margin-top: 68px;
    }
    .number-title {
        margin: 10px auto 5px;
        font-size: 2rem;
    }
    .package-img {
        width: 70%;
    }
    .contentSingle h5 {
        font-size: calc(14px + 5 * (100vw - 320px)/1020);
        padding: 3px 0;
    }
    .enjoytoy h2 {
        line-height: 1.2;
    }
}
/*-----------------------
    pagetop
-------------------------*/
#page_top {
    width: 50px;
    height: 50px;
    position: fixed;
    right: 0;
    bottom: 10px;
    background: #fff;
    opacity: 0.8;
    border-radius: 50%;
    filter: drop-shadow(2px 4px 6px rgba(0, 0, 0, .2));
	z-index: 1;
}
#page_top a {
    position: relative;
    display: block;
    width: 50px;
    height: 50px;
    text-decoration: none;
}
#page_top a::before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f106';
    font-size: 25px;
    color: #141414;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -15px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}