@charset "UTF-8";
/*
Theme Name: 特定非営利活動法人そらっく
Template: twentynineteen
Author: 特定非営利活動法人そらっく
Author URI: https://ht-soluck.com/
Description:
Version: 1.0
Updated: 2021-04-19
*/

/* Color Scheme
-----------------------------------------------------

	=Theme Color = #00a0e9, #06ce80

-----------------------------------------------------
*/

@import url(reset.css);
@import url(wordpress.css);

/*
-----------------------------------------------------

 	=Global Layout

-----------------------------------------------------
*/

* {
	margin: 0; padding: 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;
}

html {
	font-family: brother-1816, "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
	-webkit-font-smoothing: antialiased !important;
	-webkit-text-stroke: 1px transparent;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	text-rendering: optimizeLegibility;
	color: #000;
	font-size: 10px;
	font-weight: normal;
	line-height: 1.8;
	word-wrap: break-word;
	letter-spacing: 0.00em;
}
/* Firefox */
@-moz-document url-prefix() {
	html {
		font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
	}
}
/* IE11 */
_:-ms-lang(x)::-ms-backdrop, html {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
}

body{
	background-color: #fff;
	font-size: 1.6rem;
}

h1, h2, h3, h4, h5, h6, p, pre, dt, dd, li {
	line-height: 1.8;
}
p, ul, ol, dl, table {
	margin-bottom: 2.0rem;
}
p:last-child, ul:last-child, ol:last-child, dl:last-child, table:last-child {
	margin-bottom: 0;
}
table {
	width: 100%;
	border-collapse: collapse;
	line-height: 1.8;
	text-align: left;
}
th, td {
	padding: 1em 1.5em;
	vertical-align: top;
	border: none;
}
th {
	font-weight: bold;
	text-align: justify;
}
tr {}

hr {
	clear: both;
	border: none;
}
img {
	display: inline-block;
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
}
a img {
	border: none;
}
a {
	color: #00a0e9;
	text-decoration: underline;
}
a,
a img {
	cursor: pointer;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}
a:hover {
	opacity: 0.5;
	text-decoration: none;
}
/*::selection {
	background-color: rgba(0,0,0,0.25);
}*/

em {}

ol{
	counter-reset: number;
	list-style: none;
}
ol li {
	position: relative;
	padding-left: 2.5em;
}
ol li:not( :last-child ) {
	margin-bottom: 1.5em;
}
ol li::before {
	position: absolute;
	left: 0;
	counter-increment: number;
	content: "("counter(number)")";
	margin: 0 1.0em 0 0;
}
ol li ol:last-child { margin-bottom: 2em; }
ol li ol li::before {
	content: "("counter(number,lower-roman)")";
}
ol li ol li:not( :last-child ) {
	margin-bottom: .5em;
}


strong { font-weight: bold; }
iframe { display: block; max-width: 100%;}
form {}
input[type="text"],
input[type="submit"],
textarea {
	-webkit-appearance: none;
	-webkit-border-radius: 0;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}
input[type=text],
input[type=email],
input[type=password],
textarea {
	padding: 5px;
	font-size: 16px;
	font-weight: inherit;
	color: inherit;
	-webkit-appearance: none;
}
input[type=text],
input[type=email],
input[type=password],
textarea,
select {
	background-color: #eee;
	color: #555;
	border: 1px solid #eee;
	line-height: 1;
	vertical-align: middle;
	max-width: 100%;
	border-radius: 5px;
}
input[type=text] { margin-bottom: 0.5em; }
input[type=text]:last-child { margin-bottom: 0; }
input[type=email] {}
input[type=submit] { cursor: pointer;}
input[type=text]:focus,
textarea:focus {
	color: #555;
}
textarea {
}
form ul { margin: 0 !important; padding: 0 !important; border: none !important;}
form ul li { display: inline-block !important;}
form label { margin-right: 1.4em;}
form input[type*="submit"] {}
form input[type*="submit"]:hover { opacity: 0.8;}

/*
-----------------------------------------------------

 	=Global Style

-----------------------------------------------------
*/

#container {}

.wrapper {
	width: 100%;
	max-width: 1120px;
	margin: auto;
}

.wrapper-big {
	max-width: 1200px;
}

.wrapper-min {
	max-width: 800px;
}


/*
-----------------------------------------------------

 	=Header & H

-----------------------------------------------------
*/

/* =Header
----------------------------------------------------- */

#header {
	position: fixed;
	z-index: 9999;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	padding: 0;
	-webkit-transition: all ease-out 0.4s;
	   -moz-transition: all ease-out 0.4s;
	    -ms-transition: all ease-out 0.4s;
	        transition: all ease-out 0.4s;
}
#header #header-in {
	padding: 40px;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}

