@charset "UTF-8";

/* reset
-------------------------------------------------*/
html, body, div, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video, input {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: bottom;
}
ol, ul {
	list-style: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
img {
    vertical-align: middle;
}

/* base setting
-------------------------------------------------*/
html {
font-size: 10px;
overflow-x: hidden;
scroll-behavior: smooth;
}
body {
	font-family: 'M PLUS 1p', sans-serif;
	font-feature-settings: "palt";
	color: #000;
	font-size: 1.6rem;
	font-weight: 400;
	text-align: left;
}
@media(max-width: 599px) {
body {
font-size: 1.4rem;
}
}

body {
	width: 100%;
	height: 100%;
	position: relative;
	-webkit-font-smoothing: antialiased;
}
a {
	position: relative;
	color: #000;
	text-decoration: none;
}
a:hover {
	color: #000;
	text-decoration: none;
	opacity: 0.7;
}

a,
a:before,
a:after,
a > *,
a > *:before,
a > *:after {
	transition: all 0.4s;
}
a:hover,
a:hover:before,
a:hover:after,
a:hover > *,
a:hover > *:before,
a:hover > *:after {
	transition: all 0.3s;
}
img {
	width: 100%;
	height: auto;
	vertical-align: top;
}
ul {
	list-style-type: none;
}
section,
#scene {
	padding: 100px 0;
	scroll-margin-top: 100px;
}
@media(max-width: 599px) {
section,
#scene {
	padding: 30px 0;
	scroll-margin-top: 50px;
}
}


