
/* reset css */

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;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
}
 
body {
    line-height:1;
}
 
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
 
nav ul {
    list-style:none;
}
 
blockquote, q {
    quotes:none;
}
 
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

ul, li{
    list-style: none;
}
 
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.flex_around {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}

.flex_between {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.flex_wrap{
    flex-wrap: wrap;
}
  
 
/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
 
/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}
 
del {
    text-decoration: line-through;
}
 
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
 
table {
    border-collapse:collapse;
    border-spacing:0;
}
 
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
 
input, select {
    vertical-align:middle;
}

/* reset css */






body{
	font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
	font-family: Georgia, 'Hiragino Mincho ProN', 'Yu Mincho', serif;
    font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
}

.topic-text{
	    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
}

img{
	/*width: 100%;*/
	height: auto;
	max-width: 100%;
	/*margin: 0 auto;*/
	vertical-align: bottom;
}

.cf:after{
  content: "."; 
  display: block; 
  height: 0; 
  font-size:0;	
  clear: both; 
  visibility:hidden;
}


ul, li{
	list-style: none;
}

a{
	text-decoration: none;
}

b{
	font-weight: normal;
}

main{
	display: block;
}

p{
	font-size: 12px;
}

.bold{
    font-weight: bold;
}

.img-center-block{
    margin: 0 auto;
    text-align: center;
}

.center{
    text-align: center;
}

.section-block-headline.center{
    text-align: center;
}

.center-contact-bloxk{
    margin: 0 auto;
    text-align: center;
}

.center-margin-imgFloat .img{
    display: inline-block;
    margin: 52px auto;
}

.center-margin-imgFloat.three .img{
    width: 32%;
}

.float-left{
	float: left;
}

.float-right{
	float: right;
}

.section-block-headline.pink-text{
	color: #f94d9d;	
}

.banner{
    overflow: hidden;
}

.float-banner-area .banner{
    display: inline-block;
}

.nav a, .btn, .banner-wrap{
    cursor: pointer;
    /*-webkit-transition: .4s all ease-in-out;
    -o-transition: .4s all ease-in-out;
    transition: .4s all ease-in-out;*/
}

/*
.banner-wrap:hover{
    transform: scale(1.019);
}
*/

.nav a:hover, .btn:hover, .banner-wrap:hover{
    opacity: .8;
}

.btn-text{
    display: block;
    font-size: 15px;
    color: #ffffff;
    text-align: center;
    font-weight: bold;
}

.suisosui_tex {
	font-size:9px;
}

.suisosui_tex02 {
	font-size:12px;
}

.btn-wrapper{
    margin: 0 auto;
    background: url("../img/common/btn_wrapper.png");
    background-size:  !important;
    background-repeat: no-repeat !important;
}

.float-item{
    float: left;
}

.option, .catch-text{
    font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}

.option{
    color: #000000;
}

.catch-text{
    text-align: center;
    color: #4c4c4c;
}

.header{
    height: 300px;
    background: url("../img/common/header_bg.png");
    background: url("../img/common/header.png");
    background-position: center center;
    background-repeat: repeat-x;
}

.tel-area{
    font-size: 20px;
    font-weight: bold;
}

.tel-area-top:before{
    content: "";
    display: inline-block;
    width: 21px;
    height: 28px;
    background: url(../img/common/tel.png);
    background-size: 70%;
    background-repeat: no-repeat;
    vertical-align: bottom;
}

.header-option-item{
    /*display: inline-block;*/
    display: table-cell;
    vertical-align: middle;
}

.header-option-item-right-block{
    display: table-cell;
    vertical-align: middle; 
}

.tel-area-top{
    padding-bottom: 4px;
}

.tel-area span{
    display: block;
    font-size: 10.5px;
    font-weight: lighter;
}

.nav li{
    /*width: 25%;*/
    text-align: center;
}

.nav a span{
    display: block;
    padding: 4px 0;
    color: #000000;
    font-weight: bold;
}

.nav a{
    /*display: block;*/
    color: #ffffff;
}

.footer{
    background: url("../img/common/footer_bg.png");
    background: url("../img/common/footer.png");
    background-repeat: repeat-x;
    background-position: center center;
}

.copyright{
    text-align: center;
    font-size: 12px;
}

.banner-wrap{
    overflow: hidden;
}

