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

#page-top {position: fixed;bottom: 40px;right: 40px;width: 60px; z-index:400;}
@media screen and (max-width: 896px) {
	#page-top {position: fixed;bottom: 5px;right: 5px;width: 30px; z-index:400;}
}

.EN {font-family: "EB Garamond", serif; font-optical-sizing: auto; font-weight: 500;}

.bgWH {background-color: #FFF;}
.bgBL {background-color: #192644;}
.bgGR {background-color: #4F8914;}
.bgGRY {background-color: #EEEEEE;}
.txtWH {color: #FFF;}
.txtLGR {color: #06C755;}

.ratioBox {position: relative;width: 100%;height: auto;}
.ratio1-1:before {content: "";display: block;padding-top: 100%; /* 1:1 */}
.ratio2-1:before {content: "";display: block;padding-top: 50%; /* 2:1 */}
.ratio3-2:before {content: "";display: block;padding-top: 66%; /* 3:2 */}
.ratio4-3:before {content: "";display: block;padding-top: 75%; /* 4:3 */}
.ratioInner {position: absolute;top: 0; left: 0;width: 100%;height: 100%;}

#header {position: fixed; width: 100%; background: rgba(25,38,68,.8); padding: 20px 30px; z-index: 3;}
#header .logo {width: 103px;}
#hanburger {display: none;}
.menu_button {width: 55px; height: 55px; position: fixed; top: 0; right: 0; background: #192644; z-index: 15;}
#hanburger:checked ~ .menu_button {top: 0;}
#hanburger:checked ~ .span2 {display: none;}
#hanburger:checked ~ .span1 {width: 34px; transform: rotate(45deg); top: 27px; right: 11px;}
#hanburger:checked ~ .span3 {width: 34px; transform: rotate(-45deg); top: 27px; right: 11px;}
.global_menu {visibility: hidden; width: 100%; height: 100%; position: fixed; top: 0; left: 0; overflow-y: scroll; text-align: center;}
#hanburger:checked ~ .global_menu {visibility: visible;}
.global_menu a {display: block; width: 100%; padding: 0 30px; color: #FFF;}
.global_menu a:hover {background: #FFF; color: #192644;}
.menu {font-size: 18px; border-right: 1px solid #FFF;}
.menu:last-child {border-right: none;}
#hanburger,.spOnly {display: none;}
.pcOnly {display: block;}
@media screen and (min-width: 896px) {
  .menu_button {display: none;}
  .global_menu {position: inherit; padding: 0; color: #fff; visibility: visible; overflow-y: visible; height: auto; width: auto;}
}
@media screen and (max-width: 896px) {
	#header {padding: 13px 20px 12px;}
	.pcOnly {display: none;}
  .spOnly {display: block;}
  span.span1,span.span2,span.span3 {width: 29px; height: 1px; background-color: #FFF; position: absolute; right: 13px; transition: .3s; z-index: 100; position: fixed;}
  .span1 {top: 17px;}
  .span2 {top: 27px;}
  .span3 {top: 37px;}
  .menu {display: block; border-right: none;}
  .menu > a {padding: 10px 15px; text-align: left; border-bottom: 1px solid #CCC;}
  .menu > a span {margin-right: 10px; width: 30px!important;}
  .menu > a span img {width: 100%;}
  .global_menu {z-index: 10;}
  .global_menu a {border-top-left-radius: 0; border-top-right-radius: 0;}
  .menu_wrap {display: none;}
  #hanburger:checked ~ * .menu_wrap {display: block; opacity: 1; min-height: 100vh; background: #192644; /*position: fixed;*/ top: 0; z-index: 5;}
  #hanburger:checked ~ * .menu {max-height: inherit; overflow-y: visible; padding: 0; margin-left: 0; position: relative;}
  #hanburger:checked ~ * .child_menu {max-height: 0; overflow-y: hidden; visibility: hidden; text-align: left;}
  .menu > label:hover {cursor: pointer; cursor: hand;}
  .menu input[type="checkbox"]:checked ~ .child_menu {max-height: inherit!important; overflow-y: visible; visibility: visible!important;}
}

footer {padding: 60px 0; border-top: 2px solid #192644;}
footer .logo {width: 200px;}
.footCopy small {font-size: 14px;}
#ftNavi {display: none;}
@media screen and (max-width: 950px) {
  footer .logo {width: 300px;}
}
@media screen and (max-width: 896px) {
	footer {margin-bottom: 50px; padding: 40px 0;}
	footer .logo {width: 100px;}
	#ftNavi {display: block; background: #192644; position: fixed; z-index: 5; bottom: 0; width: 100%;}
	#ftNavi ul {text-align: center; font-size: 10px; font-weight: bold;}
	#ftNavi li {letter-spacing: normal; display: inline-block; width: calc(100%/3 - 2px);}
	#ftNavi li a {display: block; padding: 5px 0; color: #FFF; border-left: 1px solid #344E8B; border-right: 1px solid #111C38;}
	#ftNavi li:first-child a {border-left: none;}
	#ftNavi li:last-child a {border-right: none;}
	#ftNavi li span {width: 24px; margin: 0 auto 5px; display: block;}
}

.container {width: 100%; max-width: 1212px; padding-left: 0; padding-right: 0;}
.containers {width: calc(100% - 40px); max-width: 888px; padding-left: 0; padding-right: 0;}
.mlr,.container,.containers {margin-left: auto; margin-right: auto;}
.mlr5 {margin-left: 5px; margin-right: 5px;}
.mlr20,.col1,.col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {margin-left: 20px; margin-right: 20px;}
.mr10 {margin-right: 10px;}
.col1 {width: calc(16.6666% - 40px);}
.col2,.box3 {width: calc(33.3333% - 40px);}
.col3 {width: calc(50% - 40px);}
.col4 {width: calc(66.6666% - 40px);}
.col5 {width: calc(83.3333% - 40px);}
.col6 {width: calc(100% - 40px);}
.box4 {width: calc(25% - 30px); margin-left: 15px; margin-right: 15px;}
.w300 {max-width: 300px; width: 100%;}
.w400 {max-width: 400px; width: 100%;}
.full {width: 100%;}
.half {width: 50%;}
.w46 {width: calc(46% - 50px);}
.w54 {width: calc(54% - 50px);}
@media screen and (max-width: 896px) {
  .containers {width: calc(100% - 30px);}
  .mlr20,.col1,.col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {margin-left: 15px; margin-right: 15px;}
  .col1 {width: calc(16.6666% - 30px);}
  .col2,.box3 {width: calc(33.3333% - 30px);}
  .col3 {width: calc(50% - 30px);}
  .col4 {width: calc(66.6666% - 30px);}
  .col5 {width: calc(83.3333% - 30px);}
  .col6 {width: calc(100% - 30px);}
  .w46 {width: calc(46% - 30px);}
  .w54 {width: calc(54% - 30px);}
}
@media screen and (max-width: 568px) {
  .col1 {width: calc(33.3333% - 30px);}
  .col2,.col3,.col4,.col5,.col6,.box3,.w46,.w54 {width: calc(100% - 30px);}
  .mlr5 {margin-left: 5px; margin-right: 5px;}
  .box4 {width: calc(50% - 20px); margin-left: 10px; margin-right: 10px;}
}

ul.dot {list-style: disc; margin-left: 1.5em;}
ul.num {list-style: decimal; margin-left: 1.5em;}

table {width: 100%;}
table tr:nth-child(odd) {background-color: #FFF;}
table tr:nth-child(even) {background-color: #EEEEEE;}
table th,table td {padding: 10px 20px; line-height: 1.7; text-align: center; border: 1px solid #CCCCCC;}
table.tblGR th {width: 25%; background: #4A8308; color: #FFF;}
table.tblGR2 th {width: 280px; background: #4A8308; color: #FFF;}
table.tblGR2 td {text-align: left; width: calc(100% - 250px);}
@media screen and (max-width: 568px) {
  table.tblGR th,table.tblGR td {padding: 10px 5px;}
  table.tblGR2 th,table.tblGR2 td {width: 100%; display: block;}
  table.tblGR2 td {border-top: none;}
}

#top01 {height: 80vh;}
#top01 .container {padding-top: 170px;}
#top02 {margin-top: -90px; z-index: 1;}
#top02 .txt {width: calc(100% - 560px); margin-bottom: 20px;}
#top02 .imgArea {width: 500px;}
#top02 .subImg {width: 84%; margin: -75px auto 0;}
#top02 .logo {width: 200px; margin: 0 20px; display: inline-block;}
#top03 {max-width: 1680px; width: 100%; margin: 0 auto;}
#top03 .name {position: absolute; top: -25px; left: 60px;}
#top03 .name .EN {line-height: 1; margin-bottom: 5px;}
#top03 .txt {padding: 30px 250px 40px 60px;}
#top03 .bgGR .txt {padding: 30px 60px 40px 250px;}
#top03 .subImg {position: absolute; bottom: 0; right: 0; width: 346px;}
#top03 .bgGR .subImg {width: 264px; right: inherit; left: 0;}
#top03 .img01,#top03 .img02 {width: 56%;}
#top03 .img02 {margin-left: -12%; margin-top: 60px; position: relative; z-index: -1;}
#top03 .img01 p,#top03 .img02 p {position: absolute; top: 0; left: 0; padding: 0 20px;}
#top03 .img02 p {top: inherit; left: inherit; bottom: 0; right: 0;}
#top04 .txt {width: calc(48% - 60px);}
#mailform {width: 52%;}
.line {width: 162px; margin-right: 30px;}
.linetxt {width: calc(100% - 192px); word-break: break-all;}
.cmnBtn,input[type="submit"].cmnBtn {display: block; width: 100%; text-align: center; padding: 18px 20px; border: 4px solid #192644; box-shadow: 3px 3px 3px rgba(0,0,0,.5); border-radius: 40px; background: rgb(55,96,188); background: linear-gradient(180deg, rgba(55,96,188,1) 0%, rgba(25,38,68,1) 100%);cursor: pointer;}
.cmnBtn:hover,input[type="submit"].cmnBtn:hover {background: rgb(55,96,188); background: linear-gradient(0deg, rgba(55,96,188,1) 0%, rgba(25,38,68,1) 100%);}
input[type="submit"].cmnBtn {}
#thanks,#news {padding-top: 80px;}
#thanks .mv {padding: 40px 0;}
#thanks .mv::before {position: absolute; content: ''; width: 100%; height: 100%; top: 0; z-index: 1; background: rgba(255,255,255,.6);}
#thanks .container {position: relative; z-index: 2;}
#top05::before {position: absolute; content: ''; width: 100%; height: 2px; background: #192644; left: 0; top: 85px;}
#top05 a {padding-left: 15px; background: url("../img/top/05-01.svg") no-repeat left center;}
.map {width: 100%; height: 285px; position: relative; overflow: hidden;}
.map iframe {width: 100%; height: 100%;}
#top06 {padding-bottom: 30px;}
#top06::before {position: absolute; content: ''; width: 100%; height: calc(100% - 85px); background: url("../img/top/06-01.jpg") no-repeat center; background-size: cover; bottom: 0; z-index: -1;}
#top06 dt,#top06 dd {padding-top: 20px; padding-bottom: 15px;}
#top06 dt {width: 140px; border-bottom: 2px solid #4F8914;}
#top06 dd {width: calc(100% - 140px); padding-left: 20px; border-bottom: 2px solid #FFF;}
#top06 .col3:last-of-type {margin-top: -150px;}
#top06 .img01 {width: 75%; margin: 0 0 0 15%; position: relative; z-index: 1;}
#top06 .img02 {margin-top: -40px;}
#top07 .news,#news .news {width: 872px;}
.news li {border-bottom: 1px solid #222222;}
.news li a {padding: 20px 0; width: 100%;}
.news li a:hover {background: #EEE;}
.news .date {width: 100px; margin-right: 20px;}
.news .newsTtl {width: calc(100% - 120px);}
.bdrBtm {padding-bottom: 20px; margin-bottom: 20px; border-bottom: 2px solid #192644; position: relative;}
.bdrBtm::before {position: absolute; content: ''; width: 140px; height: 2px; background: #4F8914; bottom: -2px; left: 0;}
@media screen and (max-width: 1560px) {
	#top03 .bgBL .txt {padding: 30px 300px 40px 60px;}
}
@media screen and (max-width: 1460px) {
	#top03 .bgBL .txt {padding: 30px 350px 40px 60px;}
	#top03 .name .txt60 {font-size: 40px;}
}
@media screen and (max-width: 1200px) {
	#top03 .bgBL .txt,#top03 .bgGR .txt {padding: 20px 30px;}
	#top03 .name {left: 10px;}
	#top03 .subImg {width: 48%; position: relative; margin-left: 52%;}
	#top03 .bgGR .subImg {width: 36%; margin-left: 0;}
	#top03 .txt p {position: relative; z-index: 1;}
}
@media screen and (max-width: 1110px) {
	#top02 .txt {width: calc(100% - 410px);}
	#top02 .imgArea {width: 350px;}
	#top06 .col3:last-of-type {margin-top: 0;}
}
@media screen and (max-width: 896px) {
	#top02 {margin-top: -45px;}
	#top02 .logo {width: 140px;}
	#top03 .half {width: 100%;}
	#top04 {margin-bottom: 30px;}
	#top04 .txt {width: 100%;}
	#top03 .name .txt60 {font-size: 30px;}
	#mailform {width: 100%;}
	#top05::before {top: 45px;}
	#top06 .col3 {width: calc(100% - 30px);}
	#top06::before {height: calc(100% - 45px);}
}
@media screen and (max-width: 770px) {
	#top02 .txt {width: 100%;}
	#top02 .imgArea {width: 80%; margin: 0 auto;}
}
@media screen and (max-width: 568px) {
	#top06 dt {width: 140px;}
	#top06 dd {width: 100%; padding-left: 0;}
	.news .date {width: 100%; margin-right: 0;}
	.news .newsTtl {width: 100%;}
}


