@charset "UTF-8";
/*
Theme Name: lavalise
Theme URI: 
Description: lavalise.jp 専用
Author: fu-mi.
Author URI: -
version: 1.0
*/
/*------------------------------------------------
	fonts styles
-------------------------------------------------*/

body { font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', helvetica, arial, clean, sans-serif;}
@media screen and (min-width: 0\0) and (min-resolution: +72dpi) {
	.selector {
			property: value;
	}
	body {
		font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', helvetica, arial, clean, sans-serif;
	}
}
/*------------------------------------------------
	reset styles
--------------------------------------------------*/
li {
	list-style: none;
}
h1, h2, h3, h4, h5 {
	font-weight: normal;
}
img {
	vertical-align: top;
}
table {
	table-layout: fixed;
	border-collapse: collapse;
	border-spacing: 0;
}
/*------------------------------------------------
	clear styles
--------------------------------------------------*/
.clear:after {
	content: "";
	display: block;
	clear: both;
}
/*------------------------------------------------
	base styles
--------------------------------------------------*/
:root {
	--txt-color: #333;
	--color-main-blk: #333;
	--color-main-gry: #8a9296;
	--color-sub-wht: #f2f1ef;
	--color-sub-gry: #d5d7d7;
	--safe-bottom: env(safe-area-inset-bottom, 0px);
}
html {
	font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	font-size: 62.5%;
	background-color: #fff;
}
.noto-serif-jp {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
body {
	-webkit-text-size-adjust: 100%;
	color: var(--txt-color);
	font-weight: 400;
	font-size: 1.4rem;
	line-height: calc(30 / 14);
	letter-spacing: .1em;
	position: relative;
	padding-top: 55px;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	body {
		padding-top: 85px;
	}
}
body.noscroll {
	overflow: hidden;
}
html.wf-active {
}
html, body {
	height: auto;
}
h1, h2, h3, h4, h5, p, dt, dd, li {
	font-feature-settings: "normal";
}
i svg {
	vertical-align: middle;
}
.wrap {
	width: 100%;
	overflow: hidden;
	position: relative;
}
.section {
	width: 100%;
	padding-top: 50px;
	padding-bottom: 50px;
}
.section-wht {
	background-color: #fff;
}
.foot-section,
.footer {
	background-color: var(--color-main-blk);
	text-align: center;
	padding-top: 45px;
	padding-left: 25px;
	padding-right: 25px;
}
.content {
	width: 100%;
	padding: 0 25px; 
	margin-left: auto;
	margin-right: auto;
}
.div-section {
	width: 100%;
}
.mds {
	text-align: center;
}
.mds > span {
	display: block;
	font-size: 1.6rem;
	line-height: calc(28 / 16);
	letter-spacing: .15em;
	padding-left: .15em;
	position: relative;
	padding-bottom: 3px;
}
.mds > span::first-letter {
	color: var(--color-main-pnk);
}
.mds > span::after {
	content: "";
	width: 30px;
	height: 1px;
	background-color: var(--color-main-nvy);
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 0;
}
.mds > h2,
.mds > h3 {
	font-size: 2.0rem;
	line-height: calc(36 / 20);
	letter-spacing: .15em;
	padding-left: .15em;
	margin-top: 12px;
}
.btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 150px;
	height: 30px;
	border: 1px solid var(--color-main-blk);
	background-color: #fff;
	text-decoration: none;
	color: var(--txt-color);
	background-image: url(images/ico-arrow.svg);
	background-repeat: no-repeat;
	background-size: 14px auto;
	background-position: right 8px center;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.btn {
		width: 178px;
		height: 38px;
	}
	.btn:hover {
		background-color: #d5d7d7;
		background-position: right 6px center;
	}
}
.header {
	width: 100%;
	height: 55px;
	background-color: var(--color-main-blk);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	transition: all 0.5s ease;
}
.navbar {
	width: 100%;
	height: 55px;
	padding-left: 15px;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.header {
		height: 85px;
	}
	.navbar {
		height: 85px;
		padding-left: 25px;
	}
}
.navbar h1,
.navbar a {
	height: 100%;
	display: flex;
	align-items: center;	
}
.navbar h1 img,
.navbar a img {
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.navbar h1 img,
	.navbar a img {
		width: auto;
		height: 36px;
		transition: all 0.5s ease;
	}
}
.gnav_btn {
	width: 55px;
	height: 55px;
	position: fixed;
	z-index: 10001;
	top: 0;
	right: 10px;
	transition: all 0.5s ease;
}
.gnav_btn > a {
	width: 55px;
	height: 55px;
	display: block;
	background-image: url(images/menu-open.svg);
	background-size: cover;
	
}
@media (min-width: 700px) {
	.gnav_btn {
		width: 85px;
		height: 85px;
	}
	.gnav_btn > a {
		width: 85px;
		height: 85px;
	}
}
.gnav_btn > a.active {
	background-image: url(images/menu-close.svg);
}
/* ===============================
   Overlay メニュー全体
   =============================== */
#overlay {
	position: fixed;
	left: 0;
	right: 0;
	top: 55px;   /* スマホヘッダー高に合わせる */
	bottom: 0;
	background-color: var(--color-sub-wht);
	z-index: 9998;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.4s ease, visibility 0.4s ease;
	overflow: hidden;
}

