@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Roboto:400,700');

/* RESET
----------------------------------------------------------------------------------------------------*/
a,
article,
body,
dd,
div,
dl,
dt,
em,
form,
footer,
header,
h1,
h2,
h3,
h4,
h5,
h6,
html,
i,
iframe,
img,
label,
legend,
li,
nav,
ol,
p,
section,
main,
span,
table,
tbody,
tfoot,
thead,
time,
tr,
th,
td,
ul,
video {
	font-family: inherit;
	font-size: 100%;
	font-weight: inherit;
	font-style: inherit;
	vertical-align: baseline;
	white-space: normal;
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	background: transparent;
	line-height: 1.6;
	text-align: left
}

textarea {
	font-family: inherit;
	font-size: 100%;
	font-weight: inherit;
	font-style: inherit;
	vertical-align: baseline;
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	background: transparent;
	line-height: 1.6;
	text-align: left
}

article,
footer,
header,
nav,
section,
main {
	display: block
}

ol,
ul {
	list-style: none
}

table {
	border-collapse: collapse;
	border-spacing: 0
}

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

 * 設定をしなおす

---------------------------------------------- */
body {
	margin: 0 auto;
	padding: 0;
	font-size: 16px;
	line-height: 1.6em;
	font-family: 'Roboto', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-weight: 500;
	color: #333;
	/*color: #535761;*/
	-webkit-text-size-adjust: 100%;
}



@media only screen and (max-width : 768px) {
	body {
		font-size: 14px;
	}
}

table {
	margin: 0;
	border-collapse: collapse;
	border-spacing: 0;
	empty-cells: show;
}

img {
	vertical-align: middle;
	border: none;
}



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

 * アンカータグの設定

---------------------------------------------- */
a {
	outline: none;
	color: #a68365;
}

a:hover {
	text-decoration: none;
}


a,
a:hover,
a:hover img {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	text-decoration: none;
}

a:hover {
	filter: alpha(opacity=80);
	-moz-opacity: 0.80;
	opacity: 0.80;
}




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

 * 見出し	h2

---------------------------------------------- */
/* h1 ------------------------------*/
h1 {
	font-size: 3rem;
	position: relative;
	padding: 0.5rem;
	text-align: center;
	color: #a68365;
	font-weight: bold;
}

h1:before {
	position: absolute;
	bottom: -10px;
	left: calc(50% - 30px);
	width: 60px;
	height: 5px;
	content: '';
	border-radius: 3px;
	background: #E23F48;
}

h1 span {
	display: block;
	text-align: center;
	font-size: 12px;
	font-weight: normal;
}

/* h2 ------------------------------*/
h2 {
	font-size: 3rem;
	position: relative;
	padding: 0.5rem;
	text-align: center;
}

h2:before {
	position: absolute;
	bottom: -10px;
	left: calc(50% - 30px);
	width: 60px;
	height: 5px;
	content: '';
	border-radius: 3px;
	background: #E23F48;
}

/* h3 ------------------------------*/
.uline_style04 {
	padding: 0.7em 0.5em;
	border-bottom: 1px solid #333;
	position: relative;
	font-weight: bold;

}

.uline_style04::before {
	content: "";
	display: block;
	position: absolute;
	bottom: -14px;
	right: 10px;
	width: 1px;
	height: 80%;
	background: #333;
}

/*その他の設定*/
*,
::before,
::after {
	box-sizing: border-box;
}

h3 {
	margin: 30px 20px;
	color: #333;
	font-size: 1.2em;
}

/* h4 ------------------------------*/
h4 {
	margin: 50px 10px 30px;
	width: calc(100% - 2rem);
	font-weight: bold;
	font-size: 1em;
	position: relative;
	padding-left: 1.5em;
}

h4:before {
	font-family: "FontAwesome";
	content: "\f101";
	margin-right: 9px;
}