#header .logo {
	padding: 0;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}
#header .logo .img {
	max-width: 237px;
	float: left;
	margin: 0 1em 0 0;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}
#header .logo .sitetitle {
	display: inline-block;
	font-size: 1.2rem;
}

#header .button {
	text-align: right;
}
#header .button ul {
	letter-spacing: 0;
	font-size: 0;
}
#header .button ul li {
	display: inline-block;
	margin: 0 0 0 15px;
	vertical-align: top;
	font-size: 1.8rem;
}
#header .button ul li.button-tel {}
#header .button ul li.button-contact {}
#header .button ul li.button-menu {}
#header .button ul li a {
	display: block;
	width: 100px;
	height: 100px;
	border-radius: 10px;
	color: #000;
	font-size: 1.6rem;
	text-align: center;
	text-decoration: none;
	padding-top: 60px;
}
#header .button ul li.button-tel a {
  background: url(assets/images/icon-tel.png) no-repeat center top 16px;
  background-size: 36px auto;
  background-color: rgb(255, 240, 0);
  box-shadow: 0px 4px 0px 0px rgba(184, 168, 0, 1);
}
#header .button ul li.button-contact a {
  background: url(assets/images/icon-envelope.png) no-repeat center top 20px;
  background-size: 36px auto;
	background-color: #f19149;
  box-shadow: 0px 4px 0px 0px rgba(179, 104, 48, 1);
	color: #fff;
}
/*#header .button ul li.button-menu a {
	background-color: #17b7ff;
  box-shadow: 0px 4px 0px 0px rgba(38, 56, 104, 1);
	color: #fff;
}*/


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

	#header.scrolled {
		background-color: rgba(255,255,255,0.8);
	}
	#header.scrolled #header-in {
		padding: 20px;
	}
	#header.scrolled .logo {
		padding: 0;
	}
	#header.scrolled .logo .img {
		max-width: 140px;
	}	
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	#header #header-in {
		padding: 3.125vw;
	}
	#header .logo {
		padding: 0;
	}
	#header .logo .img { max-width: 120px; }
	#header .logo .sitetitle { display: none; }

	#header .button {
		padding-right: 65px;
		padding-right: 0;
	}
	#header .button ul li {
		margin: 0 0 0 5px; 
	}
	#header .button ul li a {
		display: block;
		width: 60px;
		height: 60px;
		border-radius: 5px;
		color: #000;
		font-size: 1.0rem;
		text-align: center;
		text-decoration: none;
		padding-top: 36px;
	}
	#header .button ul li.button-tel a {
		background-position: center top 10px;
		background-size: 23px auto;
	}
	#header .button ul li.button-contact a {
		background-position: center top 13px;
		background-size: 20px auto;
	}

	.toggler {
		position: absolute;
		z-index: 9999;
		top: 0;
		right: 0;
		margin: 3.25vw;
		padding: 15px;
		width: 60px;
		height: 60px;
		border-radius: 5px;
		background-color: #00a0e9;
	  box-shadow: 0px 4px 0px 0px rgba(38, 56, 104, 1);
	  text-align: center;
		-webkit-transition: all ease-out 0.4s;
			 -moz-transition: all ease-out 0.4s;
				-ms-transition: all ease-out 0.4s;
						transition: all ease-out 0.4s;
		cursor: pointer;
	}
	a.trigger-bars {
		position: relative;
		z-index: 9999;
		width: 26px;
		height: 14px;
		color: #fff;
		text-decoration: none;
	}

	.toggler::after {
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		padding-top: 36px;
		content: "メニュー";
		font-size: 1.0rem;
		width: 60px;
		color: #fff;
		text-align: center;
		line-height: 1.8;
	}

	a.trigger-bars,
	a.trigger-bars span {
		box-sizing: border-box;
		display: inline-block;
		-webkit-transition: all ease-out 0.4s;
			 -moz-transition: all ease-out 0.4s;
				-ms-transition: all ease-out 0.4s;
						transition: all ease-out 0.4s;
	}
	a.trigger-bars span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 1px;
		background-color: #fff;
		border-radius: 0;
		-webkit-transition: all ease-out 0.14s;
			 -moz-transition: all ease-out 0.14s;
				-ms-transition: all ease-out 0.14s;
						transition: all ease-out 0.14s;
	}

	.trigger-bars span:nth-of-type(1) { top: 0;}
	.trigger-bars span:nth-of-type(2) { top: 7px;}
	.trigger-bars span:nth-of-type(3) {	bottom: 0;}
	.trigger-bars.active span:nth-of-type(1) {
		-webkit-transform: translateY(7px) rotate(-45deg);
		        transform: translateY(7px) rotate(-45deg);
	}
	.trigger-bars.active span:nth-of-type(2) {
		opacity: 0;
	}
	.trigger-bars.active span:nth-of-type(3) {
		-webkit-transform: translateY(-7px) rotate(45deg);
		        transform: translateY(-7px) rotate(45deg);
	}
	/*.trigger-bars.active span {
		background-color: #fff;
	}*/
}



