@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+Antique:wght@400;500;700&family=Zen+Old+Mincho:wght@700&display=swap');

/*------------------------------------------------------

	リセット

------------------------------------------------------*/

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	font-style: normal;
	font-weight: 400;
	vertical-align: baseline;
	background: transparent;
}
body { line-height: 1;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block;}
ul { list-style: none;}
blockquote, q { quotes: none;}
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none;}
a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
table { border-collapse: collapse; border-spacing: 0;}
hr {
	display: block;
	height: 0px;
	border: 0;
	border-bottom: 1px solid #cbcbcb;
	margin: 0;
	padding: 0;
}
input, select { vertical-align: middle;}
img {
	max-width: 100%;
	height: auto;
	border: none;
	vertical-align: bottom;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}
*, *:before, *:after { box-sizing: border-box;}


/*------------------------------------------------------

	グローバル

------------------------------------------------------*/

body {
	font-family: "Zen Kaku Gothic Antique", sans-serif;
 	color: #000;
	font-size: 1em;
  letter-spacing: 0.05em;
	line-height: 1.8;
	position: relative;
  background-image: image-set(url("../images/common/bg01.webp") 1x, url("../images/common/bg01@2x.webp") 2x);
  background-size: 526px auto;
}

.bold, .bold * { font-weight: 700;}
.medium, .medium * { font-weight: 500;}

.fo_mincho { font-family: "Zen Old Mincho", serif; font-weight: 700;}

p { margin-bottom: 30px;}
p:last-child { margin-bottom: 0px;}

