@charset "utf-8";
/* CSS Document */

html {
	margin: 0;
	padding: 0;
}

body {	
	text-align: center;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
    font-family: 'Kosugi Maru', sans-serif;
}

.contents {
	overflow: hidden;
    background-color: #F7FAFD;
/*    background-color: aqua;*/
}

h1,h2{
    margin: 0;
}

.res img {
	max-width: 100%;
	/*min-width: 500px;*/
	height: auto;
}

.MV {
    position: relative;
    z-index: 1;
    background-color: white;
}

.loop {
	width: 100%;
	position: absolute;
	background: url(/lp/general/img/mv_bg_loop2.png) repeat-x 0 0;
	animation: bg-slider 40s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
}

.loop_mug {
	width: 100%;
	position: absolute;
	background: url(/lp/general/img/mv_bg_loop2_m.png) repeat-x 0 0;
	animation: bg-slider 40s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
}

.loop_towel {
	width: 100%;
	position: absolute;
	background: url(/lp/general/img/mv_bg_loop2_t.png) repeat-x 0 0;
	animation: bg-slider 40s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
}

@keyframes bg-slider {
	from { background-position: 0 0; }
    to { background-position: -1500px 0; } /* 1518pxとは使用した背景画像の長さ */
}

.loop img {
	margin-top: 230px;
    margin-bottom: 230px;
}

.loop_mug img {
	margin-top: 230px;
    margin-bottom: 230px;
}

.loop_towel img {
	margin-top: 230px;
    margin-bottom: 230px;
}

.sentence{
    background-image: url(/lp/general/img/pc_bg_1.png); /* 画像ファイルの指定 */
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    position: relative;
    top: -6px;
    padding-top: 48.78%;
    color: #C8161E;
}

.sentence p{
    position: absolute;
    top: 14%;
    left: 20%;
    right: 20%;
    line-height: 3em;
    font-size: 1.8vw;
}

