@charset "UTF-8";
/*
Theme Name: DESIGN WOLF theme
Version: 2018
Author: DESIGN WOLF CO.,LTD.
*/

/* reset  -------------------------------- */
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:top;background:transparent;}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:none;}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;}ins{background-color:#ff9;color:#222;text-decoration:none;}mark{background-color:#ff9;color:#222;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;}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0;}input,select{vertical-align:middle;}
a {
	text-decoration: none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
@media screen and (min-width: 901px) { a:hover { cursor: pointer; } }
ul, li { list-style: none;}
img { max-width: 100%; height: auto; }
img[src$=".svg"] { width: 100%; }
a:focus { outline: none; }
body, h1, h2, h3, h4 { font-weight: normal; }
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

/* clearfix ----------------------*/
.clearfix { zoom: 1; }
.clearfix:after { content: ""; display: block; clear: both; }

/* img hover ----------------------*/
a img {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
@media screen and (min-width: 901px) {
	a:hover img {
	opacity: 0.5;
    filter: alpha(opacity=50);
    -moz-opacity: 0.5;
	}
}

body {
	/*font-family: 'Noto Sans JP', sans-serif;*/ /*20231010*/
	font-family: 'Midashi Go MB31', sans-serif;
	
	/*font-family: 'Noto Sans JP', sans-serif; 
	font-weight: 500;*/
	
/*	-webkit-font-feature-settings: 'palt' 1;
	font-feature-settings: 'palt' 1;*/
	letter-spacing: 0.1rem;
}
@media screen and (max-width: 600px) {
	body {
		/*letter-spacing: 0;*/
	}
}

/* font color ----------------------*/
body { color: #222; }
/*
	ブルーグレー　#222
	赤　#e50038
*/

/* font size ----------------------*/
html { font-size: 62.5%;  }

/* image ----------------------*/
.image_mobile { display: none; }
@media screen and (max-width: 600px) {
	.image_mobile { display: block; }
	.image_pc { display: none; }
}

/* space */

.space_topbottom { padding: 100px 0; }
.space_top { padding: 100px 0 0 0; }
.space_bottom { padding: 0 0 100px 0; }
.space_top50 { padding: 50px 0 0 0; }
.space_bottom50 { padding: 0 0 50px 0; }
.space_top30 { padding: 30px 0 0 0; }
.space_bottom30 { padding: 0 0 30px 0; }
.space_top20 { padding: 20px 0 0 0; }
.space_bottom20 { padding: 0 0 20px 0; }
.space_bottom5 { padding: 0 0 5px 0; }
@media screen and (max-width: 600px) {
	.space_topbottom { padding: 50px 0; }
}

/* z-index */

#header { z-index: 98; }
#menuButton { z-index: 200; }
.header_nav { z-index: 99; }
.contents { z-index: 0; }



/* 本文  ---------------------- */

.blog_body h1 {
	font-size: 4rem; line-height: 130%; padding: 80px 0 20px 0;
	text-align: justify; text-justify: inter-ideograph !important;
	letter-spacing: 0.05rem;
	-webkit-font-feature-settings: 'palt' 1;
	font-feature-settings: 'palt' 1;
}
.blog_body h2 {
	font-size: 2.2rem; line-height: 160%; padding: 30px 0;
	border-top: solid 5px #ccc; margin: 30px 0 0 0; text-align: center;
}
.blog_date {
	display: block; vertical-align: middle; padding: 0 0 60px 0;
	font-size: 1rem; text-indent: 1px; color: #e50038;
	line-height: 150%;
}
.blog_date span, .blog_date strong { display: inline-block; vertical-align: middle; font-weight: 400;  }
.blog_date span {  }
.blog_date strong {
	padding: 0; font-size: 120%;
}
.logo_page { width: 80px; }
.blog_body p {
	font-size: 1.6rem; line-height: 220%; padding: 0 0 40px 0;
	text-align: justify; text-justify: inter-ideograph !important;
}
.blog_body p a { color: #e50038; }
@media screen and (min-width: 901px) { .blog_body p a:hover { color: #666; }  }

.caption {
	font-size: 1rem; line-height: 160%; text-align: center;
	padding: 0 0 40px 0; margin: -30px 0 0 0;
}
@media screen and (max-width: 1100px) {
	.blog_body h1 { padding: 70px 0 15px 0; }
	.blog_body p { font-size: 1.4rem;  }
	.caption { transform: scale(0.8);  margin: -35px 0 0 0; }
}
@media screen and (max-width: 600px) {
	.blog_date {  transform: scale(0.8); transform-origin: left; }
	.blog_date span { /*transform: scale(0.8); transform-origin: top left;*/ }
	.blog_date strong { display: block; }
	.caption { font-size: 1rem; margin: -25px 0 0 0; }
	.blog_body h1 { font-size: 3.5rem; text-align: left; }
	.blog_body h2 { text-align: left; }
	.blog_body h1, .blog_body p, .nextprev_prev a, .nextprev_next a { letter-spacing: 0rem; }
	.blog_body p { font-size: 1.3rem;  }
	.caption { transform: scale(0.6);  margin: -42px 0 0 0; }
}

@media screen and (min-width: 901px) {
	.blog_body p a:hover img {
		opacity: 0.8;
    	filter: alpha(opacity=80);
    	-moz-opacity: 0.8;
	}
}


.blogimage { margin: 20px 0 0 0; }
@media screen and (max-width: 640px) { .blogimage { margin: 0 -20px; }	}

/* nextprev  ---------------------- */

.nextprev { width: 100%;  padding: 100px 0; }
.nextprev_prev { float: left; } .nextprev_next { float: right; }
.nextprev_prev a, .nextprev_next a {
	display: block; width: 150px;
	position: relative;
	font-size: 1.2rem; text-align: center; color: #e50038;
	padding: 50px 0 20px 0;
}
@media screen and (min-width: 901px) {
 .nextprev_prev a:hover, .nextprev_next a:hover { opacity: 0.5; }
}

.nextprev_prev a:after, .nextprev_next a:after {
	content: ""; display: block; background: #e50038; width: 145px; height: 1px;
}
.nextprev_prev a:after { position: absolute; left: 5px; top: 30px; }
.nextprev_next a:after { position: absolute; right: 5px; top: 30px; }

.nextprev_prev a:before {
	display: block; width: 0; height: 0; content: "";
	border-style: solid;
	border-width: 10px 20px 0 0;
	border-color: transparent #e50038 #e50038 transparent;
	position: absolute; top: 21px; left: 0;
}
.nextprev_next a:before {
	display: block; width: 0; height: 0; content: "";
	border-style: solid;
	border-width: 0 20px 10px 0;
	border-color: transparent transparent #e50038 #e50038;
	position: absolute; top: 21px; right: 0;
}
@media screen and (max-width: 400px) {
	.nextprev_prev a, .nextprev_next a { width: 100px; }
	.nextprev_prev a:after, .nextprev_next a:after { width: 95px; }
	
}

/* 404  ---------------------- */

.not_found {
	display: block; width: 200px; height: 260px;
	position: fixed; top: 0; bottom: 0; left: 0; right: 0; margin: auto;
	color: #e50038;
	font-size: 1.4rem; text-align: center; line-height: 220%;
}
.not_found span { display: block; font-size: 4rem;}
.not_found img { width: 300px; padding: 0 0 30px 0; }



/*━━━━━━━━━━━━━━━━━━━━━━━━━━
━━━━━━━━━━━━━━━━━━━━━━━━━━*/


/* header and contents ━━━━━━━━━━━━━━━━━━━━━*/

#header {
}

/* header_title */

@media screen and (min-width: 1101px) {
	.header_title, .header_title_top {
		position: fixed; top: 0px; bottom: 0; right: 30px; margin: auto;
		width: 200px; height: 40px;
	}
}
@media screen and (min-width: 1200px) { .header_title, .header_title_top { width: 250px; height: 50px; } }
@media screen and (min-width: 1300px) { .header_title, .header_title_top { width: 300px; height: 60px; } }
@media screen and (min-width: 1400px) { .header_title, .header_title_top { width: 350px; height: 70px; } }
@media screen and (min-width: 1500px) { .header_title, .header_title_top { width: 400px; height: 80px; } }

@media screen and (max-width: 1100px) {	
	#header {
		width: 100%; height: 60px;
		background: #fff; position: fixed; top: 0; left: 0
	}
	.header_title_top {
		width: 40%;
		position: absolute; top: 100px; left: 0; right: 0; margin: auto;
	}
	.header_title, .header_title_top.scroll  {
		width: 140px;
		position: absolute; top: 15px; left: 20px; right: auto;
	}
}
@media screen and (max-width: 900px) { .header_title_top {  width: 40%; } }
@media screen and (max-width: 600px)  { .header_title_top {  width: 50%; top: 110px; } }
@media screen and (max-width: 500px)  { .header_title_top {  width: 60%; top: 120px; } }

/* contents */
.contents { padding: 0 20px; max-width: 800px; margin: 0 auto; position: relative; }
@media screen and (min-width: 1101px) { .contents { margin: 0 0 0 30px; } }
@media screen and (min-width: 1400px) { .contents { margin: 0 0 0 10%; } }
@media screen and (min-width: 1600px) { .contents { margin: 0 0 0 15%; } }


/* 左の英文（PC） */
.pc_left { display: none; }
@media screen and (min-width: 1100px) {
    .pc_left {
        display: block; height: 20px; line-height: 20px;
        transform: rotate(90deg);
        position: fixed; top: 0; bottom: 0; left: 0px; margin: auto;
        font-size: 1.4rem; letter-spacing: 0.2rem;
		font-family: Arial, Helvetica, "sans-serif";
        color: #e50038; text-align: center;
    }  
}

/* menuButton ━━━━━━━━━━━━━━━━━━━━━*/
#menuButton { display: block;  }
#menuButton span {
    display: block;
    background: #e50038;
    position: absolute; left: 9px;
    transition: all 0.4s;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
}
#menuButton span:first-child { }
#menuButton.active span:first-child,
#menuButton.active span:last-child { opacity: 0; }
@media screen and (min-width: 1101px) {
	#menuButton {
	width: 60px; height:60px;
	position: fixed; top: 20px; right: 30px;
	}
	#menuButton span { width: 50px; height: 2px; position: absolute; left: 9px; }
	#menuButton span:first-child { top: 12px; }
	#menuButton span:nth-child(2) { margin-top: -1px; top: 50%; width: 35px; }
	#menuButton span:last-child { bottom: 12px; }
	#menuButton.active span:nth-child(2) { width: 50px; }
}
@media screen and (max-width: 1100px) {
	#menuButton {
		position: fixed; top: 8px; right: 20px;
		width: 42px; height:42px;
		}
	#menuButton span { width: 24px; height: 2px; position: absolute; left: 9px; }
	#menuButton span:first-child { top: 12px; }
	#menuButton span:nth-child(2) { margin-top: -1px; top: 50%; width: 14px; }
	#menuButton span:last-child { bottom: 12px; }
	#menuButton.active span:nth-child(2) { width: 24px; }
}

/* header_nav  ━━━━━━━━━━━━━━━━━━━━━*/

.header_nav {
	position: fixed; top: 0; left: 0; 
	background: #fff; width: 100%; height: 100vh; opacity: 0; display: none;
	overflow: auto;
}
.header_nav_contents {
	position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto;
	width: 220px; height: 130px; text-align: center;
}
.header_nav_title { padding: 0 0 10px 0; width: 212px; display: inline-block; }
.header_nav_by { color: #e50038; font-size: 1rem; text-align: center; }
.header_nav_logo { width: 110px; margin: 5px auto 10px auto; }
.header_nav_sns { text-align: center; letter-spacing: -0.4em; }
.header_nav_sns a {
	display: inline-block; letter-spacing: normal;
	background: #e50038; width: 110px; padding: 10px 0;
	border: solid 2px #fff;
}
.header_nav_sns a img { width: 26px; }
@media screen and (min-width: 901px) {
	.header_nav_sns a:hover { background: #222; }
}


/* post_link  ━━━━━━━━━━━━━━━━━━━━━*/

.post_link { padding: 0 0 30px 0;  }
.post_link li {
	font-size: 1.6rem; line-height: 100%;
	border-bottom: solid 1px #e50038;
}
.post_link li span {
	width: 200px; display: inline-block;
	-webkit-font-feature-settings: 'palt' 0;
	font-feature-settings: 'palt' 0;
	letter-spacing: 0.1rem;
}
.post_link a {
	color: #e50038;
	display: block; transition: all 0.2s ease;
	padding: 30px 0 10px 0;
	position: relative;
}
.post_link a:after {
	content: ""; display: block; background: #e50038;
	width: 8px; height: 8px; border-radius: 50%;
	position: absolute; right: 0; bottom: -5px;
}
@media screen and (min-width: 901px) { .post_link a:hover { color: #222; transform: translate(30px, 0); } }
@media screen and (max-width: 1100px) { .post_link li { font-size: 1.4rem; } }
@media screen and (max-width: 600px) {
	.post_link li { font-size: 1.3rem; }
	.post_link li span { width: 160px;  }
}
@media screen and (max-width: 480px) {
	.post_link li span { display: block; padding: 0 0 10px 0; }
}

/* post_link_sns */
.post_link_sns { letter-spacing: -0.4em;  margin: -60px 0 0 0; }
.post_link_sns a {
	display: inline-block; letter-spacing: normal;
	background: #fff; width: 40px; padding: 10px 0;
	border: solid 2px #fff;
}
.post_link_sns a img { width: 26px; }
/*@media screen and (min-width:600px) and ( max-width: 1110px) {
	.copyright, .post_link_sns { text-align: center; }
}*/

/* copyright */
.copyright {
	font-size: 1rem; line-height: 150%; color: #e50038;
	padding: 40px 0 10px 0;
}
.copyright img { width: 90px; padding: 0 0 5px 0; }
@media screen and (max-width: 1100px) { 
	.copyright { transform: scale(0.8); transform-origin: left; padding: 40px 0 0 0; }
}
@media screen and (max-width: 600px) { 
	.copyright { transform: scale(0.7); transform-origin: left; }
}

/* link_post_top  ━━━━━━━━━━━━━━━━━━━━━*/

.link_post_top { padding: 100px 0; }
@media screen and (max-width: 1100px) { .link_post_top {  padding: 220px 0 100px 0; } }
@media screen and (max-width: 900px) { .link_post_top {  padding: 230px 0 100px 0; } }
@media screen and (max-width: 600px) { .link_post_top {  padding: 240px 0 100px 0; } }

/* footer  ━━━━━━━━━━━━━━━━━━━━━*/

#footer { height: 300px; }



