/*================================
// reset
=================================*/
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: normal;
}

h2 {
    margin-bottom: 45px;
}

h3 {
    margin-bottom: 30px;
}


h4,
h5,
h6 {
    margin-bottom: 15px;
}

p {
    margin-bottom: 15px;
}

a {
    text-decoration: none;
}

ul,
ol {
    list-style: none;
}


li {
    margin-bottom: 15px;
}

em {
    font-style: normal;
}

img {
    vertical-align: middle;
}

s {
    color: #999;
}



@media print,
screen and (max-width: 768px) {

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        margin-bottom: .5em;
    }
}





/*======================================
	// note flexbox
========================================*/

/*
.flexbox {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
}
*/


/*======================================
	// note float and clearfix
========================================*/

.left {
    float: left;
}

.right {
    float: right;
}

.clr {
    clear: both;
}

.cf:before,
.cf:after {
    content: "";
    display: table
}

.cf:after {
    clear: both
}

.cf {
    zoom: 1
}




/*================================
// note flexbox
=================================*/

.flexbox {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
}



/*================================
// note anchor
=================================*/

a {
    color: #4474a0;
    transition: .2s linear;
    -webkit-transition: .2s linear;
    -moz-transition: .2s linear;
    -o-transition: .2s linear;
    -ms-transition: .2s linear;
}

a:hover {
    filter: alpha(opacity=60);
    -moz-opacity: 0.6;
    opacity: 0.6;
}

a.underline {
    text-decoration: underline;
}


/*================================
// note arrow
=================================*/


.arrow_r {

    display: inline-block;
    vertical-align: top;

}

.arrow_r.x_small {
    margin-right: .5em;
    width: 6px;
}

.arrow_r.small {
    margin-right: .5em;
    width: 8px;
}

.arrow_r.medium {
    margin-right: .25em;
    width: 10px;
    margin-top: -3px;
}


.arrow_b {
    display: block;
    text-align: center;
    line-height: 1.1;
}

.arrow_b img {
    margin: auto;
}

.arrow_b.small img {
    width: 12px;
}

.arrow_b.medium img {
    width: 14px;
}


a.button_s {
    font-size: 1.3rem;
    color: #fff;
    background: #c8373c;
    border-radius: 2em;
    padding: .2em 2em;
}

a.button_m {
    font-size: 1.6rem;
    color: #fff;
    background: #c8373c;
    border-radius: 2em;
    padding: .25em 2em;
}


@media print,
screen and (max-width: 768px) {

    a.button_s {
        padding: .5em 2em;
    }

    a.button_m {
        padding: .5em 2em;
    }


    .arrow_r.small {
        margin-right: .5em;
        width: 6px;
    }

    .arrow_r.medium {
        margin-right: .25em;
        width: 8px;
        margin-top: -3px;
    }
}




/*==================================
	// note display
====================================*/

.hidetxt {
    text-indent: 110%;
    white-space: nowrap;
    overflow: hidden;
    line-height: 1;
    font-size: 1.0rem;
    display: block;
}

.d_none {
    display: none;
}

.d_nonePC {
    display: none;
}

.d_none_sale {
    display: none;
}

.d_block {
    display: block;
}

ul.read_more {
    display: none !important;
}


@media screen and (min-width: 1024px) {
    img.mob {
        display: none;
    }
}


@media screen and (min-width: 769px) and (max-width: 1023px) {
    img.pc {
        display: none;
    }

    .d_noneMOB {
        display: none;
    }
}

@media screen and (max-width: 768px) {
    img.pc {
        display: none;
    }

    .mobHidetxt {
        display: none;
    }

    ul.read_more {
        display: block !important;
    }
}



/*==================================
	// note break
====================================*/


@media screen and (min-width: 1024px) {
    br.pc {
        display: block;
    }

    br.tab,
    br.mob {
        display: none;
    }
}

@media screen and (min-width: 769px) and (max-width: 1023px) {
    br.tab {
        display: block !important;
    }

    br.pc,
    br.mob {
        display: none;
    }
}

@media screen and (max-width: 768px) {
    br.mob {
        display: block !important;
    }

    br.pc,
    br.tab {
        display: none;
    }
}


/*==================================
	// note hedding common
====================================*/

h2,
h3 {
    text-align: center;

}

h2 {
    color: #fff;
    font-size: 3.4rem;
}

h2 em {
    padding: 30px 0 30px;
    display: block;
    background: url(../img/common/bg_h2_silhouette.png) center center no-repeat;
}


h3 {
    padding: 20px 0 20px;
    font-size: 2.8rem;
    font-weight: bold;
}


/*
h3.orange{
	color:#ff8939;
	border-top:#ff8939 2px solid;
	border-bottom:#ff8939 2px solid;
	}
*/

h3.orange {
    color: #ff840c;
    border-top: #ff840c 2px solid;
    border-bottom: #ff840c 2px solid;

}







h3.pink {
    color: #dd4b9b;
    border-top: #fabedf 2px solid;
    border-bottom: #fabedf 2px solid;
}


h4 {
    padding: 8px 0 6px;
    font-size: 2.2rem;
}


@media print,
screen and (max-width: 768px) {

    h2 {
        font-size: 2.6rem;
    }


    h2 em {
        background: url(../img/common/bg_h2_silhouette_mob.png) center center no-repeat;
        background-size: 100%;
    }

    h3 {
        font-size: 2.4rem;
        padding: 10px 0 10px;
        line-height: 1.4;
    }


    h4 {
        padding: 0px 0 0px;
    }
}



/*==================================
	// note font size 
====================================*/

.f_10 {
    font-size: 1.0rem !important;
}

.f_11 {
    font-size: 1.1rem !important;
}

.f_12 {
    font-size: 1.2rem !important;
}

.f_13 {
    font-size: 1.3rem !important;
}

.f_14 {
    font-size: 1.4rem !important;
}

.f_16 {
    font-size: 1.6rem !important;
}

.f_18 {
    font-size: 1.8rem !important;
}

.f_20 {
    font-size: 2.0rem !important;
}

.fw_normal {
    font-weight: normal !important;
}

.fw_bold {
    font-weight: bold;
}



/*==================================
	// note common
====================================*/



.notice {
    font-size: 1.2rem;
}


.notice li {
    margin-bottom: 0;
}

.notice_number {
    font-size: 1.2rem;
    font-weight: normal;
}



ul.indent li::before {
    content: '\25CF';
    /*まる*/
    margin-right: 5px;
}

ul.indent.orange li::before {
    color: #ff8939;
}


/*==================================
	// note color
====================================*/

.red {
    color: #f00;
}



/*==================================
	// class .bannerArea
====================================*/

.bannerArea {
    width: 95%;
    max-width: 1080px;
    margin: auto auto 3em;
    padding-top: 2em;
}

.bannerArea a {
    margin-bottom: 1em;
    display: block;
}


.bannerArea .visible-pc {
    display: block;
}

.bannerArea .visible-sp {
    display: none;
}

/* chrome opera */
@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
    .bannerArea ul li {
        padding-bottom: .1em;
    }
}



@media print,
screen and (max-width: 768px) {
    .bannerArea img.visible-pc {
        display: none !important;
    }

    .bannerArea img.visible-sp {
        display: block;
    }


}