.fade_nonscroll {
    animation-name: fadenon;
    animation-duration: 1s;
}
@keyframes fadenon {
from {
    opacity: 0;
    transform: translateY(20px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

.link-t-a{
    padding-top: 70px;
    margin-top: -70px;
}

.fade_off {
    opacity : 0;
    transform : translate(0, 100px);
    transition : all 500ms;
}

.fade_on {
    opacity : 1;
    transform : translate(0, 0);
}


.button {
    display: inline-block;
    width:60%;
    padding: 2%;
	text-decoration: none;
	font-size: 2.5vw;
	color: #ffffff;
	border-radius:25px;
	background: #C8161E;
    transition: .2s;
    margin-top: 2%;
    margin-bottom: 8%;
}

.button:hover {
    color: #ffffff;
    background: #F5B08E;
    text-decoration: none;
}

.nav {
    background-image: url(/lp/general/img/pc_rec.png); /* 画像ファイルの指定 */
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
}

.nav_sp {
    background-image: url(/lp/general/img/sp_rec.png); /* 画像ファイルの指定 */
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
}

.nav li{
	display:inline-block;
}

.nav_sp li{
	display:inline-block;
}

.flex_container {
    display: flex;
    flex-wrap: wrap;
    max-width: 950px;
    margin: 0 auto;
}

.flex_box {
    margin: 0 auto;
}

.imp_title img{
    vertical-align:top;
}

.imp_bg {
    position: relative;
    top: -20px;
    float: right;
    width: 256px;
/*    height: 620px;*/
    background-color: #FFF;
    margin: 0 auto;
    padding: 10px;
    color: #404040;
}

.imp_bg_p {
    text-align:left;
    height:180px;
    line-height: 25px;
 }

.user {
    text-align: right;
    height: 30px;
    font-size: 13px;
    padding-right: 10px;
}

.button_s {
    display: inline-block;
    width:150px;
    position: relative;
    top: -5px;
    padding: 5px;
	text-decoration: none;
	font-size: 15px;
	color: #ffffff;
	border-radius:25px;
	background: #C8161E;
    transition: .1s;
    font-family: 'Lato', sans-serif;
}

.button_s:hover {
    color: #ffffff;
    background: #F5B08E;
    text-decoration: none;
}

.item_list{
    margin-top: 10%;
}

.flexbox_select {
	margin:0 auto;
	max-width: 900px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 25px 10px;
}

.flexbox_select_mug {
	margin:0 auto;
	max-width: 800px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 25px 10px;
}

.flexbox_select_towel {
	margin:0 auto;
	max-width: 800px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 25px 10px;
}

.flexbox_select_item {
	width: 150px;
	font-size:1.5vw;
	padding-bottom:30px;
}

.flexbox_select_item img{
	width: 115px;
}

.flexbox_select_item a{
	display: inline-block;
	color: #474342;
	text-decoration:none;}

.flexbox_select_item img:hover{
		-webkit-transform: rotate(5deg);
		-moz-transform: rotate(5deg);
		-ms-transform: rotate(5deg);
		-o-transform: rotate(5deg);
	transform: rotate(5deg);}

.flexbox_select_item a:hover{
	transition: 0.2s;
	color: red;
}

/* FOOTER STYLE
----------------------- */

footer {
    padding: 25px 0;
    background-color:#C8161E; 
    color: white;
}

footer a {
    color: white;
    text-decoration: none;
    border-bottom: 1px solid white;
    padding-bottom: 4px;
    
}

footer p{
    line-height: 0px;
}

footer a:hover {
    text-decoration: none;
    border-bottom: none;
}

.footer_tel a{
    border: none;
}

ul {
    margin-top: 0;
    margin-bottom: 10px;
    display: block;
    list-style-type: disc;
}

.list-inline {
    margin-left: -5px;
    margin-top: 25px;
    padding-left: 0;
    list-style: none;
}

.list-inline>li {
    display: inline-block;
    white-space:nowrap;

}


.copyright{
    font-family: 'Lato', sans-serif;
    margin: 40px 0 10px 0;
}

.footer_tel{
    font-size: 35px;
}

.footer_time{
    font-size: 15px;
}

.pc {
	display: block;
}
.sp {
	display: none;
}



@media screen and (min-width:1143px) {
    .sentence {
	    padding-top: 0;
	    height: 649px;
    }
    
    .sentence p {
	    font-size: 20px;
        line-height: 3em;
        top: 17%;
    }
    
    .button {
        width:700px;
        padding: 20px;
	    font-size: 25px;
        margin: 15px 0 115px; 
    }
    
    .item_list{
        margin-top: 70px;
    } 
 
    .flexbox_select_item {
	    font-size:14px;
    }
}


@media screen and (min-width:1000px) {
    .flexbox_select_item {
	    font-size:14px;
    }
}


@media screen and (max-width:899px) {
    .flex_container {
        max-width: 80%;
        padding-right: 1%;
    }
}


@media screen and (max-width:749px) {
    .loop{
        background-size: 170%;
    }
    
    .loop_mug{
        background-size: 170%;
    }
    
    .loop_towel{
        background-size: 170%;
    }
    
    .loop img {
        margin-top: 25%;
        max-width: 55%;
    }
    
    .loop_mug img {
        margin-top: 25%;
        max-width: 55%;
    }
    
    .loop_towel img {
        margin-top: 25%;
        max-width: 55%;
    }
    
    .loop_bg{
        width: 230%;
    }
    
    .flex_box {
	    width: 40%;
    }
    
    .imp_bg {
        width: 82.5%;
    }
    
    .imp_bg_p {
        height: 210px;
        line-height: 180%;
        font-size: 2vw;
    }

    .user {
        height: 0; 
        font-size: 1.5vw;
        padding-right: 2%;
    }
    
    .button_s {
        width: 80%;
        font-size: 1.8vw;
    }    
    
    .flexbox_select_item {
	    font-size:1.8vw;
    }    
}

@media screen and (max-width:600px) {
    .list-inline>li{
        font-size: 2.3vw;
        padding-left: 3px;
        padding-right: 3px;
    }
    
    .copyright{
        font-size: 2vw;
        margin-top: 7%;
    }
    
    .imp_bg {
        width: 81%;
    }
    
    .imp_bg_p {
        height: 180px;
        line-height: 170%;
        font-size: 2vw;
    }
    
    .button_s {
        font-size: 2.5vw;
}
    
    .flexbox_select_item {
	    font-size:2.3vw;
    }    
}


@media screen and (max-width:500px) {
     .flex_container {
        max-width: 90%;
    }
    
    .imp_bg {
        width: 80%;
    }
    
    .imp_bg_p {
        line-height: 180%;
        font-size: 2.3vw;
    }
    
    .flexbox_select_item {
	    font-size:2.2vw;
        width: 110px;
    }    
}


@media screen and (max-width:450px) {    
    .pc {
	    display: none;
    }
    .sp {
	    display: block;
        margin-right: 0.5%;
    }
    
    .loop {
	    animation: bg-slider 50s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
    }
    
    .loop_mug {
	    animation: bg-slider 50s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
    }
    
    .loop_towel {
	    animation: bg-slider 50s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
    }
    
    .imp_bg {
        width: 78%;
    }
    
    .imp_bg_p {
        height: 170px;
        line-height: 160%;
        font-size: 2.5vw;
    }
    
    .button {
        width: 70%;
        padding: 3%;
        font-size: 3.5vw;
        margin-top: 0%;
        margin-bottom: 15%;
    }
    
    .flexbox_select_item {
	    font-size:2.4vw;
    } 
}


@media screen and (max-width:399px) {
    .flex_container {
        max-width: 90%;
/*        padding-right: 1%;*/
    }
    
    .flex_box {
        width: 46%;
    }
    
    .imp_bg {
        width: 78%;
    }
    
    .imp_bg_p {
        height: 150px;
        font-size: 2.6vw;
    }
    
    .flexbox_select_item {
	    font-size:2.3vw;
        width: 90px;
    } 
    
    .tel_title{
        font-size: 4vw;
    }
    
    .footer_tel{
        font-size: 9vw;
    }
    
    .footer_time{
        font-size: 4vw;
    }
}


@media screen and (max-width:299px) {
    .imp_bg {
        width: 75%;
    }
    
    .imp_bg_p {
        height: 140px;
        line-height: 150%;
        font-size: 3vw;
    }
    
    .flexbox_select_item {
        font-size: 2.9vw;
        width: 80px;
    }
    
}