a { color: #000; text-decoration: none;}
a:hover { color: #ab7b39;}

/* 文字装飾 */
.fo06 { font-size: 0.6em !important;}
.fo07 { font-size: 0.7em !important;}
.fo075 { font-size: 0.75em !important;}
.fo08 { font-size: 0.8em !important;}
.fo085 { font-size: 0.85em !important;}
.fo09 { font-size: 0.9em !important;}
.fo095 { font-size: 0.95em !important;}
.fo105 { font-size: 1.05em !important;}
.fo11 { font-size: 1.1em !important;}
.fo115 { font-size: 1.15em !important;}
.fo12 { font-size: 1.2em !important;}
.fo125 { font-size: 1.25em !important;}
.fo13 { font-size: 1.3em !important;}
.fo14 { font-size: 1.4em !important;}
.fo15 { font-size: 1.5em !important;}
.fo16 { font-size: 1.6em !important;}
.fo17 { font-size: 1.7em !important;}
.fo18 { font-size: 1.8em !important;}
.fo19 { font-size: 1.9em !important;}
.fo20 { font-size: 2em !important;}

.lh12 { line-height: 1.2;}
.lh14 { line-height: 1.4;}
.lh16 { line-height: 1.6;}
.lh18 { line-height: 1.8;}
.lh20 { line-height: 2;}

.fo_white { color: #FFFFFF !important;}
.fo_brown { color: #ab7b39 !important;}
.fo_gray { color: #b3b3b3 !important;}

.ls005 { letter-spacing: 0.05em;}
.ls01 { letter-spacing: 0.1em;}
.ls02 { letter-spacing: 0.2em;}

.break_keep { word-break: keep-all;}

/* ボックス */
.cont910 { max-width: 940px; padding: 0px 15px; margin: auto;}
.cont1000 { max-width: 1030px; padding: 0px 15px; margin: auto;}
.cont1100 { max-width: 1130px; padding: 0px 15px; margin: auto;}
.cont1200 { max-width: 1230px; padding: 0px 15px; margin: auto;}

.z50 { z-index: 50;}
.z-1 { z-index: -1;}

.left { float: left;}
.right { float: right;}

.pos_rel { position: relative;}
.pos_ab { position: absolute;}

.ta_center { text-align: center;}
.ta_right { text-align: right;}
.ta_left { text-align: left;}
.ta_right-s_center { text-align: right;}
.ta_left-s_center { text-align: left;}
.ta_center-s_left { text-align: center;}
.ta_center-s_right { text-align: center;}

.back_white { background-color: #fff !important;}

.back_image01 { background-image: image-set(url("../images/common/bg01.webp") 1x, url("../images/common/bg01@2x.webp") 2x);   background-size: 525px auto;}
.back_image02 { background-image: image-set(url("../images/common/bg02.webp") 1x, url("../images/common/bg02@2x.webp") 2x);   background-size: 525px auto;}

@media print,  (min-width: 769px) {
	.hidden_l { display: none !important;}
}

/* リスト */
ol { padding-left: 2em;}
ol li { list-style: outside decimal;}

.list_disc { padding-left: 1em;}
.list_disc li { list-style: outside disc;}

.list_indent { padding-left: 1em;}
.list_indent li { text-indent: -1em;}

/* margin */
.mb00 { margin-bottom: 0px !important;}
.mb05 { margin-bottom: 5px !important;}
.mb10 { margin-bottom: 10px !important;}
.mb15 { margin-bottom: 15px !important;}
.mb20 { margin-bottom: 20px !important;}
.mb25 { margin-bottom: 25px !important;}
.mb30 { margin-bottom: 30px !important;}
.mb40 { margin-bottom: 40px !important;}
.mb50 { margin-bottom: 50px !important;}
.mb60 { margin-bottom: 60px !important;}
.mb80 { margin-bottom: 80px !important;}

.mb40-20 { margin-bottom: 40px !important;}
.mb50-30 { margin-bottom: 50px !important;}
.mb60-30 { margin-bottom: 60px !important;}
.mb80-40 { margin-bottom: 80px !important;}
.mb100-60 { margin-bottom: 100px !important;}
.mb120-60 { margin-bottom: 120px !important;}
.mb120-80 { margin-bottom: 120px !important;}
.mb160-80 { margin-bottom: 160px !important;}

.mt05 { margin-top: 5px !important;}
.mt10 { margin-top: 10px !important;}
.mt15 { margin-top: 15px !important;}
.mt20 { margin-top: 20px !important;}
.mt30 { margin-top: 30px !important;}
.mt40 { margin-top: 40px !important;}
.mt50 { margin-top: 50px !important;}
.mt60 { margin-top: 60px !important;}
.mt70 { margin-top: 70px !important;}
.mt80 { margin-top: 80px !important;}

.mt120-60 { margin-top: 120px !important;}

/* clearFix */
.clearFix { zoom: 100%;}
.clearFix:after {
	content: "";
	clear: both;
	height: 0;
	display: block;
	visibility: hidden;
}

/* ------------------------
	ヘッダー
------------------------ */

.header h1 { position: fixed; left: 0px; top: 0px; z-index: 999; padding: 2em;}

.overlay-bg {
  position: fixed;
  inset: 0;
  background: rgba(87, 77, 56, 0.2);
  z-index: 9998;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
body.no-scroll .overlay-bg { opacity: 1; pointer-events: auto;}


/* ------------------------
	グローバルナビ
------------------------ */

/* ハンバーガーメニュー */
.humberger {
	cursor: pointer;
	display: block;
	position: fixed;
	top: 2%;
	right: 2%;
	width: 63px;
	height: 67px;
  background: url("../images/common/hum01.svg") no-repeat center calc(100% - 1.4em);
  background-size: 100% auto;
	z-index: 10001;
}
.humberger.black, .humberger.scroll { background-image: url("../images/common/hum01_black.svg");}
.humberger:after {
	color: #fff;
	content: 'MENU';
	display: block;
	font-size: 1em;
  line-height: 1;
  letter-spacing: 0.35em;
  font-weight: bold;
	text-decoration: none;
	text-align: center;
	position: absolute;
  transform: translateX(-50%);
	left: 50%;
	bottom: 0px;
	width: 100%;
}
.humberger.black:after, .humberger.scroll:after { color: #000;}
.is-open .humberger { background: url("../images/common/hum03.svg") no-repeat center calc(100% - 1.4em); background-size: 65% auto;}
.is-open .humberger.black, .is-open .humberger.scroll { background-image: url("../images/common/hum03_black.svg");}
.is-open .humberger:after { content: 'CLOSE'; color: #fff; letter-spacing: 0.2em;}
.is-open .humberger.black:after, .is-open .humberger.scroll:after { color: #000;}
.humberger img { vertical-align: top; width: 37%; margin-left: -40%; transition: 0.4s; opacity: 1;}
@media (hover: hover) {
  .humberger:hover img { opacity: 0; transform: translateY(0.6em);}
}
.is-open .humberger img { opacity: 0; transform: none;}

/* ナビ本体 */
.sp-navi { -webkit-text-size-adjust: 100%;}
.sp-navi.is-open .sp-navi-inner {
	opacity: 1;
	visibility: visible;
	z-index: 10000;
	left: 0px;
  transform: translateY(0);
}
.sp-navi .sp-navi-inner {
	overflow-y: visible;
	opacity: 0;
	visibility: hidden;
	position: fixed;
	z-index: 10000;
	top: 0;
	height: 100%;
	width: 100%;
	transition: .8s;
  transform: translateY(100%);
  display: flex;
  flex-direction: column;
}

.sp-navi .bg01 { margin: -3% 0px -1px;}
.sp-navi .back_image02 { display: flex; justify-content: center; align-items: center; flex: 1;}
.sp-navi .box01 { display: flex; justify-content: center; align-items: center; column-gap: 3em;}
.sp-navi .box01 .logo_wrap { width: 25%;}
.sp-navi .footer_nav { width: 95%; column-gap: 3em; margin-top: 2em;}

.scroll-arrow {
  position: absolute;
  bottom: 2em;
  left: 4%;
  z-index: 10001;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  width: 6%;
  max-width: 35px;
}
.scroll-arrow.is-visible { opacity: 1;}

@media only screen and (min-width: 1201px) {
  .is-open .humberger { background-image: url("../images/common/hum03_black.svg");}
  .is-open .humberger:after { color: #000;}
}

@media only screen and (max-width: 1200px) {
  .sp-navi .sp-navi-inner { height: 85%; transform: translateY(85%); top: auto; bottom: 0px;}
  .sp-navi .back_image02 { overflow-y: scroll;}
  .sp-navi ul.show_sp { display: block; width: 10em;}
  .sp-navi ul.hide_sp { display: none;}
  .sp-navi .box01 { flex-flow: column; flex-wrap: wrap; padding: 30px 10px 5em; margin-top: 2%; font-size: min(2vw,1.2em);}
  .sp-navi .box01 .logo_wrap { width: 100%; display: flex; justify-content: space-between; align-items: center;; padding: 0px 0px 40px;}
  .sp-navi .box01 .logo02 { width: 45%;}
  .sp-navi .footer_nav { width: auto; font-size: 1em;}
  .sp-navi .footer_nav li { margin-bottom: 1.5em;}
}

/* bodyスクロール禁止 */
.no-scroll { overflow: hidden; height: 100%; position: fixed; width: 100%;}


/* ------------------------
	フッター
------------------------ */

.footer .bg01:before { content: ""; position: absolute; left: -5%; width: 110%; height: 75%; background-image: image-set(url("../images/common/footer_bg01.webp") 1x, url("../images/common/footer_bg01@2x.webp") 2x); background-repeat: no-repeat; background-position: center bottom; background-size: 100% 100%; top: calc(-75% + 1px);}
.footer .bg01 { background: #e2e1cd; padding: 20px 0px;}
.footer .bg01 .box01 { display: flex; justify-content: space-between;}

.footer_nav { display: flex; justify-content: space-between; column-gap: 5em; margin-top: 1em;}
.footer_nav li { margin-bottom: 0.8em; word-break: keep-all;}
.footer_nav a { color: #000; position: relative;}
.footer_nav a:after { content: ""; position: absolute; left: 0px; bottom: -0.3em; width: 0px; height: 3px; background: url("../images/common/footer_nav_line.svg") repeat-x left bottom; background-size: auto 3px; transition: 0.3s;}
.footer_nav a:hover:after { width: 100%;}

.footer .bg_img01 { left: -5%; bottom: 30%}
.footer .bg_img02 { right: -5%; bottom: 25%}

@media only screen and (max-width: 1200px) {
  .footer .bg01:before { height: 60%; top: calc(-60% + 1px);}
}

@media only screen and (max-width: 1100px) {
  .footer .logo_wrap { width: 18%;}
  .footer_nav { column-gap: 2.5em; font-size: min(1.6vw,1em);}
}

@media only screen and (min-width: 641px) and (max-width: 1129px) {
  .footer .bg01 .box01 { padding: 0px 10px;}
}


/*------------------------------------------------------

	トップページ

------------------------------------------------------*/

.slider { position: relative; aspect-ratio: 2 / 1;}
.slider li {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s ease;
}
.slider li img { width: 100%; height: 100% !important; object-fit: cover; display: block;}
.slider li.active { opacity: 1; z-index: 1;}

.slide_wrap .bg01 { width: 25%; left: 0px; bottom: -2%;}
.slide_wrap .bg02 { width: 26%; right: 0px; bottom: 7%;}
.slide_wrap .bg03 { bottom: -1px; left: 0px; width: 100%;}
.slide_wrap .bg img { width: 100%;}
.slide_wrap .text_box { left: 50%; top: 50%; transform: translate(-50%,-50%); font-size: min(2vw,1.2em);}
.slide_wrap .text01 { font-size: 3.3em; line-height: 1.3; margin-bottom: 0.3em;}
.slide_wrap .text01 span { margin-left: 0.7em;}

.top_sec01 h2 { background: url("../images/common/line01.svg") no-repeat center bottom; background-size: 12em auto; padding-bottom: 0.6em;}
.top_sec01 .bg01 { left: -1%; top: -1%;}
.top_sec01 .bg02 { left: -4%; top: 22%;}
.top_sec01 .bg03 { right: 0; top: 0;}
.top_sec01 .bg04 { right: -5%; top: 22%;}
.top_sec01 .more_btn { margin: -12% 8% 0px 0px;}

.top_sec02 .bg_box { max-width: 1050px; margin: auto; padding-top: 4%;}
.top_sec02 .bg_box:before { content: ""; position: absolute; z-index: -1; width: 105%; height: 104%; background: url("../images/top/top_sec02_line.svg") no-repeat center top; background-size: auto 100%; top: -0.5%; left: -13%;}
.top_sec02 .img01 { margin-left: 20%; padding: 0px 24%;}

.top_sec02 section { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 7%;}
.top_sec02 .box01.back_image01 { background: none;}
.top_sec02 .box01 .text01, .top_sec02 .box01 h2 { background: url("../images/common/bg01.webp"); background-size: 525px auto; display: table;}
.top_sec02 .btn_area span:before { content: ""; position: absolute; z-index: -1; background: url("../images/common/bg01.webp"); background-size: 525px auto; top: -0.2em; right: -0.2em; bottom: -0.2em; left: -0.2em;}

.top_sec02 .text01:before { content: ""; position: absolute; background: url("../images/common/list_ico01.svg") no-repeat center center, url("../images/common/bg01.webp"); background-size: 100% auto, 525px auto; width: 1.7em; height: 2em; left: -2.6em; top: -0.3em; transform: rotate(-25deg);}

.top_sec02 .btn_area span { display: inline-block; border-bottom: dashed 1px #000; margin-right: 2.7em; position: relative; cursor: pointer; transition: 0.3s;}
.top_sec02 .btn_area span:after { content: ""; position: absolute; width: 2.2em; height: 2.2em; background: url("../images/top/top_sec02_arrow.svg") no-repeat center center; background-size: 100% auto; right: -2.7em; top: -5%;}
.top_sec02 .box01:hover .btn_area span { transform: translateX(0.4em);}

.top_sec02 .box01 { padding: 0.5em 0px 0.5em 3em; z-index: 50; cursor: pointer;}
.top_sec02 .sec_img01 { z-index: -2;}

.top_sec02 .sec01 .box01 { margin-left: 16%;}
.top_sec02 .sec01 .sec_img01 { left: 12%; top: 10em;}
.top_sec02 .sec01 .sec_img02 { margin: 3% 0px 0px -25%;}

.top_sec02 .sec02 { flex-flow: column;}
.top_sec02 .sec02 .box01 { margin: 0px auto 1.5% 0px;}
.top_sec02 .sec02 .sec_img01 { right: 7%; top: 6em;}
.top_sec02 .sec02 .sec_img02 { margin-left: -2%;}

.top_sec02 .sec03 .box01 { margin-left: 10%;}
.top_sec02 .sec03 .sec_img01 { left: 14%; top: 11em;}
.top_sec02 .sec03 .sec_img02 { margin: 10% -1% 0px 0px;}

.top_sec02 .sec04 { flex-flow: row-reverse; margin: 13% 0px;}
.top_sec02 .sec04 .box01 { margin: 3% 8% 0px -4%;}
.top_sec02 .sec04 .sec_img01 { right: 4%; top: 14em;}
.top_sec02 .sec04 .sec_img02 { margin: -3% -20% 0px 2%;}

.top_sec02 .sec05 .box01 { margin-left: 10%;}
.top_sec02 .sec05 .sec_img01 { left: 16%; top: 11em;}
.top_sec02 .sec05 .sec_img02 { margin: 6% 5% 0px -25%;}

.top_sec02 .sec06 { margin: 12% 0px 13%;}
.top_sec02 .sec06 .box01 { margin-left: 10%;}
.top_sec02 .sec06 .sec_img01 { left: -5%; top: 10em;}
.top_sec02 .sec06 .sec_img02 { margin: 13% 3% 0px -20%;}

.top_sec02 .bg01 { left: -5%; top: 0px;}
.top_sec02 .bg02 { right: -3%; top: 2%;}
.top_sec02 .bg03 { left: -15%; top: 10%;}
.top_sec02 .bg04 { right: -2%; top: 30%;}
.top_sec02 .bg05 { left: -15%; top: 30%;}
.top_sec02 .bg06 { right: 22%; top: -12%;}
.top_sec02 .bg07 { left: -17%; bottom: 5%;}
.top_sec02 .bg08 { right: -7%; bottom: -50%;}
.top_sec02 .bg09 { left: -1%; bottom: 20%;}
.top_sec02 .bg10 { right: -13%; top: -10%;}
.top_sec02 .bg11 { left: -2%; bottom: 8%;}

@media only screen and (max-width: 1000px) {
  .top_sec02 .sec01 .box01 { margin: 0px -100% 0px 3%;}
  .top_sec02 .sec01 .sec_img01 { width: 24%; left: 5%; top: 8em;}
  .top_sec02 .sec01 .sec_img02 { width: 70%;}

  .top_sec02 .sec02 .sec_img01 { width: 29%; right: -2%; top: 8em;}
  .top_sec02 .sec02 .sec_img02 { width: 75%;}

  .top_sec02 .sec03 .box01 { margin: 0px -100% 0px 1%;}
  .top_sec02 .sec03 .sec_img01 { width: 29%; left: 2%;}
  .top_sec02 .sec03 .sec_img02 { width: 63%; margin: 12% -1% 0px 0px;}

  .top_sec02 .sec04 .box01 { margin: 0 2% 0px -100%;}
  .top_sec02 .sec04 .sec_img01 { width: 27%; right: -2%; top: 10em;}
  .top_sec02 .sec04 .sec_img02 { width: 65%; margin: -3% -10% 0px -1%;}

  .top_sec02 .sec05 .box01 { margin: 0px -100% 0px 2%;}
  .top_sec02 .sec05 .sec_img01 { width: 27%; left: 4%; top: 7em;}
  .top_sec02 .sec05 .sec_img02 { width: 55%; margin: 10% 0 0px 0px;}

  .top_sec02 .sec06 { margin: 7% 0px 90px;}
  .top_sec02 .sec06 .box01 { margin: 0px -100% 0px 1%;}
  .top_sec02 .sec06 .sec_img01 { width: 29%; left: -1%; top: 8em; z-index: 50;}
  .top_sec02 .sec06 .sec_img02 { margin: 18% 5% 0px 0px; width: 57%}

  .top_sec02 .bg01 { width: 35%; left: 0;}
  .top_sec02 .bg02 { width: 35%; right: -3%; top: -1%;}
  .top_sec02 .bg03, .top_sec02 .bg05, .top_sec02 .bg08 { display: none;}
  .top_sec02 .bg04 { width: 22%; top: 65%;}
  .top_sec02 .bg06 { width: 4%; top: -20%;}
  .top_sec02 .bg07 { width: 22%; left: -1%;}
  .top_sec02 .bg09 { width: 10%; bottom: -3%;}
  .top_sec02 .bg10 { width: 12%; right: 1%; top: -7%;}
  .top_sec02 .bg11 { width: 6%; left: 0; bottom: -3%;}
}

.post_list { display: flex; flex-wrap: wrap; gap: 60px 20px;}
.post_list > li { width: calc((100% - 60px) / 4);}
.post_list figure { aspect-ratio: 1 / 1;}
.post_list figure:after { content: ""; position: absolute; left: 0px; bottom: 0px; width: 100%; height: 3px; background-image: image-set(url("../images/common/img_bg.webp") 1x, url("../images/common/img_bg@2x.webp") 2x); background-repeat: no-repeat; background-position: left bottom; background-size: 100% 100%; z-index: 50;}
.post_list figure img { width: 100%; height: 100%; object-fit: cover; display: block;}

.cat_list { display: flex; flex-wrap: wrap; gap: 0.5em;}
.cat_list a { display: block; background: #997662; color: #fff; font-size: 500; font-size: 0.75em; padding: 0px 0.7em; line-height: 1.6; transition: 0.2s;}
.cat_list a:hover { opacity: 0.7;}

.top_sec03 .top_en_ttl:before { content: ""; position: absolute; background: url("../images/top/top_sec03_icon.svg") no-repeat center center; background-size: 100% auto; width: 1.5em; height: 3em; left: -2em; top: -1.7em;}

.top_sec03 .bg01 { right: 10%; top: -5%;}
.top_sec03 .bg02 { right: -17%; top: 47%;}

@media only screen and (max-width: 1200px) {
  .top_sec03 .ttl_box { margin-left: 0px;}
  .top_sec03 .top_en_ttl:before { display: none;}
}

.top_sec04 { padding-bottom: 15%;}
.top_sec04:after { content: ""; position: absolute; z-index: -1; background: url("../images/top/top_sec04_line.svg") no-repeat center bottom; width: 180%; height: 50%; bottom: -10%; left: -54%;}

.top_sec04 .bg01 { left: -12%; top: -7%;}
.top_sec04 .bg02 { right: -8%; top: 2%;}
.top_sec04 .bg03 { left: -10%; bottom: 27%;}
.top_sec04 .bg04 { right: -10%; bottom: 33%;}

@media only screen and (min-width: 641px) and (max-width: 1129px) {
  .top_sec03, .top_sec04 { padding-left: 10px; padding-right: 10px;}
}

/* popup */
.popup-trigger { cursor: pointer; }
#popup-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(87, 77, 56, 0.2);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 999999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
#popup-overlay.active { opacity: 1; pointer-events: auto;}

.popup-content {
  position: relative;
  background-image: image-set(url("../images/common/bg01.webp") 1x, url("../images/common/bg01@2x.webp") 2x);
  background-size: 525px auto;
  padding: 40px 40px 25px;
  width: 95vw;
  max-width: 670px;
  max-height: 95vh;
  overflow-y: auto;
  animation: zoomIn 0.3s ease;
}
@keyframes zoomIn { from { opacity: 0; transform: scale(0.85);} to { opacity: 1; transform: scale(1);}}

.popup-content .list01 { display: flex; justify-content: center; gap: 2em;}
.popup-content .list01 li { width: 33.3333%; display: flex; flex-direction: column; align-items: center;}
.popup-content .list01 figure { position: relative; z-index: 50; display: flex; justify-content: center; align-items: center; flex: 0 0 auto; height: 6.6em;}
.popup-content .list01 figure:before { content: ""; position: absolute; height: 100%; aspect-ratio: 1 / 1; background: #fff; border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: -1;}
.popup-content .list01 figure img, .popup-content .list01 figure picture { aspect-ratio: 1 / 1; display: block; width: auto; height: 100%;}
.popup-content .list01 figure.small img { height: calc(100% - 1em);}

.popup-content .list01 .btn_area02 { display: inline-block; width: 6em; vertical-align: top; transition: 0.3s; margin-top: -0.3em;}
.popup-content .list01 a:hover .btn_area02 { transform: translateX(0.3em);}

#popup05 .list01 { padding-left: 1em;}

#popup-close {
  position: absolute;
  top: 0px;
  right: -6em;
  letter-spacing: 0.2em;
  background: url("../images/common/hum03.svg") no-repeat center top;
  background-size: 2.5em auto;
  padding-top: 3em;
  cursor: pointer;
  user-select: none;
  z-index: 10000;
}

@media only screen and (max-width: 900px) {
  .popup-content { padding: 7.5% 7.5% 5%; max-height: calc(100dvh - 100px); margin: 80px 0px 20px; font-size: min(3.5vw,1em);}
  #popup-close { top: 20px; right: 2.5vw; background-size: 2em auto; padding-top: 2em; font-size: 0.95em;}
}


/*------------------------------------------------------

	下層ページ

------------------------------------------------------*/

.show_sp { display: none;}
.over_hidden { overflow: hidden;}

/* 下層共通 */
.more_btn a {
	display: inline-block;
	width: 225px;
	text-align: left;
	text-decoration: none;
	position: relative;
	color: #000;
  font-weight: 500;
	background: url("../images/common/more_bgn01.svg") no-repeat left top;
  background-size: 100% 100%;
  padding: 0.75em 3em 0.75em 1.3em;
  margin-right: 1em;
	transition: 0.3s;
}
.more_btn a:after {
	content: "";
	position: absolute;
	background: url("../images/common/more_bgn02.svg") no-repeat center center, url("../images/common/bg01@2x.webp");
  background-size: 100% auto, 526px auto;
  width: 4.3em;
  height: 1em;
  right: -1.3em;
  top: 50%; transform: translateY(-50%);
	transition: 0.3s;
}
.more_btn a:hover { color: #ab7b39;}
.more_btn a:hover:after { transform: translate(0.4em,-50%);}

.more_btn.center a { text-align: center;}

.img_hover { overflow: hidden;}
.img_hover a img, a .img_hover img { transition: 0.3s;}
.img_hover a:hover img, a:hover .img_hover img { transform: scale(1.05);}

.heading_large { font-size: 2.2em; letter-spacing: 0.1em;}
.heading_middle { font-size: 1.8em; letter-spacing: 0.1em;}

.list_icon li { position: relative; padding-left: 2em;}
.list_icon li:before { content: ""; position: absolute; background-repeat: no-repeat; background-position: center center; background-size: 100% auto; width: 1.2em; height: 1.5em; left: 0px; top: 0.2em;}
.list_icon li:nth-child(4n+1):before { background-image: url("../images/common/list_ico01.svg");}
.list_icon li:nth-child(4n+2):before { background-image: url("../images/common/list_ico02.svg");}
.list_icon li:nth-child(4n+3):before { background-image: url("../images/common/list_ico03.svg");}
.list_icon li:nth-child(4n+4):before { background-image: url("../images/common/list_ico04.svg");}

/* pagettl */
.ttl_business .box01 { display: flex;}
.ttl_business .box01 > * { flex: 1;}
.ttl_business .box01 > figure img { width: 100%; height: 100%; object-fit: cover; display: block;}
.ttl_business .box_inner { display: flex; justify-content: center; align-items: center; font-size: min(2vw,1.2em); padding: 1em;}
.ttl_business h1 { max-width: 15em; font-size: 3vw;}
.ttl_business .bg01 { bottom: -1px; left: 0px; width: 100%;}
.ttl_business .bg01 img { width: 100%;}


/* animation */
.scroll_in { opacity: 0;}
.displayed { animation-duration: 1s; animation-fill-mode: both;}
.delay02s { animation-delay: 0.2s;}
.delay04s { animation-delay: 0.4s;}
.delay1s { animation-delay: 1s;}
.duration2s { animation-duration: 2s;}
.duration3s { animation-duration: 3s;}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1;}
}
.fadeIn.displayed { animation-name: fadeIn;}


/* ------------------------------
	about
------------------------------ */

.ttl_about { padding-top: 130px;}
.ttl_about:before { content: ""; position: absolute; z-index: -1; background: url("../images/about/about_head.svg") no-repeat center bottom; background-size: 100% auto; width: 2800px; height: 100%; bottom: 25%; right: 0px;}
.ttl_about h1 { font-size: 2.1em; letter-spacing: 0.05em;}
.ttl_about .list01 { display: flex; gap: 1em; animation: scrollLoop linear infinite; will-change: transform;}
.ttl_about .list01 li { flex: 0 0 auto;}

@keyframes scrollLoop {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@media only screen and (max-width: 1400px) {
  .ttl_about:before { right: -8%;}
}

.about_sec01 .heading_large, .about_sec04 .heading_large { letter-spacing: 0px;}

.about_sec01 .box01 { display: flex; justify-content: center;}

.about_sec { display: flex;}
.about_sec .ttl_box { width: 260px; margin-right: 80px; writing-mode: vertical-rl;}
.about_sec .ttl_box .fo_mincho { font-size: 2.2em; line-height: 1.3;}
.about_sec .ttl_box .fo_brown { display: inline-block; padding-top: 5.5em; letter-spacing: 0.2em; margin-top: 2em;}
.about_sec .ttl_box .fo_brown:before { content: ""; position: absolute; top: 0px; left: 50%; width: 1px; height: 4em; background: #333333;}
.about_sec .ttl_box .text01 { margin-top: 2em;}
.about_sec .box_inner { margin-top: 30px;}

.about_sec04 .box01 { display: flex; justify-content: center; gap: 3.5em; padding-left: 2em;}

@media only screen and (max-width: 1000px) {
  .about_sec { justify-content: center;}
  .about_sec .ttl_box { width: auto; margin-right: 50px;}
}


/* ------------------------
	投稿
------------------------ */

/* archive */
.news_pagettl { display: flex; align-items: center; gap: 1em; position: relative;}
.news_pagettl::before { content: ""; flex-grow: 1; height: 1px; background: #4d4d4d; order: 1;}
.news_pagettl h1 { order: 0; white-space: nowrap; margin: 0;}
.news_pagettl .cat { order: 2; white-space: nowrap;}

.news_cat { display: flex; flex-wrap: wrap; gap: 0.5em 3em;}

/* single */
.single_header { display: flex; flex-flow: row-reverse;}
.single_header > * { width: 50%;}
.single_header .box_inner { display: flex; justify-content: center; align-items: center; padding: 0px 5%;}
.single_header .box_inner > div { width: 100%;}
.single_header h1 { font-size: min(3vw,2.5em);}
.single_header > figure img { width: 100%; height: 100%; object-fit: cover; display: block;}
.single_header > figure:after { content: ""; position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 20%);}
.single_header .cat_wrap { border-top: solid 1px #4d4d4d; border-bottom: solid 1px #4d4d4d; padding: 1em 0px; display: flex; flex-wrap: wrap;}
.single_header .cat_wrap li:not(:last-child):after { content: ","; margin: 0px 0.5em;}
.single_header .tag_list { display: flex; flex-wrap: wrap;}
.single_header .tag_list li:not(:last-child):after { content: "/"; margin: 0px 0.5em;}
.single_header .tag_list a { color: #ab7b39;}
.single_header .tag_list a:hover { color: #4d4d4d;}

.single_art.blog_content { max-width: 970px; padding: 0px 30px; margin: auto;}


@media only screen and (max-width: 1100px) {
  .single_header { font-size: min(1.5vw,1em);}
  .single_art.blog_content { margin-top: -50px}

  .page_container .blog_content, .archive_wrap { padding: 0px 15px;}
}


/* 本文 */
.blog_content p:last-child { margin-bottom: 30px;}
.blog_content h2 {
  font-weight: bold;
	font-size: 1.8em;
	line-height: 1.5;
	padding-bottom: 0.5em;
	border-bottom: solid 1px #4d4d4d;
	clear: both;
	margin-bottom: 1em;
}
.blog_content h3 {
  font-weight: 500;
	font-size: 1.6em;
	line-height: 1.5;
	background: url("../images/common/h3.svg") repeat-x left bottom;
  background-size: auto 0.12em;
	padding-bottom: 0.5em;
	clear: both;
	margin-bottom: 1.5em;
}
.blog_content h4 {
  font-weight: 500;
	font-size: 1.45em;
	line-height: 1.5;
	border-top: solid 1px #4d4d4d;
  border-bottom: solid 1px #4d4d4d;
	padding: 0.4em 0px;
	clear: both;
	margin-bottom: 1.5em;
}
.blog_content h5 {
  font-weight: 500;
	font-size: 1.1em;
	line-height: 1.5;
  background: url("../images/common/h5.svg") no-repeat left 0.25em;
  background-size: 1em auto;
	padding-left: 1.5em;
	clear: both;
	margin-bottom: 1.3em;
}
.blog_content h6 {
  font-weight: 500;
	font-size: 1.1em;
	line-height: 1.5;
	clear: both;
	margin-bottom: 1.3em;
}

/* 引用 */
.blog_content blockquote {
	position: relative;
	padding: 7%;
	margin: 70px 0px;
  background: url("../images/common/blq01.svg") no-repeat 3% 15%, url("../images/common/blq02.svg") no-repeat calc(100% - 3%) 15% #f4efe2;
  background-size: 1.3em auto;
	clear: both;
}
.blog_content blockquote p:last-child { margin-bottom: 0px;}
.blog_content blockquote cite { display: block; text-align: right; font-size: 0.85em; line-height: 1.6;}
.blog_content blockquote cite:before { content: "引用元："; font-weight: 500;}

/* リスト */
.blog_content ul { margin-bottom: 30px; clear: both;}
.blog_content ul li { position: relative; padding-left: 1.1em;}
.blog_content ul li:before { content: ""; position: absolute; left: 0px; top: 0.55em; width: 0.8em; height: 0.8em; background-color: #ab7b39; border-radius: 100%;}
.blog_content ul ul { padding-left: 1em;}
.blog_content ul ul li { list-style: outside disc; padding: 0px;}
.blog_content ul ul li:before { display: none;}

.blog_content .list_icon li { padding-left: 2em;}
.blog_content .list_icon li:before { width: 1.2em; height: 1.5em; top: 0.2em; background-color: initial;}

.blog_content ol { margin-bottom: 30px; padding: 0px; counter-reset:num;}
.blog_content ol li { position: relative; padding-left: 1.5em; list-style: none;}
.blog_content ol li:before { content: counter(num) ','; counter-increment: num; position: absolute; width: 1em; height: 1.2em; left: 0px; top: 0; color: #ab7b39; font-weight: 700; text-align: right;}

/* テーブル */
.blog_content table {
	clear: both;
	border: solid 1px #4d4d4d;
	background: #fff;
	margin: 60px 0px;
	width: 100%;
}
.blog_content th, .blog_content td { padding: 0.8em 1em; border-bottom: solid 1px #4d4d4d;}
.blog_content th { background: #ab7b39; color: #fff; border-bottom-color: #fff; font-weight: bold; text-align: left;}
.blog_content tr:last-child th { border-bottom: none;}

.blog_content iframe { max-width: 100%;}

.blog_content strong { font-weight: bold;}
.blog_content em { color: #ab7b39;}

.blog_content .underline { text-decoration: underline;}

.blog_content a { color: #488f84; text-decoration: underline;}
.blog_content a:hover { color: #b1cfcb;}

.blog_content .wp-block-button__link {
  font-size: 1em;
  border-radius: 0px;
  height: auto;
	display: inline-block;
	min-width: 225px;
	text-align: center;
	text-decoration: none;
	position: relative;
	color: #000 !important;
  font-weight: 500;
	background: url("../images/common/more_bgn01.svg") no-repeat left top;
  background-size: 100% 100%;
  padding: 0.75em 3em 0.75em 1.3em;
  margin-right: 1em;
	transition: 0.3s;
  cursor: pointer;
}
.blog_content .wp-block-button__link:after {
	content: "";
	position: absolute;
	background: url("../images/common/more_bgn02.svg") no-repeat center center, url("../images/common/bg01@2x.webp");
  background-size: 100% auto, 526px auto;
  width: 4.3em;
  height: 1em;
  right: -1.3em;
  top: 50%; transform: translateY(-50%);
	transition: 0.3s;
}
.blog_content .wp-block-button__link:hover { color: #ab7b39;}
.blog_content .wp-block-button__link:hover:after { transform: translate(0.4em,-50%);}

.blog_content .btn01 .wp-block-button__link { display: inline-block; border-bottom: dashed 1px #000; margin-right: 2.7em; min-width: 0px; width: auto; background: none; padding: 0;}
.blog_content .btn01 .wp-block-button__link:after { content: ""; position: absolute; width: 2.2em; height: 2.2em; background: url("../images/top/top_sec02_arrow.svg") no-repeat center center; background-size: 100% auto; right: -2.7em; top: -5%; transform: none;}
.blog_content .btn01 .wp-block-button__link:hover { transform: translateX(0.4em);}

.blog_content .btn02 .wp-block-button__link { display: flex; flex-flow: column; align-items: center; justify-content: center; background: url("../images/common/shop_btn01.svg") no-repeat center center; background-size: auto 100%; font-size: 0.95em; line-height: 1.5; color: #fff !important; width: 9em; height: 9em; min-width: initial; padding: 0px;}
.blog_content .btn02 .wp-block-button__link:after { position: static; background-image: url("../images/common/shop_btn02.svg"); width: 3em; height: 1em; transform: none; margin-top: 0.5em;}
.blog_content .btn02 .wp-block-button__link:hover { transform: translateX(0.5em);}


.blog_content hr { border: none; background: url("../images/common/line02.svg") no-repeat center center; background-size: auto 100%; height: 1.2em; margin: 50px 0px 80px;}
.blog_content hr.is-style-wide { background: none; height: 0px; border-bottom: solid 1px #4d4d4d;}


/*WP用 投稿表示*/
.aligncenter, .alignnone { display: block; margin: 0px auto 20px;}
.alignright { margin: 0px 0 20px 20px; float: right;}
.alignleft { margin: 0px 20px 20px 0; float: left;}

.wp-block-image { margin-bottom: 60px;}
.wp-element-caption { text-align: center; color: #4d4d4d; font-size: 0.8em; margin: 1em 0px;}


.pagination { display: flex; flex-wrap: wrap; justify-content: center; gap: 1em;}

.breadcrumb { border-bottom: solid 1px #4d4d4d; padding-bottom: 2em;}

@media only screen and (max-width: 1200px) and (min-width: 641px) {
  .blog_content { padding: 0px 15px;}
  .shop_info { margin: auto -15px;}
}


/* shop info */
.shop_info { background: url("../images/common/shop_bg.svg") no-repeat center center; background-size: 100% 100%; display: flex; flex-flow: row-reverse; justify-content: space-between; padding: 5.5%; font-size: min(1.8vw,1em);}
.shop_info > figure { width: 45%;}
.shop_info .box_inner { width: 50%;}
.shop_info .catch01 { background: url("../images/common/catch_bg.svg") no-repeat center center; background-size: 100% 100%; padding: 0.25em 1em; display: table;}
.shop_info dl { background: url("../images/common/h3.svg") repeat-x left top, url("../images/common/h3.svg") repeat-x left bottom; background-size: auto 0.15em; padding: 1em 0px 1.5em; line-height: 1.4; display: flex; flex-wrap: wrap; gap: 0.4em 0px;}
.shop_info dt { width: 5.5em; padding-right: 0.5em;}
.shop_info dd { width: calc(100% - 5.5em);}
.shop_info .sns_list { display: flex; column-gap: 1em; align-items: center;}
.shop_info .btn_area { right: 1em; bottom: 1em; transform: translate(50%, 50%);}
.shop_info .btn_area a { display: flex; flex-flow: column; align-items: center; justify-content: center; background: url("../images/common/shop_btn01.svg") no-repeat center center; background-size: auto 100%; font-size: 0.9em; line-height: 1.5; color: #fff; text-decoration: none; width: 9.5em; height: 9.5em; transition: 0.3s;}
.shop_info .btn_area a:hover { transform: translateX(0.5em);}
.shop_info .btn_area img { vertical-align: top; margin: 0.6em 0px -0.8em; width: 2.7em;}

@media only screen and (max-width: 1050px) {
  .shop_info .btn_area { right: 4em; bottom: 0px;}
}


/* project */
.pro_list { display: flex; flex-wrap: wrap; gap: 60px 3%; font-size: min(1.75vw,1em);}
.pro_list li { width: calc(91% / 4);}
.pro_list figure { padding: 0px 12%;}

@media only screen and (min-width: 641px) and (max-width: 1000px) {
  .sec_project { padding: 0px 15px;}
}