/* common
-------------------------------------------------*/
.sp_obj {
display: none !important;
}
.common_wrap {
width: calc(100% - 50px);
max-width: 128.5rem;
margin-left: auto;
margin-right: auto;
position: relative;
}
.common_wrap_s {
width: calc(100% - 50px);
max-width: 100rem;
margin-left: auto;
margin-right: auto;
position: relative;
}
a.common_btn {
	min-width: 30rem;
	max-width: 40rem;
	height: 63.5px;
	margin: 0 auto;
	color: #fff;
	background: linear-gradient(90deg, #ff1a7c, #d81066);
	border-radius: 5px;
	position: relative;
	font-size: 23px;
	text-align: center;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	transform: rotate(0.05deg);
}
a.common_btn::after {
	content: '';
	display: block;
	background-image: url(../img/arrow_wh.svg);
	background-position: center center;
	background-size: contain;
	background-repeat: no-repeat;
	width: 8px;
	height: 10px;
	position: absolute;
	top:0;
	bottom:0;
	margin: auto;
	right: 20px;
}
.common_btn_s {
	width: 165px;
	height: 35px;
	text-align: center;
	color: #e8468a;
	border-radius: 999px;
	border: 1px solid #e8468a;
	background-color: #fff;
	font-weight: 700;
	margin-top: 15px;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 0;
	display: block;
	line-height: 30px;
	transform: rotate(0.05deg);
}
a.common_btn_s::after {
	content: '';
	display: block;
	background-image: url(../img/arrow_pk.svg);
	background-position: center center;
	background-size: contain;
	background-repeat: no-repeat;
	width: 8px;
	height: 10px;
	position: absolute;
	top:0;
	bottom:0;
	margin: auto;
	right: 20px;
}
a.common_btn_s:hover {
	color: #fff;
	background-color: #e8468a;
	opacity: 1;
}
a.common_btn_s:hover::after {
	background-image: url(../img/arrow_wh.svg);
}
.common_btn_group {
	display: flex;
	flex-direction: column;
	gap: 16px;
	align-items: center;
	justify-content: center;
}
@media(min-width: 599px) {
	.common_btn_group {
		flex-direction: row;
	}
}
.common_btn_group .common_btn {
	margin: 0;
}
.common_ttl_set {}
.common_ttl_set .common_sttl {
	background-color: #0253ac;
	color: #fff;
	text-align: center;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 35px;
	width: 210px;
	height: 30px;
	line-height: 30px;
	font-weight: 700;
	transform: rotate(0.05deg);
}
.common_ttl_set h3 {
	color: #e8468a;
	text-align: center;
	font-size: 40px;
	font-weight: 700;
	line-height: 1.3em;
	margin-bottom: 60px;
	transform: rotate(0.05deg);
}
.common_lead {
	color: #666464;
	text-align: center;
	font-size: 20px;
	padding-bottom: 30px;
	font-weight: 700;
	transform: rotate(0.05deg);
}
.common_txt {
	margin-bottom: 30px;
	line-height: 2em;
	transform: rotate(0.05deg);
}
.bg_gr {
	background-color: #f7f7f7;
}
@media(max-width: 599px) {
.pc_obj {
display: none !important;
}
.sp_obj {
display: block !important;
}
.common_wrap,
.common_wrap_s {
margin-left: 2rem;
margin-right:2rem;
}
a.common_btn {
	font-size: 16px;
	height: 50px;
/*
box-shadow: 0px 5px 0 #0b3775;
	-webkit-box-shadow: 0px 5px 0 #0b3775;
*/
}
.common_ttl_set .common_sttl {
	margin-bottom: 20px;
}
.common_ttl_set h3 {
	font-size: 20px;
	margin-bottom: 30px;
}
.common_lead {
	font-size: 16px;
	padding-top: 0px;
}
}

/* header
-------------------------------------------------*/
.hd_common {
	width: 100%;
	height: 100px;
	position: fixed;
	z-index: 9999;
	top: 0px;
	left: 0;
	right: 0;
	background-color: #fff;
	box-shadow: 0px 5px 5px -3px rgba(0,0,0,0.20);
		-webkit-box-shadow: 0px 5px 5px -3px rgba(0,0,0,0.20);
	display: flex;
	justify-content: center;
	align-items: center;
}
.hd_nav_area {
display: flex;
justify-content: space-between;
align-items: center;
	}
.hd_logo {
	width: 235px;
	height: auto;
	display: flex;
justify-content: center;
align-items: center;
}
ul.hd_nav {
display: flex;
align-items: center;
justify-content: flex-end;
}
ul.hd_nav li {
	margin-left: 30px;
	transform: rotate(0.05deg);
}
ul.hd_nav li a {
	color: #e8458b;
	font-size: 16px;
	font-weight: 700;
	line-height: 1em;
	display: block;
	position: relative;
}
ul.hd_nav li.demo a {
	color: #fff;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 200px;
	height: 45px;
}
.burger-btn {
display: none;
}
@media(max-width: 599px) {
.hd_common {
width: 100%;
max-width: 100%;
height: 5rem;
padding:0 1px;
align-items: center;
}
.hd_nav_area {
	}
.hd_logo {
	width: 144px;
	margin: 0;
}
/* ボタンリセット */
button {
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		background: transparent;
		border: 0;
		border-radius: 0;
		color: inherit;
		cursor: pointer;
		font: inherit;
		margin: 0;
		outline: none;
		padding: 0;
		vertical-align: middle;
	}
/* ハンバーガーボタン */
.burger-btn{
	display: block;
	width: 50px;
	height: 50px;
	position: relative;
	z-index: 3;
	border: none;
	margin-left: auto;
	margin-right: 10px;
}    
.bar{      
  width: 30px;      
  height: 2px;        
  display: block;      
  position: absolute;      
  left: 50%;      
  transform: translateX(-50%);      
  background-color: #e8458b    
}    
.bar_top{   
  top: 15px;
}
.bar_mid{    
  top: 50%;
  transform: translate(-50%,-50%);
}
.bar_bottom{
  bottom: 15px;
}
.burger-btn.close .bar_top{      
  transform: translate(-50%,10px) rotate(45deg);      
  transition: transform .3s;
    background-color: #fff;    
}    
.burger-btn.close .bar_mid{      
  opacity: 0;       
  transition: opacity .3s;
  background-color: #fff;    
}    
.burger-btn.close .bar_bottom{      
transform: translate(-50%,-8px) rotate(-45deg);      
transition: transform .3s;
background-color: #fff;    
}

/* ハンバーガーメニュー */
.nav-wrapper{      
  visibility: hidden;
  opacity: 0;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  transition: all .5s;       
  z-index: 2;     
}     
.header-nav{        
  width: 100%;        
  height: 100%;        
  background: linear-gradient(135deg, #113567, #B81872);
  z-index: 2;
  padding: 30px;
}

/* ナビゲーション */
.hd_common ul.hd_nav  {
width: 100%;
display: block;
padding-top: 5rem;
margin-left: auto;
margin-right: auto;
}
.hd_common ul.hd_nav li {
	margin-bottom: 30px;
}
.hd_common ul.hd_nav li a:link {
color: #fff;
	font-size: 20px;
}
.hd_common ul.hd_nav li a:visited {
color: #fff;
}
.hd_common ul.hd_nav li:last-child {
}
ul.hd_nav li.demo a {
	color: #fff;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: auto;
	height: 45px;
}
.sp_nav_btn {
	margin-bottom: 20px !important;
}
.sp_nav_logo {
	width: 40%;
	margin: 50px auto 0;
}

/* メニューオープン時 */
.nav-wrapper.fade {
	visibility: visible;
	opacity: 1;
}

.noscroll{
  overflow: hidden;
}
}

/* mv
-------------------------------------------------*/
.mv {
	width: 100%;
	height: calc(100vh - 100px );
	background-position: center top;
	background-size: cover;
	background-repeat: no-repeat;
background-image: url(../img/mv_bg_01.jpg);
	position: relative;
	margin-top: 100px;
	padding-top:0px;
	padding-bottom:0px;
}
.mv h2.mv_ttl {
	color: #e8468a;
	font-size: 5vh;
	padding-top: 70px;
	-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
		transform: rotate(0.05deg);
}
.mv .common_btn {
position: absolute;
left: 0;
right: 0;
bottom: 0;
margin: auto;
z-index: 1;
}
.mv_anchr_wrap {
	height: 100%;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0px;
	margin: auto;
	text-align: center;
background-position: center bottom 100px;
	background-size: 1000px;
	background-repeat: no-repeat;
background-image: url(../img/mv_bg_03.png);
}

ul.mv_anchr_area {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
	grid-gap: 10px;
	position: absolute;
	left:0;
	right:0;
	bottom:10px;
	margin:auto;
	padding-bottom: 0px;

}
ul.mv_anchr_area li {
	background-color: #0253ac;
	padding-right: 18px;
	padding-left: 18px;
	font-weight: 700;
	border-radius: 15px;
	position: relative;
	transform: rotate(0.05deg);
}
ul.mv_anchr_area li a {
	color: #fff;
	display: block;
	height: 100%;
	padding-bottom: 40px;
}
ul.mv_anchr_area li a::after {
	content: '';
	background-image: url(../img/arrow_wh.svg);
	transform: rotate(90deg);
	height: 22px;
	width: 10px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
	position: absolute;
	margin: auto;
	left:0;
	right:0;
	bottom:10px;
}
ul.mv_anchr_area li .mv_anchr_num {
	background-image: url(../img/mv_num_bg.svg);
	background-position: center top;
	background-size: contain;
	background-repeat: no-repeat;
	width: 85px;
	display: block;
	text-align: center;
	color: #fff;
	font-size: 30px;
	margin-bottom: 10px;
	margin-left: auto;
	margin-right: auto;
	transform: rotate(0.05deg);
}
ul.mv_anchr_area li.demo {
background:none;
padding-right: 0px;
padding-left: 0px;
    margin-top: 25px;
    margin-bottom: 25px;
}
ul.mv_anchr_area li.demo a {
	background: linear-gradient(90deg, #ff1a7c, #d81066);
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0;
	font-size: 21px;
	border-radius: 15px;
}
ul.mv_anchr_area li.demo a::after {
	content: '';
	background-image: url(../img/arrow_wh.svg);
	transform: rotate(0deg);
	height: 22px;
	width: 10px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
	position: absolute;
	margin: auto;
	top:0;
	bottom:0;
	right:10px;
	left:auto;
}
ul.mv_anchr_area li.demo a:hover {
	opacity: 0.7;
}
@media(max-width: 599px) {
.mv {
	height: auto;
	margin-top: 50px;
	background-image: url(../img/mv_bg_01_sp.jpg);
	background-size: contain;
	padding-top: 0px;
	background-position: center top;
}
.mv h2.mv_ttl {
	font-size: 23px;
	padding-top: 30px;
}
.mv .common_btn {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -70px;
	margin: auto;
	width: 90%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.mv_anchr_wrap {
	position: static;
	left: 0;
	right: 0;
	bottom: auto;
	top: 0;
	margin: auto;
	background-image: url(../img/mv_bg_02_sp.png);
	background-position: center top;
	background-size: cover;
	background-repeat: no-repeat;
	padding-top: 250px;
}
ul.mv_anchr_area {
	display: grid;
	grid-template-columns: 1fr;
	grid-gap: 10px;
	position: static;
	padding-bottom: 25px;
}
ul.mv_anchr_area li {
	background-color: #0253ac;
	padding-right: 18px;
	padding-left: 18px;
	font-weight: 700;
	border-radius: 15px;
	position: relative;
}
ul.mv_anchr_area li a {
	color: #fff;
	display: block;
	height: 100%;
	padding-bottom: 25px;
}
ul.mv_anchr_area li a::after {
	content: '';
	background-image: url(../img/arrow_wh.svg);
	transform: rotate(90deg);
	height: 22px;
	width: 10px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
	position: absolute;
	margin: auto;
	left:0;
	right:0;
	bottom:3px;
}
ul.mv_anchr_area li .mv_anchr_num {
	width: auto;
	font-size: 20px;
	margin-bottom: 5px;
}
ul.mv_anchr_area li.demo {
	background: linear-gradient(90deg, #ff1a7c, #d81066);
	margin-top:auto;
	margin-bottom:auto;
}
ul.mv_anchr_area li.demo a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 30px;
	font-size: 21px;
}
ul.mv_anchr_area li.demo a::after {
	content: '';
	background-image: url(../img/arrow_wh.svg);
	transform: rotate(0deg);
	height: 22px;
	width: 10px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
	position: absolute;
	margin: auto;
	top:0;
	bottom:0;
	right:10px;
	left:auto;
}
}

/* about
-------------------------------------------------*/
.about {
	padding-bottom: 0px;
	margin-bottom: 50px;
}
.about .about_block {
	padding: 60px 50px;
	border-radius: 15px;
}
.about h4.about_sttl{
	color: #0253ac;
	font-size: 35px;
	text-align: center;
    margin-bottom: 35px;
				transform: rotate(0.05deg);
				padding: 0 !important;
}
.about .about_mv {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	margin-bottom: 70px;
}
.about .about_mv iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.about ul.scene_list {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-gap: 10px;
}
.about ul.scene_list li {
}
.about ul.scene_list li .scene_img {
}
.about ul.scene_list li .scene_txt {
	padding: 25px 0;
	text-align: center;
	transform: rotate(0.05deg);
	font-weight: 700;
}
.about ul.scene_list li .scene_txt2 {
font-size: 14px;
}
.about h5 {
	font-size: 16px;
	text-align: center;
}
@media(max-width: 599px) {
.about {
	padding-bottom: 0px;
}
.about .about_block {
	padding: 30px 20px;
	border-radius: 15px;
}
.about h4.about_sttl{
	color: #0253ac;
	font-size: 20px;
	text-align: center;
	margin-bottom: 0px;
}
.about .about_mv {
	margin-bottom: 30px;
}
.about ul.scene_list {
	display: grid;
	grid-template-columns: 1fr;
	grid-gap: 32px;
}
.about ul.scene_list li {
}
.about ul.scene_list li .scene_img {
}
.about ul.scene_list li .scene_txt {
	padding: 5px 0;
	text-align: center;
}
}

/* point01
-------------------------------------------------*/
.point01 {
}
.point01 .point01_block {
/*
	border-radius: 30px;
	box-shadow: 3px 3px 30px #2222221F;
*/
	padding: 35px;
}
.point01 .point01_figure_logo {
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 20px;
	width: 140px;
}
.point01 .point01_figure_list {
}
@media(max-width: 599px) {
.point01 .point01_block {
	border-radius: 15px;
	padding: 15px;
}
.point01 .point01_figure_logo {
	width: 100px;
}
}

/* point02
-------------------------------------------------*/
.point02 {
}
.point02 .point02_block {
display: flex;
justify-content: space-between;
	position: relative;
}
.point02 .point02_box {
	width: 46%;
	border-radius: 30px;
	box-shadow: 3px 3px 30px #2222221F;
	padding: 35px;
	background-color: #fff;
	}
.point02 .point02_logo {
	width: 70px;
	margin:0 auto;
}
.point02 .point02_ttl {
	color: #0253ac;
	text-align: center;
	font-size: 25px;
	font-weight: 700;
	margin-bottom: 35px;
	transform: rotate(0.05deg);
}
.point02 .point02_ill {
	margin: 0 auto;
}
.point02 .point02_box:nth-of-type(1) .point02_ill {
	width: 283px;
}
.point02 .point02_box:nth-of-type(3) .point02_ill {
	width: 142px;
}
.point02 .point02_arrow {
	width: 130px;
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
margin: auto;
display: flex;
justify-content: center;
align-items: center;
}
@media(max-width: 599px) {
.point02 .point02_logo {
	width: 50px;
	margin-bottom:10px;
}
.point02 .point02_ttl {
	font-size: 16px;
	margin-bottom: 15px;
}
.point02 .point02_box {
	width: 46%;
	border-radius: 15px;
	padding: 20px;
	}
.point02 .point02_box:nth-of-type(1) .point02_ill {
	width: auto;
}
.point02 .point02_box:nth-of-type(3) .point02_ill {
	width: auto;
}
.point02 .point02_arrow {
width: 50px;
}
}

/* point03
-------------------------------------------------*/
.point03 {
}
.point03 .note {
	font-size: 12px;
	text-align: right;
	padding-top: 10px;
}
.tab-group{
  display: flex;
  justify-content: center;
}
.tab{
  flex-grow: 1;
  padding:5px;
  list-style:none;
  border:solid 1px #CCC;
  text-align:center;
  cursor:pointer;
}
.panel-group{
  border:solid 1px #CCC;
  border-top:none;
  background:#eee;
}
.panel{
  display:none;
}
.tab.is-active{
  background:#e8468a;
  color:#FFF;
  transition: all 0.2s ease-out;
}
.panel.is-show{
  display:block;
}
model-viewer {
  width: 1000px;
  height: 500px;
  background-color: #eee;
}
model-viewer.reveal {
    --poster-color: transparent;
}
@media(max-width: 599px) {
model-viewer {
  width: 325px;
  height: 300px;
  background-color: #eee;
}
}

/* point04
-------------------------------------------------*/
.point04 {
}
.point04 ul.point04_list{
display: flex;
justify-content: space-between;
align-items: center;
}
.point04 ul.point04_list li{
}
.point04 ul.point04_list li.point04_arrow {
	padding: 0 35px;
}
@media(max-width: 599px) {
.point04 ul.point04_list{
display: block;
justify-content: space-between;
align-items: center;
}
.point04 ul.point04_list li.point04_arrow {
	padding: 10px 0px;
	margin: 0 auto;
	width: 20px;
	transform:rotate(90deg);
}
}

.copy {
	padding-top: 90px;
	padding-bottom: 30px;
	transform: rotate(0.05deg);
}
@media(max-width: 599px) {
.copy {
	padding-top: 30px;
	padding-bottom: 0px;
}
}

.copy {
	padding-top: 90px;
	padding-bottom: 30px;
	transform: rotate(0.05deg);
}
@media(max-width: 599px) {
.copy {
	padding-top: 30px;
	padding-bottom: 0px;
}
}

/* cta
-------------------------------------------------*/
.cta {
	background-image: url(../img/cta_bg.jpg);
	background-position: center center;
	background-size: cover;
	padding: 60px 0;
	background-repeat: no-repeat;
}
.cta h3 {
	color: #fff;
	transform: rotate(0.05deg);
}
@media(max-width: 599px) {
.cta {
padding-left: 25px;
padding-right: 25px;
}
}

/* blog
-------------------------------------------------*/
.blog {
}
.blog .blog_logo {
	margin: 0 auto;
	padding: 30px 0;
	width: 240px;
}
.blog h3 {
	color: #e8468a;
	font-size: 30px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 60px;
	transform: rotate(0.05deg);
}
.blog .blog_sttl {
	background-color: #1b3a62;
	color: #fff;
	text-align: center;
	font-weight: 700;
	padding: 10px 0;
	font-size: 20px;
	transform: rotate(0.05deg);
}
.blog .blog_link {
	width: 350px;
	margin: 0 auto;
	height: 45px;
	color: #e8468a;
	text-align: center;
	line-height: 40px;
	font-weight: 700;
	border-radius: 5px;
	border: 2px solid #e8468a;
	display: block;
	transform: rotate(0.05deg);
}
.blog .blog_link::after {
	content: '';
	display: block;
	background-image: url(../img/arrow_pk.svg);
	background-position: center center;
	background-size: contain;
	background-repeat: no-repeat;
	width: 8px;
	height: 10px;
	position: absolute;
	top:0;
	bottom:0;
	margin: auto;
	right: 20px;
}
.blog .blog_link:hover {
	color: #fff;
	background-color: #e8468a;
	opacity: 1;
}
.blog .blog_link:hover::after {
	background-image: url(../img/arrow_wh.svg);
}
.vmt-tec-list li a dl dt {
    font-size: 14px;
}
.note_vmversr {
	text-align: center;
}
@media(max-width: 599px) {
.blog .blog_logo {
	width: 160px;
}
.blog h3 {
	font-size: 20px;
	margin-bottom: 30px;
}
.blog .blog_sttl {
	font-size: 16px;
}
.blog .blog_link {
	width: auto;
}
}

/* footer
-------------------------------------------------*/
nav#sectionFooterMenu {
    background: #f0f0f0;
    padding: 15px 30px 10px;
    margin: 1rem 0 0;
    width: auto;
    text-align: center
}

nav#sectionFooterMenu ul {
    text-align: center;
    margin: 0 auto
}

nav#sectionFooterMenu ul li {
    display: inline-block;
    line-height: .8rem;
    padding: 0 10px;
    margin-bottom: 10px;
				transform: rotate(0.05deg);
}

nav#sectionFooterMenu ul li a {
    color: #000;
font-size: 1.6rem;
}
footer {
    width: 100%;
    padding: 50px 10px 40px;
    text-align: center
}

