* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

*, *: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-size: 62.5%; /* sets the base font to 10px for easier math */
}

body {
	font-family: 'Lato', 'Noto Sans JP', '���S�V�b�N Medium', '���S�V�b�N��', 'Yu Gothic Medium', YuGothic, '�q���M�m�p�S ProN', 'Hiragino Kaku Gothic ProN', '���C���I', Meiryo, '�l�r �o�S�V�b�N', 'MS PGothic', sans-serif;
	font-style: normal;
	font-weight: 300;
	font-size: 1.6rem;
	color: #444444;
	width: 100%;
	line-height: 1.44;
	letter-spacing: 0.01em;
}

a,a:hover,a:visited {
	color: #333;
}

a{
	outline: none;
}

a:focus{
	outline: none;
}

h1,h2,h3,h4,h5 {
	font-weight: bold;
}

button,
input[type="submit"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
}

button, input, select, textarea {
	font-family : inherit;
	font-size   : 100%;
}

@media print, screen and (min-width:0px){

.pc {
	display: inherit;
}

.mobile {
	display: none;
}

/* ---------- page top �{�^�� ---------- */

#pageTop {
	position: fixed;
	bottom: 2em;
	right: 2em;
	z-index: 200;
}

#pageTop a {
	display: block;
	z-index: 999;
	border-radius: 30px;
	width: 60px;
	height: 60px;
	border: solid 1px rgba(0,0,0,0.1);
	color: #333;
	font-size: 2em;
	font-weight: bold;
	line-height: 55px;
	text-decoration: none;
	text-align: center;
	background-color: rgba(255,255,255,0.4);
}

/* ---------- �p���������X�g ---------- */

.breadcrumb {
	width: 1200px;
	height: auto;
	overflow: hidden;
	margin: 0 auto;
}

.breadcrumb-box {
	width: 100%;
	background-color: #ff6c1b;
}

.breadcrumb,
.breadcrumb li::after,
.breadcrumb li a {
	color: #ffffff;
}

.breadcrumb li {
	display: inline-block;
	height: auto;
	list-style: none;
	font-weight: normal;
	padding: 0.5rem 0;
}

.breadcrumb li::after {
	content: '>';
	padding: 0 3px;
}

.breadcrumb li a {
	text-decoration: none;
}

.breadcrumb li a:hover {
	text-decoration: underline;
}

/* ---------- �n���o�[�K�[���j���[ ---------- */

#nav-drawer {
	position: relative;
}

/*�`�F�b�N�{�b�N�X���͔�\����*/
.nav-unshown {
	display:none;
}

/*�A�C�R���̃X�y�[�X*/
#nav-open {
	position: fixed;
	top: 3rem;
	right: 3rem;
	z-index: 5;
	display: inline-block;
	width: 50px;
	height: 50px;
	vertical-align: middle;
}

/*�n���o�[�K�[�A�C�R����CSS�����ŕ\��*/
#nav-open span, #nav-open span:before, #nav-open span:after {
	position: absolute;
	height: 5px;/*���̑���*/
	width: 50px;/*����*/
	border-radius: 5px;
	background: #666;
	display: block;
	content: '';
	cursor: pointer;
}
#nav-open span:before {
	bottom: -17px;
}
#nav-open span:after {
	bottom: -34px;
}

/*����p�̔����J�o�[*/
#nav-close {
	display: none;/*�͂��߂͉B���Ă���*/
	position: fixed;
	z-index: 99;
	top: 0;/*�S�̂ɍL����悤��*/
	left: 0;
	width: 100%;
	height: 100%;
	background: black;
	opacity: 0;
	transition: .3s ease-in-out;
}

