/*　カスタムプロパティ
------------------------------*/
:root {
	--Ys-color: rgb(22, 94, 131);
	--Ys-color-light: rgb(238, 247, 255);
	--Ys-font-color: #333333;
	--Ys-line-height: 1.8;
}
/*　全体レイアウト
------------------------------*/
html {
	font-size: 62.5%; /*16px=1.6rem*/
	background-color: #ffffff;
}
img {
	width: 100%;
	height: auto;
}
.body {
	/* background-color: aquamarine; */
	width: 100%;
	padding: 0;
	margin: 0 auto;
	color: #333333; /* 文字色*/
	font-size: 1.5rem; /* fontサイズ*/
	line-height: var(--Ys-line-height); /* 行間 */
	letter-spacing: 0.05rem; /* 文字間 */
	overflow-x: hidden; /* 横スクロール */
	font-family: '游ゴシック体', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ Pro',
		'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'MS Pゴシック', 'MS PGothic', sans-serif;
	background-image: url(../img/common/bg.webp);
}

.header {
	width: 100%;
	display: flex;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9999;
}

.main {
	width: 100%;
}

.footer {
	width: 100%;
	text-align: center;
}

.top,
.wlecom,
.service,
.price,
.access,
.greeting {
	width: 100%;
	/*コンテンツ幅を実質1000pxに設定*/
	padding: 0 calc((100vw - 1000px - calc(100vw - 100%)) / 2);
}

/*----------------------------------*/
/*トップ */
/*----------------------------------*/
.top {
	background-image: url(../img/top/top_bg.webp);
	background-size: cover;
	background-position: center center;
	max-height: 1080px;
	padding: 100px;
	height: 100vh;
	/* text-align: right; */
	display: flex;
	justify-content: flex-end;
}
/*トップ看板*/
.top_msg_wrap {
	align-self: flex-start;
	width: 30%;
	max-width: 576px;
	padding: 30px 10px;
	border: solid 1px var(--Ys-color);
	text-align: center;
	background-color: #ffffff;
}
.top_ttl {
	font-weight: bold;
	font-size: 2rem;
}
.top_company_name {
	font-size: 5rem;
	font-family: '游明朝', 'YuMincho', 'ヒラギノ明朝 ProN', 'ヒラギノ明朝 Pro', 'ＭＳ 明朝', serif;
	color: var(--Ys-color);
	border-bottom: solid 3px var(--Ys-color);
	margin-bottom: 30px;
}
.top_msg {
	width: 75%;
	margin: 0 auto;
}
/*----------------------------------*/
/* Y's工房とは */
/*----------------------------------*/
.wlecom {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	text-align: center;
	padding-top: 100px;
	/* padding-bottom: 50px; */
}
.wlecom_left {
	width: 47.5%;
	/* border: solid 10px #ffffff; */
}
.wlecom_img {
	max-width: 100%;
	height: auto;
	border: solid 10px #ffffff;
}