@media only screen and (max-width : 768px) {

	.uline_style04 {
		padding:0.7em 0.5em 0.7em 0;
		margin:0 10px;
	}


}

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

 * 要素を左右中央寄せ

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

.taC {
	text-align: center !important;
}

.taR {
	text-align: right !important;
}

.taL {
	text-align: left !important;
}



* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	*behavior: url(/scripts/boxsizing.htc);
}

.container {
	margin: 0 auto
}

.clr:after,
.col:after,
.container:after,
.group:after,
.row:after {
	content: "";
	display: table;
	clear: both
}

.row {
	padding-bottom: 0
}

.col {
	display: block;
	float: left;
	width: 100%
}

@media (min-width:769px),
print {
	.gutters .col {
		margin-left: 2%
	}

	.gutters .col:first-child {
		margin-left: 0
	}

	.gutters .colR:first-child {
		margin-right: 0
	}

	.sp {
		display: none
	}
}

@media(max-width:768px) {
	.sp_none {
		display: none !important;
	}
}


img {
	max-width: 100%;
	height: auto;
	width
	/***/
	: auto;
	/*IE8のみ適用*/
}

@media only screen and (max-width : 768px) {
	.sbox {
		margin-bottom: 20px;
	}

	section {
		padding: 50px 0;
	}

	.container {
		width: calc(100% - 10px);
	}
}

@media only screen and (max-width : 480px) {}

@media only screen and (max-width : 374px) {}

@media print,
screen and (min-width : 769px) {
	.sbox {
		margin-bottom: 25px;
	}

	section {
		padding: 50px 0;
	}

	#sitetop section {
		padding: 100px 0 150px;
	}
	#sitetop #sec04 {
		padding: 100px 0 120px;
	}
	.container {
		width: calc(100% - 60px);
		padding: 0 30px;

	}
}

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

     HEADER

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

#header {
	box-shadow: 0px 3px 15px rgba(0, 0, 0, 0.2);
	z-index: 99;
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background: #000;
}

#gNav a:hover {
	color: #999;
}

nav li a {
	font-size: 13px;
	letter-spacing: 0.2em;
}

nav .sub-menu,
.mean-container .mean-nav ul ul {
	background: #fff;
	background-image: linear-gradient(to top, #f2dcc9 0%, #d9b79a 100%);
}

@media only screen and (max-width : 768px) {
	#header {
		padding: 10px 0;
		height: 60px;
	}

	.h_logo {
		width: 200px;
		position: absolute;
		top: 18px;
		left: 10px;
		z-index: 100;
	}

	#gNav .nav {
		overflow-y: auto;
		height: 100vh;
	}

	.mean-nav .container {
		padding: 0;
	}

	nav li .fa {
		display: none;
	}
}

@media print,
screen and (min-width : 769px) {
	#header {
		height: 80px;
	}

	.h_logo img {
		width: 300px;
	}

	#h_top {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	#gNav ul {
		position: relative;
		display: flex;
	}

	#gNav li {
		position: relative;
		margin-right: 3em;
	}

	#gNav li:last-child {
		margin-right: 0;
	}

	#gNav li i {
		font-size: 16px;
		margin-left: 5px;
	}

	#gNav li a {
		position: relative;
		display: block;
		text-align: center;
		line-height: 80px;
	}

	#gNav .sub-menu {
		visibility: hidden;
		opacity: 0;
		z-index: 1;
		display: block;
		position: absolute;
		top: 50px;
		left: 50%;
		margin-left: -100px;
		width: 200px;
		-webkit-transition: all .2s ease;
		transition: all .2s ease;
	}

	#gNav .sub-menu a {
		padding: 10px;
		display: block;
		border-bottom: none;
		padding: 20px;
		line-height: 1.2em;
	}

	#gNav .sub-menu a:hover:after {
		content: none;
	}

	#gNav .sub-menu li {
		display: block;
		font-size: 16px;
		padding: 0;
		margin: 0;
	}

	#gNav .sub-menu li:last-child {
		border-bottom: none;
	}

	#gNav ul>li:hover {
		-webkit-transition: all .5s;
		transition: all .5s;
	}

	#gNav ul>li:hover a,
	#gNav .current-menu-item a,
	#gNav .current-menu-parent a {
		color: #2ABCA7;
	}

	#gNav li:hover ul.sub-menu {
		top: 80px;
		visibility: visible;
		opacity: 1;
		z-index: 9999;
	}

	#gNav li ul li:after {
		content: none;
	}

	#gNav li:hover ul.sub-menu a {
		color: #111;
	}

	#gNav .sub-menu li a:hover {
		background: #fff;
	}

	#gNav .contact_btn a:hover {
		color: #fff;
	}
}

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

     FOOTER