.section-headline{
	color: #58a7f0;
	color: #45caf5;
	text-align: center;
}

.section-block-headline{
    color: #58a7f0;
    font-weight: bold;
    text-align: center;
}

.simple-section-detail .detail-text{
	text-align: center;
}

.bg-pink{
	display: inline-block;
	background: #f9358f;
	color: #ffffff;
    font-weight: bold;
}

.introduce-item-detail{
	line-height: 23px;
}

.simple-section{
	margin: 33px 0;
	background: url("../img/common/simple_section_bg.png");
    background-position: center;
}

.section-headline.kasou:after{
	content: "";
	display: block;
	height: 25px;
	background: url(../img/common/seciton-headline-bg.png);
    background-repeat: no-repeat;
    background-position: center center;
}

.contact-area{
	cursor: pointer;
}

.only-now_white{
    display: block;
    color: #ffffff;
    font-size: 18px;
}

.only-now_black{
    display: block;
    padding: 4px 0;
    color: #000000;
    font-size: 10px;
    font-weight: bold;
}

@media screen and (min-width: 768px){

    .sp-only{
        display: none;
    }

    .sp-br{
        display: none;
    }

    .inner{
        width: 1002px;
        width: 87%;
        max-width: 1002px;
        margin: 0 auto;
    }

    .default-detail-text{
    	line-height: 25px;
    }

    .header-top{
        padding-top: 21px;
    }
    .header-nav{
        margin-top: 26px;
        width: 100%;
    }

    .header-nav ul{
        width: 100%;
    }

    .header-top-rightArea{
        /*width: 600px;
        width: 71%;
        max-width: 600px;
        float: right;*/

        /* width: 600px;
        width: 75%;
        max-width: 600px; */
        /* float: right; */
    }

    .header-top-rightArea .contact-area .contact-btn{
        width: 93%;
    }

    .header-top-rightArea .contact-area{
        /*padding-right: 13px;*/
    }

    .header-top-leftArea{
        width: 24%; 
        float: left;
    }

    .header-top-leftArea .header-logo{
        max-width: 160px;
    }

    .nav a{
        font-size: 18px;
    }

    .nav a span{
        font-size: 10px;
    }

    .option-nav{
        /*width: 55%;*/
        margin: 0 auto;
        text-align: center;
    }

    .option-nav li:nth-of-type(2), .option-nav li:nth-of-type(3), .option-nav li:nth-of-type(4), .option-nav li:nth-of-type(5){
        width: initial;
    }

    .btn-wrapper{
        width: 365px;
        height: 55px;
        margin: 35px auto;
    }

    .product .btn-wrapper{
        margin: 67px auto;
    }

    .btn-text{
       line-height: 55px;
    }

    .catch-text{
        line-height: 35.3px;
    }

    .banner{
        margin-top: 45px;
    }

    .banner.between{
       /*width: 43.2%;*/
       margin: 30px auto 0 auto;
       text-align: center;
    }

    .footer{
        height: 314px;
        position: relative;
    }

    .footer .inner{
        position: absolute;
        right: 0;
        left: 0;
        margin: auto;
        top: 190px;
    }

    .footer nav{
        max-width: 800px;
        margin: 0 auto;
    }

    .copyright{
        padding-top: 55px;
    }

	.section-headline{
		font-size: 39px;
	    padding-bottom: 50px;
	}

    .section-block-headline{
    	font-size: 36px;
    }

    .simple-section{
    	padding: 65px 0 65px 0;
    }

    .simple-section .section-block-headline{
    	padding-bottom: 25px;
    }

    .section-block-headline .small{
    	font-size: 27px;
    }

    .breadcrumb{
    	/*width: 1000px;*/
        width: 86%;
        max-width: 1000px;
    	margin: 0 auto;
    	padding-bottom: 35px;
    }

    .breadcrumb li{
    	float: left;
	    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    }

    .breadcrumb a{
    	font-size: 12px;
    	color: #8c8c8c;
    }

    .main{
        margin-top: -75px;
        min-height: calc(100vh - 614px);
    }

    .section-headline.kasou:after{
        margin-top: 5px;
    }

    .center-contact-block{
        /*width: 475px;*/
        width: 490px;
    }

    .float-banner-area{
        width: 90%;
        margin: 0 auto 8% auto;
    }

    .float-banner-area .banner{
        width: 48%;
    }

    .float-banner-area .center-contact-block{
        width: 100%;
    }

    .float-banner-area .banner:first-of-type{
        margin-right: 16px;
    }

    .header-option-item.tel-area{
        -webkit-transform: translateX(-15px);
        -ms-transform: translateX(-15px);
        -o-transform: translateX(-15px);
        transform: translateX(-15px);
    }

    .footer .option-nav{
        margin: 20px auto 0 auto;
        max-width: 360px;
    }

    .option-nav .cf{
        display: flex;
        justify-content: center;
    }

    .copyright{
        padding-bottom: 25px;
    }


}