.wlecom_right {
	width: 47.5%;
	border: solid 3px var(--Ys-color);
	border-radius: 10px;
	background-color: #ffffff;
	padding: 20px;
}
.wlecom_msg_ttl {
	font-size: 3rem;
	font-weight: bold;
	color: var(--Ys-color);
}
.wlecom_msg {
	text-align: left;
	margin-top: 2rem;
}
.wlecom_msg:last-child {
	text-align: right;
	font-weight: bold;
}
/*----------------------------------*/
/* Y's工房のサービス */
/*----------------------------------*/
.service {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	/* align-items: flex-start; */
	margin: 100px 0 50px;
}
.service_wrap {
	margin-top: 30px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.service_ttl {
	display: inline-block;
	/* width: 100%; */
	font-size: 3rem;
	font-weight: bold;
	text-align: center;
	/* padding-bottom: 30px; */
	color: var(--Ys-color);
	background-color: #ffffff;
	border: 2px solid var(--Ys-color);
	padding: 5px 20px;
}
.service_content {
	width: 48%;
	display: flex;
	flex-wrap: wrap;
	background-color: #ffffff;
	align-self: flex-start;
	text-align: center;
	margin-bottom: 50px;
	border: 12px solid #ffffff;
}
.service_content_img {
	width: 100%;
	height: auto;
	object-fit: contain;
}
.service_content_ttl {
	display: block;
	width: 100%;
	margin-top: 20px;
}
.service_content_msg {
	padding: 20px;
	text-align: left;
	background-color: #ffffff;
}

/*----------------------------------*/
/* 料金について */
/*----------------------------------*/
.price {
	background-image: url(../img/top/price.webp);
	background-size: cover;
	background-position: center center;
	max-height: 1080px;
	padding: 100px;
	display: flex;
	flex-wrap: wrap;
}
.price_wrap {
	width: 100%;
	margin-bottom: 100px;
	text-align: center;
}
.price_ttl {
	font-size: 3rem;
	font-weight: bold;
	display: inline-block;
	padding: 5px 30px;
	border: solid 2px rgb(255, 255, 255);
	background-color: var(--Ys-color);
	color: #ffffff;
}
.price_msg {
	margin-top: 20px;
	background-color: rgba(255, 255, 255, 0.8);
	background-blend-mode: overlay;
	padding: 20px;
}
.price_contents_wrap {
	width: 100%;
	max-width: 1920px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.price_circle_ttl {
	font-size: 2rem;
	color: var(--Ys-color);
	font-weight: bold;
}
.price_circle_width {
	width: 30%;
	max-width: 576px;
	border-radius: 50%;
	border: 2px solid var(--Ys-color);
	background-color: #ffffff;
	background-size: cover;
	background-position: center center;
	background-color: rgba(255, 255, 255, 0.8);
	background-blend-mode: overlay;
}
.price_circle_width:nth-child(1) {
	background-image: url(../img/top/price01.webp);
	/* background-color: red; */
}
.price_circle_width:nth-child(2) {
	background-image: url(../img/top/price02.webp);
}
.price_circle_width:nth-child(3) {
	background-image: url(../img/top/price03.webp);
}

.price_circle_height {
	/* 内包する要素の基準にする */
	position: relative;
	/* paddingの％指定は親要素の横幅に依存する
	padding-top: 100%にすることで親要素の横幅と同じ長さになる
	親要素が正方形になる */
	padding-top: 100%;
	/* 要素自体の高さがあるとずれるので高さを０にする */
	height: 0;
}

.price_circle {
	/* 要素のたかさをなくす */
	position: absolute;

	/* 正方形の幅-文字の高さ/2 で上下真ん中に要素がくる */
	top: calc((100% - (calc(4.5 * var(--Ys-line-height)) * 1em)) / 2);

	/* 要素伸ばす */
	left: 0;
	right: 0;

	/* 文字中央寄せ */
	text-align: center;
}

/*----------------------------------*/
/* アクセス */
/*----------------------------------*/
.access {
	background-color: #ffffff;
	padding-top: 100px;
	text-align: center;
}
.access_ttl {
	display: inline-block;
	/* background-color: red; */
	font-size: 3rem;
	color: var(--Ys-color);
	font-weight: bold;
}
.access_wrap {
	display: flex;
	flex-wrap: wrap;
	margin-top: 20px;
}
.access_left {
	width: 50%;
	font-weight: bold;
	text-align: left;
	padding-top: 5rem;
	padding-left: 12%;
	background-color: var(--Ys-color-light);
}
.access_tel {
	display: inline-block;
	font-size: 3rem;
	text-decoration: underline;
	text-decoration-color: var(--Ys-color);
	margin-top: 15px;
}
.access_tel::before {
	font-family: 'Font Awesome 5 Free';
	content: '\f3cd';
	font-size: 3rem;
	font-weight: 900;
	margin-right: 4px;
	color: var(--Ys-color);
	text-decoration: none;
}
.access_right {
	width: 50%;
}
.access_map {
	width: 100%;
	width: 100vw;
	margin: 50px calc(50% - 50vw) 0;
}
/*----------------------------------*/
/* 工場長からのあいさつ */
/*----------------------------------*/
.greeting {
	margin: 100px auto;
	text-align: center;
}
.greeting_ttl {
	font-size: 3rem;
	background-color: red;
	display: inline-block;
	padding: 5px 30px;
	border: solid 2px rgb(255, 255, 255);
	background-color: var(--Ys-color);
	color: #ffffff;
}
.greeting_wrap {
	display: flex;
	justify-content: space-between;
	margin-top: 30px;
}
.greeting_left {
	width: 40%;
}
.greeting_img {
	border: 12px solid #ffffff;
}
.greeting_right {
	width: 55%;
}
.greeting_msg {
	text-align: left;
	padding: 30px;
}
/*----------------------------------*/
/* フッター */
/*----------------------------------*/
.footer {
	background-color: var(--Ys-color);
	padding: 25px 0;
	color: #ffffff;
}

/*　ハンバーガーメニュー
>.header
------------------------------*/
.hamburger-nav {
	position: fixed;
	top: 0;
	/*ナビメニューを右に隠した状態になる*/
	right: -30%;
	width: 30%;
	height: 100vh;
	background-color: var(--Ys-color-light);
	/*０.7秒かけてナビメニューがスライドする*/
	transition: 0.7s;
}
.hamburger-nav ul {
	padding-top: 80px;
}
.hamburger-nav ul li {
	list-style-type: none;
	/* font-size: 20px; */
}
.hamburger-nav a {
	display: block;
	text-decoration: none;
	color: var(--Ys-color);
	margin: 0 15px;
	padding: 10px;
	transition: 0.5s;
}
.hamburger-nav li a:hover {
	color: #ffffff;
	background: var(--Ys-color);
	border-bottom: none;
}

/*----------------------------------*/
/* ハンバーガーメニュー設定 */
/*----------------------------------*/
.hamburger-icon {
	display: block;
	position: fixed;
	top: 20px;
	right: 20px;
	width: 30px;
	height: 22px;
	cursor: pointer;
	transition: 1s;
	z-index: 9999;
}
.hamburger-icon-line {
	display: block;
	position: absolute;
	right: 0;
	width: 30px;
	height: 2px;
	background-color: var(--Ys-color);
	transition: 1s;
	border-radius: 4px;
}
#line1 {
	top: 0;
}
#line2 {
	top: 10px;
}
#line3 {
	top: 20px;
}
#line4 {
	position: absolute;
	top: 30px;
	font-size: 1rem;
	color: var(--Ys-color);
}
.in {
	transform: translateX(-100%);
}
.line_1,
.line_2,
.line_3 {
	background: var(--Ys-color);
}
.line_1 {
	/* -45度回転させる */
	transform: translateY(10px) rotate(45deg);
	top: 0;
}
.line_2 {
	opacity: 0;
}
.line_3 {
	/* 45度回転させる */
	transform: translateY(-10px) rotate(-45deg);
	bottom: 0;
}
/*----------------------------------*/
/* アニメーション設定 */
/*----------------------------------*/
/**fadein**/
.fade-in {
	opacity: 0;
	transform: translateY(50px);
	transition: all 500ms;
}
/* フェードインするためのクラス */
.fade-in.show {
	opacity: 1;
	transform: translateY(0);
}
/* ------------------------------------------------------------- */
/* media query */
/* ------------------------------------------------------------- */
@media (min-width: 768px) {
	a[href^='tel:'] {
		pointer-events: none;
		cursor: default;
	}
}

