@charset "UTF-8";


@font-face{
  font-display: swap;
  font-weight: 600;
  font-style: normal
  font-family: 'MuseoModerno';
  src: url('/fonts/MuseoModerno-VariableFont_wght.ttf') format('ttf');
 }



html{font-size:100%;}

	@media screen and ( max-width:479px ){
		html{font-size:80%;}
	}
	
	
/** ----------
body
------------- */
body{margin: 0; padding: 0; font-size: 1.2em; line-height: 1.8; letter-spacing: 0.2rem; color: #444; font-family:ヒラギノ角ゴシック, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", メイリオ, sans-serif; background: #fecacb;}
body.white{margin: 0; padding: 0; font-size: 1.2em; line-height: 1.8; letter-spacing: 0.2rem; color: #444; font-family:ヒラギノ角ゴシック, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", メイリオ, sans-serif; background: #fecacb;}



/** ----------
wrapper container side main
------------- */

.wrapper{max-width: 1200px; margin: 0 auto; padding: 0 2rem;}
.bg_wrapper{max-width: 1200px; margin: 0 auto; padding: 0 2rem;}
.container{display: table; table-layout: auto; margin: 0; padding: 0; width: 100%;}
.side{display: table-cell; width: 25%; margin: 0; padding: 1rem 2rem; vertical-align: top;}
.main{display: table-cell; width: 75%; margin: 0; padding-top: 0.5rem; vertical-align: top;}
	@media screen and ( max-width:479px ){
		.wrapper{display: block; margin: 0 auto; padding: 0 2rem; width: auto;}
		.bg_wrapper{display: block; margin: 0 auto; padding: 0; width: auto;}
		.container{display: block; margin: 0; padding: 0 0.4rem; width: auto;}
		.side{display: none; width: 100%; margin: 0; padding: 0;}
		.main{display: block; width: 100%; margin: 0; padding: 0;}
		
	}
	




/** ---------------------------------------
span_icon
--------------------------------------- */
img.material_icon{margin: 0; padding: 0 0.6rem; width: 50px;}


/** ---------------------------------------
index_video
--------------------------------------- */

article.index_video{position: relative; width: 100%; height: 100%; height: 100vh;}
article.index_video .bg_video_dot{position: fixed; min-width: 100%; min-height: 100%; width: 100%; height: 100%; object-fit: cover;  z-index: -99; background-image:url("../img/bg_dot.webp");}
article.index_video video.kuma{position: fixed; width: 100%; height: 100%; object-fit: cover; z-index: -100;}
article.index_video .index_message{position: absolute; width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%);}
article.index_video .index_message h1{font-size: 3rem;}
article.index_video .index_message h2{font-size: 4rem;}
article.index_video .index_message h3{font-size: 1.2rem;}

@media screen and ( max-width:800px ){
	article.index_video .index_message h1{font-size: 2.4rem;}
	article.index_video .index_message h2{font-size: 1.9rem;}
	article.index_video .index_message h3{font-size: 1.1rem;}
}

@media screen and ( max-width:479px ){
	article.index_video .index_message h1{font-size: 1.6rem;}
	article.index_video .index_message h2{font-size: 2.6rem;}
	article.index_video .index_message h3{font-size: 1rem;}
}


article.index_video .index_houjinka{position: absolute; width: 100%; bottom: 6rem; left: 50%; transform: translate(-50%, -50%);}
article.index_video .index_houjinka h1{padding: 1rem; letter-spacing: 0.1rem; text-align: center; font-weight: bold; background: #fff;}


article.header_title{position: fixed; left: 0; top: 0; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -997; background-image:url("../img/bg_dot.webp");}
article.header_title_bg{position: fixed; display: block; left: 0; top: 0; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -998; background:url("../img/logo_m.webp") no-repeat top left; background-color:rgba(254,202,203,0.8); background-blend-mode:lighten;}





header{display: flex; position: fixed; margin: 0; padding: 1rem 0; width: 100%; top: 0; line-height: 0; align-items: center; z-index: 999; background: #fff;}
header .box{width: 96%; margin: 0 auto; padding: 0;}
header h1{padding: 0 2rem;}

@media screen and ( max-width:860px ){
	header h1 img{width: 80px; height: auto;}
}


nav.menu_header_pc{margin: 0 0 0 auto; padding: 0 3rem; width: auto;}
nav.menu_header_pc ul{display: table; table-layout: fixed;}
nav.menu_header_pc li{display: table-cell; margin: 0; padding: 0 1rem; text-align: center; font-size: 80%; letter-spacing: 0.1rem;}
nav.menu_header_pc span{padding-right: 0.3rem;}
nav.menu_header_pc a{text-decoration: none; font-weight: bold; color: #363636;}
nav.menu_header_pc a:hover{color: #ccc; -webkit-transition: all .5s; transition: all .5s;}

@media screen and ( max-width:860px ){
	nav.menu_header_pc{display: none;}
}


nav.menu_header_mobile{display: none; height: 30px; position: absolute; right: 1rem; top: 1rem; width: 20px; z-index: 9999;}
nav.menu_header_mobile .menu_header__line{background: #666; display: block; height: 3px; position: absolute; transition:transform .3s; width: 100%;}
nav.menu_header_mobile .menu_header__line--center{top: 8px;}
nav.menu_header_mobile .menu_header__line--bottom{top: 16px;}
nav.menu_header_mobile .menu_header__line--top.active{top: 16px; transform: rotate(45deg);}
nav.menu_header_mobile .menu_header__line--center.active{transform:scaleX(0);}
nav.menu_header_mobile .menu_header__line--bottom.active{bottom: 1px;transform: rotate(135deg);}


@media screen and ( max-width:860px ){
	nav.menu_header_mobile{display: inline;}
}



.accordion{background: #fff; display: none; height: 100%; position: fixed; width: 100%; z-index: 98;}
.accordion .box{position: absolute; display: block; width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%);}
.accordion .box nav{display: block; margin: 0; padding: 0;}
.accordion .box nav ul.menu_accordion{margin: 0; padding: 0; border-bottom: 1px solid #ddd;}
.accordion .box nav ul.menu_accordion li{margin: 0; padding: 0 1rem; text-align: center; border-top: 1px solid #ddd;}
.accordion .box nav ul.menu_accordion a{display: block; padding: 1rem 0; color: #444; font-weight: bold; text-decoration: none;}

.accordion .menu_accordion_contact{margin: 2rem 0; padding: 0 1rem;}
.accordion .box nav ul.menu_accordion_footer{display: flex; flex-wrap: wrap; justify-content: space-between;}
.accordion .box nav ul.menu_accordion_footer li{margin: 0; padding: 0; font-size: 1rem;}
.accordion .box nav ul.menu_accordion_footer li a{display: block; margin: 0; padding: 1rem; text-decoration: none; color: #444;}













article.title_page{margin: 0; padding: 12rem 0 6rem 0;}
article.title_page .box{margin: 0; padding: 0;}
article.title_page .box h1{font-size: 200%;}
article.title_page .box h2{font-size: 85%;}



article.page_space{margin: 0; padding-top: 5rem; width: 100%; background: #fff;}



article.sitemap{margin: 0; padding-bottom: 5rem;}
article.sitemap ul{margin: 0; padding: 0;}
article.sitemap li{margin: 0; padding-bottom: 1rem;}
article.sitemap span{margin: 0; padding-right: 1rem;}
article.sitemap a{display: block; padding: 1rem; color: #e59a9b; font-weight: bold; text-decoration: none;}
article.sitemap a:hover{background: #fff1f1;}
article.sitemap p{padding: 0 1rem; line-height: 1.8;}



article.sitepolicy{margin: 0; padding-bottom: 5rem;}
article.sitepolicy h1{margin: 0; padding-bottom: 4rem; font-size: 2rem; text-align: center;}
article.sitepolicy section.box{margin: 0; padding-bottom: 2rem; line-height: 1.8;}
article.sitepolicy section.box p{padding-bottom: 2rem;}
article.sitepolicy section.box h2{margin: 0; padding-bottom: 1rem; font-size: 1.4rem;}
article.sitepolicy ul{padding: 1rem 2.5rem;}
article.sitepolicy ul li{display: list-item; list-style: decimal;}


article.siteprivacy{margin: 0; padding-bottom: 5rem;}
article.siteprivacy h1{margin: 0; padding-bottom: 4rem; font-size: 2rem; text-align: center;}
article.siteprivacy section.box{margin: 0; padding-bottom: 2rem; line-height: 1.8;}
article.siteprivacy section.box p{padding-bottom: 2rem;}
article.siteprivacy section.box h2{margin: 0; padding-bottom: 1rem; font-size: 1.4rem;}
article.siteprivacy ul{padding: 1rem 2.5rem;}
article.siteprivacy ul li{display: list-item; list-style: decimal;}




article.contact{margin: 0; padding-bottom: 5rem;}
article.contact section.box{margin: 0; padding-bottom: 2rem; line-height: 1.8;}
article.contact section.box p{padding-bottom: 2rem;}


article.contact section.box_form{margin: 0; padding: 2rem 0; line-height: 1.8;}
article.contact section.box_form ul{margin: 0 auto; padding-bottom: 2rem; width: 80%;}
article.contact section.box_form h3{margin: 0; padding-bottom: 1rem;}
article.contact section.box_form input[type=text]{padding: 0.6rem 1rem; box-sizing: border-box; width: 100%; border: 1px solid #aaa; font-size: 1.25rem; border-radius:5px; -webkit-border-radius:5px; -moz-border-radius:5px;}
article.contact section.box_form input[type=tel]{padding: 0.6rem 1rem; box-sizing: border-box; width: 100%; border: 1px solid #aaa; font-size: 1.25rem; border-radius:5px; -webkit-border-radius:5px; -moz-border-radius:5px;}
article.contact section.box_form input[type=email]{padding: 0.6rem 1rem; box-sizing: border-box; width: 100%; border: 1px solid #aaa; font-size: 1.25rem; border-radius:5px; -webkit-border-radius:5px; -moz-border-radius:5px;}
article.contact section.box_form input[type=checkbox]{-ms-transform: scale(1.5, 1.5); -webkit-transform: scale(1.5, 1.5); transform: scale(1.5, 1.5);}
article.contact section.box_form input[type=submit]{padding: 1rem 1rem; box-sizing: border-box; width: 80%; border: 1px solid #aaa; font-size: 1.25rem; font-weight: bold; color: #666; text-align: center; background: #eee; border-radius:5px; -webkit-border-radius:5px; -moz-border-radius:5px;}
article.contact section.box_form input[type=submit]:hover{background: #fafafa;}
article.contact section.box_form textarea{padding: 0.6rem 1rem; box-sizing: border-box; width: 100%; height: 180px; border: 1px solid #aaa; font-size: 1.25rem; border-radius:5px; -webkit-border-radius:5px; -moz-border-radius:5px;}
article.contact section.box_form p.form_text{display: block; padding-bottom: 1rem;}
article.contact section.box_form p.form_submit{text-align: center;}
article.contact section.box_form p.mini{padding-bottom: 1rem; font-size: 1rem; color: #e59a9b;}
article.contact section.box_form span{padding-left: 1rem; font-size: 1rem; color: #e59a9b;}
article.contact section.box_form label.label{display: block; padding: 1rem 0; font-size: 1rem;}


article.contact section.box_message_err{margin: 0; padding: 3rem; line-height: 1.8; background: #f7e8e9;}
article.contact section.box_message_err p{padding-bottom: 1rem; color: #e59a9b; font-weight: bold;}
article.contact section.box_message_err span{padding-right: 0.6rem;}


article.contact section.box_message_finish{margin: 0; padding: 6rem 0;}
article.contact section.box_message_finish h1{padding: 2rem 0; font-size: 1.6rem; font-weight: bold; text-align: center;}
article.contact section.box_message_finish p{padding-bottom: 3rem; line-height: 1.6;}


article.company{margin: 0; padding-bottom: 5rem;}
article.company section.overview{margin: 0; padding-bottom: 3rem;}
article.company section.overview p.title{margin: 0; padding: 6rem 0 3rem 0; text-align: center;}
article.company section.overview img{width: 220px;}
article.company section.overview .title_under{margin: 0 auto; padding: 2rem 0 6rem 0; width: 220px;}
article.company section.overview .title_under a{display: block; padding: 1rem 1.2rem; text-decoration: none; color: #444; text-align: center; font-weight: bold; border: 2px solid #aaa;}
article.company section.overview .title_under a:hover{background: #eee; -webkit-transition: all .5s; transition: all .5s;}
article.company section.overview ul{display: table; table-layout: auto;   margin-bottom: 1rem; padding: 0; width: 100%;}
article.company section.overview ul li{display: table-cell; margin: 0; padding: 1rem 1rem;}
article.company section.overview ul li.item{width: 20%; font-weight: bold; background: #eee;}
article.company section.overview ul li.text{width: auto;}
article.company section.overview ul li.text p{padding-bottom: 1rem;}
article.company section.overview a{text-decoration: none; color: #444;}


article.company section.history{margin: 0; padding-bottom: 5rem;}
article.company section.history h1{margin: 0; padding: 3rem 0; font-size: 2rem; text-align: center; font-weight: bold;}
article.company section.history ul{display: table; table-layout: auto;   margin-bottom: 1rem; padding: 0; width: 100%; border: 1px solid #aaa;}
article.company section.history ul li{display: table-cell; margin: 0; padding: 1rem 1rem;}
article.company section.history ul li.item{width: 25%; font-weight: bold;}
article.company section.history ul li.item span{padding-right: 1rem;}
article.company section.history ul li.text{width: auto;}

@media screen and ( max-width:479px ){
	article.company section.history ul{display: block; table-layout: auto;   margin-bottom: 1rem; padding: 0; width: 100%; border: 1px solid #aaa;}
	article.company section.history ul li{display: block; margin: 0; padding: 0.3rem 1rem;}
	article.company section.history ul li.item{width: auto; font-weight: bold;}
	article.company section.history ul li.item span{padding-right: 1rem;}
	article.company section.history ul li.text{width: auto;}
}



article.projects{margin: 0; padding-bottom: 5rem;}
article.projects section.title{margin: 0; padding: 0; text-align: center; letter-spacing: 0.1rem;}
article.projects section.title h1{margin: 0; padding: 3rem 0; font-size: 2.5rem; text-align: center; font-weight: bold;}
article.projects section.title span{display: block;}
article.projects section.title .image{margin-top: -1rem;}
article.projects section.title img{width: 100%;}

@media screen and ( max-width:479px ){
	article.projects section.title h1{margin: 0; padding: 2rem 0; font-size: 2.5rem; text-align: center; font-weight: bold;}
	article.projects section.title h1{margin: 0; padding: 3rem 0; font-size: 1.8rem; text-align: center; font-weight: bold;}
}


article.projects section.bigdate{margin: 0; padding: 0;}
article.projects section.bigdate .box{display: flex; flex-direction: row; margin: 0; padding: 3rem 0;}
article.projects section.bigdate .box .text{margin: 0; padding: 3rem 5rem; width: auto; background: #fff; border: 1px solid #aaa;}
article.projects section.bigdate .box .text:hover{background: #eee;}
article.projects section.bigdate .box .text h1{padding-bottom: 2rem; font-weight: bold; font-size: 1.8rem;}
article.projects section.bigdate .box .text p{padding-bottom: 2rem;}
article.projects section.bigdate .box .image{margin: 0; padding: 3rem 0;}
article.projects section.bigdate .box .image img{width: 100%;}
article.projects section.bigdate .box ul{padding: 1rem 2.5rem;}
article.projects section.bigdate .box ul li{display: list-item; list-style: decimal;}


@media screen and ( max-width:479px ){
	article.projects section.bigdate .box{display: flex; flex-direction: column-reverse; margin: 0; padding: 3rem 0;}
	article.projects section.bigdate .box .text{margin: 0; padding: 3rem; width: auto; background: #fff; border: 1px solid #aaa;}
}





article.partner{margin: 0; padding-bottom: 5rem;}
article.partner section.title{margin: 0; padding: 0; text-align: center; letter-spacing: 0.1rem;}
article.partner section.title h1{margin: 0; padding: 3rem 0; font-size: 2.5rem; text-align: center; font-weight: bold;}
article.partner section.title span{display: block;}
article.partner section.title .image{margin-top: -1rem;}


@media screen and ( max-width:479px ){
	article.projects section.title h1{margin: 0; padding: 2rem 0; font-size: 2.5rem; text-align: center; font-weight: bold;}
	article.projects section.title h1{margin: 0; padding: 3rem 0; font-size: 1.8rem; text-align: center; font-weight: bold;}
}


article.partner section.start{margin: 0; padding: 0;}
article.partner section.start .image{margin: 0 auto; padding: 3rem 0; text-align: center;}
article.partner section.start .image img{margin: 0; padding: 0; width: 50%; text-align: center;}
article.partner section.text{margin: 0; padding: 3rem 5rem; width: auto; background: #fff; border: 1px solid #aaa;}

article.partner section.button{display: flex; justify-content: center; margin: 0; padding: 3rem 0; text-align: center;}
article.partner section.button a{display: block; padding: 1rem 3rem; color: #fff; font-weight: bold; text-decoration: none; border: 2px solid #aaa; background: #00b2cc; -webkit-transition: all .5s; transition: all .5s;}
article.partner section.button a:hover{display: block; padding: 1rem 3rem; color: #444; font-weight: bold; text-decoration: none; border: 2px solid #aaa; background: #fff;}



/** ---------------------------------------
button
--------------------------------------- */

.button{display: block; margin: 0; padding: 3rem; text-align: center;;}
.button a{display: block; padding: 1rem 3rem; font-weight: bold; color: #fff; text-decoration: none; background: #666; -webkit-transition: all .5s; transition: all .5s;}
.button a:hover{background: #93cce0;}


a.button_contact{display: block; margin: 0; padding: 1rem 1.2rem; text-decoration: none; color: #444; font-weight: bold; text-align: center; border: 2px solid #aaa; background: #eee;}


.button_01{display: flex; justify-content: center; margin: 0; padding: 3rem 0; text-align: center;}
.button_01 a{display: block; padding: 1rem 3rem; color: #fff; font-weight: bold; text-decoration: none; border: 2px solid #aaa; background: #00b2cc; -webkit-transition: all .5s; transition: all .5s;}
.button_01 a:hover{display: block; padding: 1rem 3rem; color: #444; font-weight: bold; text-decoration: none; border: 2px solid #aaa; background: #fff;}


/** ---------------------------------------
header.other
--------------------------------------- */

header.frame_text{margin: 0; padding-top: 10rem; text-align: center; line-height: 1.6;}
header.frame_text h1{font-size: 2.7rem;}
header.frame_text h1.sub{font-size: 1.5rem; color: #aaa; font-weight: bold; text-align: center;}
header.frame_text span{display: inline-block:}

	@media screen and ( max-width:479px ){
		header.frame_text{margin: 0; padding-top: 10rem; text-align: left; line-height: 1.6;}
		header.frame_text h1{font-size: 2.5rem;}
		header.frame_text h1.sub{font-size: 1.25rem; color: #aaa; font-weight: bold; text-align: left;}
		header.frame_text span{display: inline-block:}
		
	}
	






/** ----------
footer
------------- */
footer{padding: 1rem 0; line-height: 2; text-align: center; background: #666;}
footer nav.footer_menu{margin: 0; padding: 1rem 0; font-size: 90%; color: #fff; text-align: center;}
footer nav.footer_menu ul{margin: 0; padding: 0;}
footer nav.footer_menu li{display: inline-block; margin: 0; padding: 0 0.3rem;}
footer nav.footer_menu a{color: #fff; text-decoration: none;}
footer p.copy{font-weight: bold; color: #fff;}
footer p.copy a{color: #fff; text-decoration: none; font-size: 90%;}

