--------------------------------------------------------------------------------------------- */
#rakuda{
	position: relative;
	top: 120px;
}

#footer {
	background-color: #000;
	font-size: 14px;
}

.f_logo,
.f_logo p {
	text-align: center;
}

.copy {
	display: block;
	text-align: center;
}

footer div ul li {
	margin: 0 10px 20px;
}

footer div ul li::after {
	content: "|";
	margin-left: 10px;
}

@media only screen and (max-width : 768px) {
	#footer {
		padding: 40px 0;
	}

	.f_logo {
		padding: 0 20px;
		text-align: center;
	}

	.f_logo p {
		text-align: center;
	}

	.f_logo img {
		margin-bottom: 20px;
		width: 100px;
	}
}

@media only screen and (max-width : 480px) {}

@media print,
screen and (min-width : 769px) {
	#footer {
		padding: 30px 0 10px;
	}
	.f_logo img {
		margin-bottom: 20px;
		width: 200px;
	}
}





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

     CONTENTS

--------------------------------------------------------------------------------------------- */
#main p {
	word-break: break-all;
}

section {
	text-align: center;
}

section div {
	text-align: center;
}

#sec01 {
	background: #000;
}

#sec02 {
	background: #594636;
}

#sec03 {
	background: #d9b79a;
}

#sec04 {
	background: #f2dcc9;
	padding-bottom:120px;
}

.btn {
	display: inline-block;
	/*  background-color: #2ABCA7;*/
	/*  background: #2ABCA7;*/
	color: #fff;
	padding: 0.8em 1em;
	text-align: center;
	margin: 20px auto 0;
	border-radius: 100px;
	font-size: 16px;
}

#about .btn,#quiz .btn,#link .btn,
#use .btn,
#sitetop .btn {
	background-color: #a68365;
	cursor: pointer;
}

.btn:after {
	content: "\f105";
	font-family: "FontAwesome";
	margin-left: 10px;
}

@media only screen and (max-width : 768px) {
	.btn {
		width: 60%;
	}
}

@media only screen and (max-width : 480px) {
	.btn {
		width: 80%;
	}
}

@media print,
screen and (min-width : 769px) {
	#main {
		padding-top: 80px;
	}

	.btn {
		width: 300px;
	}
}



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

     ページトップ

--------------------------------------------------------------------------------------------- */
#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 14px;
	line-height: 1;
	z-index: 99;
}

#page-top a {
	text-decoration: none;
	color: #fff;
	width: 80px;
	padding: 28px 5px;
	text-align: center;
	display: block;
	border-radius: 90px;
	opacity: 0.9;
	transition: all .3s ease;
}

#page-top a:hover {
	text-decoration: none;
	opacity: .5;
}

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

 * フォーム

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

input {
	margin-bottom: 10px;
}

input:-webkit-autofill {
	box-shadow: 0 0 0px 100px #d9b79a inset;
	-webkit-text-fill-color: #333 !important;
}

textarea {
	height: 100px;
	margin-bottom: 10px;
}