/* PCヘッダー 85px に合わせる */
@media (min-width: 700px) {
	#overlay {
		top: 85px;
	}
}

/* 開いた状態 */
#overlay.open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

/* 背面スクロール固定（既にあればそのままでOK） */
body.no-scroll {
	overflow: hidden;
	padding-right: var(--scrollbar-width, 0);
}

/* ===============================
   スクロール領域（ここだけが縦スクロール）
   =============================== */
.overlay-scroll {
	height: 100%;
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
}
.overlay-main {
	flex: 1 0 auto;                /* 残り高さをすべてここで受ける */
	display: flex;
	flex-direction: column;
	background-color: var(--color-sub-wht);
	background-image: url(images/overlay-bg.png);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
}


/* ===============================
   グローバルナビゲーション
   =============================== */
.gnav {
	flex: 0 0 auto;
	padding-top:    clamp(12px, 6vh, 24px);
	padding-bottom: clamp(20px, 8vh, 30px);
}
@media (min-width: 700px) {
	.gnav {
		display: flex;
		align-items: center;

		/* PC は余白広め。ただし取りすぎないように上限付き */
		padding-top:    clamp(40px, 8vh, 80px);
		padding-bottom: clamp(56px, 10vh, 120px);
	}
}

.gnav ul {
	list-style: none;
	margin: 0 auto;
	padding: 0;
	width: 70%;
	max-width: 523px;
}