footer .btt {
    font-size: .8rem;
    display: none
}

footer nav ul {
    text-align: center;
    margin: 0 auto
}

footer nav ul li {
	display: inline-block;
	line-height: .8rem;
	padding: 0 6px 0 10px;
	margin-bottom: 10px;
	transform: rotate(0.05deg);
	font-size: 12px;				
}
footer nav ul.sns li+li {
    border-left: none
}

footer nav ul.sns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

footer nav ul.sns li {
    padding: 0;
    width: 40px;
    height: 40px;
    margin: 10px;
				transform: rotate(0.05deg);
}

footer nav ul.sns li a {
    padding: 0;
    width: 40px;
    height: 40px;
    background-color: #e74589;
    border-radius: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1px!important;
    text-indent: -200000%;
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center center
}

footer nav ul.sns li.instagram a {
    background-image: url(../img/icon-instagram.svg)
}

footer nav ul.sns li.youtube a {
    background-image: url(../img/icon-youtube.svg)
}

.drawer-menu ul.sns {
    display: none
}

footer small,footer small span {
    font-size: .7rem;
    color: #000;
    font-family: Montserrat,sans-serif;
    font-weight: 400!important
}

footer small {
    padding: 30px 0 0 0;
    display: block
}
@media(max-width: 599px) {
footer.ft_common {
	padding-top: 30px;
}
footer.ft_common .ft_copyright_area {
	padding-top: 50px;
	background-image: url(../img/ft_bg_sp.png);
	background-position: center top;
	background-repeat: no-repeat;
	padding-bottom: 50px;
	padding-left: 2rem;
	padding-right: 2rem;
	background-size: cover;
	transform: rotate(0.05deg);
}
}