input,
textarea,
select {
	font-size: 1em;
	padding: 15px 10px 10px;
	font-family: 'Source Sans Pro', arial, sans-serif;
	border: 1px solid #d9b79a;
	background: #d9b79a;
	color: #333;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	-moz-background-clip: padding;
	-webkit-background-clip: padding-box;
	background-clip: padding-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	max-width: 600px;
}

input[type="submit"] {
	background-color: #a68365;
	border: 1px solid #a68365;
	cursor: pointer;
	transition: background-color 1s;
}

select {
	margin-bottom: 10px;
}

::-webkit-input-placeholder {
	color: #a68365;
}

:-moz-placeholder {
	color: #a68365;
}

::-moz-placeholder {
	color: #a68365;
}

:-ms-input-placeholder {
	color: #a68365;
}

input[type=radio] {
	width: 30px;
	margin-bottom: 20px;
	margin-left:0px;
}

button {
	width: 300px;
	background-color: #2ABCA7;
	/*  border: 1px solid #2ABCA7;*/
	border: none;
	-webkit-transition: .5s;
	transition: .5s;
	display: inline-block;
	cursor: pointer;
	display: block;
	color: #fff;
	padding: 0.8em 1em;
	text-align: center;
	margin: 50px auto;
	border-radius: 100px;
}

button:hover,
.button:hover {
	background: #19a08c;
}

label.error {
	font-family: 'Source Sans Pro', arial, sans-serif;
	font-size: 1em;
	display: block;
	padding-top: 10px;
	padding-bottom: 10px;
	background-color: #d89c9c;
	width: 80%;
	margin: auto;
	color: #a68365;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
}

/* media queries */
@media (max-width: 700px) {
	label.error {
		width: 90%;
	}

	input,
	textarea {
		width: calc(100% - 20px);
	}

	button {
		width: 90%;
	}

	body {
		padding-top: 10px;
	}
}

.message {
	font-family: 'Source Sans Pro', arial, sans-serif;
	font-size: 1.1em;
	display: none;
	padding-top: 10px;
	padding-bottom: 10px;
	background-color: #2ABCA7;
	width: 80%;
	margin: auto;
	color: #a68365;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
}

#calc table {
	width: calc(100% - 100px);
	margin: 0 auto;
}

#calc table tr td {
	padding: 10px;
	width: 20%;
}

#calc table tr td:last-of-type {
	width: 3em !important;
}

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

 * flex-box

---------------------------------------------- */
/* 横並び ------------------------------*/
.flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

/* 横並び（降順） ------------------------------*/
.flex_reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

