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

/*------------------------------
  MV
-------------------------------*/
.mainWrap #titleSec { background: url("/works/images/pages_title_bg.png") no-repeat center top / cover; }
.mainWrap #titleSec.designMv { background-image: url("/works/design/images/design_title_bg_pc.png"); background-size: 100%; }
.mainWrap #titleSec.designMv #pageTitle { color: #000; }

.mainWrap #titleSec.designIndexMv { height: auto; }
.mainWrap #titleSec.designIndexMv > div { width: 1240px; margin: 0 auto; position: relative; left: auto; bottom: auto; }
.mainWrap #titleSec.designIndexMv > div #mvTxt { position: absolute; right: 0; bottom: 80px; width: 500px; color: #000; }
.mainWrap #titleSec.designIndexMv > div #mvTxt p { margin-top: 20px; }

/*------------------------------
  共通
-------------------------------*/
.importantTitle { text-align: left; font-size: 253%; font-weight: normal; }
.importantTitle > span { font-size: 53%; font-weight: bold; margin-bottom: 0; }

#indexSlider { display: none; }
#indexSlider.slick-initialized { display: block; }

/* 扉ページリスト */
.indexItem { width: 100%; margin: 0; }
.indexItem a { display: block; position: relative; }
.indexItem a .worksImgListImg img { width: 100%; height: 640px; object-fit: cover; width: 100%; }
.indexItem a .worksImgListTxt { position: absolute; right: 0; bottom: 0; background-color: rgba(255, 255, 255, 0.7); width: 520px; padding: 20px 35px; border-radius: 15px 0 0 0; margin-top: 0; }
.indexItem a .worksImgListTxt dl dt { font-size: 160%; }
.indexItem a .worksImgListTxt dl dd { margin-top: 10px; }