@media screen and (max-width: 950px){
    #header .inner{
        width: 98%;
    }
}


@media screen and (max-width: 767px){

    .pc-only{
        display: none;
    }

    .pc-br{
        display: none;
    }

    .sp-nav{
        display: none;
        padding: 10px;
        background: #58A7F0;
        background: #58C6E6;
    }

    .sp-nav li{
        width: 50%;
        height: 34px;
        padding: 10px 0;
    }

    .sp-nav li span{
        font-size: 10px;
    }

    .only-now{
        margin-top: 2px;
    }

    .only-now_white{
        font-size: 14px !important;
    }

    .only-now_black{
        font-weight: bold;
    }

    .center-margin-imgFloat .img{
        margin: 22px auto;
    }

    #header .inner{
        width: auto;
    }

    .header-top-rightArea .btn-item.contact-area{
        margin-right: 0;
    }

    .bg-pink{
        padding: 8px;
    }

    p{
        line-height: 23px;
    }

    dt, dd{
        font-size: 12px;
    }

    .sp-left-text{
        text-align: left !important;
    }

    .main{
        padding-top: 100px;
        min-height: calc(100vh - 513px);
    }

    .inner{
        margin: 0 8px;
        margin: 0 1.63rem;
    }

    .nav a{
        font-size: 14px;
    }

    .nav a span{
        font-size: 10px;
    }

    .header{
        width: 100%;
        height: 125px;
        background-size: 100% 100%;
        background-size: contain;
        height: 100px;
        background: url("../img/common/s_header_bg.png");
        background-size: 124% 140%;
        background-repeat: no-repeat;
        background-position: -42px 0px;
        position: fixed;
        z-index: 11;
    }

    .header-top-leftArea{
        /* width: 41%; */
        width: 25.2vw;
        /* left: 0;
        height: 29px;
        top: 0;
        bottom: 0;
        margin: auto;
        bottom: 0;
        margin: auto; */
        max-width: 240px;
        /* height: 6vw; */
    }

    .header-top-rightArea{
        /* width: 76%;
        width: 66%;
        width: 61.5vw;
        max-width: 510px;
        right: 0%; */
        /*padding-left: 9.5%;
        padding-left: 6.5%;*/
    }

    .tel-area{
        /*width: 54%;
        width: 98px;
        font-size: 16px;*/
    }

    .header-top-rightArea .btn-item{
        display: inline-block;
        width: 48px;
        height: 48px;
        margin-right: 5px;
        position: relative;
        vertical-align: top;
    }

    .header-top-rightArea .menu-btn{
        margin-right: 0 !important;
    }


/*
    .header-top-rightArea .buy-area{
        padding-right: 7px;
    }
*/