/* =Navigation
----------------------------------------------------- */

ul.nav-main {
	display: block;
	height: 60px;
	border-radius: 30px;
	overflow: hidden;
	margin: 0 0 30px;
	padding-left: 30px;
	background-color: #fff;
	text-align: right;

	letter-spacing: 0;
	font-size: 0;
}
ul.nav-main li {
	display: inline-block;
	font-size: 1.6rem;
}
ul.nav-main li:not( :last-child )::after { content: ""; }
ul.nav-main li a {
	display: block;
	width: auto;
	line-height: 30px;
	padding: 15px 1em;
	color: #000;
	font-weight: bold;
	text-decoration: none;
}
ul.nav-main li a:hover {
	color: #aaa;
}

@media screen and (min-width: 600px) {
	#nav {
		position: fixed;
		z-index: 9997;
		top: -200px;
		right: 0;
		padding: 40px;
		height: auto;
		-webkit-transition: all ease-out 0.2s;
		   -moz-transition: all ease-out 0.2s;
		    -ms-transition: all ease-out 0.2s;
		        transition: all ease-out 0.2s;
	}
	#nav ul.nav-main {
		max-width: 1100px;
		/*min-width: 1000px;*/
		box-shadow: 0 0 25px rgba(0,0,0,0.15);
	}
	#nav.scrolled {
		top: 0;
	}
	#nav #nav-in {}
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	#nav {
		position: fixed;
		z-index: 9997;
		top: 0;
		left: 0;
		bottom: auto;
		width: 100vw;
		height: 100vh;
		padding: 0;
		background: url(assets/images/bg-cubism01.jpg) no-repeat center fixed;
		background-size: cover;
		/*background-color: #e4e9eb;*/
		overflow-y:scroll;
		-webkit-overflow-scrolling:touch;
		-webkit-transform:translate3d(-100%,0,0);
			 -moz-transform:translate3d(-100%,0,0);
				-ms-transform:translate3d(-100%,0,0);
						transform:translate3d(-100%,0,0);
		-webkit-transition: opacity ease-out 0.25s;
			 -moz-transition: opacity ease-out 0.25s;
				-ms-transition: opacity ease-out 0.25s;
						transition: opacity ease-out 0.25s;
		opacity: 0;
		text-align: center;
	}

	#nav.on {
		opacity: 1;
		-webkit-transform:translate3d(0,0,0);
		   -moz-transform:translate3d(0,0,0);
		    -ms-transform:translate3d(0,0,0);
		        transform:translate3d(0,0,0);
	}
	#nav.on #nav-in {
		opacity: 1;
	}

	#nav,
	#nav a {}

	#nav #nav-in {
		margin: 0;
	  padding: 6.25vw;
	}
	#nav ul.nav-main {
		height: auto;
		text-align: center;
		padding-left: 0;
		padding: 6.25vw;
	}
	#nav ul.nav-main li {
		display: block;
		margin: 0;
	}
	#nav ul.nav-main li:not( :last-child )::after { content: ""; }
	#nav ul.nav-main li a {
		display: block;
		width: auto;
		padding: 0.5em 0;
		letter-spacing: 0.07em;
		text-decoration: none;
	}
	#nav ul.nav-main > li > a {
		line-height: 1.5;
		height: auto;
	}
	#nav ul.nav-main li a:hover {}

}


/*
-----------------------------------------------------

	=Firstview (Frontpage)

-----------------------------------------------------
*/

#key.top {
	position: relative;
	z-index: 1;
}
#key.top .mainvisual {
	height: 100vh;
	overflow: hidden;
}
#key.top .mainvisual .image {}
#key.top .mainvisual .image ul {
	letter-spacing: 0;
	font-size: 0;
}
#key.top .mainvisual .image ul li {
	display: inline-block;
	width: 50%;
	height: 100vh;
	overflow: hidden;
}
#key.top .mainvisual .image ul li img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
#key.top .mainvisual .image {}
#key.top .mainvisual .content {
  position: absolute;
  z-index: 4;
  top: 50%;
  left: 0;
  right: 0;
  width: 420px;
  margin: 0 auto;
  transform: translate(0%, -50%);
  -webkit-transform: translate(0%, -50%);
  -moz-transform: translate(0%, -50%);
  -ms-transform: translate(0%, -50%);
  -o-transform: translate(0%, -50%);
}

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

}
@media screen and (min-width: 0px) and (max-width: 599px) {
	#key.top {
		height: 100vh;
	}
	#key.top .mainvisual .image {}
	#key.top .mainvisual .image ul li {
		display: block;
		width: 100%;
		height: 50vh;
	}
	#key.top .mainvisual .content {
		max-width: 80%;
	}

}