.gnav li {
	position: relative;
	width: 100%;
	text-align: center;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

.gnav li + li {
	margin-top: 1px;
}

.gnav li::after {
	content: '';
	width: 100%;
	height: 1px;
	background-color: #a6a6af;
	position: absolute;
	bottom: -1px;
	left: 0;
}
.gnav li:last-of-type::after {
	display: none;
}

.gnav a {
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 1.8rem;
	line-height: calc(30 / 18);
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	color: #333;
	padding-top: 35px;
	padding-bottom: 35px;
	background-image: url(images/ico-arrow.svg);
	background-repeat: no-repeat;
	background-size: 14px auto;
	background-position: calc(100% - 10px) center;
	background-origin: content-box;
	text-align: center;
	transition: all 0.5s ease;
}


/* ===============================
   下部エリア（ロゴ・住所）
   =============================== */
.overlay-btm {
	flex: 0 0 auto;
	margin-top: auto; /* ★ 余白があるときは下に押し付けるポイント */
	background-color: var(--color-main-blk);
	text-align: center;
	padding-top: 30px;
	padding-bottom: calc(30px + var(--safe-bottom));
	padding-left: 25px;
	padding-right: 25px;
	color: #b6b2b0;
}
@media (max-width: 768px) {
  @supports (-webkit-touch-callout: none) {
    .overlay-btm {
      /* URLバーぶんを見越して +24〜32px くらい余白を足すイメージ */
      padding-bottom: calc(54px + env(safe-area-inset-bottom));
      /* ↑ 30 + 24 = 54px（好みで 60px とかに調整可） */
    }
  }
}
.overlay-btm > p + p {
	border-top: 1px solid #a6a6af;
	margin-top: 25px;
	padding-top: 25px;
}




.top-eyecatch img {
	width: 100%;
	height: auto;
}
@media (min-width: 700px) {
	.top-eyecatch {
		max-height: 1100px;
		overflow: hidden;
	}
	.top-eyecatch img {
		height: 100%;
		object-fit: cover;
	}
}
.section-blk {
	background-color: var(--color-main-blk);
}
.section-gry {
	background-color: #f2f1ef;
}
.top00-section {
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
	color: #fff;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	transition: all 0.5s ease;
}
.top00-section > div > p {
}
.top00-section > div > p:first-child {
	font-size: 1.4rem;
	line-height: calc(46 / 28);
	letter-spacing: .3em;
	padding-left: .3em;
}
.top00-section > div > p:nth-child(2) {
	font-weight: 700;
	font-size: 2.4rem;
	line-height: calc(64 / 48);
	letter-spacing: .09em;
	padding-left: .09em;
	margin-top: 10px;
}
.top00-section > div > p:last-child {
	font-size: 1.1rem;
	line-height: calc(26 / 22);
	letter-spacing: .33em;
	padding-left: .33em;
	margin-top: 6px;
}
@media (min-width: 700px) {
	.top00-section {
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.top00-section > div > p:first-child {
		font-size: 2.0rem;
		line-height: calc(30 / 22);
	}
	.top00-section > div > p:nth-child(2) {
		font-size: 3.4rem;
		line-height: calc(42 / 34);
		margin-top: 12px;
	}
	.top00-section > div > p:last-child {
		font-size: 1.6rem;
		line-height: calc(22 / 16);
		margin-top: 6px;
	}
}
.section02 {
	padding-bottom: 110px;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.section02 {
		padding-top: 95px;
		padding-bottom: 125px;
	}
}
.top01-box > figure {
	width: calc((240 / 340) * 100%);
	max-width: 660px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.top01-box > figure > img {
	width: 100%;
	height: auto;
}
.top01-box > figure > h2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: calc((51 / 240) * 100%);
}
.top01-box > figure > h2 img {
	width: 100%;
	height: auto;
}
.top01-box > p {
	text-align: center;
	margin-top: 35px;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.top01-box > p {
		text-align: center;
		margin-top: 70px;
		font-size: 1.8rem;
		font-weight: 400;
		line-height: calc(39 / 18);
		letter-spacing: .12em;
		padding-left: .12em;
	}
}
.top02-section {
	padding-top: 1px;
}
.top02-section > figure {
	width: calc((730 / 780) * 100%);
	margin-top: -65px;
	position: relative;
	z-index: 1;
	transition: all 0.5s ease;
}
.top02-section > figure img {
	width: 100%;
	height: auto;
}
@media (min-width: 1200px) {
	.top02-section > figure {
		width: 1200px;
		padding-right: 100px;
		margin-left: auto;
		margin-right: auto;
		margin-top: -65px;
	}
}
.top02-box {
	width: calc((566 / 780) * 100%);
	max-width: 526px;
	margin-left: auto;
	margin-right: auto;
	margin-top: -28px;
	background-color: #f2f1ef;
	position: relative;
	z-index: 2;
	text-align: center;
	padding-top: 46px;
	padding-bottom: 40px;
	transition: all 0.5s ease;
}
.top02-box h2 img {
	width: calc((280 / 560) * 100%);
	height: auto;
}
.top02-box > p {
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	font-size: 1.4rem;
	line-height: calc(54 / 28);
	letter-spacing: .1em;
	padding-left: .1em;
	margin-top: 35px;
}
.top02-box .btn {
	margin-left: auto;
	margin-right: auto;
	margin-top: 35px;
	font-size: 1.3rem;
	line-height: 1;
}
.top02-box .btn + .btn {
	margin-top: 10px;
}
@media (min-width: 700px) {
	.top02-box > p {
		font-size: 2.0rem;
		line-height: calc(38 / 20);
		letter-spacing: .18em;
		padding-left: .18em;
		margin-top: 50px;
	}
	.top02-box .btn {
		font-size: 1.5rem;
		margin-top: 50px;
	}
	.top02-box .btn + .btn {
		margin-top: 25px;
	}
}
.top02-btm {
	position: relative;
	z-index: 3;
	margin-top: -16px;
	display: flex;
	justify-content: space-between;
}
.top02-btm > figure {
	width: calc((459 / 780) * 100%);
	padding-top: 51px;
}
.top02-btm > figure + figure {
	width: calc((276 / 780) * 100%);
	padding-top: 0;
}

.top02-btm > figure > img {
	width: 100%;
	height: auto;
}
@media (min-width: 700px) {
	.top02-btm {
		margin-top: 74px;
	}
}
@media (min-width: 1200px) {
	.top02-btm {
		width: 1200px;
		margin-left: auto;
		margin-right: auto;
	}
}
.section04 {
	background-color: #8a9296;
	color: #fff;
}
.section04 table {
	width: 100%;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
	table-layout: auto;
}
.section04 table tr {
	display: flex;
  width: 100%;
}
.section04 table th,
.section04 table td {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: calc(42 / 28);
	letter-spacing: .1em;
	transition: all 0.5s ease;
}
.section04 table th {
	width: 36.5%;
	vertical-align: top;
	text-align: left;
	padding-right: 15px;
}
.section04 table td {
	width: 63.5%;
}
.section04 table th > div,
.section04 table td > div {
	padding-top: 10px;
	padding-bottom: 10px;
	border-top: 1px solid #fff;
	display: flex;
	height: 100%;
}
@media (min-width: 700px) {
	.section04 table th,
	.section04 table td {
		font-size: 1.8rem;
		font-weight: 400;
		line-height: calc(32 / 18);
	}
	.section04 table th {
		padding-right: 25px;
	}
	.section04 table th > div,
	.section04 table td > div {
		padding-top: 12px;
		padding-bottom: 12px;
	}
}
.section04 table tr:last-of-type th > div,
.section04 table tr:last-of-type td > div {
	border-bottom: 1px solid #fff;
}
.mds {
	text-align: center;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	transition: all 0.5s ease;
}
.mds h2 {
	font-size: 2.2rem;
	line-height: calc(82 / 44);
	letter-spacing: .19em;
	padding-left: .19em;
}
.mds span {
	font-size: 1.1rem;
	line-height: calc(42 / 22);
	letter-spacing: .17em;
	padding-left: .17em;
}
@media (min-width: 700px) {
	.mds h2 {
		font-size: 3.2rem;
		line-height: calc(60 / 32);
		letter-spacing: .19em;
		padding-left: .19em;
	}
	.mds span {
		font-size: 1.6rem;
		line-height: calc(32 / 16);
		letter-spacing: .17em;
		padding-left: .17em;
	}
}

/* フォーム全体 */
.contact-form {
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	margin-top: 35px;
}
@media (min-width: 700px) {
	.contact-form {
		max-width: 500px;
		margin-left: auto;
		margin-right: auto;
	}
}

/* 各ブロック */
.form-group {
  margin-bottom: 15px;
}

/* ラベル部分：左＝空き、中央＝項目名、右＝必須 */
.form-label {
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* 左・中央・右の3分割 */
  align-items: center;
  background: #ccc;
  padding: 10px;
  font-size: 1.5rem;
	line-height: calc(40 / 30);
  position: relative;
	margin-bottom: 5px;
	transition: all 0.5s ease;
	color: #333;
}
@media (min-width: 700px) {
	.form-label {
		font-size: 2.2rem;
	}
}

/* 左スペース用の空白を疑似要素で作る */
.form-label::before {
  content: "";
}

/* 中央（項目名） */
.form-label span:first-child {
  justify-self: center;
  font-weight: 500;
}

/* 右端（必須） */
.required {
  justify-self: end;
  background: #444;
  color: #fff;
  padding: 2px 5px;
  font-size: 1.1rem;
	line-height: calc(20 / 11);
}

/* 入力欄 */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 4px 5px;
  border: 1px solid #999;
  font-size: 1.2rem;
  background: #fff;
  color: #333;
	font-family: "Noto Sans JP", serif;
}
textarea {
  height: 150px;
  resize: vertical;
}
input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="tel"]::placeholder {
	color: #b3b3b3;
}
@media (min-width: 700px) {
	.required {
		font-size: 1.3rem;
	}
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	textarea {
		font-size: 1.8rem;
	}
}
/* 送信ボタン */
.form-submit {
  text-align: center;
  margin-top: 36px;
  border-top: 1px solid #444;
  padding-top: 35px;
	transition: all 0.5s ease;
	
}
input[type="submit"] {
  background: #333;
  color: #fff;
  width: 160px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
  font-size: 1.3rem;
  border: none;
  cursor: pointer;
	margin-left: auto;
	margin-right: auto;
	font-family: "Noto Sans JP", serif;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.form-submit {
		margin-top: 45px;
		padding-top: 46px;
	}
	input[type="submit"] {
		width: 230px;
		height: 46px;
		font-size: 2.0rem;
	}
	input[type="submit"]:hover {
		background-color: #8a9296;
	}
	.wpcf7-response-output {
		max-width: 500px;
		margin-left: auto!important;
		margin-right: auto!important;
	}
}