/*���g*/
#nav-content {
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;/*�őO�ʂ�*/
	width: 90%;/*�E���Ɍ��Ԃ����i����J�o�[��\���j*/
	max-width: 25%;/*�ő啝�i�������Ă��������j*/
	height: 100%;
	background: #333;/*�w�i�F*/
	transition: .3s ease-in-out;/*���炩�ɕ\��*/
	-webkit-transform: translateX(-105%);
	transform: translateX(-105%);/*���ɉB���Ă���*/
	padding: 2rem;
}

#nav-content span.menu-midashi {
	display: block;
	width: 100%;
	height: auto;
	font-size: 2rem;
	font-weight: bold;
	color: #ffffff;
	text-align: center;
	margin: 2rem auto;
}

#nav-content ul,
#nav-content li {
	list-style: none;
}

#nav-content li a {
	display: block;
	width: 100%;
	height: auto;
	padding: 2rem 1rem;
	text-decoration: none;
	color: #ffffff;
	border-bottom: dotted 1px #ffffff;
}

/*�`�F�b�N����������������\��*/
#nav-input:checked ~ #nav-close {
	display: block;/*�J�o�[��\��*/
	opacity: .5;
}

#nav-input:checked ~ #nav-content {
	-webkit-transform: translateX(0%);
	transform: translateX(0%);/*���g��\���i�E�փX���C�h�j*/
	box-shadow: 6px 0 25px rgba(0,0,0,.15);
}

/* ---------- ���C���G���A ---------- */

#main {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin: 0;
	padding: 0;
}

/* ---------- �^�C�g�� ---------- */