/* カテゴリトップリスト */
ul.worksImgList { display: flex; flex-wrap: wrap; }
ul.worksImgList li a { display: block; }
ul.worksImgList li a .worksImgListImg { display: flex; justify-content: center; align-items: center; height: 308px; background-color: #edf5f8; }
ul.worksImgList li a .worksImgListImg img { max-width: 100%; max-height: 100%; }
ul.worksImgList li a .worksImgListTxt { margin-top: 12px; }
ul.worksImgList li a .worksImgListTxt dl dt { font-weight: normal; font-size: 133%; }
ul.worksImgList li a .worksImgListTxt dl dd { margin-top: 10px; }
ul.worksImgList li a .worksImgListTxt dl dd ul { display: flex; margin-top: 15px; }
ul.worksImgList li a .worksImgListTxt dl dd ul li { width: auto; font-size: 80%; margin-right: 10px; padding: 4px 10px; background-color: #eff5f7; border: solid 1px #cddbe0; border-radius: 5px; color: #32485b; }

/* ボタン */
.txtBlueBtn { margin-top: 45px; font-size: 126%; text-align: center; }
.txtBlueBtn a { display: inline-block; border-radius: 30px; padding: 10px 45px; }

/* ページネーション */
.pagenationBox { display: flex; align-items: center; justify-content: center; margin-top: 45px; }
.pagenationBox a { display: block; width: 50px; height: 50px; border-radius: 5px; background-color: #fff; text-align: center; padding: 10px 0; border: solid 1px #e5e5e5; margin: 0 5px; font-size: 120%; }
.pagenationBox a:hover,
.pagenationBox a.jp-current { background-color: #eef5f8; border: solid 1px #eef5f8; }
.pagenationBox a.jp-disabled { display: none; }

.pagenationBox a.jp-previous,
.pagenationBox a.jp-next { width: 45px; }
.pagenationBox a.jp-previous,
.pagenationBox a.jp-next { position: relative; border: none; }
.pagenationBox a.jp-previous:hover,
.pagenationBox a.jp-next:hover { background-color: #fff; opacity: 0.7; }
.pagenationBox a.jp-previous::before,
.pagenationBox a.jp-next::before { content: ""; position: absolute; top: calc(50% - 7px); left: calc(50% - 7px); width: 13px; height: 13px; border-top: 2px solid #018dd6; border-right: 2px solid #018dd6; transform: rotate(45deg); }
.pagenationBox a.jp-previous::before { transform: rotate(225deg); }
.pagenationBox > span { font-size: 126%; margin: 0 12px; }

#resultNone { display: none; }

/* MT用 */
.breadcrumbNavi ul li br,
#designDetail #detailArea.designDetailArea #detailInfoInner ul li.constructionSubject br { display: none; }

/*------------------------------
  index
-------------------------------*/
.singleColumn { width: 100%; }
.singleColumn .mainContents { padding: 0; }

/* 最近の実績 */
#indexArea .importantTitle { font-weight: bold; }
#indexArea { padding: 0; }
#indexArea #recentInner { margin-top: 30px; }

#indexArea #recentInner #indexSlider { margin-top: 35px; }
#indexArea #recentInner #indexSlider .slick-list { border-radius: 15px; overflow: hidden; background-color: #edf5f8; height: 640px; }
#indexArea #recentInner #indexSlider #slick-prev { left: 42px; transform: translateY(-50%) rotate(180deg); }
#indexArea #recentInner #indexSlider #slick-next { right: 42px; }
#indexArea #recentInner #indexSlider .slick-arrow img { width: 60px; }

#indexArea #recentInner #indexSlider .slick-dots { margin-top: 25px; }
#indexArea #recentInner #indexSlider .slick-dots li { margin: 0 5px; }
#indexArea #recentInner #indexSlider .slick-dots li span { width: 102px; height: 8px; border-radius: 10px; background-color: #d1e0e6; }
#indexArea #recentInner #indexSlider .slick-dots li.slick-active span { background-color: #008ed8; }

/* カテゴリーリスト */
#indexArea #recentInner #cateList { margin-top: 80px; }
#indexArea #recentInner #cateList li { width: 400px; }
#indexArea #recentInner #cateList li a > img { border: solid 1px #e3e8ea; border-radius: 15px; overflow: hidden; }
#indexArea #recentInner #cateList li .arrowLink { margin-top: 28px; font-size: 125%; display: flex; align-items: center; }
#indexArea #recentInner #cateList li .arrowLink span { display: block; }
#indexArea #recentInner #cateList li .arrowLink img { width: 55px; margin-left: 21px; }

/* 実績検索 */
#indexArea #searchInner { margin-top: 70px; background-color: #edf5f8; padding: 65px 0 85px; }
#indexArea #searchInner .enTitle { text-align: left; }
#indexArea #searchInner .enTitle span { font-size: 64%; margin-bottom: 3px; }
#indexArea #searchInner .bgWhite { margin-top: 60px; padding: 55px 38px 50px; }
#indexArea #searchInner .enTitle + .bgWhite { margin-top: 35px; padding-top: 40px; padding-bottom: 40px; }
#indexArea #searchInner .bgWhite ul.searchLink { display: flex; flex-wrap: wrap; }
#indexArea #searchInner .bgWhite ul.searchLink li { width: 370px; border-radius: 10px; border: solid 1px #e3e8ea; font-size: 120%; margin-left: 25px; }
#indexArea #searchInner .bgWhite ul.searchLink li:nth-child(3n+1) { margin-left: 0; }
#indexArea #searchInner .bgWhite ul.searchLink li:nth-child(n+4) { margin-top: 25px; }
#indexArea #searchInner .bgWhite ul.searchLink li a { display: block; padding: 20px 25px; }
#indexArea #searchInner .bgWhite ul.searchLink li a span { display: block; padding-right: 20px; background: url("/common/images/bg_arrow_blue.png") no-repeat right center; }

#indexArea #searchInner .bgWhite ul#jumpList li a span { background: none; position: relative; }
#indexArea #searchInner .bgWhite ul#jumpList li a span::after { background: none; content: ""; width: 12px; height: 12px; border-right: solid 2px #018dd6; border-bottom: solid 2px #018dd6; transform: rotate(45deg) translateY(-50%); position: absolute; right: 9px; top: calc(50% - 3px); }

#indexArea #searchInner .bgWhite .enTitle { text-align: center; }
#indexArea #searchInner .bgWhite h4 + h5 { margin-top: 20px; }
#indexArea #searchInner .bgWhite h5 { margin-top: 45px; display: flex; align-items: center; font-size: 153%; }
#indexArea #searchInner .bgWhite h5 span { margin-left: 15px; }
#indexArea #searchInner .bgWhite h5 + ul.searchLink { margin-top: 30px; }
#indexArea #searchInner .bgWhite h4 + ul.searchLink { margin-top: 45px; }
#indexArea #searchInner .bgWhite ul.searchLink + ul.searchLink { margin-top: 25px; }

/*------------------------------
  list.html
-------------------------------*/
#cateTopArea { padding-bottom: 100px; }
#cateTopArea .contentsOuter { width: 1300px; }
#cateTopArea .importantTitle { margin: 0 10px; }
#cateTopArea .importantTitle .cateName { color: #0a273f; font-size: 100%; font-weight: normal; padding-right: 10px; display: none; }
#cateTopArea #searchNumInner { display: flex; align-items: baseline; margin: 160px 10px 0; }
#cateTopArea #searchNumInner #searchNum { font-size: 120%; }
#cateTopArea #searchNumInner #searchNum span { font-size: 278%; }
#cateTopArea #searchNumInner p#overTxt { margin-left: 20px; display: none; }

/* 各カテゴリ別 */
.searchContents,
.engineeringContents,
.architectureContents,
.areaContents,
.themeContents { display: none; }

.listEngineering .engineeringContents,
.listArchitecture .architectureContents,
.listArea .areaContents,
.listTheme .themeContents,
#designList .searchContents { display: block; }

#designList #cateTopArea .importantTitle .cateName { margin-left: 0 !important; }

.listEngineering #searchInner #conditionsArea #conditionsSearch ul li > div .engineeringContents,
.listArchitecture #searchInner #conditionsArea #conditionsSearch ul li > div .architectureContents { display: inline-block; }

.listEngineering #case_all,
.listArchitecture #case_all,
.listEngineering .architectureOption,
.listArchitecture .engineeringOption { display: none; }

#cateTopArea #searchInner { margin: 40px 10px 0; position: relative; }
#cateTopArea #searchInner #conditionsArea { position: absolute; top: 0; width: 1240px; }
#cateTopArea #searchInner #conditionsArea.posFixed { position: fixed; top: 20px; z-index: 10; }
#cateTopArea #searchInner #conditionsArea #conditionsChange { border-radius: 15px; border: solid 1px #0c283f; padding: 35px; font-size: 133%; text-align: center; position: relative; cursor: pointer; background-color: #fff; }
#cateTopArea #searchInner #conditionsArea #conditionsChange::before,
#cateTopArea #searchInner #conditionsArea #conditionsChange::after { content: ""; position: absolute; right: 35px; top: 50%; width: 33px; height: 1px; background-color: #0c283f; }
#cateTopArea #searchInner #conditionsArea #conditionsChange::after { transform: rotate(90deg); }
#cateTopArea #searchInner #conditionsArea #conditionsChange:hover { opacity: 0.7; }
#cateTopArea #searchInner #conditionsArea #conditionsChange.open { border-radius: 15px 15px 0 0; border-bottom: none; }
#cateTopArea #searchInner #conditionsArea #conditionsChange.open:hover { opacity: 1; }
#cateTopArea #searchInner #conditionsArea #conditionsChange.open::after { display: none; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch { display: none; background-color: #eef5f8; border-radius: 0 0 15px 15px; padding: 40px 60px 55px; position: relative; z-index: 10; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch h4 { color: #0090db; font-size: 173%; text-align: center; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul { display: flex; justify-content: space-between; flex-wrap: wrap; margin-top: 30px; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li { width: 540px; font-size: 133%; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li:nth-child(n+3) { margin-top: 20px; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li .selectBg { font-size: 90%; width: 100%; background-color: #fff; border-radius: 8px; margin-top: 25px; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li .selectBg select { padding: 11px 30px; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li .selectBg::before { display: none; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch ul li .selectBg::after { width: 12px; height: 12px; border: none; border-right: solid 2px #018dd6; border-bottom: solid 2px #018dd6; transform: rotate(45deg) translateY(-50%); position: absolute; right: 35px; top: calc(50% - 3px); }

#cateTopArea #searchInner #conditionsArea #conditionsSearch #conditionsSearchBtn { margin: 45px auto 0; width: 240px; border-radius: 30px; background-color: #fff; color: #008ed8; padding: 10px 0; text-align: center; font-size: 126%; cursor: pointer; transition-duration: 0.7s; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch #conditionsSearchBtn span { display: inline-block; position: relative; padding-left: 30px; background: url("/common/images/icon_search.png") no-repeat left center / 20px; }
#cateTopArea #searchInner #conditionsArea #conditionsSearch #conditionsSearchBtn:hover { opacity: 0.7; }

#cateTopArea #resultInner { margin-top: 30px; }
#cateTopArea #resultInner ul.worksImgList { min-height: auto !important; }
#cateTopArea #resultInner ul.worksImgList li { width: 400px; margin: 0 10px 55px; }
#cateTopArea #resultInner ul.worksImgList li a .worksImgListTxt { margin-top: 20px; }
#cateTopArea #resultInner ul.worksImgList li a .worksImgListTxt dl dt { font-size: 146%; }
#cateTopArea #resultInner ul.worksImgList li a .worksImgListTxt dl dd ul li { width: auto; margin-left: 0; margin-right: 10px; }
#cateTopArea #resultInner ul.worksImgList li a .worksImgListTxt dl dd ul li:nth-child(n+2),
#cateTopArea #resultInner ul.worksImgList li a .worksImgListTxt dl dd ul li:nth-child(n+4) { margin-top: 0; }

/*------------------------------
  詳細ページ共通
-------------------------------*/
#detailArea .importantTitle .categoryBasename { text-transform: uppercase; font-size: 100%; display: inline; margin-bottom: 0; }

#detailArea { padding: 0 0 100px; }
#detailArea #detailTitleInner { background-color: #0177b5; color: #fff; padding: 38px 0; margin-top: 35px; }
#detailArea #detailTitleInner h4 { font-size: 253%; text-align: center; }
#detailArea #detailTitleInner h4 + div { margin-top: 20px; display: flex; justify-content: center; align-items: center; }
#detailArea #detailTitleInner h4 + div div { font-size: 133%; }
#detailArea #detailTitleInner h4 + div ul { display: flex; align-items: center; margin-left: 20px; }
#detailArea #detailTitleInner h4 + div ul li { margin-left: 10px; border: solid 1px #fff; border-radius: 5px; background-color: #008ed8; padding: 3px 10px; }
#detailArea #detailTitleInner h4 + div ul li:first-child { margin-left: 0; }

#detailArea #detailImgInner #sliderMainOuter { height: 500px; overflow: hidden; }
#detailArea #detailImgInner #sliderMain { width: 650px; margin: 0 auto; }
#detailArea #detailImgInner #sliderMain .slick-slide,
#detailArea #detailImgInner #sliderMain .slick-slide div,
#detailArea #detailImgInner #sliderMain .slick-slide div div { height: 500px; }
#detailArea #detailImgInner #sliderMain .slick-slide div div { display: flex !important; align-items: center; justify-content: center; }
#detailArea #detailImgInner #sliderMain .slick-slide div div img { max-width: 100%; max-height: 100%; }
#detailArea #detailImgInner #sliderMain .slick-arrow { width: 60px; border: solid 1px #ccc; border-radius: 50%; }
#detailArea #detailImgInner #sliderMain #slick-prev { left: -100px; transform: translateY(-50%) rotate(180deg); }
#detailArea #detailImgInner #sliderMain #slick-next { right: -100px; }

#detailArea #detailImgInner #sliderThumbs { margin: 20px auto 0; width: 906px; display: flex; justify-content: center; }
#detailArea #detailImgInner #sliderThumbs > div { display: flex; align-items: center; justify-content: center; width: 200px; height: 154px; overflow: hidden; margin: 0 13px; text-align: center; background-color: #edf5f8; }
#detailArea #detailImgInner #sliderThumbs > div:hover { cursor: pointer; opacity: 0.7; transition: all 1s; }
#detailArea #detailImgInner #sliderThumbs > div img { max-width: 100%; max-height: 100%; }

#detailArea #detailTxtInner { width: 1000px; margin: 60px auto 0; }

#detailArea #detailInfoInner { margin-top: 80px; }
#detailArea #detailInfoInner ul { border: solid 1px #e3e8ea; border-radius: 15px; padding: 45px 60px; display: flex; flex-wrap: wrap; position: relative; }
#detailArea #detailInfoInner ul li { display: flex; font-size: 106%; line-height: 1.8; padding-bottom: 12px; width: 50%; }
#detailArea #detailInfoInner ul li:nth-child(2n) { padding-left: 50px; }
#detailArea #detailInfoInner ul li:nth-child(2n+1) { padding-right: 50px; position: relative; }
#detailArea #detailInfoInner ul li:nth-child(2n+1)::before { content: ''; position: absolute; top: 0; right: 0; width: 1px; height: calc(100%); background-color: #e3e8ea; }
#detailArea #detailInfoInner ul li.listNote { width: 100%; padding: 0; margin-top: 12px; }
#detailArea #detailInfoInner ul li.listNote::before { display: none; }

#detailArea #detailInfoInner ul li span:first-child { color: #008ed8; width: 130px; }
#detailArea #detailInfoInner ul li span + span { flex: 1; word-break: break-all; }
#detailArea #detailInfoInner ul li sup { top: -0.5em; }

/* ジャンプページ用 */
#jumpPageArea { padding: 100px 0; }


/*------------------------------
  建築設計作品集
-------------------------------*/
/* 扉ページ */
#designIndex { position: relative; }
#designIndex #designMv img { width: 100%; }
#designIndex #indexArea #designMvTxt { position: absolute; top: 21.5vw; right: 5.5vw; }
#designIndex #indexArea #designMvTxt h2 { font-size: 2.3vw; }
#designIndex #indexArea #designMvTxt p { font-size: 1.06vw; line-height: 3vw; margin-top: 2vw; }
#designIndex .breadcrumbNavi { position: absolute; top: 46.3vw; left: 0; right: 0; }

@media screen and (max-width: 1400px) {
	#designIndex #indexArea #designMvTxt { top: 305px; right: 80px; }
	#designIndex #indexArea #designMvTxt h2 { font-size: 213%; }
	#designIndex #indexArea #designMvTxt p { font-size: 100%; line-height: 2.9; margin-top: 28px; }
	#designIndex .breadcrumbNavi { top: 655px; }
}

#indexArea #pickup01Inner .indexItem { background-color: #edf5f8; height: 640px; border-radius: 15px; overflow: hidden; }
#indexArea #pickup01Inner ul li:nth-child(n+2) { display: none; }

#indexArea #pickup02Inner { margin-top: 80px; }
#indexArea #pickup02Inner ul { display: flex; flex-wrap: wrap; }
#indexArea #pickup02Inner ul li { width: 400px; overflow: hidden; border-radius: 15px; margin-left: 20px; }
#indexArea #pickup02Inner ul li:nth-child(n+4) { margin-top: 20px; }
#indexArea #pickup02Inner ul li:nth-child(3n+1) { margin-left: 0; }
#indexArea #pickup02Inner ul a { display: block; position: relative; }
#indexArea #pickup02Inner ul a .pickup02Img { display: flex; justify-content: center; align-items: flex-end; height: 308px; }
/*#indexArea #pickup02Inner ul a .pickup02Img img { object-fit: cover; max-width: 100%; height: 100%; object-position: 50% 100%; }*/
#indexArea #pickup02Inner ul a .pickup02Img img { object-fit: cover; width: 100%; max-width: 100%; height: 100%; object-position: 50% 50%; }
#indexArea #pickup02Inner ul a .pickup02Info { display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color:rgba(0, 0, 0, 0.5); justify-content: center; align-items: center; }
#indexArea #pickup02Inner ul a .pickup02Info dl { color: #fff; width: 90%; margin: 0 auto; }
#indexArea #pickup02Inner ul a .pickup02Info dl dt { font-size: 160%; text-align: center; }
#indexArea #pickup02Inner ul a .pickup02Info dl dd { margin-top: 10px; text-align: center; }
#indexArea #pickup02Inner ul a:hover .pickup02Info { display: flex; opacity: 1; }
#indexArea #pickup02Inner ul a:hover .pickup02Img img { transform: scale(1.2); }

/* 詳細ページ */
.mainWrap #titleSec.designMv .titleColor01 { color: #9ab1d3; }
.mainWrap #titleSec.designMv .titleColor02 { color: #adc3ce; }
.mainWrap #titleSec.designMv .titleColor03 { color: #89bae2; }

#designDetail #detailArea .importantTitle .categoryBasename { font-size: 53%; display: block; }

#designDetail #detailArea.designDetailArea #detailTitleInner { background-color: transparent; color: #000; border-top: solid 1px #e3e8ea; padding-top: 55px; }
#designDetail #detailArea.designDetailArea #detailTitleInner h4 + div ul li { color: #fff; }
#designDetail #detailArea.designDetailArea #detailImgInner #sliderMainOuter { background-color: transparent; }
#designDetail #detailArea.designDetailArea #detailImgInner #sliderMain .slick-arrow { border: solid 1px #ccc; border-radius: 50%; }


#bnSec #bnSlider .slick-slide { height: auto; }







