@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;}

.bgWH {background-color: #FFF;}
.bgBR {background-color: #D88D00;}
.bgBE {background-color: #FBF3E5;}
.bgGR {background-color: #4A8308;}
.bgGRY {background-color: #EEEEEE;}
.txtWH {color: #FFF;}
.txtBL {color: #00A4E4;}
.txtGRY {color: #666;}

.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%;}

#side {position: fixed; right: 0; bottom: 60px; z-index: 3;}
#side li {width: 130px; height: 130px; margin: 1px 0;}
#side li a {background: #00A4E4; border: 1px solid #00A4E4; border-right: none; color: #FFF; width: 100%; height: 100%; text-align: center;}
#side li a:hover {background: #FFF; color: #00A4E4;}
#side li:first-child a {border-radius: 10px 0 0 0;}
#side li:last-child a {border-radius: 10px 0 0 10px;}
#side .txt {position: relative; padding-top: 48px;}
#side .txt::before,#side .txt::after {position: absolute; content: ''; left: 0; right: 0; margin: auto; top: 0;}
#side .txt::before {width: 22px; height: 22px; top: 9px; z-index: 1; background-size: cover; background-repeat: no-repeat; background-image: url("../img/cmn/icon_catalog_bl.svg");}
#side li:last-child .txt::before {background-image: url("../img/cmn/icon_mail_bl.svg");}
#side .txt::after {width: 40px; height: 40px; border-radius: 50%; background: #FFF;}
#side li a:hover .txt::before {background-image: url("../img/cmn/icon_catalog_wh.svg");}
#side li:last-child a:hover .txt::before {background-image: url("../img/cmn/icon_mail_wh.svg");}
#side li a:hover .txt::after {background: #00A4E4;}
@media screen and (max-width: 1024px) {
	#side li {width: 100px; height: 100px; margin: 1px 0; font-size: 14px;}
	#side .txt {padding-top: 35px;}
	#side .txt::before {width: 16px; height: 16px; top: 7px;}
	#side .txt::after {width: 30px; height: 30px;}
}
@media screen and (max-width: 568px) {
	#side {display: none;}
}

/*main {min-height: 2000px;}*/
#header {position: relative; width: 100%; padding: 40px 30px 20px;}
#header h1,#header .copy {padding: 8px 20px; background: #00A4E4; position: absolute; top: 0; right: 30px; border-radius: 0 0 5px 5px; line-height: 1.5;}
.logo {width: 419px;}
.gNav {margin-left: auto;}
/*.menu:hover > a {background: #222;}*/
/*.child_menu > li > a:hover {background: #FFF;}*/
/*.child_menu {width: 100%; left: 0; color: #222; background: #00A4E4;}*/
.menu:hover .child_menu {visibility: visible;}
/*.child_menu a:hover {color: #FFF;}*/
#hanburger {display: none;}
.menu_button {width: 55px; height: 55px; position: fixed; top: 0; right: 0; background: #00A4E4; 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; color: #222; overflow-y: scroll;}
#hanburger:checked ~ .global_menu {visibility: visible;}
.global_menu a {display: block; width: 100%;}
/*.global_menu a:hover {background: #00A4E4; color: #FFF;}*/
.menu {font-size: 18px; line-height: 30px; font-weight: 400; white-space: nowrap;}
.menu > a {padding: 0 30px;}
.menu .pd {display: none;}
.menu:last-child {margin-right: 0px;}
/*.child_menu > li > a {padding: 10px 20px; text-align: left;}*/
#hanburger,.spOnly {display: none;}
@media screen and (max-width: 1245px) {
	.menu > a {padding: 0 20px;}
}
@media screen and (max-width: 1145px) {
	.logo {width: 319px;}
}
@media screen and (max-width: 1145px) {
	#header {padding: 40px 20px 20px;}
	#header h1,#header .copy {right: 20px;}
	.menu {font-size: 16px;}
	.menu > a {padding: 0 15px;}
}
@media screen and (max-width: 930px) {
	.logo {width: 100%; max-width: 280px;}
}
@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;}
	.menu_wrap {display: flex; flex-wrap: wrap;}
	.menu:not(:last-child) {border-right: 1px solid #222;}
  .menu:hover > a {background: #00A4E4; color: #FFF;}
  .child_menu {width: 100%; max-width: 800px; position: absolute; top: 78px; right: 30px; padding: 20px 30px 0 250px; color: #FFF; background: #00A4E4; visibility: hidden; opacity: 0; transition: .5s top, .5s opacity; z-index: 10; display: flex; flex-wrap: wrap;}
	.child_menu::after {position: absolute; content: ''; width: 220px; height: 100%; left: 0; top: 0; background: url("../img/cmn/nav_business.png") no-repeat; background-size: cover;}
	.child_menu::before {position: absolute; content: ''; top: -12px; left: 50%; transform: translateX(-50%); border-bottom: 15px solid #00A4E4; border-right: 20px solid transparent; border-left: 20px solid transparent;}
  .menu:hover .child_menu {visibility: visible; top: 90px; opacity: 1;}
  .child_menu > li {width: 50%; margin-bottom: 20px;}
	.child_menu > li:first-child {width: 100%; padding-bottom: 10px; margin-bottom: 20px; border-bottom: 1px solid #FFF;}
	.child_menu > li:first-child span {margin-left: 1em;}
  .child_menu > li a {color: #FFF;}
	.child_menu > li:not(:first-child) a {font-size: 16px; padding-left: 37px; background: url("../img/cmn/arrow_wh.svg") no-repeat center left;}
	.child_menu > li:not(:first-child) a:hover {background-position: center left 10px;}
}
@media screen and (max-width: 896px) {
  #header,.spOnly {display: block;}
	#header {padding: 0 60px 10px 20px;}
	#header h1,#header .copy {right: inherit; left: 0; font-size: 10px; position: relative; margin-bottom: 10px; display: inline-block;}
	#header .sns {display: none;}
  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;}
  .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;}
  .child_menu > li > a,.child_menu > li > ul > li a {padding: 10px 15px; color: #FFF; text-align: left; border-bottom: 1px dotted #999; background: #00A4E4;}
  .child_menu > li > ul > li a {padding: 15px 20px 15px 35px; position: relative;}
  .child_menu > li > ul > li:last-child a {border-bottom: 1px solid #CCC;}
  .child_menu > li > ul > li a::before {border-top: solid 1px #222; content: ''; left: 20px; position: absolute; top: 50%; width: 10px;}
  .menu .pd {display: inline-block; width: 100%; position: absolute; top: 0; left: 0; height: 100%;}
  .menu_wrap {display: none;}
  #hanburger:checked ~ * .menu_wrap {display: block; opacity: 1; min-height: 100vh; background: #FFF; /*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 .child_menu {border-top: 1px solid #DDD; position: relative; opacity: 1; top: 0; margin-left: auto; left: auto; width: auto;}
  .child_menu li {display: block;}
  .menu > label:hover {cursor: pointer; cursor: hand;}
  .menu input[type="checkbox"]:checked ~ .child_menu {max-height: inherit!important; overflow-y: visible; visibility: visible!important;}
  /*
  .angletoggle:before {content: "\f107";}
  #nav input[type="checkbox"]:checked ~ * .angletoggle:before {content: "\f106";}
  */
	.pcOnly {display: none!important;}
}

footer {padding-bottom: 50px;}
#cmnContact {padding: 100px 0; background: url("../img/cmn/bg_foot.jpg") no-repeat center; background-size: cover;}
#cmnContact h2 span {font-size: 66%;}
#cmnContact dl {margin-left: 50px;}
#cmnContact dd.EN,#contact .tel {padding-left: 40px; font-size: 40px; background: url("../img/cmn/icon_tel.svg") no-repeat left center;}
#contact .tel {margin-left: 30px;}
#cmnContact dl:last-child {width: 285px;}
#cmnContact .btnBL {display: block; width: 100%; padding: 15px 57px 15px 30px; background-color: #00A4E4; background-image: url("../img/cmn/arrow_wh.svg"); background-repeat: no-repeat; background-position: center right 30px; color: #FFF; border: 1px solid #00A4E4;}
#cmnContact .btnBL:hover {background-image: url("../img/cmn/arrow_bl.svg"); background-position: center right 20px; background-color: #FFF; color: #00A4E4;}
footer .ftNav > .flex > ul:not(:first-child) {margin-left: 40px;}
footer .ftNav ul li {margin-bottom: 10px;}
footer .ftNav ul li ul {margin-top: 10px; margin-left: 40px; position: relative;}
footer .ftNav ul li ul::after {position: absolute; content: ''; width: 1px; height: 100%; background: #222; top: 0; left: -20px;}
.footCopy {text-align: right;}
.footCopy small {font-size: 14px;}
#ftNavi {display: none;}
@media screen and (max-width: 1080px) {
	#cmnContact dl {margin-left: 20px;}
}
@media screen and (max-width: 1024px) {
	#cmnContact {padding: 60px 0;}
	#cmnContact h2 {width: 100%; text-align: center; margin-bottom: 20px;}
	#cmnContact .mla {margin-right: auto;}
	#cmnContact dl {margin-left: 10px; margin-right: 10px;}
}
@media screen and (max-width: 610px) {
	#cmnContact dl {width: 100%; margin: 0 auto 10px;}
	#cmnContact dl:first-child {text-align: center;}
	#cmnContact dd.EN {display: inline-block;}
}
@media screen and (max-width: 896px) {
	footer {margin-bottom: 50px;}
	.ftInfo {margin-bottom: 20px;}
	#ftNavi {display: block; background: #00A4E4; letter-spacing: -.4em; position: fixed; z-index: 5; bottom: 0; border-top: 1px solid #FFF; width: 100%;}
	#ftNavi ul {text-align: center; font-size: 10px; font-weight: bold;}
	#ftNavi li {letter-spacing: normal; display: inline-block; width: 25%;}
	#ftNavi li a {display: block; padding: 5px 0; color: #FFF; border-left: 1px solid #03A8E8; border-right: 1px solid #028ABF;}
	#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;}
}
@media screen and (max-width: 568px) {
	.ftInfo {text-align: center; width: 100%;}
	.ftInfo .logo {margin-left: auto; margin-right: auto;}
	footer .ftNav > .flex > ul:not(:first-child) {margin-left: 0;}
	footer .ftNav > .flex > ul {width: 50%;}
}

.w1300 {width: 100%; max-width: 1332px; padding-left: 0; padding-right: 0;}
.w1500 {width: 100%; max-width: 1520px; padding-left: 0; padding-right: 0;}
.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;}
.mla {margin-left: auto;}
.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%;}
.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;}
}

.abs {position: absolute; z-index: 1;}
.r10 {border-radius: 10px;}
.r20 {border-radius: 20px;}
.w1680 {width: 1680px; max-width: 100%;}
.w1340 {width: 1340px; max-width: 100%;}
@media screen and (max-width: 568px) {
	.r10 {border-radius: 5px;}
	.r20 {border-radius: 10px;}
}

#kv .kvImg {width: 100%; height: 400px;}
#kv .kvImg > .container,#kv .kvImg > .containers {left: 0; right: 0; bottom: -5px;}
#kv h1 {display: inline-block; padding: 10px 30px; line-height: 1.5; color: #666; background: #FFF;}
#kv dt {padding-left: 30px;}
#kv dt::before {position: absolute; content: ''; width: 22px; height: 1px; background: #00A4E4; left: 0; top: 50%;}
.bread li:not(:last-child) {margin-right: 10px;}
.bread li a {display: block; padding-right: 20px; background: url("../img/cmn/bread.svg") no-repeat right center; color: #999; text-decoration: underline;}
@media screen and (max-width: 1024px) {
	#kv .kvImg {width: 100%; height: 300px;}
}
@media screen and (max-width: 896px) {
	#kv .kvImg {width: 100%; height: 250px;}
}
@media screen and (max-width: 568px) {
	#kv .kvImg {width: 100%; height: 150px;}
	#kv h1 {font-size: 24px; padding: 8px 20px;}
}

#top01 {padding: 0 30px 30px; margin-bottom: 20px;}
#top01 .mv {width: 100%; height: calc(100vh - 130px);}
#top01 .logo {max-width: 600px; width: 80%; top: 50%; left: 0; right: 0; margin: 0 auto; transform: translateY(-50%);}
@media screen and (max-width: 896px) {
	#top01 {padding: 0 20px 30px;}
	#top01 .mv {height: 50vh;}
}
@media screen and (max-width: 568px) {
	#top01 .mv {height: 40vh;}
}

#top02 {padding-bottom: 80px; background: url("../img/top/02-05.jpg") no-repeat center bottom; background-size: 100% auto;}
#top02 .half.txt {width: calc(50% + 20px); padding-top: 50px;}
#top02 .mainImg {width: calc(50% - 20px); top: 0; right: 0;}
#top02 .subImg {width: 58%;}
#top02 .alEnd .txt {width: 42%; padding-left: 60px;}
#top02 .txt li:first-child {width: 180px;}
#top02 .txt li:last-child {width: 120px;}
@media screen and (max-width: 1060px) {
	#top02 .half.txt {width: calc(60% + 20px); padding-right: 20px;}
	#top02 .mainImg {width: calc(40% - 20px);}
	#top02 .subImg {width: 42%;}
	#top02 .alEnd .txt {width: 58%; padding-left: 40px;}
}
@media screen and (max-width: 896px) {
	#top02 .half.txt {width: calc(70% + 20px);}
	#top02 .mainImg {width: calc(30% - 20px);}
}
@media screen and (max-width: 680px) {
	#top02 .subImg {width: 100%;}
	#top02 .alEnd .txt {width: 100%; padding-left: 0;}
}
@media screen and (max-width: 568px) {
	#top02 .half.txt {width: 100%; padding-right: 0; padding-top: 0;}
	#top02 .mainImg {width: 30%; bottom: 0; top: inherit;}
	#top02 .inner {width: 70%;}
}

#top03 h2,#top03 .EN,.businessBox li h3 {-webkit-writing-mode: vertical-rl; writing-mode: vertical-rl;}
#top03 h2 {letter-spacing: .2em;}
#top03 .businessBox {width: calc(100% - 95px);}
.businessBox li {width: calc(100%/3 - 40px); margin-left: 40px;}
.businessBox li h3 {top: 0; right: 0; padding: 20px 15px; letter-spacing: .2em; border-radius: 0 10px 0 10px;}
.businessBox li .thumb {overflow: hidden;}
.businessBox li a:hover .thumb img {transform: scale(1.1); transition: .3s;}
.businessBox li p {padding-right: 37px; background: url("../img/cmn/arrow_bk.svg") no-repeat right center; transition: .3s;}
.businessBox li a:hover p {background-position: right 10px center;}
#business01 .businessBox li {margin: 0 20px;}
@media screen and (max-width: 896px) {
	#top03 .ttl {position: absolute;}
	#top03 .businessBox {width: 100%; justify-content: space-between;}
	.businessBox li {width: calc(100%/3 - 20px); margin-left: 0;}
	.businessBox li h3 {padding: 10px 5px;}
	#business01 .businessBox li {margin: 0 10px;}
}
@media screen and (max-width: 568px) {
	#top03 .ttl {flex-direction: column;}
	#top03 h2,#top03 .EN {-webkit-writing-mode: horizontal-tb; writing-mode: horizontal-tb;}
	.businessBox li h3 {border-radius: 0 5px 0 5px;}
	.businessBox li {width: calc(50% - 10px);}
	#top03 .businessBox li {margin-bottom: 30px;}
	#top03 .businessBox li:first-child {margin-left: calc(50% + 10px);}
	#business01 .businessBox li {margin: 0 15px; width: calc(50% - 30px); margin-bottom: 30px;}
}

#top04 .ttl {margin-right: 60px;}
#top04 .mainImg {margin: 0 30px 30px;}
#top04 .copy {height: calc(100% - 100px); z-index: 2;}
#top04 .copy h2,#top04 .copy .txt24 {-webkit-writing-mode: vertical-rl; writing-mode: vertical-rl; letter-spacing: .2em;}
#top04 .copy span {display: block;}
#top04 .copy span:first-of-type {margin-top: 1em;}
#top04 .copy span:last-of-type {margin-top: 2em;}
#top04 .nameImg {width: 80px; margin: 0 60px; position: relative;}
#top04 .mainImg.cat01::before {position: absolute; content: ''; width: 60%; height: 100%; top: 0; right: 0; background: #FFF; background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);}
#top04 .mainImg.cat01 .copy {top: 60px; right: 60px;}
#top04 .mainImg.cat02 .copy {top: 60px; left: 60px; text-shadow: 2px 2px 2px #000;}
#top04 .copy h2 {margin-top: auto;}
#top04 .itemList {margin: 0 15px;}
#top04 .itemList li {width: calc(25% - 30px); margin: 0 15px 30px;}
.itemList .ratioBox::before {content: ""; display: block; padding-top: 81.7%;}
.itemList .txt {position: relative; padding-left: 42px;}
.itemList .txt::before {position: absolute; content: ''; width: 2px; height: calc(100% + 30px); border-radius: 2px; background: #00A4E4; bottom: 0; left: 20px;}
.flow li {width: calc(25% - 40px); margin: 0 20px 20px;}
.flow li .num {position: absolute; top: -20px; left: 10px; width: 70px;}
.flow li:not(:last-child)::before {position: absolute; content: ''; width: 60px; height: 60px; background: url("../img/top/04-11.svg") no-repeat; background-size: cover; top: 70px; right: -50px; z-index: 1;}
@media screen and (max-width: 1270px) {
	#top04 .copy {position: relative;}
	#top04 .mainImg .inner {position: absolute; top: 0; width: 100%; height: 100%;}
	#top04 .mainImg.cat01 .copy {top: 0; right: 0; padding: 60px 30px 60px 0;}
	#top04 .mainImg.cat02 .copy {top: 0; left: 0; padding: 60px 0 60px 30px;}
}
@media screen and (max-width: 896px) {
	#top04 .mainImg {margin: 0 15px 20px;}
	#top04 .nameImg {width: 60px; margin: 0 20px;}
	#top04 .itemList {margin: 0;}
	#top04 .itemList li {width: calc(50% - 30px);}
	.itemList .txt {padding-left: 22px;}
	.itemList .txt::before {left: 10px;}
	.flow li {width: calc(50% - 30px); margin: 0 15px 30px;}
	.flow li:not(:last-child)::before {right: -47px;}
	.flow li:not(:last-child)::before {content: none;}
}
@media screen and (max-width: 568px) {
	#top04 .nameImg {width: 40px; margin: 0 20px;}
	#top04 .mainImg.cat01 .copy {padding: 30px 15px 30px 0;}
	#top04 .mainImg.cat02 .copy {padding: 30px 0 30px 15px;}
	.flow li .num {top: -10px; left: 5px; width: 50px;}
}

#topNews .ttl {width: 200px;}
#topNews .newsList {width: calc(100% - 260px);}
#topNews .newsList li {width: 100%;}
.newsList li {border-bottom: 1px solid #CCC;}
.newsList li a {padding: 15px 0;}
.newsList li a p:last-child {padding-right: 37px; background: url("../img/cmn/arrow_bk.svg") no-repeat right center;}
.newsList li a:hover {background: #EEE;}
.moreBtn {display: block; width: 100%; position: relative; padding: 20px 60px 20px 23px; background-color: #EEE; background-image: url("../img/cmn/arrow_bk.svg"); background-repeat: no-repeat; background-position: right 23px center;}
.moreBtn::before,.moreBtn::after {position: absolute; content: ''; width: 80px; height: 20px;}
.moreBtn::before {top: -3px; left: -3px; background: url("../img/cmn/btn_cnr01.svg") no-repeat; background-size: cover;}
.moreBtn::after {bottom: -3px; right: -3px; background: url("../img/cmn/btn_cnr02.svg") no-repeat; background-size: cover;}
.moreBtn:hover {background-position: right 13px center;}
@media screen and (max-width: 896px) {
	#topNews .ttl {width: 100%; justify-content: space-between; flex-direction: row;}
	#topNews .ttl > p {width: 200px;}
	#topNews .newsList {width: 100%;}
	.moreBtn {padding: 15px 60px 15px 23px;}
}

#top05.w1680 {padding: 0 30px;}
#top05 .container {top: 50%; transform: translateY(-50%); left: 0; right: 0;}
.w250 {width: 100%; max-width: 250px;}
.txtShdw {text-shadow: 2px 2px 2px #000;}
@media screen and (max-width: 896px) {
	#top05.w1680 {padding: 0 15px;}
	#top05 .container {position: relative; top: 0; transform: translateY(0); padding: 60px 30px;}
	#top05 .inner {position: absolute; width: calc(100% - 30px); height: 100%; top: 0; left: 15px;}
}

.mr40 {margin-right: 40px;}
.txtBR {color: #6A5C40;}
.w330 {width: 330px;}

#material02 .read {background: #6A5C40;}
#material02 .mainImg {width: 52.9%; margin-left: 47.1%; padding-right: 40px;}
#material02 .read {position: relative;}
#material02 .read .container {left: 0; right: 0; bottom: 50px;}
#material02 .read .container .col6 {padding-left: 110px;}
#material02 .read .container .col6 span {font-size: 500%; left: 0; top: 50%; transform: translateY(-50%);}
#material02 .materialList {padding: 40px 0 60px; background: #F6F1E8;}
#material02 .materialList .thumb {width: 51.2%;}
#material02 .materialList .txt {width: 48.8%; padding-left: 30px;}
#material02 .materialList .txt h3::before,#material03 .materialList .txt h3::before {position: absolute; content: ''; width: 40px; height: 2px; border-radius: 1px; background: #00A4E4; left: -50px; top: 50%; transform: translateY(-50%);}
.materialIcon li {padding: 5px 20px; border-radius: 18px; display: inline-block; margin-bottom: 10px; margin-right: 20px;}
.materialIcon li:first-child {background: #BF9E60; border: 1px solid #BF9E60; color: #FFF;}
.materialIcon li:last-child {background: #FFF; border: 1px solid #BF9E60; color: #BF9E60;}
#material02 .materialList .col6 {border: 1px solid #6A5C40; background: #FFF; padding: 35px 40px;}
#material02 .materialList .col6::after {content: ""; display: block;	position: absolute;	width: 30px; height: 30px; background-color: #6A5C40;	clip-path: polygon(0% 0%, 0% 100%, 100% 0%); top: 10px; left: 10px; z-index: 1;}
#material02 .materialList .col6 p.txt18 {width: calc(100% - 330px); padding-right: 40px;}
#material03 .materialList .thumb {width: calc(50% + 20px);}
#material03 .materialList .txt {width: calc(50% - 20px); padding-left: 30px;}
#material03 .materialList .txt h3 span {font-size: 80%;}
@media screen and (max-width: 1024px) {
	#material02 .mainImg {width: 48.9%; margin-left: 51.1%; padding-right: 0;}
	.materialList .alEnd,.materialList.alEnd {align-items: normal;}
	.materialList .txt {padding-top: 20px;}
}
@media screen and (max-width: 896px) {
	#material02 .read .container .col6 {width: 50.1%; padding-left: 58px;}
	#material02 .read .container {bottom: 50%; transform: translateY(50%);}
	#material02 .read .container .col6 span {font-size: 300%; left: 0; top: 0; transform: translateY(0); line-height: 1.2;}
}
@media screen and (max-width: 800px) {
	#material02 .materialList .col6 {padding: 30px 20px;}
	#material02 .materialList .col6 p.txt18 {width: 100%; padding-right: 0; margin-bottom: 20px;}
}
@media screen and (max-width: 568px) {
	#material02 .read .container {position: relative; width: 100%; bottom: 0; transform: translateY(0); padding: 30px 0 0;}
	#material02 .read .container .col6 {width: calc(100% - 30px);}
	#material02 .mainImg {width: 100%; margin-left: 0%; padding-right: 0; margin-top: 20px; overflow: hidden;}
	#material02 .mainImg img {max-width: 124%; margin-left: -12%;}
	#material02 .materialList .thumb {width: 49.2%;}
	#material02 .materialList .txt {width: 50.8%; padding-left: 20px;}
	.materialIcon li {margin-right: 0; padding: 3px 15px;}
	#material03 .materialList .thumb {width: 100%;}
	#material03 .materialList .txt {width: 100%; padding-left: 0; padding-top: 20px;}
	#material03 .materialList .txt h3::before {content: none;}
}

#aroma01 .container {left: 0; right: 0; padding: 50px 0; height: 100%;}
#aroma02 .txt {width: calc(100%/3*2 - 20px); padding-left: 40px;}
#aroma02 .mainImg {width: calc(100%/3 + 20px);}
#aroma03 .ttl {-webkit-writing-mode: vertical-rl; writing-mode: vertical-rl; flex-direction: column-reverse;}
#aroma03 .ttl h2 {letter-spacing: .3em;}
#aroma03 .mainImg {width: 306px;}
#aroma03 ul {width: calc(100% - 440px); padding-left: 40px;}
#aroma03 li {margin-bottom: 15px; display: flex; flex-wrap: wrap; align-items: center;}
#aroma03 li .EN {width: 50px; line-height: 50px; text-align: center; margin-right: 10px; font-size: 36px; font-weight: 500; background: #00A4E4; border-radius: 50%;}
#aroma03 li .txt {width: calc(100% - 60px);}
@media screen and (max-width: 1320px) {
	#aroma01 .container {position: relative;}
	#aroma01 .bgImg {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
}
@media screen and (max-width: 896px) {
	#aroma01 .container {padding: 0 0 20px;}
	#aroma01 .bgImg {position: relative;}
	#aroma03 ul {width: 100%; padding-left: 0; margin-top: 20px;}
}
@media screen and (max-width: 700px) {
	#aroma02 .txt {width: 100%; padding-left: 0; margin-bottom: 20px;}
	#aroma02 .mainImg {width: 100%;}
}
@media screen and (max-width: 568px) {
	#aroma03 .mainImg {width: calc(100% - 80px); margin-left: auto;}
}

#company01 .mainImg {width: calc(100% - 80px); margin-top: -60px; margin-left: 20px;}
#company02 .ttl {-webkit-writing-mode: vertical-rl; writing-mode: vertical-rl; flex-direction: column-reverse;}
#company02 .ttl h2 {letter-spacing: .3em;}
#company02 dl {width: calc(100% - 95px); padding-left: 60px;}
#company02 dt,#company02 dd {padding-bottom: 20px; margin-bottom: 20px;}
#company02 dt {width: 165px; border-bottom: 1px solid #1B3679;}
#company02 dd {width: calc(100% - 165px); border-bottom: 1px solid #CCCCCC;}
#company02 .map iframe {width: 100%; height: 500px;}
@media screen and (max-width: 1024px) {
	#company01 .mainImg {margin-top: 20px; width: calc(100% - 40px);}
}
@media screen and (max-width: 896px) {
	#company01 .mainImg {margin-top: 20px; width: calc(100% - 30px); margin-left: 15px;}
	#company02 dl {width: calc(100% - 70px); padding-left: 20px;}
}
@media screen and (max-width: 568px) {
	#company02 dt {width: 100%; border-bottom: none; padding-bottom: 0; margin-bottom: 5px; font-weight: 700;}
	#company02 dd {width: 100%; }
	#company02 .map iframe {height: 300px;}
}

.pageNav {margin-top: 20px;}
.pageNav li {margin: 0 5px 10px;}
.pageNav li a,.pageNav li.active,.pageNav li .current {width: 40px; line-height: 40px; display: block; text-align: center;}
.pageNav li a {background: #FFF; position: relative; color: #00A4E4;}
.pageNav li a::before,.pageNav li a::after {position: absolute; content: ''; background: #00A4E4; border-radius: 1px; bottom: 0;}
.pageNav li a::before {width: 100%; height: 2px; left: 0;}
.pageNav li a::after {height: 100%; width: 2px; right: 0;}
.pageNav li a:hover,.pageNav li.active,.pageNav li .current {background: #00A4E4; color: #FFF;}
.pageNav li a.prev {background: url("../img/cmn/arrow_bl_back.svg") no-repeat center right 10px; text-indent: -9999px;}
.pageNav li a.next {background: url("../img/cmn/arrow_bl_next.svg") no-repeat center left 10px; text-indent: -9999px;}
.pageNav li a.prev::before,.pageNav li a.prev::after,.pageNav li a.next::before,.pageNav li a.next::after {content: none;}

#newsSingle .ttlBdr {padding-bottom: 30px;}
#newsSingle .ttlBdr::before {position: absolute; content: ''; width: 80px; height: 2px; border-radius: 1px; background: #00A4E4; bottom: 0; left: 0;}
.post p:not(:last-child) {margin-bottom: 20px;}
.postNav {padding: 20px 0 0; border-top: 1px solid #CCC;}
.postNav li a {text-decoration: underline;}
.postNav .next {margin-left: auto;}
.postNav .prev a {padding-left: 20px; background: url("../img/cmn/arrow_bl_back.svg") no-repeat left center;}
.postNav .next a {padding-right: 20px; background: url("../img/cmn/arrow_bl_next.svg") no-repeat right center;}