@media screen and (max-width: 767px) {
	/* TOP */
	.top {
		justify-content: center;
	}
	.top_msg_wrap {
		width: 85%;
		position: absolute;
		top: 450px;
	}
	.top_msg {
		width: 100%;
	}
	/* Y's工房とは */
	.wlecom {
		flex-wrap: wrap;
	}
	.wlecom_left {
		width: 100%;
		padding: 0 10%;
	}
	.wlecom_right {
		width: 100%;
		padding: 25px;
		margin: 30px 10% 0;
		border-radius: 10px;
	}
	.wlecom_msg_ttl {
		font-size: 2rem;
	}
	/* Y's工房のサービス */
	.service_ttl {
		font-size: 2.5rem;
	}
	.service_wrap {
		padding: 0 50px;
	}
	.service_content {
		width: 100%;
		border-width: 30px;
	}
	/* 料金について */
	.price {
		max-height: none;
		padding: 10%;
	}
	.price_ttl {
		font-size: 2.5rem;
	}
	.price_circle_width {
		width: 100%;
		margin-bottom: 20px;
	}
	.price_msg {
		padding: 10px;
		text-align: left;
	}
	.price_circle_content {
		padding: 0 20%;
		text-align: left;
	}
	/* アクセス */
	.access_left {
		width: 100%;
		padding: 10%;
		order: 2;
	}
	.access_right {
		width: 100%;
		order: 1;
	}
	.access_map {
		margin-top: 0;
	}
	/* ご挨拶 */
	.greeting {
		margin-bottom: 50px;
	}
	.greeting_wrap {
		flex-wrap: wrap;
	}
	.greeting_left {
		width: 100%;
		padding: 0 15%;
	}
	.greeting_right {
		width: 100%;
		padding: 0 10%;
		background-color: rgba(255, 255, 255, 0.8);
		background-blend-mode: overlay;
	}

	.hamburger-nav {
		/* width: 100%; */
		/* right: 100%; */
	}
	.footer {
		font-size: 1.2rem;
	}
}