/*
-----------------------------------------------------

	=Firstview (Subapge)

-----------------------------------------------------
*/

/*#key.sub {
	height: 400px;
}
#key.sub .in {
	padding-top: 220px;
}
#key.sub .in .title {
	text-align: left;
}
#key.sub .in .title,
#key.sub .in .title em {
	color: #fff;
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	#key.sub {
		height: 360px;
	}
	#key.sub .in {
		padding-top: 180px;
	}
}*/

/*
-----------------------------------------------------

	=Main

-----------------------------------------------------
*/

#cont {}
#main {}
#main main {}
.top #main {}
.sub #main {}


/*
-----------------------------------------------------

	=Footer

-----------------------------------------------------
*/

/* =Action
----------------------------------------------------- */
#action {
	padding: 6.25vw 0;
}
.action-box {
	background-color: #fff;
	border-radius: 10px;
	padding: 3.125vw;
	box-shadow: 0px 4px 0px 0px rgba(170, 170, 170, 1);
}
.action-box,
.action-box a {}
.action-box a { text-decoration: none; }

.action-box .action-header {
	margin-bottom: 3.125vw;
	text-align: center;
}
.action-box .action-header .title-section {
	padding-bottom: 0;
	margin-bottom: 0;
}
.action-box .action-header .title-section::after {
	display: none;
}

.action-box .action-content {}
.action-box .action-content ul {
	padding-left: 0;
	text-align: center;
}
.action-box .action-content ul li {
	display: inline-block;
	text-align: left;
	position: relative;
}
.action-box .action-content ul li a {
	color: #000;
}

.action-box .action-content ul li p {	margin: 0;}
.action-box .action-content ul li.button-tel {
	padding-left: 100px;
}
.action-box .action-content ul li.button-tel::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 80px;
	height: 80px;
	background: url(assets/images/icon-circle-tel.png) no-repeat;
	background-size: 100% auto;	
}
.action-box .action-content ul li.button-tel p { line-height: 1.6; }
.action-box .action-content ul li.button-tel .num {
	font-size: 3.2rem;
	font-weight: bold;
}
.action-box .action-content ul li.button-tel .text {
	font-size: 1.2rem;
}


@media screen and (min-width: 0px) and (max-width: 599px) {
	.action-box .action-header,
	.action-box .action-header .title {
		text-align: center;
	}
	.action-box .action-header .title {
		margin-bottom: 0.5em;
	}
	.action-box .action-content ul li.button-tel {
		padding-left: 75px;
	}
	.action-box .action-content ul li.button-tel::before {
		width: 60px;
		height: 60px;
	}
	.action-box .action-content ul li.button-tel .num {
		font-size: 2.4rem;
	}
	.action-box .action-content ul li.button-tel .text {
		font-size: 9px;
	}
}


/* =Footer
----------------------------------------------------- */
#footer {
	position: relative;
	background-color: #31ade4;
	color: #fff;
	text-align: center;
}
#footer,
#footer a { color: #fff; }
#footer a { text-decoration: none; }
#footer #footer-in {
	padding: 6.25vw 0;
}
#footer #pagetop {
	position: absolute;
	right: 0;
	bottom: 0;
	margin: 6.25vw;
	width: 40px;
	height: 21px;
	-webkit-transition: all ease-out 0.4s;
	   -moz-transition: all ease-out 0.4s;
	    -ms-transition: all ease-out 0.4s;
	        transition: all ease-out 0.4s;
}
#footer #pagetop a {
	display: block;
}
#footer p:not( :last-child ),
#footer ul:not( :last-child ) {
	margin: 0 0 .85em;
}

#footer .logo {
	max-width: 180px;
	margin: 0 auto 3.125vw; 
}
#footer .logo img {
	display: inline-block;
}
#footer .info {}