.top-title {
	width: 100%;
	height: 0;
	overflow: hidden;
	padding-top: 400px;
	margin: 0 auto;
	position: relative;
	background-image: url("images/top_image.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}

.content {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin: 0 auto;
}

.content01 .comment-box {
	width: 1200px;
	height: auto;
	margin: 4rem auto;
	text-align: center;
	line-height: 3rem;
	font-size: 1.8rem;
}

/* ---------- ���o�^���@ ---------- */

.content02 .entry-box {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1200px;
	height: auto;
	overflow: hidden;
	margin: 4rem auto;
}

.content02 h2 {
	width: 100%;
	height: auto;
	text-align: center;
	font-size: 4rem;
	margin: 0 auto;
	color: #00b900;
	padding-bottom: 1rem;
	border-bottom: solid 1px #00b900;
}

.content02 .screen-image {
	width: 50%;
	height: auto;
	overflow: hidden;
	padding: 2rem;
	text-align: center;
	float: left;
}

.content02 .screen-image .no-box {
	width: max-content;
	height: 6rem;
	padding: 0 3rem;
	border-radius: 3rem;
	color: #ffffff;
	background-color: #ff6c1b;
	margin: 0 auto;
	line-height: 6rem;
	font-size: 3rem;
	font-weight: bold;
}

.content02 .screen-image .text-box {
	width: 100%;
	height: auto;
	font-size: 2rem;
	margin: 2rem auto;
}

.content02 .screen-image .image-box {
	width: auto;
	height: auto;
	margin: 0 auto;
	padding: 2rem;
	text-align: center;
}

.content02 .screen-image .image-box img {
	width: 80%;
	height: auto;
}

.content02 .button-box {
	width: 33.3%;
	height: auto;
	text-align: center;
	float: left;
}

.content02 .button-box a {
	display: block;
	width: max-content;
	padding: 1rem 3rem;
	font-size: 2.4rem;
	font-weight: bold;
	color: #ffffff;
	background-color: #00b900;
	border-radius: 0.5rem;
	text-decoration: none;
	margin: 4rem auto;
}

.content02 .button-box a:hover {
	opacity: 0.7;
}

/* ---------- LINE�ł̂����p���@ ---------- */

.content03 {
	background-color: rgba(0,185,0,0.05);
}

.content03 h2 {
	width: 100%;
	height: auto;
	text-align: center;
	font-size: 4rem;
	margin: 4rem auto;
	color: #00b900;
}

.content03 .line-flow-box {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1200px;
	height: auto;
	margin: 4rem auto;
	margin-top: 8rem;
}

.content03 .line-flow-box .step-box {
	width: 27%;
	height: auto;
	background-color: #ffffff;
	border-radius: 1rem;
	position: relative;
	padding: 2rem;
	padding-top: 6rem;
}

.content03 .line-flow-box .step-box .step-no {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	margin: auto;
	top: -3rem;
	width: 6rem;
	height: 6rem;
	border-radius: 3rem;
	font-size: 3rem;
	font-weight: bold;
	line-height: 6rem;
	text-align: center;
	color: #ffffff;
	background-color: #00b900;
}

.content03 .line-flow-box .step-box .step-text {
	width: 100%;
	height: 6rem;
	margin-bottom: 2rem;
}

.content03 .line-flow-box .step-box .step-image {
	width: 100%;
	height: auto;
	text-align: center;
}

.content03 .line-flow-box .step-box .step-image img {
	width: 100%;
	height: auto;
}

.content03 .line-flow-box .arrow-box {
	width: 6%;
	height: auto;
	text-align: center;
	font-size: 4.5rem;
	color: #00b900;
}

/* ---------- �o�^�{�^�� ---------- */

.content-button .button-box {
	width: 1200px;
	height: auto;
	margin: 6rem auto;
}

.content-button .button-box span {
	display: block;
	width: 100%;
	height: auto;
	font-size: 2.8rem;
	font-weight: bold;
	text-align: center;
	color: #00b900;
}

.content-button .button-box a {
	display: block;
	width: max-content;
	padding: 1.5rem 5rem;
	font-size: 3rem;
	font-weight: bold;
	color: #ffffff;
	background-color: #00b900;
	border-radius: 0.5rem;
	text-decoration: none;
	margin: 4rem auto;
}

.content-button .button-box a:hover {
	opacity: 0.7;
}

.content-button-bottom .button-box {
	margin: 8rem auto;
}

.content03 .flow-box03 {
	justify-content: left;
}

/* ---------- �`���b�g�ł̂����p���@ ---------- */

.content05 {
	background-color: rgba(91,192,222,0.1);
}

.content05 h2 {
	width: 100%;
	height: auto;
	text-align: center;
	font-size: 4rem;
	margin: 4rem auto;
	color: #005cb9;
}

.content05 .chat-flow-box {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 1200px;
	height: auto;
	margin: 4rem auto;
	margin-top: 8rem;
}

.content05 .chat-flow-box .step-box {
	width: 28%;
	height: auto;
	background-color: #ffffff;
	border-radius: 1rem;
	position: relative;
	padding: 2rem;
	padding-top: 6rem;
}

.content05 .chat-flow-box .step-box .step-no {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	margin: auto;
	top: -3rem;
	width: 6rem;
	height: 6rem;
	border-radius: 3rem;
	font-size: 3rem;
	font-weight: bold;
	line-height: 6rem;
	text-align: center;
	color: #ffffff;
	background-color: #005cb9;
}

.content05 .chat-flow-box .step-box .step-text {
	width: 100%
	height: 6rem;
	margin-bottom: 2rem;
}

.content05 .chat-flow-box .step-box .step-image {
	width: 100%;
	height: auto;
	text-align: center;
}

.content05 .chat-flow-box .step-box .step-image img {
	width: 100%;
	height: auto;
}

.content05 .chat-flow-box .arrow-box {
	width: 8%;
	height: auto;
	text-align: center;
	font-size: 4.5rem;
	color: #005cb9;
}

/* ---------- ��������X�}�z�p�i��ʃT�C�Y��767px�ȉ��̏ꍇ�ǂݍ��ށj ---------- */

@media only screen and (max-width: 768px) {

*, *: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;
}

/* iOS�ł̃f�t�H���g�X�^�C�������Z�b�g */
input[type="submit"],
input[type="reset"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

html{
	font-size: 62.5%;
}

body {
	width: 100%;
	font-size: 1.4rem;
	background-image: none;
	margin: 0 auto;
}

.pc {
	display: none;
}

.mobile {
	display: inherit;
}

/* ---------- �n���o�[�K�[���j���[ ---------- */

#nav-open {
	top: 1.5rem;
	right: 1rem;
	width: 35px;
	height: 35px;
}

#nav-open span,
#nav-open span:before,
#nav-open span:after {
	width: 35px;
	height: 3px;
	border-radius: 3px;
}

#nav-open span:before {
	bottom: -12px;
}