.webfont {
transform: rotate(0.05deg);
}

.contact .sectionMain {
font-size: 16px;
}

@media(max-width: 599px) {
section.sectionMain {
    padding: 0px;
}
}

/* media
-------------------------------------------------*/
.media {
	margin: 100px auto;
	text-align: center;
}
.common_sttl_02 {
	font-size: 2rem;
	margin-bottom: 50px;
	color: #0253ac;
	font-weight: bold;
	    display: flex;
    align-items: center;
}
.common_sttl_02:before,
.common_sttl_02:after {
    content: "";
    height: 1px;
    flex-grow: 1;
    background-color: #0253ac;
}
 
.common_sttl_02:before {
    margin-right: 5rem;
}
 
.common_sttl_02:after {
    margin-left: 5rem;
}
.media ul.media_list {
  display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    grid-gap: 4rem;
}
.media ul.media_list li {
    width: 100%;
}
.media ul.media_list li img {
    width: 100%;
    height: 50px;
    object-fit: contain;
}

@media(max-width: 599px) {
.media {
	margin: 50px auto;
}
.common_sttl_02 {
	margin-bottom: 30px;
}
.media ul.media_list {
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
		grid-gap: 2rem;
}
.common_sttl_02:before {
    margin-right: 2rem;
}
.common_sttl_02:after {
    margin-left: 2rem;
}
}