/*#footer .navigation ul {
	display: inline-block;
	vertical-align: top;
	margin: 0 2em 3.125vw 0;
}
#footer .navigation ul:not( :first-child ) {
	margin-right: 2em;
}
#footer .navigation ul li {
	display: block;
	padding-left: 12px;
	background: url(../images/icon-arrow-right-footer.png) no-repeat left center;
	background-size: 5px auto;
	font-size: 1.4rem;
}
#footer .navigation ul li.external {
	padding-left: 20px;
	background: url(../images/icon-external.png) no-repeat left center;
	background-size: 13px auto;
}

#footer .navigation ul li::before {}
#footer .navigation ul li a {}*/

#footer .copyright {
	padding-top: 3.125vw;
	font-size: 1.2rem;
}
@media screen and (min-width: 600px) {
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	#footer {}
	#footer #pagetop {}
	#footer #footer-in {
		padding: 6.25vw;
	}
	#footer .logo,
	#footer .info,
	#footer .copyright {
		text-align: center;
		margin: 0 auto 20px;
		font-size: 1.2rem;
	}
	#footer .logo {
		max-width: 120px;
	}
	#footer .copyright {
		margin: 6.25vw 0 0;
		font-size: 1.0rem;
	}
}

/*
-----------------------------------------------------

	=Common Parts

-----------------------------------------------------
*/


/* =Section
----------------------------------------------------- */
.block:not( :last-child ) {
	margin-bottom: 100px;
}

.section {
	padding: 100px 0;
}

hr {
	clear: both;
	border: none;
	height: 50px;
}

hr.hr-border {
	height: 1px;
	background-color: #dcdcdc;
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	.block:not( :last-child ) {
		margin: 0 auto 12.5vw;
	}
	.section {
		padding: 12.5vw 0;
	}
	hr { height: 6.25vw; }
}


/* =Breadcrumbs
----------------------------------------------------- */
#breadcrumbs {
	padding: 19px 0;
	background-color: #404040;
	font-size: 1.6rem;
	line-height: 20px;
	color: #fff;
}

#breadcrumbs .wrapper {}
#breadcrumbs,
#breadcrumbs a {
	color: #fff;
}
#breadcrumbs a {
	color: #fff;
	font-weight: bold;
	text-decoration: none;
}
#breadcrumbs a:hover {
	text-decoration: underline;
}
@media screen and (min-width: 0px) and (max-width: 599px) {
	#breadcrumbs {
		font-size: 1.2rem;
	}
}

/* =Decoration
----------------------------------------------------- */

/* background */
.bg-toy {
	background: url(assets/images/bg-toy.jpg) no-repeat center fixed;
	background-size: cover;
}
@media screen and (min-width: 0px) and (max-width: 599px) {
	.bg-toy {
		background: url(assets/images/bg-toy.jpg) no-repeat center;
		background-size: cover;
	}
}

/* Text */
a.link-non-style {
	color: inherit;
	text-decoration: none;
}

/* Frame */
.frame {
	padding: 2.5em;
}
.frame:not( :last-child ) {
	margin-bottom: 25px;
}

/* =Heading
----------------------------------------------------- */
.title-section {
	position: relative;
	margin: 0 0 1.0em;
	padding-bottom: 60px;
	color: #000;
	font-size: 3.2rem;
	font-weight: normal;
	line-height: 1.5;
	text-transform: uppercase;
}
.title-section em {
	display: block;
	font-size: 2.0rem;
	margin: 0.25em 0 0;
	color: #00a0e9;
	letter-spacing: 0.2em;
}
.title-section::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: 0;
	width: 100px;
	height: 2px;
	background-color: #00a0e9;
}