/*
    .contact-area{
        padding: 0 7px;
    }
*/

    .menu-btn-wrap {
        height: 24px;
        position: relative;
        /* height: 25px; */
        position: absolute;
        right: 0;
        left: 0;
        margin: auto;
        /* width: 50px; */
        /* padding: 10px 0; */
        height: ;
        top: 0;
        bottom: 0;
        margin: auto;
        margin: 10px auto;
        /* height: 30px; */
    }

    .menu-btn span {
        position: absolute;
        right: 0;
        left: 0;
        margin: auto;
        width: 29px;
        height: 3.7px;
        border-radius: 3px;
        background: #ffffff;
        -webkit-transition: .4s all ease-in-out;
        -o-transition: .4s all ease-in-out;
        transition: .4s all ease-in-out;
    }

    .header-top .cf{
        /*display: table;*/
        /* width: 100%;
        position: relative;
        height: 48px; */
    }

    .header-float-item{
        /*display: table-cell;
        vertical-align: middle;*/
        /* position: absolute; */
    }


    .menu-btn span:first-of-type {
        top: 15px;
        top: 0;
    }

    .menu-btn span:nth-of-type(2) {
        top: 25px;
        top: 9px;
    }

    .menu-btn{
        background: #f15ba4;
    }

    .menu-btn span:last-of-type {
        bottom: 2.5px;
    }

    .menu-btn-textWrap {
        width: 100%;
        bottom: 3.5px;
        position: absolute;
        text-align: center;
        font-size: 10px;
        color: #ffffff;
    }

    .header-top{
        padding-top: 11px;
    }

    .catch-text{
        font-size: 12px;
        line-height: 18px;
    }

    .menu-btn.active span:nth-of-type(1){
        transform: rotate(45deg);
    }

    .menu-btn.active span:nth-of-type(1), .menu-btn.active span:nth-of-type(3) {
        top: 9px;
        bottom: initial;
    }

    .menu-btn.active span:nth-of-type(2) {
        display: none;
    }

    .menu-btn.active span:nth-of-type(3) {
        transform: rotate(-45deg);
    }

    .btn-wrapper{
        width: 87%;
        max-width: 400px;
        margin: 0 auto;
        background-size: 100% 100%;
    }

    .btn-text{
        padding: 18px 0;
        /* width: 77%; */
        margin: 20px auto;
        font-size: 14px;
    }

    .banner{
        width: 95%;
        margin: 0 auto;
    }

    .footer{
        background: url("../img/common/s_footer_bg.png");
        background-position: center center;
        background-size: 100% 100%;
        background-size: 100% 120%;
        background-position: center -48px;
    }

    .footer .inner{
        max-width: 330px;
        margin: 0 auto;
   	    padding-top: 120px;
   	    padding-top: 91px;
        padding-top: 72px;
        padding-top: 100px;
    }

    .footer li{
    	width: 50%;
    }

    .footer li:nth-of-type(1), .footer li:nth-of-type(2){
    	/*margin-bottom: 25px;*/
    }

    .footer li{
        margin-bottom: 20px;
    }

    .footer li span{
    	/*font-size: 12px;*/
    }

    .copyright{
        /*padding-top: 15px;*/
    	font-size: 10px;
    }

    .breadcrumb{
        display: none;
    }

    .section-headline{
        padding-top: 30px;
        padding-bottom: 25px;
        font-size: 20px;
    }

    .section-block-headline{
        line-height: 20px;
    }

    .simple-section{
        margin: 15px 0;
        background-size: cover;
    }

    .one-img-block{
        padding: 10px 0;
    }

    .company-item-right .company-item-block{
        margin-top: 15px;
    }

    .btn-text{
        font-size: 12px;
    }

    .section-headline.kasou:after{
        background-size: 100%;
    }

    .complex-main .section-headline{
        margin: 0 1.6rem;
    }
    
    .section-headline.kasou:after{
        width: 85%;
        height: 20px;
        margin: 0 auto;
    }

    .center-contact-block{
        width: 81%;
        max-width: 350px;
        margin: 0 auto;
    }

    .section-block-headline{
        font-size: 16px;
    }

    .float-banner-area{
        margin: 15px 0 0 0;
        margin: .3vw 0 6vw 0;
        text-align: center;
    }
    
    .float-banner-area .banner:nth-of-type(2){
        margin: 10px auto 27px auto;
        margin: .95vw auto .95vw auto;
    }

    .banner.between{
        padding: 10px 0 15px 0;
    }

    .header-option-area{
        display: table;
        /* width: 42%; */
    }


	


}



@media screen and (max-width: 320px){

    .menu-btn-wrap{
        margin: 8px auto;
    }

    .header-top-rightArea{
        padding-left: 5px;
    }

    .header-option-area{
        right: 2px;
    }

    .header-top-rightArea .btn-item{
        width: 44px;
        height: 44px;
        width: 43px;
        height: 43px;
    }

    .contact-area{
        padding: 0 9px;
        padding: 0 1vw;
    }

    .header-top-rightArea .btn-item.contact-area{
        padding: 0 1px 0 0;
    }

    .menu-btn-textWrap{
        bottom: 1px;
    }
}