#nav-open span:after {
	bottom: -24px;
}

#nav-content {
	max-width: 60%;
	padding: 1rem;
}

#nav-content span.menu-midashi {
	margin: 1rem auto;
}


.breadcrumb {
	width: 94%;
	margin: 0 auto;
}

.breadcrumb li {
	display: inline-block;
}

.breadcrumb li a {
    text-decoration: underline;
}

.top-title {
	padding-top: 36%;
}

.top-title-box {
	height: 280px;
	font-size: 2rem;
	margin-bottom: 0;
}

.top-title-text {
	padding: 0;
}

.content {
	width: 100%;
}

.content-button .button-box {
	width: 94%;
	margin: 2rem auto;
}

.content-button .button-box span {
	font-size: 2rem;
}

.content-button .button-box a {
	width: 100%;
	font-size: 2rem;
	padding: 2.5rem 1.5rem;
	margin: 2rem auto;
}


.content01 .comment-box {
	width: 94%;
	margin: 1rem auto;
	font-size: inherit;
	text-align: left;
}

.content h2 {
	font-size: 2.6rem;
	margin: 3rem auto;
}

.content02 .entry-box {
	display: block;
	width: 94%;
	overflow: hidden;
	margin: 0 auto;
}

.content02 .screen-image .no-box {
	width: max-content;
	height: 4rem;
	border-radius: 2rem;
	line-height: 4rem;
	font-size: 2rem;
}

.content02 .screen-image {
	width: 100%;
	padding-top: 0;
	float: none;
	padding: 0;
	margin-bottom: 4rem;
}

.content02 .screen-image .image-box {
	padding: 0;
}

.content02 .screen-image .image-box img {
	width: 100%;
}

.content03 .line-flow-box {
	display: block;
	width: 94%;
	margin-top: 6rem;
}

.content03 .line-flow-box .step-box {
	width: 100%;
	padding-top: 4rem;
}

.content03 .line-flow-box .step-box .step-no {
	top: -2.5rem;
	width: 5rem;
	height: 5rem;
	border-radius: 2.5rem;
	line-height: 5rem;
}

.content03 .line-flow-box .arrow-box {
	width: 100%;
	margin-bottom: 4rem;
	float: none;
}

.content03 .line-flow-box .arrow-box i {
	transform:rotate(90deg);
}

.content-button-mid {
	margin: 4rem auto;
}

.content05 .chat-flow-box {
	display: block;
	width: 94%;
	margin-top: 6rem;
}

.content05 .chat-flow-box .step-box {
	width: 100%;
	padding-top: 4rem;
}

.content05 .chat-flow-box .step-box .step-no {
	top: -2.5rem;
	width: 5rem;
	height: 5rem;
	border-radius: 2.5rem;
	line-height: 5rem;
}

.content05 .chat-flow-box .step-box .step-text {
	height: auto;
}

.content05 .chat-flow-box .arrow-box {
	width: 100%;
	margin-bottom: 4rem;
	float: none;
}

.content05 .chat-flow-box .arrow-box i {
	transform: rotate(90deg);
}

.content-button-bottom {
	margin: 4rem auto;
}

/* ---------- �����܂ŃX�}�z�p�i��ʃT�C�Y��767px�ȉ��̏ꍇ�ǂݍ��ށj ---------- */
}