.top06-btm {
	margin-top: 30px;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
	transition: all 0.5s ease;
	
}
.top06-btm h3 {
	font-size: 1.4rem;
	font-weight: 700;
	line-height: calc(40 / 28);
	letter-spacing: .06em;
	color: #666;
}
.top06-btm p {
	margin-top: 10px;
	font-size: 1.2rem;
	line-height: calc( 42 / 24);
	letter-spacing: .1em;
	color: #666;
}
@media (min-width: 700px) {
	.top06-btm {
		margin-top: 45px;
	}
	.top06-btm h3 {
		font-size: 2.1rem;
		line-height: calc(30 / 21);
	}
	.top06-btm p {
		margin-top: 15px;
		font-size: 1.8rem;
		line-height: calc( 32 / 18);
	}
}

.eyecatch {
	width: 100%;
	height: 186px;
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.5s ease;
}
.title {
	text-align: center;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	color: #fff;
}
.title h1 {
	font-size: 2.2rem;
	line-height: calc(52 / 44);
	letter-spacing: .37em;
	padding-left: .37em;
}
.title span {
	font-size: 1.1rem;
	line-height: calc(30 / 22);
	letter-spacing: .17em;
	padding-left: .17em;
}
.eyecatch > figure {
	width: 100%;
	height: 100%;
	position: absolute;
	overflow: hidden;
	top: 0;
	left: 0;
	z-index: -1;
}
.eyecatch > figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (min-width: 700px) {
	.eyecatch {
		height: 560px;
	}
	.title h1 {
		font-size: 2.6rem;
	}
}
.case-box {
	max-width: 1000px;
	transition: all 0.5s ease;
}
.case-head01 {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.case-head01 > div {
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.case-head01 > div > span {
	font-weight: 500;
	font-size: 1.2rem;
	line-height: calc(16 / 12);
	letter-spacing: .06em;
	background-color: #333;
	color: #fff;
	padding-left: calc(10px + .06em);
	padding-right: 10px;
}
.case-head01 > div > p {
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	font-size: 2.2rem;
	line-height: calc(26 / 22);
	letter-spacing: .19em;
	margin-left: 13px;
}
.case-head01 > p {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: calc(26 / 16);
	letter-spacing: .06em;
	padding-left: calc(9px + .06em);
	background-color: #f1f0ee;
	padding-right: 9px;
}
.section-gry .case-head01 > p {
	background-color: #fff;
}
@media (min-width: 700px) {
	.case-head01 > div > span {
		font-size: 1.6rem;
		line-height: calc(26 / 16);
	}
	.case-head01 > div > p {
		font-size: 3.0rem;
	line-height: calc(34 / 30);
	}
	.case-head01 > p {
		font-size: 2.2rem;
	line-height: calc(34 / 22);
	}
}
.case-head02 {
	border-top: 1px solid var(--txt-color);
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 9px;
	padding-top: 10px;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: calc(16 / 14);
	letter-spacing: .06em;
}
.case-box > figure {
	margin-top: 25px;
}
.case-box > figure img {
	width: 100%;
	height: auto;
}
.case-box > p {
	margin-top: 36px;
}
.case-btm {
	margin-top: 36px;
	display: grid;
	grid-template-columns: repeat(2, 1fr); /* 横2枚 */
	grid-template-rows: repeat(2, auto);   /* 縦2枚 */
	gap: 14px; /* ← 横・縦とも14px */
	max-width: 1000px; /* 任意（全体幅） */
	margin-left: auto;
	margin-right: auto;
}
.case-btm > figure {
	width: 100%;
}
.case-btm > figure > img {
	width: 100%;
	height: auto;
}
@media (min-width: 700px) {
	.case-head02 {
		font-size: 1.8rem;
	}
	.case-box > p {
		font-size: 1.8rem;
		line-height: calc(36 / 18);
	}
}


.plan-section > div {
	max-width: 600px;
}

.plan-section01 h2 {
	text-align: center;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 1.6rem;
	line-height: calc(33 / 16);
	letter-spacing: .05em;
	padding-left: .05em;
	transition: all 0.5s ease;
}
.plan-box {
	width: 100%;
	background-color: #fff;
	padding-top: 20px;
	padding-bottom: 20px;
	padding-left: 20px;
	padding-right: 20px;
}
.plan-box + .plan-box {
	margin-top: 46px;
	position: relative;
}
.plan-box + .plan-box::before {
	content: "";
	width: 22px;
	height: 11px;
	background-color: #333;
	clip-path: polygon(50% 11px, 0% 0%, 22px 0%);
	position: absolute;
	top: -28px;
	left: 50%;
	transform: translateX(-50%);
	transition: all 0.5s ease;
}
.plan-mds {
	border: 1px solid #8e8e8e;
	display: flex;
	align-items: center;
	padding-top: 21px;
	padding-bottom: 21px;
	padding-left: 18px;
	padding-right: 18px;
}
.plan-mds > span {
	display: block;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 200;
	font-style: normal;
	font-size: 4.7rem;
	line-height: calc(47 / 47);
	letter-spacing: .05em;
	padding-bottom: 5px;
	padding-right: 13px;
	color: #333;
	transition: all 0.5s ease;
}
.plan-mds > h2 {
	font-weight: 700;
	font-size: 1.6rem;
	line-height: calc(25 / 16);
	letter-spacing: .05em;
	color: #333;
	padding-left: 15px;
	position: relative;
	transition: all 0.5s ease;
}
.plan-mds > h2::before {
	content: "";
	width: 1px;
	height: 42px;
	background-color: #333;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	transition: all 0.5s ease;
}
.plan-mds > h2 > span {
	font-weight: 400;
}
.plan-mds-black {
	background-color: #333;
	color: #fff;
}
.plan-mds-black > span,
.plan-mds-black > h2 {
	color: #fff;
}
.plan-mds-black > h2::before {
	background-color: #fff;
}

.plan-box ul {
	margin-top: 14px;
}
.plan-box ul li {
	position: relative;
	padding-left: 1.1em;
	font-size: 1.4rem;
	line-height: calc(28 / 14);
	padding-top: 5px;
	padding-bottom: 5px;
	transition: all 0.5s ease;
}
.plan-box ul li + li {
	margin-top: 1px;
}
.plan-box ul li + li::after {
	content: "";
	width: 100%;
	height: 1px;
	background-color: #b4b4b4;
	position: absolute;
	top: -1px;
	left: 0;
}
.plan-box ul li::before {
	content: "・";
	position: absolute;
	top: 5px;
	left: 0;
}
.plan-box > p {
	line-height: calc(26 / 14);
	margin-top: 20px;
	transition: all 0.5s ease;
}
.plan-box h3 {
	font-weight: 700;
	font-size: 1.5rem;
	line-height: calc(25 / 15);
	color: #333;
	border-bottom: 1px solid #333;
	padding-bottom: 4px;
	margin-top: 32px;
	transition: all 0.5s ease;
}

.plan-section03 h2 {
	font-size: 1.4rem;
	line-height: calc(26 / 14);
	letter-spacing: .1em;
	transition: all 0.5s ease;
}
a.btn2 {
	margin-top: 26px;
	width: 100%;
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #666;
	color: #fff;
	text-decoration: none;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 1.8rem;
	line-height: calc(21 / 18);
	letter-spacing: .19em;
	padding-left: .19em;
	transition: all 0.5s ease;
}
a.btn2:hover {
	background-color: rgba(102, 102, 102, .7);
}
a.btn2 i {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-left: 15px;
	padding-right: 15px;
	padding-top: 3px;
	padding-bottom: 3px;
}
@media (min-width: 520px) {
	.plan-br {
		display: none;
	}
}
@media (min-width: 700px) {
	.plan-section01 h2 {
		font-size: 2.2rem;
		line-height: calc(50 / 22);
	}
	.plan-mds > span {
		font-size: 5.4rem;
		padding-bottom: 6px;
		padding-right: 16px;
	}
	.plan-mds > h2 {
		font-size: 2.0rem;
		line-height: calc(29 / 20);
		padding-left: 20px;
	}
	.plan-mds > h2::before {
		height: 48px;
	}
	.plan-box ul li {
		font-size: 1.8rem;
	}
	.plan-box > p {
		font-size: 2.0rem;
	}
	.plan-box h3 {
		font-size: 2.0rem;
	}
	.plan-section03 h2 {
		font-size: 1.8rem;
	}
	a.btn2 {
		line-height: calc(20 / 18);
	}
	a.btn2:hover {
	}
	a.btn2 i {
		padding-top: 0px;
		padding-bottom: 0px;
	}
	a.btn2 i img {
		width: auto;
		height: 20px;
	}
}



.footer-top {
	text-align: center;
}

/* 共通スタイル */
.footer-menu {
	margin-top: 40px;              /* 1段目の上余白 */
	display: inline-flex;          /* 中身を横並び + 全体を中央寄せしやすく */
	align-items: center;
	justify-content: center;
	gap: 1.4em;
	padding: 0;
}
.footer-menu-lower {
	margin-top: 4px;
}

.footer-menu li {
	list-style: none;
	position: relative;
	font-size: 1.3rem;
	font-weight: 400;
	line-height: calc(52 / 26);
	color: #b6b2b0;
}

/* 各行の 2番目以降にだけ「｜」を付ける */
.footer-menu li + li::before {
	content: "|";
	position: absolute;
	top: 50%;
	left: -0.7em;
	transform: translate(-50%, -50%);
}

.footer-menu li a {
	font-size: 1.3rem;
	font-weight: 400;
	line-height: calc(52 / 26);
	letter-spacing: .16em;
	padding-left: .16em;
	text-decoration: none;
	color: #b6b2b0;
	white-space: nowrap; /* 折り返し防止。不要なら消してOK */
}





.footer-top > a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 30px;
	transition: all 0.5s ease;
}
@media (min-width: 700px) {
	.footer-top li a:hover {
		text-decoration: underline;
	} 
	.footer-top li,
	.footer-top li a {
		font-size: 1.8rem;
	}
}
.copyright {
	height: 35px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-top: 1px solid #948e8b;
	margin-top: 32px;
}
.copyright p {
	font-size: 1.1rem;
	letter-spacing: .12em;
	padding-left: .12em;
	color: #b6b2b0;
}
.preload {
	background-image: url(images/menu-close.svg);
}
.fade-box {
	opacity: 0;
	transition: 2s ease;
	transform: translate(0, 1rem);
}
.fade-box.fade-up {
	opacity: 1;
	transform: translate(0, 0);
}
.anker {
	position: relative;
}
.anker > span {
	width: 100%;
	height: 0;
	position: absolute;
	top: -55px;
	left: 0;
}