@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;}
}

.cormorant {font-family: "Cormorant", serif; font-optical-sizing: auto; font-weight: 600; font-style: normal;}
.eb-garamond {font-family: "EB Garamond", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal;}
.raleway {font-family: "Raleway", sans-serif; font-optical-sizing: auto; font-weight: 700; font-style: normal;}
.mincho {font-family: "Noto Serif JP", serif; font-optical-sizing: auto; font-weight: 600; font-style: normal;}

.bgWH {background-color: #FFF;}
.bgGRY {background-color: #EEEEEE;}
.txtWH {color: #FFF;}
.txtBL {color: #1B3679;}
.txtPI {color: #D15E67;}

.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%;}

main {min-height: 1000px;}
#header {position: relative; width: 100%;}
#header .siteName {margin-bottom: 5px;}
.logo {width: 220px;}
#header .logo {margin: 20px 30px;}
#header .sns {margin: auto auto 20px 0;}
.sns li {width: 30px; margin: 0 15px 0 0;}
#hanburger {display: none;}
.menu_button {width: 55px; height: 55px; position: fixed; top: 0; right: 0; background: #222; 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; text-align: center; background: #FFF;}
#hanburger:checked ~ .global_menu {visibility: visible;}
.global_menu a {display: block; width: 100%;}
.global_menu a:hover {background: #222; color: #FFF;}
.menu:not(:last-child) {font-size: 12px; font-weight: 600; white-space: nowrap; margin-right: 30px; position: relative; margin-top: auto;}
.menu a {padding: 20px; line-height: 1.2;}
.menu:not(:last-child) a::before {position: absolute; content: ''; width: 100%; height: 2px; border-radius: 1px; background: #222; bottom: 44px; left: 0;}
.menu:not(:last-child) a:hover::before {background: #FFF;}
.menu span {display: block; font-size: 18px; font-family: "Raleway", sans-serif; font-optical-sizing: auto; font-weight: 700; font-style: normal; padding-bottom: 18px;}
.menu:last-child {margin: -30px 0 0 0; font-size: 12px; font-weight: 600; border-left: 1px solid #222;}
.menu:last-child span {padding-bottom: 5px;}
.menu:last-child a {height: 100%; background: #222 url("../img/cmn/icon_mail_wh.svg") no-repeat center top 24px; color: #FFF; padding: 55px 20px 24px;}
.menu:last-child a:hover {background: #FFF url("../img/cmn/icon_mail_bk.svg") no-repeat center top 24px; color: #222;}
#hanburger,.spOnly {display: none;}
@media screen and (max-width: 1410px) {
	#header .logo {margin: 20px 10px 20px 20px;}
	.menu:not(:last-child) {margin-right: 20px;}
}
@media screen and (max-width: 1320px) {
	.menu:not(:last-child) {margin-right: 10px;}
	.menu a {padding: 20px 15px;}
	.menu:last-child a {padding: 55px 15px 24px;}
}
@media screen and (max-width: 1210px) {
	.logo {width: 160px;}
	.sns li {width: 24px; margin: 0 10px 0 0;}
	.menu span {font-size: 16px;}
	.menu:last-child {margin: 0;}
	.menu:last-child a {padding: 55px 15px 20px;}
}
@media screen and (max-width: 1055px) {
	.menu span {font-size: 14px;}
	.menu a {padding: 20px 10px;}
	#header .sns {flex-direction: column;}
	.sns li {margin: 8px 0 0;}
}
@media screen and (max-width: 910px) {
	.menu:not(:last-child) {margin-right: 5px;}
}
@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; margin-top: auto;}
}
@media screen and (max-width: 896px) {
  .spOnly {display: block;}
	.logo > a {width: 130px; display: block;}
	#header .logo {margin: 10px 0 10px 15px;}
	#header .sns {flex-direction: row; margin: auto auto 10px 0}
	.sns li {margin: 0 10px 0 0;}
  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:not(:last-child) {margin-right: 0;}
	.menu:not(:last-child) a::before {content: none;}
  .menu a {padding: 10px 15px; text-align: left; border-bottom: 1px solid #CCC; line-height: 1.5;}
  .menu a span {margin-right: 10px; display: inline-block; padding-bottom: 0; font-size: 16px;}
	.menu:last-child {margin: 0; border-left: none;}
	.menu:last-child span {padding-bottom: 0;}
	.menu:last-child a {padding: 10px 15px 10px 45px; background-size: 20px; background-position: left 15px center;}
  .global_menu {z-index: 10;}
  .global_menu a {border-top-left-radius: 0; border-top-right-radius: 0;}
  .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;}
}

footer {padding: 140px 0 80px; background: #222 url("../img/cmn/foot_bg.jpg") no-repeat top center; width: 100%; overflow-x: hidden; position: relative;}
footer::before {position: absolute; content: ''; width: 240px; height: 298px; background: url("../img/cmn/foot_mark.svg") no-repeat; bottom: 0; right: 0; background-size: cover;}
.footNav {width: 570px; position: relative; z-index: 1;}
.footNav li {margin: 0 0 15px 30px; line-height: 1.5;}
.footNav li a {color: #FFF;}
.footNav li a:hover {text-decoration: underline;}
.footCopy {text-align: right;}
.footCopy small {font-size: 14px;}
#ftNavi {display: none;}
@media screen and (max-width: 896px) {
	footer {margin-bottom: 57px; padding: 70px 0 50px; background-size: auto 80px; border-bottom: 1px solid #111;}
	footer::before {width: 140px; height: 149px;}
	#ftNavi {display: block; background: #222; position: fixed; z-index: 5; bottom: 0; border-top: 1px solid #333; width: 100%;}
	#ftNavi ul {text-align: center; font-size: 10px; font-weight: 700;}
	#ftNavi li {letter-spacing: normal; width: 25%;}
	#ftNavi li a {display: block; padding: 5px 0; color: #FFF; border-left: 1px solid #333; border-right: 1px solid #111;}
	#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: 760px) {
	footer .logo {display: flex; justify-content: center; width: 100%;}
	footer .logo h2 {width: 160px; margin-right: 20px;}
	footer .sns {margin-top: auto; margin-bottom: 20px;}
	.footNav {width: 100%; margin-top: 15px;}
	.footNav ul {justify-content: center;}
	.footNav li {margin: 0 10px 15px;}
	.footCopy {text-align: center;}
}

.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;}
.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%;}
.w100 {width: 100%;}
.w50 {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;}
.btnCmn {width: 100%; max-width: 240px;}
.btnWH {display: block; width: 100%; padding: 10px 40px 9px 20px; line-height: 1.5; color: #222; border: 2px solid #222; background: #FFF url("../img/cmn/arrow_bk.svg") no-repeat center right 20px;}
.btnWH:hover {color: #FFF; background: #222 url("../img/cmn/arrow_wh.svg") no-repeat center right 10px;}

.ttlBdr {position: relative; padding-bottom: 15px; margin-bottom: 15px;}
.ttlBdr::before {position: absolute; content: ''; width: 80px; height: 2px; background: #222; border-radius: 1px; bottom: 0; left: 0;}
.more {position: relative; padding: 7px 27px 10px 0; background: url("../img/cmn/arrow_bk.svg") no-repeat top 13px right 10px; display: inline-block; margin-left: auto; transition: .3s;}
a:hover .more {background: #222 url("../img/cmn/arrow_wh.svg") no-repeat top 13px right 5px; color: #FFF; padding: 7px 27px 10px 5px;}
.more::before,.more::after {position: absolute; content: ''; background: #222; border-radius: 1px;}
.more::before {width: 100%; height: 2px; bottom: 0; left: 0;}
.more::after {width: 2px; height: 100%; bottom: 0; right: 0;}
@media screen and (max-width: 568px) {
	.more,a:hover .more {padding: 5px 27px 7px 0; background-position: top 12px right 10px;}
}

#kv { /* padding-top: 50px; */ }
#kv::before {position: absolute; content: ''; top: 0; left: 0; width: 100%; height: 50px; 
	background: url("../img/cmn/kv_empty.png") no-repeat center;
	background-size: cover;}
#kv .container.abs {left: 0; right: 0; top: 50%; transform: translateY(-50%);}
#kv h1 {padding-top: 20px;}
#kv h1::before {position: absolute; content: ''; width: 100px; height: 2px; border-radius: 1px; background: #222; top: 0; left: 0;}
#kv h1.txtWH::before {background: #FFF; box-shadow: 2px 2px 2px rgba(0,0,0,.8)}
#kv h1.txtWH,#kv .raleway.txtWH {text-shadow: 2px 2px 2px rgba(0,0,0,.8);}
.kvImg .objFit {height: 360px;}
#bread {border-bottom: 1px solid #CCC; padding-bottom: 20px;}
#bread li:not(:last-child) {margin-right: 10px;}
#bread li a {padding-right: 20px; text-decoration: underline; color: #999; background: url("../img/cmn/arrow_gry.svg") no-repeat right center;}
#bread li a:hover {color: #222;}
@media screen and (max-width: 1200px) {
	.kvImg .objFit {height: auto;}
}
@media screen and (max-width: 896px) {
	#kv {padding-top: 30px;}
	#kv::before {height: 30px;}
	.kvImg {margin-bottom: 10px;}
	#kv .container.abs {position: relative; padding: 50px 0 30px; top: 0; transform: translateY(0); z-index: 1;}
	#kv .raleway {margin-bottom: 10px; font-size: 26px;}
	#kv h1 {padding-top: 10px;}
	.kvImg .objFit {width: 100%; height: 100%; position: absolute; top: 0; left: 0;}
	#bread {padding-bottom: 10px; font-size: 10px;}
}
@media screen and (max-width: 568px) {
	#kv {padding-top: 20px;}
	#kv::before {height: 20px;}
	#kv .container.abs {padding: 20px 0 20px;}
}

.newsList li:not(:last-child) {margin-bottom: 30px;}
.newsList a {display: flex; flex-wrap: wrap;}
.newsList .thumb {width: 31%; overflow: hidden; min-height: 186px;}
.newsList .thumb .raleway {bottom: 10px; left: 10px; z-index: 1;}
.newsList .thumb .mark {width: 30px; bottom: 10px; right: 10px;}
.newsList a:hover img.thumbImg {transform: scale(1.1); transition: .3s;}
.newsList .thumb .noImg {opacity: .4;}
.newsList .newsSummary {width: 69%; padding-left: 30px;}
.new {width: 50px; line-height: 30px; text-align: center; border-radius: 3px; background: #D15E67;}
@media screen and (max-width: 896px) {
	.newsList .thumb {width: 45%;}
	.newsList .newsSummary {width: 55%;}
	.new {width: auto; line-height: 1.5; font-size: 12px; padding: 3px 7px;}
}
@media screen and (max-width: 568px) {
	.newsList .thumb {width: 100%; margin-bottom: 10px; max-height: 100px;}
	.newsList .newsSummary {width: 100%; padding-left: 0;}
}

#top01 {width: 100%; height: calc(100vh - 124px); /*max-height: 1050px;*/}
#top01 .mv {height: calc(100% - 80px);}
#top01 .inner {width: 100%; height: 100%; overflow: hidden;}
#top01 .inner > video {position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); min-width: 100%; min-height: 100%;}
#top01 h2 {bottom: 40px; right: 80px; z-index: 1; line-height: 1.3; text-shadow: 2px 2px 2px rgba(0,0,0,.8);}
#top01 h2 .brackets {position: relative; padding: 5px 15px;}
#top01 h2 .brackets::before,#top01 h2 .brackets::after {position: absolute; content: ''; width: 30px; height: 50px;}
#top01 h2 .brackets::before {border-top: 2px solid #FFF; border-left: 2px solid #FFF; top: 0; left: 0;}
#top01 h2 .brackets::after {border-bottom: 2px solid #FFF; border-right: 2px solid #FFF; bottom: 0; right: 0;}
#top01 .anchor {margin: 30px 0 0 30px;}
#top01 .anchor a {display: block; padding-right: 26px; background: url("../img/cmn/arrow_down.svg") no-repeat right center;}
#top03 .pickUp:first-of-type {padding: 75px 0 60px; background: url("../img/top/03-01.jpg") no-repeat center; background-size: cover;}
#top03 .pickUp:last-of-type {background: url("../img/top/03-02.jpg") no-repeat center; background-size: cover;}
#top03 .pickUp ul {margin: 0 -10px;}
#top03 .pickUp li {width: calc(25% - 60px); margin: 0 30px 50px;}
#top03 .pickUp li a {display: flex; flex-wrap: wrap; align-items: flex-end;}
#top03 .pickUp li a h3 {margin: 15px 0 10px; width: 100%;}
#top03 .pickUp li a:hover img {transform: scale(1.1); transition: .3s;}
#top03 .pickUp:first-of-type li:first-child {display: flex; flex-wrap: wrap;}
#top03 .pickUp:first-of-type li:nth-child(5) {margin-left: auto;}
#top03 .pickUp:last-of-type li:first-child {background: #000; padding: 60px 0; margin-bottom: 0;}
#top03 .pickUp:last-of-type li:not(:first-child) {margin: 25px 30px;}
#top04 .sideImg01,#top04 .sideImg02 {width: 33.5%; max-width: 562px; top: -100px; z-index: -1;}
#top04 .sideImg02 {right: 0;}
#top04 .container .ttl::before {position: absolute; content: ''; width: 172px; height: 31px; background: url("../img/top/04-01.svg") no-repeat; background-size: cover; top: -10px; right: -135px;}
#top04 .blk {padding: 5px 40px 5px 12px; margin: 10px 0;}
#top04 .blk::before,#top04 .blk::after {position: absolute; content: ''; width: 20px; height: 34px;}
#top04 .blk::before {border-top: 1px solid #222; border-left: 1px solid #222; top: 0; left: 0;}
#top04 .blk::after {border-bottom: 1px solid #222; border-right: 1px solid #222; bottom: 0; right: 28px;}
#top04 .concept {/*text-shadow: 2px 2px 2px rgba(255,255,255.8);*/}
#top04 .conceptTxt {width: calc(100% - 350px); margin-left: auto;}
.conceptSlide {max-width: 1412px; width: 100%; margin: 0 auto;}
.conceptSlide li {margin: 0 20px;}
.conceptSlide .thumb {overflow: hidden;}
.conceptSlide .thumb .cormorant {top: 20px; left: 20px; line-height: 1; z-index: 1; text-align: center;}
.conceptSlide .thumb .cormorant .ttl,.modalContents .ttl {font-size: 35%; display: block;}
.conceptSlide .thumb .cormorant .num,.modalContents .num {display: block; position: relative; top: -20px;}
.conceptSlide .thumb .cormorant .num span,.modalContents .num span {font-size: 150%;}
.conceptSlide .thumb .icon,.modalContents .btnPlay {width: 60px; margin: 0 auto; top: 50%; left: 0; right: 0; transform: translateY(-50%); z-index: 1;}
.conceptSlide li a:hover .thumbImg {transform: scale(1.1); transition: .3s;} 
.slideArrow {position: absolute; top: 35%; transform: translateY(-50%); width: 80px; height: 80px; background-color: #707070; border: 1px solid #707070; border-radius: 50%; cursor: pointer; z-index: 1; transition: .3s;}
.slideArrow:hover {background-color: #FFF;}
.prevArrow {left: -20px; background-image: url("../img/cmn/slide02_wh.svg"); background-repeat: no-repeat; background-position: center;}
.nextArrow {right: -20px; background-image: url("../img/cmn/slide01_wh.svg"); background-repeat: no-repeat; background-position: center;}
.prevArrow:hover {background-image: url("../img/cmn/slide02_gry.svg"); background-repeat: no-repeat; background-position: center;}
.nextArrow:hover {background-image: url("../img/cmn/slide01_gry.svg"); background-repeat: no-repeat; background-position: center;}
.modal {display: none; height: 100vh; position: fixed; top: 0; width: 100%; z-index: 2;}
.modalBg {background: rgba(0,0,0,0.8); height: 100vh; position: absolute; width: 100%;}
.modalContents {position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 80%; max-width: 928px; padding: 0 40px; color: #FFF;}
.modalContents .num {top: -10px; line-height: 30px;}
.modalContents .ttlBdr {margin-left: 30px;}
.modalContents .ttlBdr::before {background: #FFF;}
.modalContents .movieWrap video {width: 100%;}
.movieWrap .btnPlay.playActive{display:none;}
.ttlModal {height: 60px;}
.modalContents .modalClose {position: absolute; text-indent: 9999px; width: 40px; height: 40px; top: 0; right: 40px;}
.modalContents .modalClose::before,.modalContents .modalClose::after {position: absolute; content: ''; background: #FFF; top: 50%; right: 50%;}
.modalContents .modalClose::before {width: 40px; height: 1px; transform: translate(0,-50%) rotate(-45deg); right: 0;}
.modalContents .modalClose::after {width: 1px; height: 40px; transform: translate(-50%,-50%) rotate(135deg);}
@media screen and (max-width: 1452px) {
	.prevArrow {left: 10px;}
	.nextArrow {right: 10px;}
}
@media screen and (max-width: 1410px) {
	#top01 {height: calc(100vh - 114px);}
	#top04 .sideImg01,#top04 .sideImg02 {top: inherit; bottom: -100px;}
}
@media screen and (max-width: 1232px) {
	#top03 .pickUp ul {margin: 0;}
	#top04 .conceptTxt {padding-right: 10%;}
	.slideArrow {width: 60px; height: 60px;}
	.prevArrow,.nextArrow {background-size: 15px auto;}
}
@media screen and (max-width: 1055px) {
	#top01 {height: calc(100vh - 111px);}
	#top04 .sideImg01,#top04 .sideImg02 {bottom: -60px;}
}
@media screen and (max-width: 1024px) {
	#top01,#top01 .mv {height: auto;}
	#top01 .inner {width: 100%; height: 100%; overflow: hidden;}
	#top01 .inner > video {position: relative; top: 0; left: 0; transform: translateX(0) translateY(0); min-width: inherit; min-height: inherit; width: 100%;}
	#top01 h2 {bottom: 20px; right: 40px; font-size: 3.5vw;}
	#top01 h2 .txt40 {font-size: 80%;}
	#top01 h2 .brackets {display: inline-block; margin-right: 10px; padding: 3px 10px;}
	#top01 h2 .brackets::before,#top01 h2 .brackets::after {width: 10px; height: 20px;}
	#top01 .anchor {margin: 15px 0 0 20px;}
}
@media screen and (max-width: 896px) {
	#top03 .pickUp:first-of-type {padding: 40px 0 0;}
	#top03 .pickUp:first-of-type li:first-child {width: 100%;}
	#top03 .pickUp:last-of-type {padding-bottom: 30px;}
	#top03 .pickUp li {width: calc(50% - 50px); margin: 0 25px 50px;}
	#top03 .pickUp:first-of-type li:nth-child(5) {margin-left: 25px;}
	#top03 .pickUp:last-of-type li:first-child {padding: 50px 0;}
	#top03 .pickUp:last-of-type li:first-child img {position: relative; left: 50%; transform: translateX(-50%);}
	#top03 .pickUp:last-of-type li:not(:first-child) {margin: 25px 25px;}
	#top04 .sideImg01,#top04 .sideImg02 {bottom: -30px;}
	#top04 .conceptTxt {width: calc(100% - 260px);}
	#top04 .blk::before,#top04 .blk::after {width: 10px; height: 17px;}
	.conceptSlide .thumb .cormorant .num, .modalContents .num {top: -10px;}
}
@media screen and (max-width: 700px) {
	#top04 .copy {margin-left: auto; margin-right: auto;}
	#top04 .conceptTxt {width: 100%; padding-left: 5%; padding-right: 5%;}
	#top04 .blk {display: inline-block; padding: 5px 12px; margin: 10px;}
	#top04 .blk::after {right: 0;}
	#top04 .fr {float: none;}
}
@media screen and (max-width: 568px) {
	#top01 h2 {font-size: 5vw;}
	#top03 .pickUp li {width: calc(50% - 30px); margin: 0 15px 30px;}
	#top03 .pickUp:first-of-type li:nth-child(5) {margin-left: 15px;}
	#top03 .pickUp:last-of-type li:not(:first-child) {margin: 25px 15px;}
	#top04 .container .ttl::before {top: -20px; right: -50px;}
}

#shoes01 li {text-align: center; margin: 0 15px; display: flex; flex-direction: column;}
#shoes01 li .blk {margin-bottom: 5px;}
#shoes01 li img {height: 70px;}
#shoes01 li a:hover img {transform: scale(1.1); transition: .3s;}
#shoes01 li:first-child img {height: 20px;}
#shoes01 li:first-child .blk {margin: 25px 0;}
#shoes02 .ttlBdr {margin-bottom: 40px;}
.shoesList {margin: 0 -10px;}
.shoesList > li {width: calc(100%/3 - 60px); margin: 0 30px 60px; display: flex;}
.shoesList .icon {position: relative; z-index: 1;}
.shoesList .icon,.shoesList .item,.shoesList .thumb,.shoesList h2 {flex-grow: 1;}
.shoesList .icon > ul {margin-left: auto; margin-top: auto;}
.shoesList .icon > ul > li:not(:last-child) {margin-right: 10px;}
.shoesList .icon01 {width: 100px;}
.shoesList .icon02 {width: 48px;}
.shoesList .icon03 {width: 40px;}
.shoesList a:hover > .item > img {transform: scale(1.1); transition: .3s;}
.shoesList .item {margin-top: auto;}
.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;}
.pageNav li a::before,.pageNav li a::after {position: absolute; content: ''; background: #222; 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: #222; color: #FFF;}
.pageNav li a.prev {background: url("../img/cmn/arrow_bk_back.svg") no-repeat center right 10px; text-indent: -9999px;}
.pageNav li a.next {background: url("../img/cmn/arrow_bk.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;}
.w1350 {width: 100%; max-width: 1390px;}
#shoesDetail01 .txtArea {width: 43%; padding-right: 40px;}
#shoesDetail01 .price span {font-size: 66.5%;}
.itemDesc {font-family: Meiryo, "メイリオ", 'Noto Sans JP', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;}
.itemThumb {margin-top: auto;}
.itemThumb ul {margin-left: -10px; margin-right: -10px;}
.itemThumb li {width: calc(100%/3 - 20px)!important; margin: 20px 10px 0; overflow: hidden; position: relative; cursor: pointer;}
.itemThumb li img:hover {transform: scale(1.2); transition: .3s;}
#shoesDetail01 .itemImg {width: 57%;}
#shoesDetail01 .itemImg {border: 1px solid #CCC; border-radius: 10px;}
#shoesDetail01 .itemImg .icon {position: absolute; width: 100%; top: 0; left: 0; padding: 30px 40px 0; z-index: 1;}
#shoesDetail01 .itemImg .icon .icon01 {width: 270px; margin-right: auto;}
#shoesDetail01 .itemImg .icon .icon02 {width: 140px; margin-right: auto;}
#shoesDetail01 .itemImg .icon .icon03 {width: 100px; margin-left: 20px;}
#shoesDetail01 .itemImg .zoomImg img {border-radius: 10px;}
#shoesDetail01 .itemImg .color {position: absolute; width: 100%; bottom: 0; left: 0; padding: 0 40px 30px;}
#shoesDetail01 .itemImg .color dt {margin-right: 20px;}
#shoesDetail02 ul {margin: 0 -20px; padding-top: 15px;}
#shoesDetail02 li {width: calc(25% - 40px); margin: 0 20px 20px;}
#shoesDetail02 li a:hover img {transform: scale(1.1); transition: .3s;}
.zoomImg img {max-width: 100%; display: block; height: auto;}
.zoomImg {overflow: hidden; width: 100%; margin: auto;}
.thumbArea.slick-slider {margin-bottom: 10px;}
.zoomImg.slick-slider {margin-bottom: auto; margin-top: auto;}
.thumbArea .slick-track {transform: unset!important; width: 100%!important; display: flex; flex-wrap: wrap; justify-content: space-between;}
.thumbArea .slick-slide {display: block!important; float: none!important;}
.thumbArea .slick-current {/*border: 5px solid #222;*/}
@media screen and (max-width: 1232px) {
	.shoesList {margin: 0;}
	.shoesList > li {width: calc(100%/3 - 50px); margin: 0 25px 50px;}
	#shoesDetail02 ul {margin: 0 -15px;}
}
@media screen and (max-width: 1100px) {
	#shoesDetail01 .itemImg .icon {padding: 20px 30px 0;}
	#shoesDetail01 .itemImg .icon .icon01 {width: 180px;}
	#shoesDetail01 .itemImg .icon .icon02 {width: 100px;}
	#shoesDetail01 .itemImg .icon .icon03 {width: 70px; margin-left: 10px;}
	#shoesDetail01 .itemImg .color {padding: 0 30px 20px;}
}
@media screen and (max-width: 896px) {
	.shoesList > li {width: calc(50% - 50px); margin: 0 25px 50px;}
	#shoesDetail01 .txtArea,#shoesDetail01 .itemImg {width: 100%; padding-right: 0;}
	.itemThumb ul {margin-left: -5px; margin-right: -5px;}
	.itemThumb li {width: calc(100%/3 - 10px)!important; margin: 20px 5px 0;}
	#shoesDetail02 li {width: calc(100%/3 - 30px); margin: 0 15px 20px;}
}
@media screen and (max-width: 568px) {
	.shoesList > li {width: calc(50% - 30px); margin: 0 15px 30px;}
	.itemThumb li {width: calc(50% - 10px)!important;}
	#shoesDetail01 .itemImg .icon {padding: 10px 20px 0;}
	#shoesDetail01 .itemImg .icon .icon01 {width: 135px;}
	#shoesDetail01 .itemImg .icon .icon02 {width: 70px;}
	#shoesDetail01 .itemImg .icon .icon03 {width: 50px; margin-left: 10px;}
	#shoesDetail01 .itemImg .color {padding: 0 20px 10px;}
	#shoesDetail02 li {width: calc(50% - 30px);}
}

#history01 {padding-bottom: 360px;}
#history01 .mainImg {width: 42.3%;}
#history01 .txtArea {width: 57.7%; padding-left: 40px;}
#history01 dt {max-width: 340px; width: 90%; margin-right: 20px;}
#history01 .subImg {width: 50%; bottom: 0; z-index: -1;}
#history01 .subImg::before {position: absolute; content: ''; width: 100%; height: 60%; background: #FFFFFF; background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%); top: 0;}
#history02 {margin-top: -280px;}
#history02 {padding-top: 380px;}
#history02 .mainImg {width: 31%;}
#history02 .txtArea {width: 69%; padding-left: 40px;}
#history02 .subImg {width: 50%; top: 0; right: 0; z-index: -1;}
#history02 .subImg::before {position: absolute; content: ''; width: 100%; height: 70%; background: #FFFFFF; background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%); bottom: 0;}
@media screen and (max-width: 1300px) {
	#history01 {padding-bottom: 300px;}
	#history02 {padding-top: 300px;}
}
@media screen and (max-width: 896px) {
	#history01 .mainImg,#history01 .txtArea,#history02 .mainImg,#history02 .txtArea {width: 100%; padding-left: 0;}
	#history01 .txtArea,#history02 .mainImg {margin-bottom: 20px;}
	#history01 .mainImg {height: 450px;}
	#history01 .subImg,#history02 .subImg {display: none;}
	#history01 {padding-bottom: 0;}
	#history02 {padding-top: 0; margin-top: 0;}
	#history02 .mainImg {background: #222;}
	#history02 .mainImg img {position: relative; left: 50%; transform: translateX(-50%);}
}

#shopList01 {border-bottom: 1px solid #CCC;}
.areaLink li a,#contact .areaLink li {display: block; width: 100%; padding: 10px 32px 12px 0; background: #FFF url("../img/cmn/arrow_bk.svg") no-repeat center right 10px; position: relative;}
.areaLink li a:hover {color: #FFF; padding: 10px 32px 12px 10px; background: #222 url("../img/cmn/arrow_wh.svg") no-repeat center right 5px;}
.areaLink li a::before,.areaLink li a::after,#contact .areaLink li::before,#contact .areaLink li::after {position: absolute; content: ''; background: #222; border-radius: 1px;}
.areaLink li a::before,#contact .areaLink li::before {width: 100%; height: 2px; bottom: 0; left: 0;}
.areaLink li a::after,#contact .areaLink li::after {width: 2px; height: 100%; top: 0; right: 0;}
#shopList01 .areaLink {width: 560px;}
#shopList01 .areaLink li {width: calc(50% - 40px); margin: 0 40px 20px 0;}
#shopList02 .areaLink {width: 200px; position: sticky; top: 0;}
#shopList02 .areaLink li {margin: 0 0 20px;}
.shopList {width: calc(100% - 280px);}
.shopList dt {position: sticky; top: 0; width: 160px;}
.shopList dd {width: calc(100% - 160px); padding-left: 40px; position: relative;}
.shopList dd::before {position: absolute; content: ''; width: 4px; height: 100%; border-radius: 2px; background: #1B3679; left: 0; top: 0;}
.shopList dd li:not(:last-child) {padding-bottom: 15px; border-bottom: 1px solid #CCC; margin-bottom: 15px;}
.shopList dd li h3 {margin-bottom: 5px;}
.shopList dd li h3 .new {margin-left: 20px;}
.shopList dd li .address {width: calc(100% - 140px);}
.shopList dd li .tel {width: 140px; padding-left: 30px; background: url("../img/shop/02-01.svg") no-repeat left center;}
#clickMap img {max-width: 100%; width: auto;}
@media screen and (max-width: 1024px) {
	#shopList02 .areaLink {width: 100%; position: relative; display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 20px;}
	#shopList02 .areaLink li {width: calc(100%/3 - 20px); margin: 0 0 15px;}
	.shopList {width: 100%;}
}
@media screen and (max-width: 896px) {
	#shopList01 .areaLink {width: 67%;}
	#shopList01 .areaLink li {width: calc(50% - 20px); margin: 0 20px 20px 0;}
}
@media screen and (max-width: 568px) {
	#shopList01 .areaLink {display: none;}
	#shopList02 .areaLink li {width: calc(50% - 10px); margin: 0 0 15px;}
	.shopList dt {position: relative; top: 0; width: 100%; margin-bottom: 10px;}
	.shopList dd {width: 100%; padding-left: 0; padding-top: 20px;}
	.shopList dd::before {width: 100%; height: 4px;}
	.shopList dd li .address {width: 100%;}
	.shopList dd li .tel {margin-left: auto;}
}

#faq .areaLink.sideNav {width: 300px; position: sticky; top: 0;}
#faq .areaLink.sideNav li {margin: 0 0 20px;}
.sideContents {width: calc(100% - 380px);}
#faq dl {border: 1px solid #999; border-radius: 10px;}
#faq dt {width: 135px; padding: 20px 20px 20px 30px;}
#faq dd {width: calc(100% - 135px); padding: 20px 30px 20px 20px; position: relative;}
#faq dd::before {position: absolute; content: ''; height: calc(100% - 40px); width: 1px; background: #999; top: 20px; left: 0;}
#faq dt:last-of-type,#faq dd:last-child {background: #FBEEEF;}
@media screen and (max-width: 896px) {
	#faq .areaLink.sideNav {width: 100%; position: relative; display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 20px;}
	#faq .areaLink.sideNav li {width: calc(50% - 20px); margin: 0 0 15px;}
	.sideContents {width: 100%;}
}
@media screen and (max-width: 568px) {
	#faq dt {width: 100%; padding: 15px 20px 10px 20px;}
	#faq dd {width: 100%; padding: 0 20px 20px 20px; position: relative;}
	#faq dd::before {content: none;}
}

#company .txtArea {width: calc(100% - 404px); padding-right: 40px;}
#company .mainImg {width: 404px; position: sticky; top: 0;}
#company dt,#company dd {padding: 20px 0;}
#company dt {width: 160px; border-bottom: 1px solid #1B3679;}
#company dd {width: calc(100% - 160px); border-bottom: 1px solid #CCC;}
@media screen and (max-width: 1040px) {
	#company .txtArea {width: calc(100% - 300px);}
	#company .mainImg {width: 300px;}
}
@media screen and (max-width: 930px) {
	#company .txtArea {width: 100%; margin-bottom: 40px; padding-right: 0;}
	#company .mainImg {width: 100%; position: relative; max-width: 400px; margin: 0 auto;}
}
@media screen and (max-width: 568px) {
	#company dt {width: 100%; border-bottom: 1px solid #CCC; padding: 20px 0 10px;}
	#company dd {width: 100%; border-bottom: 1px solid #1B3679; padding: 10px 0 20px;}
}

#contact .areaLink.sideNav {width: 260px; position: sticky; top: 0;}
#contact .areaLink.sideNav li {margin: 0 0 20px;}
#contact .sideContents {width: calc(100% - 340px);}
#contact .areaLink li {padding: 10px 32px 12px 20px;}
#contact .areaLink li.active {background-color: #EEE;}
.contactBox {border: 1px solid #CCC; border-radius: 10px;}
@media screen and (max-width: 1024px) {
	#contact .areaLink.sideNav {width: 100%; position: relative; display: flex; flex-wrap: wrap; justify-content: space-between;}
	#contact .sideContents {width: 100%;}
	#contact .areaLink li {width: calc(100%/3 - 20px);}
}

#news .ttlBdr {margin-bottom: 30px;}
.post p:not(:last-child) {margin-bottom: 20px;}
.postNav {padding: 30px 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_bk_back.svg") no-repeat left center;}
.postNav .next a {padding-right: 20px; background: url("../img/cmn/arrow_bk.svg") no-repeat right center;}





/* シューズ詳細 */
.eb-garamond {
	display: flex;
	align-items: center;	/* 中央揃え */
	/* align-items: flex-start; 上揃え */ 
}
.jp_new_list_mobile {
	display:none;
}



/* 以下、スマホ用 */
@media screen and (max-width: 896px) {
    .kvImg {
        margin-top: -20px;
    }
	.eb-garamond {
		display: block;
	}
	.jp_new_detail::after {
		content: "\A";   /* 改行コード */
		white-space: pre; /* 改行を有効にする */
	}
	.jp_prodicon { height:40px; }
	.jp_prodname { height:48px; }
	.jp_new_list_mobile{
		display:inline;
		position: absolute;
	}
	.jp_new_list_pc{
		display:none;
	}

	#shoes01 ul.col6 {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start; /* ← 中央寄せをやめて左寄せ */
	}
	#shoes01 ul.col6 li {
		flex: 0 0 50%; /* デフォルトは2列 */
		max-width: 50%;
		text-align: center;
		margin:0px;
	}
	/* 2行目（3,4,5番目）は3列 */
	#shoes01 ul.col6 li:nth-child(3),
	#shoes01 ul.col6 li:nth-child(4),
	#shoes01 ul.col6 li:nth-child(5) {
		flex: 0 0 33.33%;
		max-width: 33.33%;
	}
	/* 3行目（6,7番目）も3列扱いだが、要素が2つしかないので左詰めになる */
	#shoes01 ul.col6 li:nth-child(6),
	#shoes01 ul.col6 li:nth-child(7) {
		flex: 0 0 33.33%;
		max-width: 33.33%;
	}

	#shoesDetail01 .itemImg .icon .icon03 {
        width: 60px;
        margin-left: 0px;
    }
	#goToPageTop {
		margin-bottom:45px;
	}
	.sp90 {
		font-size:90%;
	}
}

