@charset "UTF-8";
/* CSS Document */

#Mainvisual { position: relative; z-index: -1;}
.topicspath { height: 130px; padding: 30px 40px; box-sizing: border-box; font-size: 0.813em; display: flex; justify-content: flex-start; align-items: flex-start; }
.topicspath li::before { content: "ー"; display: inline-block; margin: 0 5px; }
.topicspath li:first-child::before { display: none; }
.topicspath li a { color: #363130; }
.topicspath li a:hover { text-decoration: underline; }

#Contents { max-width: 1200px; width: 90%; margin: 0 auto; background: #FFF; margin-top: -130px; min-height: 400px; }
#Contents .inner { max-width: 1000px; width: 95%; margin: 0 auto; }
h1 { font-size: 2.188em; font-weight: 600; text-align: center; }
br.br { display: none; }
.btn { width: 330px; margin: 70px auto 0 auto; position: relative; z-index: 0; }
.btn a { height: 70px; border: 1px solid #606060; display: flex; justify-content: space-between; align-items: center; padding: 0 30px; color: #363130; font-size: 1.125em; }
.btn a svg { fill: none; stroke: #606060; stroke-linejoin: round; width: 88px; }
.btn a::before { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: -1; background: #606060; transform-origin: right top; transform: scale(0, 1); transition: transform .3s; }
.btn a:hover { color: #FFF; }
.btn a:hover::before { transform-origin: left top; transform: scale(1, 1); color: #FFF; }
.btn a svg { fill: none; stroke: #606060; stroke-linejoin: round; width: 88px; }
.btn a:hover svg { stroke: #FFF; }

/* About */
#About header nav ul li:nth-child(1) a { color: #00971c; }
#About h1,#Contact h1,#Policy h1 { text-align: left; letter-spacing: 0.15em; }
#About small,#Contact small,#Policy small { font-size: 1.250rem; font-family: 'Oswald', sans-serif; vertical-align: bottom; font-weight: 400; letter-spacing: 0.08em; display: inline-block; margin-left: 1em; }
#About dl { display: flex; justify-content: space-between; flex-wrap: wrap; font-size: 1.250em; line-height: 1.8em; margin-top: 100px; }
#About dl dt { width: 190px; border-bottom: 1px solid #606060; padding-bottom: 40px; margin-top: 40px; }
#About dl dd { width: calc(100% - 250px); border-bottom: 1px solid #606060; padding-bottom: 40px; margin-top: 40px; }
#About dl dt:first-child,#About dl dt:first-child + dd { border-top: 1px solid #606060; padding-top: 40px; margin-top: 0; }
#About #Map { position: relative; padding-bottom: 29.58%; padding-top: 30px; height: 0; overflow: hidden; margin-top: 195px; }
#About #Map iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#About #Map + p,#About #Map + p + p { font-size: 1.250em; line-height: 1.8em; text-align: center; margin-top: 60px; }

/* News */
#News header nav ul li:nth-child(2) a { color: #00971c; }
#News #Mainvisual { background: url(../../news/images/head_img.jpg) center top no-repeat; background-size: cover; }
#News ul.list { font-size: 1.250em; line-height: 1.5em; border-top: 1px solid #606060; margin-top: 100px; }
#News ul.list li { border-bottom: 1px solid #606060; padding-bottom: 25px; margin-top: 25px; display: block; position: relative; display: flex; justify-content: flex-start; padding-right: 10px; }
#News ul.list li::after { content: ""; display: inline-block; width: 10px; height: 17px; background: url(../images/ic_arrow_right.svg) no-repeat center; align-self: center; }
#News ul.list li a { display: block; color: #363130; }
#News ul.list li .date { width: 7em; color: #363130; }
#News ul.list li strong { color: #05966d; width: 9em;  }
#News ul.list li strong + span { width: calc(100% - 16em); color: #363130; } 
#News ul.list li a:hover { color: #05966d; transition: .3s; }

#News .inner h2,#Contact .inner h2 { font-size: 2.188em; margin-top: 80px; line-height: 1.3em; font-weight: 600; }
#News .inner p,#Contact .inner p { font-size: 1.250em; line-height: 1.8em; margin-top: 50px; }
#News .inner h2 + p { margin-top: 85px; }
#News .inner p.date { font-size: 1.250em; margin-top: 0; }
#detail { margin-top: 65px; }
.detailText { font-size: 1.250em; line-height: 1.8em; }
.detailUpfile,.detailUpfile + .detailText { margin-top: 20px; }
.detailText + .detailText { margin-top: 50px; }

.pager { display: flex; justify-content: center; align-items: center; margin-top: 50px; font-size: 1.125em; }
.pager a { color: #363130; width: 40px; height: 40px; border: 1px solid #606060; box-sizing: border-box; display: flex; justify-content: center; align-items: center; margin: 0 2px; }
.pager a.current { background: #606060; color: #FFF; }
.pager a.next,.pager a.prev { border-color: #FFF; }
.pager a.next { background: url(../images/ic_next.svg) no-repeat center; background-size: 20px auto; padding-top: 40px; height: 0; overflow: hidden; font-size: 0; }
.pager a.prev { background: url(../images/ic_prev.svg) no-repeat center; background-size: 20px auto; padding-top: 40px; height: 0; overflow: hidden; font-size: 0; }

/* Contact */
#Contact header nav ul li:nth-child(4) a { color: #00971c; }
#Contact dl { display: flex; justify-content: flex-start; align-items: stretch; flex-wrap: wrap; border-top: 1px solid #c8c8c8; font-size: 1.125em; margin-top: 80px; }
#Contact dl dt { width: 14em; border: 1px solid #c8c8c8; border-top: none; box-sizing: border-box; background: #f7f7f7; padding: 15px; padding: 20px 1.5em; }
#Contact dl dt::before { content: "必須"; font-size: 0.938rem; background: #ba0000; color: #FFF; display: inline-block; padding: 2px 5px; margin-right: 10px; }
#Contact dl dt.nin::before { content: "任意"; background: #8cabc5; }
#Contact dl dd { width: calc(100% - 14em); border-bottom: 1px solid #c8c8c8; border-right: 1px solid #c8c8c8; box-sizing: border-box; display: flex; align-items: center; padding: 0 1em; }
#Contact dl input[type="text"] { -webkit-appearance: none; appearance: none; border: 3px solid #eaeaea; font-size: 1.125em; max-width: 20em; width: 100%; padding: 3px 5px; }
#Contact dl.conf dt::before { display: none; }
#Contact dl textarea { -webkit-appearance: none; appearance: none; border: 3px solid #eaeaea; font-size: 1.125em; width: 100%; padding: 3px 5px; margin: 15px 0; }
#Contact .inner dl + p { margin-top: 35px; }
#Contact .inner .btn { position: relative; }
.btn input[type="submit"],.btn input[type="button"] { -webkit-appearance: none; appearance: none; height: 70px; border: 1px solid #606060; display: flex; justify-content: space-between; align-items: center; padding: 0 30px; color: #363130; font-size: 1.125em; background: rgba(255,255,255,0.00); width: 100%; cursor: pointer; position: relative; z-index: 1; text-align: left; }
#Contact .inner .btn svg { fill: none; stroke: #606060; stroke-linejoin: round; width: 88px; position: absolute; right: 30px; top: 0; bottom: 0; margin: auto; }
#Contact .inner .btn::before { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: -1; background: #606060; transform-origin: right top; transform: scale(0, 1); transition: transform .3s; z-index: 0; }
#Contact .inner .btn:hover::before { transform-origin: left top; transform: scale(1, 1); color: #FFF; }
#Contact .inner .btn:hover input[type="submit"],#Contact .inner .btn:hover input[type="button"] { color: #FFF; }
#Contact .inner .btn:hover svg { stroke: #FFF; }
#Contact .inner .btnarea { max-width: 700px; display: flex; flex-wrap: wrap; margin: auto; }

#Features { background: #f0efed; margin-top: 195px; position: relative; padding-bottom: 50px; box-sizing: border-box; }
#Features .bg { letter-spacing: 0.05em; font-size: 10.000em; font-family: 'Oswald', sans-serif; color: #FFF; -webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; max-width: 1700px; width: 100%; display: flex; justify-content: flex-start; position: relative; top: -20px; }
#Features .bg p { margin-right: auto; width: 1.7em; height: 4em; }
#Features .flex { max-width: 1200px; width: 95%; display: flex; justify-content: space-between; flex-wrap: wrap; position: absolute; top: 0; left: 0; right: 0; margin: 110px auto 0 auto; }
#Features h2 { width: 100%; font-size: 3.125em; line-height: 1.3em; font-weight: 600; text-align: center;  }
#Features p { font-size: 1.125em; line-height: 1.8em; margin-top: 20px; }
#Features .flex .column { width: 22%; }
#Features h3 { font-size: 1.563em; font-weight: 600; line-height: 1.3em; margin-top: 60px; }
#Features h3 + .img { margin-top: 20px; max-width: 273px; width: 100%; }
#Contact footer { margin-top: 220px; }

/* Policy */
#Policy .inner p { font-size: 1.250em; margin-top: 70px;  line-height: 1.8em; }
#Policy .inner h2 { font-size: 1.750em; margin-top: 65px; font-weight: 600; }
#Policy .inner h2 + p { margin-top: 55px; }
#Policy .inner p + h2 { margin-top: 100px; }
#Policy .inner h1 + p + h2 { margin-top: 60px; }

@media screen and (max-width:1280px) {
	#Features .flex .column h3 br { display: none; }
}

@media screen and (max-width:980px) {
	#Mainvisual { margin-top: 25px; }
	#Contents { margin-top: -70px; }
	.btn::before { display: none; }
	#Contact .inner .btn:hover input[type="submit"],#Contact .inner .btn:hover input[type="button"] { color: #363130; }
	#Contact .inner .btn:hover svg { stroke: #606060; }
	#About header nav ul li:nth-child(1) a,#News header nav ul li:nth-child(2) a,#Contact header nav ul li:nth-child(4) a { color: #FFF; }
	#About h1,#Contact h1,#Policy h1 { font-size: 1.875rem; }
	.topicspath { padding: 20px 20px; }
	
	/* About */
	#About dl { font-size: 1.000rem; margin-top: 50px; }
	#About dl dt { width: 140px; padding-bottom: 25px; margin-top: 25px; }
	#About dl dd { width: calc(100% - 160px); padding-bottom: 25px; margin-top: 25px; }
	#About dl dt:first-child,#About dl dt:first-child + dd { padding-top: 25px; }
	#About #Map { padding-bottom: 56.00%;margin-top: 75px; }
	#About #Map + p,#About #Map + p + p { font-size: 1.000rem; margin-top: 40px; }
	#About #Map + p span { margin-right: -1em; }
	
	/* News */
	#News h1 { font-size: 1.875rem; }
	#News .inner h2 { font-size: 1.500rem; margin-top: 35px; }
	#News .inner p.date { font-size: 1.000rem; margin-top: 0; }
	#News ul.list { font-size: 1.000em; margin-top: 50px; }
	#News ul.list li { padding-right: 0; flex-wrap: wrap; }
	#News ul.list li::after { display: none; }
	#News ul.list li strong + span { width: 100%; margin-top: 10px; }
	#detail { margin-top: 40px; }
	.detailText { font-size: 1.000rem; }
	
	/* Contact */
	#Contact .inner h2 { font-size: 1.500rem; margin-top: 60px; }
	#News .inner p,#Contact .inner p { font-size: 1.000rem; margin-top: 30px; }
	#Contact dl { font-size: 1.000rem; margin-top: 40px; }
	#Contact dl dt { width: 13em; border: 1px solid #c8c8c8; border-top: none; box-sizing: border-box; background: #f7f7f7; padding: 15px; padding: 20px 0.5em; }
	#Contact dl dt::before { font-size: 0.875rem; }
	#Contact dl dd { width: calc(100% - 13em); padding: 0 0.5em; }
	#Contact dl input[type="text"],#Contact dl textarea { font-size: 1.000rem; }
	#Features { padding: 50px 0; margin-top: 100px; }
	#Features .bg { -webkit-writing-mode: unset; -ms-writing-mode: unset; writing-mode: unset; top: 0; left: -10px; display: inline-block; height: auto; padding: 0; line-height: 0; font-size: 20vw; }
	#Features .bg p { margin-top: 0; line-height: 1em; height: auto; }
	#Features h2 { width: 100%; font-size: 2.500rem; }
	#Features .flex .column p { font-size: 1.000rem; line-height: 1.8em; margin-top: 20px; width: calc(100% - 290px); }
	#Features .flex .column { width: 100%; display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; }
	#Features .flex { max-width: 1200px; width: 90%; margin: auto; display: flex; justify-content: space-between; flex-wrap: wrap; position: relative; top: 0; left: 0; right: 0; margin: -70px auto 0 auto; }
	#Features .flex .column h3 { font-size: 1.500rem; width: 100%; }
	#Contact footer { margin-top: 110px; }

	/* Policy */
	#Policy .inner p { font-size: 1.000rem; margin-top: 50px; }
	#Policy .inner h2 { font-size: 1.625rem; }
	#Policy .inner h2 + p { margin-top: 40px; }
	#Policy .inner p + h2 { margin-top: 70px; }
	#Policy .inner h1 + p + h2 { margin-top: 40px; }
	
}

@media screen and (max-width:600px) {
	br.br { display: inline-block; }
	.btn a { height: 50px; padding: 0 20px; font-size: 0.938rem; }
	.btn { width: 220px; margin-top: 40px; }
	.btn a svg { width: 44px; }
	#About h1,#Contact h1,#Policy h1 { font-size: 1.375rem; letter-spacing: 0.04em; }
	#About small,#Contact small,#Policy small { font-size: 1.000rem; }
	
	/* About */
	#About dl { font-size: 0.875rem; }
	#About dl dt { width: 6em; }
	#About dl dd { width: calc(100% - 7em); }
	#About #Map + p,#About #Map + p + p { font-size: 0.875rem; }
	
	/* News */
	#News h1 { font-size: 1.375rem; }
	#News ul.list { font-size: 0.875em;}
	#News .inner p.date { font-size: 0.870rem; margin-top: 0; }
	#News .inner h2 { font-size: 1.375rem; }
	.detailText { font-size: 0.875rem; }
	
	/* Contact */
	#Contact dl { font-size: 0.875rem; }
	#Contact dl dt { width: 100%; padding: 15px 1em; }
	#Contact dl dt::before { font-size: 0.875rem; }
	#Contact dl dd { width: 100%; padding: 15px 1em; border-left: 1px solid #c8c8c8; }
	#Contact dl input[type="text"],#Contact dl textarea { max-width: initial; margin: 0; }
	#Contact .inner .btn input[type="submit"],#Contact .inner .btn input[type="button"] { font-size: 0.938rem; padding: 0 20px; height: 50px; }
	#Contact .inner .btn svg { width: 44px; }
	#Features h2 { width: 100%; font-size: 1.875rem; }
	#Features .flex { margin-top: -50px; }
	#Features .flex .column { width: 100%; }
	#Features .flex .column h3 { font-size: 1.125rem; }
	#Features .flex .column p { font-size: 0.875rem; width: 50%; }
	#Features h3 + .img { max-width: initial; width: 45%; }
	
	/* Policy */
	#Policy .inner p { font-size: 0.875rem; }
	#Policy .inner h2 { font-size: 1.063rem; }
	#Policy .inner h2 + p { margin-top: 30px; }
	
}