.title-section.black em { color: #000;}
.title-section.black::after { background-color: #000;}

.title-main {
	margin: 0 0 1.0em;
	color: #000;
	font-size: 3.2rem;
	font-weight: bold;
}


@media screen and (min-width: 0px) and (max-width: 599px) {
	.title-section {
		margin: 0 0 1.5em;
		padding-bottom: 1em;
		font-size: 2.4rem;
	}
	.title-section em {
		font-size: 1.6rem;
	}
	.title-main { font-size: 2.0rem; }
}





/* =Button
----------------------------------------------------- */
.button-more {
	position: relative;
	display: inline-block;
	width: 100%;
	max-width: 360px;
	padding: 1.125em 2.5em;
	border-radius: 36px;
	line-height: 1.25;
	background-color: #00a0e9;
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
  overflow: hidden;
}
.button-more:hover {
	color: rgb(78,89,237);
}
/*.button-more::after {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	bottom: 0;
	left: 0;
	width: 0%;
	height: 100%;
	background-color: #fff;
	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}
.button-more:hover::after {
	width: 100%;
}*/
.button-more:hover {
	opacity: 1;
}


	/* Sizing */
	/*.button-more.small {
		max-width: 200px;
		padding: .75em 1.5em;
		border-radius: 35px;
		font-size: 1.6rem;
	}
	.button-more.small:hover {}

	.button-more.large {
		max-width: 480px;
		padding: 1.125em 2.5em;
		border-radius: 40px;
		font-size: 2.4rem;
	}
	.button-more.large:hover {}*/

	/* Coloring */
	/*.button-more.white {
	  background-color: #fff;
	  color: #000;
	}
	.button-more.white:hover {
	  background-color: #000;
	  color: #fff;
	}

	.button-more.black {
	  background-color: #000;
	  color: #fff;
	}
	.button-more.black:hover {
	  background-color: #666;
	  color: #fff;
	}

	.button-more.ghost {
	  background: rgba(0,0,0,0.1);
	  border: solid 1px rgb(255, 255, 255);
	}
	.button-more.ghost:hover {}

	.button-more.disable,
	.button-more.disable:hover  {
		background-color: #999;
	}*/


@media screen and (min-width: 0px) and (max-width: 599px) {
	.button-more {
		font-size: 1.6rem;
	}

}

/*
-----------------------------------------------------

	=Frontpage

-----------------------------------------------------
*/

/* =INFORMATION
----------------------------------------------------- */
.top-information {}
.top-information .col01 { width: 25%;}
.top-information .col02 { width: 75%;}

ul.list-information {}
ul.list-information li {
	margin: 0 0 1em;
	padding: 15px;
	display: flex;
	justify-content: space-between;
	background-color: #fff;
	border-radius: 30px;
}
ul.list-information li:last-child {
	margin: 0;
	border-bottom: none;
}
ul.list-information li .category,
ul.list-information li .date,
ul.list-information li .text {
	display: inline-block;
	padding-right: 10px;
}
ul.list-information li .category { width: 16%; }
ul.list-information li .date { width: 14%; }
ul.list-information li .text { width: 70%; }

ul.list-information li .category {}
ul.list-information li .category a {
	display: block;
	background-color: #f19149;
	color: #fff;
	text-align: center;
	max-width: 100%;
	text-decoration: none;
	border-radius: 20px;
}
ul.list-information li .date {}
ul.list-information li .text {
	font-weight: bold;
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	.top-information .row > .col {
		margin-bottom: 0;
	}
	ul.list-information li {
		display: block;
		border-radius: 10px;
	}
	ul.list-information li .category {
		display: block;
		margin: 0 10px 10px 0;
		width: 100%;
		max-width: 120px;
	}
	ul.list-information li .date,
	ul.list-information li .text {
		display: inline-block;
		padding-right: 10px;
	}
	ul.list-information li .date {
		width: 20%;
	}
	ul.list-information li .text {
		width: 75%;
	}
}

/* =SERVICE
----------------------------------------------------- */
.top-service {}
.service-lineup .row {}
.service-lineup .row .col {}
.service-lineup .lineup {
	max-width: 570px;
	background-color: #fff;
	border: solid 2px #31ade4;
	border-radius: 10px;
}
.service-lineup .lineup .header {
	padding: 20px;
	background-color: #31ade4;
	color: #fff;
}

.service-lineup .lineup .header .title {
	text-align: center; 
	font-size: 3.2rem;
	font-weight: bold;
	color: #fff;
}
.service-lineup .lineup .image {
	border-bottom: solid 2px #31ade4;
}
.service-lineup .lineup .content {
	padding: 30px;
}

.service-lineup .lineup01 {}
.service-lineup .lineup02,
.service-lineup .lineup02 .image { border-color: #f49097;}
.service-lineup .lineup02 .header { background-color: #f49097; }



@media screen and (min-width: 600px) {
	.top-service .title-section {
		float: right;
		text-align: right;
	}
	.top-service .title::after {
		margin: 0;
		left: auto;
	}
}
@media screen and (min-width: 0px) and (max-width: 599px) {
	.service-lineup .lineup .header .title {
		font-size: 2.4rem;
	}
}



/* =CONTACT
----------------------------------------------------- */
.contact-content {}

.mw_wp_form table {
	width: 100%;
	border-collapse: collapse;
	line-height: 1.8;
	text-align: left;
}
.mw_wp_form tr {
	display: block;
	padding: 0.5em 0;
	border-bottom: none;
}
.mw_wp_form th,
.mw_wp_form td {
	display: block;
	padding: 0.5em 0;
	vertical-align: top;
	text-align: left;
	border: none;
	font-size: 2.0rem;
	font-weight: normal;
}
.mw_wp_form th {}

.mw_wp_form input[type="text"],
.mw_wp_form input[type="email"],
.mw_wp_form input[type="tel"],
.mw_wp_form select,
.mw_wp_form textarea {
	padding: 0.75em;
	width: 100%;
}
.mwform-tel-field input[type="text"], 
.mwform-zip-field input[type="text"] {
	display: inline-block;
	vertical-align: unset;
}
.mw_wp_form .horizontal-item + .horizontal-item {
	margin-left: 0px;
	white-space: nowrap;
}

.mw_wp_form textarea {
	width: 100%;
}
.mw_wp_form em {
	display: inline-block;
	vertical-align: middle;
	margin-left: 1em;
	padding: 0.0em 0.5em;
	background-color: #06ce80;
	color: #fff;
	font-weight: bold;
	font-size: 1.4rem;
	border-radius: 0;
}
.mw_wp_form .text-note {
	display: inline-block;
	color: #aaa;
	font-size: 1.6rem; 
}

.mw_wp_form select {
	font-size: inherit;
	-webkit-appearance: none;
	-webkit-border-radius: 5px;
	background: #eee url(assets/images/icon-select.png) no-repeat right 1em center;
	background-size: 13px auto; 
}

.mw_wp_form input[type="submit"] {
	display: block;
	margin: auto;
	padding: 1.0em 2em;
	width: 480px;
	max-width: 100%;
	border: 0;
	border-radius: 35px;
	background-color: #00a0e9;
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
	text-align: center;
	text-decoration: none;

	-webkit-transition: all ease-out 0.2s;
	   -moz-transition: all ease-out 0.2s;
	    -ms-transition: all ease-out 0.2s;
	        transition: all ease-out 0.2s;
}
.mw_wp_form input[type="submit"]:hover {
	background-position: right 1.5em center;
}

@media screen and (min-width: 600px) {
	.mw_wp_form select {
		min-width: 800px;
	}
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	/* MW WP Form */
	.mw_wp_form tr,
	.mw_wp_form th,
	.mw_wp_form td { display: block !important; text-align: left; max-width: 100%;}
	.mw_wp_form tr { padding: 10px 0; margin: 0; border-bottom: none;}
	.mw_wp_form th,
	.mw_wp_form td { width: 100% !important; padding: 5px 0 !important; font-size: 1em !important; background-color: transparent; border: none !important;}

	.mw_wp_form input,
	.mw_wp_form input[type="text"],
	.mw_wp_form input[type="email"],
	.mw_wp_form textarea,
	.mw_wp_form select,
	.mw_wp_form input[type*="submit"] { font-size: 16px !important;}
	.mw_wp_form input[type="text"],
	.mw_wp_form input[type="email"],
	.mw_wp_form textarea { padding: 0.75em; width: 100%;}
	.mw_wp_form .mwform-zip-field input[type="text"] { width: auto; }
	.mw_wp_form select { padding: 0.75em; width: auto;}
	.mw_wp_form input[type="radio"] { padding: 0 !important;}
	.mw_wp_form input[type*="submit"] { width: 100% !important;}
	.mw_wp_form .mwform-tel-field input[type="text"] { width: auto !important;}
}



/*
-----------------------------------------------------

	=Single

-----------------------------------------------------
*/

.article {
	background-color: #fff;
	padding: 30px;
	box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.15);
}
.article-content { margin-bottom: 0 !important; }

/* 記事上部 */
.article-header {
	margin-bottom: 40px;
	padding-bottom: 40px;
	border-bottom: solid 1px #dcdcdc;
}
.article-header > *:not( :last-child ) {
	margin-bottom: 20px;
}
.article-header > *:last-child {
	margin-bottom: 0;
}
.article-header:after {
	content:".";
	display: block;
	height: 0px;
	font-size: 0;
	clear: both;
	visibility: hidden;
}
.article-image {
	float: right;
	width: 32%;
	height: 180px;
	margin-left: 40px;
	margin-bottom: 40px;
}
.article-image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
.article-title {
	margin-bottom: 20px;
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.5;
}
.article-title a {
	text-decoration: none;
}
.article-title a:hover {
	text-decoration: underline;
}

.article-meta {
	margin-bottom: 20px;
	font-size: 1rem;
}
.article-meta > span {
	display: inline-block;
	margin: 0 1.5em 10px 0;
}
.article-meta .article-date,
.article-meta .article-category {
	display: inline-block;
}
.article-meta .article-date {
	margin-right: 1.5em;
}
/*.article-meta .article-category a {
	margin-right: 1em;
	color: #f6b37f;
	text-decoration: none;
}
.article-meta .article-category a:hover {
	text-decoration: underline;
}*/

.article-meta .article-category {}
.article-meta .article-category a  {
	display: inline-block;
	padding: 0.5em 1.125em;
	background: #f6b37f;
	border: solid 0 #f6b37f;
	border-radius: 0;
	color: #fff;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
}
.article-meta .article-category a :hover {
	background-color: #000;
	color: #fff;
}

.article-summary {
	color: #aaa;
	font-size: 1.2rem;
}
.article-readingtime {
	background-color: rgba(0, 0, 0, 0.05);
	padding: 3px 12px;
	font-size: 1.3rem;
	font-weight: bold;
	color: #aaa;
}
.article-readingtime strong {
	display: inline-block;
	color: #333;
}
.article-relatedposts {
	margin-top: 40px;
	margin-bottom: 20px;
	border: solid 1px #dcdcdc;
	padding: 30px;
}
.article-relatedposts .tit {
	margin-bottom: 10px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.25;
}
.article-relatedposts p,
.article-relatedposts li {
	line-height: 1.5;
}
.article-relatedposts li {
	margin-bottom: 0.5em;
}
.article-author {
	margin-bottom: 40px;
	border: solid 1px #dcdcdc;
	background-color: #fff;
	padding: 30px;
}
.article-author .pic {
	float: left;
	max-width: 150px;
	margin: 0 20px 20px 0;
}
.article-author .pic img.avatar { border-radius: 0; }
.article-author .tit,
.article-author .txt { overflow: hidden; margin-bottom: 5px; }
.article-author .tit {
	margin-bottom: 20px;
	/*padding-bottom: 20px;
	border-bottom: solid 1px #dcdcdc;*/
	font-size: 2.0rem;
	font-weight: bold;
	line-height: 1.25;
}
.article-author .tit span {
	display: block;
	margin-right: 1em;
	margin-bottom: 5px;
	color: #666;
	font-size: 1.2rem;
	font-weight: normal;
}
.article-author .txt,
.article-author .link {
	color: #666;
	font-size: 1.2rem;
}
.article-author .link {
	text-align: right;
}
.article-sns {}
.article-sns .item {
	display: inline-block;
	vertical-align: top;
	margin: 0 5px 5px 0;
	max-width: 200px;
	overflow: hidden;
}

.article-summary {}
.article-summary p {
	font-size: 1.5rem;
	line-height: 1.75;
	letter-spacing: 0;
}

/* 本分 */
/* 本文の見出しスタイルなどは、wordpress.css */
.article-content {
	margin-bottom: 80px;
}

/* 記事下部 */
.article-footer {
	margin-bottom: 80px;
}
.article-footer .article-sns {
	text-align: right;
}

@media screen and (min-width: 0px) and (max-width: 599px) {
	.article {
		background-color: #fff;
		padding: 3.125vw;
		box-shadow: none;
	}
	.article-title {
		font-size: 1.6rem;
		line-height: 1.5;
	}
	.article-image {
		width: 100%;
		height: 200px;
		margin-left: 0;
		margin-bottom: 20px;
	}
	.article-author .tit, 
	.article-author .txt {
		overflow: inherit;
	}
	.article-author .pic {
		float: none;
		max-width: 100%;
		margin: 0 auto 20px;
		text-align: center;
	}
	.article-author .tit { text-align: center;}

	#nav .button ul li {
		display: inline-block;
		border: none;
	}
	#nav .button ul li img { margin: 0 10px 0 0; }
}


/*
-----------------------------------------------------

	=Media Queries Responsive Structure

-----------------------------------------------------
*/

/* Desktop
----------------------------------------------------- */
@media screen and (min-width: 600px) {
	.sp { display: none !important; }

	body {
		min-width: 1120px;
	}
	#header #header-in {
		min-width: 1120px;
	}
}

/* Smartphone
----------------------------------------------------- */
@media screen and (min-width: 0px) and (max-width: 599px) {
	html { font-size: 10px; }
	body { font-size: 1.4rem; letter-spacing: 0;}

	.pc { display: none !important;}

	/* Apperance
	--------------------------------------------------*/
	input[type="button"],
	input[type="text"],
	input[type="submit"] {-webkit-appearance: none;border-radius: 0;}

	/* Reset
	--------------------------------------------------*/
	iframe { width: 100%; max-height: 240px;}


	/* =Global Style
	-------------------------------------------------- */
	.wrapper {
		width: auto;
		padding: 0 6.25vw;
		margin: auto;
	}

	th, td {
		font-size: 1.2rem;
		padding: 1em 0.5em;
	}
	.frame {
		padding: 6.25vw;
	}


	/* =Frontpage
	-------------------------------------------------- */
	

	/* =Subpages
	-------------------------------------------------- */

}