/* 縦並び ------------------------------*/
.flex_c {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

/* 縦並び（降順） ------------------------------*/
.flex_c_reverse {
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
}

/* 折り返し ------------------------------*/
.f_wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

/* 折り返さない ------------------------------*/
.f_no_wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

/* 左 ------------------------------*/
.jc_start {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

/* 右 ------------------------------*/
.jc_end {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}

/* 中央 ------------------------------*/
.jc_center {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

/* 等間隔中央 ------------------------------*/
.jc_between {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

/* 等間隔端寄せ ------------------------------*/
.jc_around {
	-ms-flex-pack: distribute;
	justify-content: space-around;
}
/* flex解除 ------------------------------*/
.flex_off {
	display: block;
}
/* ----------------------------------------------

 * 表示・非表示

---------------------------------------------- */
/* PC非表示・スマホ表示 ------------------------------*/
.sp_none {
	display: none;
}

/* PC非表示・スマホ表示 ------------------------------*/
@media only screen and (max-width : 768px) {
	.sp_none {
		display: block;
	}
}

/* PC表示・スマホ非表示 ------------------------------*/
.sp_none {
	display: block;
}

/* PC表示・スマホ非表示 ------------------------------*/
@media only screen and (max-width : 768px) {
	.sp_none {
		display: none;
	}
}

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

 * 余白

---------------------------------------------- */
/* margin-top ------------------------------*/
.mt_05 {
	margin-top: 5px;
}

.mt_10 {
	margin-top: 10px;
}

.mt_20 {
	margin-top: 20px;
}

.mt_30 {
	margin-top: 30px;
}

.mt_40 {
	margin-top: 40px;
}

.mt_50 {
	margin-top: 50px;
}

.mt_100 {
	margin-top: 100px;
}

/* margin-bottom ------------------------------*/
.mb_05 {
	margin-bottom: 5px;
}

.mb_10 {
	margin-bottom: 10px;
}

.mb_20 {
	margin-bottom: 20px;
}

.mb_30 {
	margin-bottom: 30px;
}

.mb_40 {
	margin-bottom: 40px;
}

.mb_50 {
	margin-bottom: 50px;
}

.mb_100 {
	margin-bottom: 100px;
}

/* padding-top ------------------------------*/
.pt_05 {
	padding-top: 5px;
}

.pt_10 {
	padding-top: 10px;
}

.pt_20 {
	padding-top: 20px;
}

.pt_30 {
	padding-top: 30px;
}

.pt_40 {
	padding-top: 40px;
}

.pt_50 {
	padding-top: 50px;
}

.pt_100 {
	padding-top: 100px;
}

/* padding-bottom ------------------------------*/
.pb_05 {
	padding-bottom: 5px;
}

.pb_10 {
	padding-bottom: 10px;
}

.pb_20 {
	padding-bottom: 20px;
}

.pb_30 {
	padding-bottom: 30px;
}

.pb_40 {
	padding-bottom: 40px;
}

.pb_50 {
	padding-bottom: 50px;
}

.pb_100 {
	padding-bottom: 100px;
}

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

 * 引用

---------------------------------------------- */
.quote-2 {
	position: relative;
	padding: 2.5em 2.5em 2em 3em;
	color: #333333;
}

.quote-2::before,
.quote-2::after {
	display: inline-block;
	position: absolute;
	width: 4em;
	height: 4em;
	content: '';
	color: #d9b79a;
}

.quote-2::before {
	top: 0;
	left: 0;
	border-top: 1px solid #333;
	border-left: 1px solid #333;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4.58341 17.3211C3.55316 16.2274 3 15 3 13.0103C3 9.51086 5.45651 6.37366 9.03059 4.82318L9.92328 6.20079C6.58804 8.00539 5.93618 10.346 5.67564 11.822C6.21263 11.5443 6.91558 11.4466 7.60471 11.5105C9.40908 11.6778 10.8312 13.159 10.8312 15C10.8312 16.933 9.26416 18.5 7.33116 18.5C6.2581 18.5 5.23196 18.0095 4.58341 17.3211ZM14.5834 17.3211C13.5532 16.2274 13 15 13 13.0103C13 9.51086 15.4565 6.37366 19.0306 4.82318L19.9233 6.20079C16.588 8.00539 15.9362 10.346 15.6756 11.822C16.2126 11.5443 16.9156 11.4466 17.6047 11.5105C19.4091 11.6778 20.8312 13.159 20.8312 15C20.8312 16.933 19.2642 18.5 17.3312 18.5C16.2581 18.5 15.232 18.0095 14.5834 17.3211Z' fill='%23212121'%3E%3C/path%3E%3C/svg%3E");
	background-position: top 35% left 35%;
	background-size: 2em;
	background-repeat: no-repeat;
}

.quote-2::after {
	bottom: 0;
	right: 0;
	border-bottom: 1px solid #333;
	border-right: 1px solid #333;
}

.quote-2 p {
	margin: 0 auto 30px;
}

.quote-2 cite {
	display: block;
	color: #737373;
	font-size: .8em;
	text-align: right;
	margin-right: 25px;
}

@media only screen and (max-width : 768px) {
	.quote-2 {
		width: calc(100% - 70px);
		padding: 2.5em 0;
	}
}