@charset "utf-8";

/* HTML初期化 */
body {
	line-height: 1;
	margin: 0;
	padding: 0;
	zoom: 1;
	/* Chromeバグ対策 */
	overscroll-behavior: none;
}

h1,h2,h3,h4,h5,h6 {
	margin: 0;
	padding: 0;
	font-weight: normal;
	font-style: normal;
}

p,dl,dt,dd,em,form,address,ul,li {
	margin: 0;
	padding: 0;
	font-style: normal;
}

/* HTML5用 */
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
	display: block;
	position: relative;
}

fieldset {
	border: 0;
	margin: 0;
	padding: 0;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}

ul {
	list-style: none;
	padding: 0;
	margin: 0;
	border: 0;
}

li {
	padding: 0;
	margin: 0;
}

input,
select {
	vertical-align: middle;
}

/* tableタグ*/
th,
td {
	padding: 0;
}

caption {
	text-align: left;
}


/* リンク設定 */
a {
	outline: 0;
	border: 0;
	transition: all 0.3s ease;
	text-decoration: none;
}

@media screen and (max-width: 799px) {
	a {
		transition: none !important;
	}
}

@media screen and (min-width: 800px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
}

a img {
	border: 0;
}

img {
	border: 0;
	max-width: 100%;
	-webkit-backface-visibility: hidden;
}

html {
	-webkit-text-size-adjust: none;
	zoom: 1;
}

body,
html {
	min-height: 100%;
}


/*============================================
基本CSS
===========================================*/
html {
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	font-size: 100px;
	-webkit-font-smoothing: antialiased;
	background-color: #FFF;
	position: relative;
	z-index: 0;
}

@media screen and (min-width: 1600px) {
	html {
		-ms-text-size-adjust: 100%;
		-webkit-text-size-adjust: 100%;
		font-size: 100px;
	}
}

@media print,
screen and (min-width:1440px) and (max-width:1599px) {
	html {
		font-size: 100px;
	}
}

@media print, screen and (min-width:1366px) and (max-width:1439px) {
		html {
		font-size: 90px;
	}
}
@media print,
screen and (min-width:1280px) and (max-width:1365px) {
	html {
		font-size: 85px;
	}
}

@media print,
screen and (min-width:641px) and (max-width:1279px) {
	html {
		font-size: 80px;
	}
}

@media print,
screen and (min-width:428px) and (max-width:640px) {
	html {
		font-size: 114px;
	}
}

@media print,
screen and (min-width:414px) and (max-width:427px) {
	html {
		font-size: 110px;
	}
}

@media print,
screen and (min-width:375px) and (max-width:413px) {
	html {
		font-size: 100px;
	}
}

@media print,
screen and (min-width:360px) and (max-width:374px) {
	html {
		font-size: 96px;
	}
}

@media print,
screen and (max-width: 359px) {
	html {
		font-size: 85px;
	}
}

body {
	font-family: "Shippori Mincho", serif;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	min-width: 960px;
	position: relative;
	font-size: .11rem;
	letter-spacing: 0.05em;
	color: #FFF;
  background-color: #000;
}

@media print,
screen and (max-width: 640px) {
	body {
		min-width: 100%;
		overflow-x: hidden;
	}

	body.menu_open {
		overflow: hidden;
	}
}

@media print,
screen and (min-width:641px) {
	.pc_only {
		display: block !important;
	}

	.sp_only {
		display: none !important;
	}
}

@media print,
screen and (max-width: 640px) {
	.pc_only {
		display: none;
	}

	.sp_only {
		display: block;
	}
}

main {
	position: relative;
	overflow: hidden;
	display: block;
}

/* インナーボックス */
.in {
	width: 100%;
	max-width: 11.80rem;
	margin: auto;
	padding-left: 0.4rem;
	padding-right: 0.4rem;
	position: relative;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	.in {
		padding-left: 0.2rem;
		padding-right: 0.2rem;
	}
}

/* ページの先頭に戻る */
#page_top {
	position: fixed;
	bottom: 0.30rem;
	right: 0.30rem;
	width: .5rem;
	height: .5rem;
	cursor: pointer;
	background-position: center center;
	background-size: cover;
	display: none;
	z-index: 10;
}

/* 丸形のボタン */
#page_top.round {
	background-image: url(../img/back_to_top_round.svg);
}

/* 四角ボタン */
#page_top.square {
	background-image: url(../img/back_to_top_square.svg);
}

@media screen and (max-width: 640px) {
	#page_top {
		width: .4rem;
		height: .4rem;
		bottom: 0.20rem;
		right: 0.20rem;
	}
}

/*=============================
スマホメニュー
=============================*/

/* 開閉ボタン */
#SPnaviBtn {
	position: absolute;
	top: 0;
	right: 0;
	width: 0.50rem;
	height: 0.50rem;
	text-align: center;
	display: block;
	z-index: 10;
}

.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .2s;
	box-sizing: border-box;
}

#SPmenuBars {
	position: absolute;
	left: 50%;
	width: 50%;
	height: 100%;
	top: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #111;
	transition: all 0.3s;
}

.menu-trigger.active span {
	background-color: #111;
}

header.scrolled .menu-trigger span {
	background-color: #111;
}

.menu-trigger span:nth-of-type(1) {
	top: 30%;
}

.menu-trigger span:nth-of-type(2) {
	top: 49%;
}

.menu-trigger span:nth-of-type(3) {
	bottom: 30%;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: rotate(-45deg);
	transform: translateY(0) rotate(-45deg);
	top: 50%;
}

.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}

.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(0) rotate(45deg);
	transform: translateY(0) rotate(45deg);
	bottom: 50%;
}

@media screen and (max-width: 640px) {
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(0) rotate(45deg);
		transform: translateY(0) rotate(45deg);
		bottom: 45%;
	}
}

/*======================
アコーディオン
======================*/
.acc_title {
	cursor: pointer;
}

.acc_contents {
	display: none;
}


/*======================
アニメーション
======================*/
/* 場所はそのままでフェードイン */
.fade_in {
	opacity: 0;
	transition: all 1.0s;
	transition-delay: 0.5s;
}

.fade_in.scrollin {
	opacity: 1;
}

/* 時間差フェード */
.fade {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 1.2s ease;
	transition-delay: 0.6s;
}

.fade02 {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 1.2s ease;
	transition-delay: 1.0s;
}

.fade03 {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 0.5s ease;
	transition-delay: 1.0s;
}

.fade04 {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 0.5s ease;
	transition-delay: 1.4s;
}

.fade05 {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 0.5s ease;
	transition-delay: 1.8s;
}

.fade06 {
	opacity: 0;
	transform: translate(0, 20px);
	transition: all 0.5s ease;
	transition-delay: 2.2s;
}

@media screen and (max-width: 640px) {
	.fade,
	.fade02,
	.fade03,
	.fade04,
	.fade05,
	.fade06 {
		transition: all 0.5s ease;
		transition-delay: 0.2s;
	}
}

.fade.scrollin,
.fade02.scrollin,
.fade03.scrollin,
.fade04.scrollin,
.fade05.scrollin,
.fade06.scrollin {
	opacity: 1;
	transform: translate(0, 0);
}

/* 右から出現 */
.fade_right {
	opacity: 0;
	transform: translate(20px, 0);
	transition: all 1.4s ease;
	transition-delay: 0.2s;
}

.fade_right.scrollin {
	opacity: 1;
	transform: translate(0, 0);
}

/* 左から出現 */
.fade_left {
	opacity: 0;
	transform: translate(-20px, 0);
	transition: all 1.4s ease;
	transition-delay: 0.2s;
}

.fade_left.scrollin {
	opacity: 1;
	transform: translate(0, 0);
}


/*=============================
コンテンツ
=============================*/
html {
  background-color: #000;
}
/* 戻るボタン */
.back_btn {
  position: absolute;
  top: 0;
  right: 0.50rem;
  z-index: 1;
}

.back_btn a {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  letter-spacing: 0;
  font-weight: 600;
  background-color: #00A5DD;
  font-size: 0.15rem;
  font-weight: 500;
  color: #FFF;
  padding: 0.10rem 0.20rem 0.12rem;
  border-radius: 0 0 0.06rem 0.06rem;
  box-shadow: 0 0 0.12rem rgba(0,0,0,0.3);
}

.back_btn a:hover {
  background-color: #4DD2FF;
}

.back_btn a span::before {
  content: "";
  width: 0.16rem;
  height: 0.10rem;
  background-image: url(../img/furukawa_time/icon_right_bold_white_rev.svg);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  position: relative;
}

/* ヘッダー */
.header {
  height: 5.00rem;
  position: relative;
  background-image: url(../img/furukawa_time/header_ph.jpg);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: cover;
}

.header::after {
  content: "";
  width: 100%;
  height: 2.50rem;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,1) 100%);
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 0;
}

.header .logo {
  width: 1.40rem;
  position: absolute;
  top: 0.50rem;
  left: 0.50rem;
  z-index: 1;
}

.intro_txt {
  position: relative;
  z-index: 1;
  text-align: center;
  margin-top: -0.50rem;
  text-shadow: 0 0 0.10rem rgba(0,0,0,0.5);
  padding-bottom: 0.70rem;
}

.intro_txt .catch {
  font-size: 0.30rem;
  font-weight: 500;
  line-height: 1.875;
  padding-bottom: 0.30rem;
}

.intro_txt .txt {
  font-size: 0.18rem;
  letter-spacing: 0.1em;
  line-height: 2;
}

.ph_block {
  max-width: 10.00rem;
  margin: auto;
  position: relative;
  z-index: 1;
}

.ph_block img {
  display: block;
  margin-bottom: 0.02rem;
}

.ph_block .flexbox {
  display: flex;
}

.ph_block .flexbox.-col2,
.ph_block .flexbox.-col3 {
  justify-content: space-between;
}

.ph_block .flexbox.-col2 .ph {
  width: 49.9%;
}

.ph_block .flexbox.-col2 .ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ph_block .flexbox.-col2.-type01,
.ph_block .flexbox.-col2.-type02 {
  height: 3.30rem;
  overflow: hidden;
  margin-bottom: 0.02rem;
}

.ph_block .flexbox.-col2.-type01 .ph:nth-of-type(1) {
  width: 45%;
}
.ph_block .flexbox.-col2.-type01 .ph:nth-of-type(2) {
  width: 54.8%;
}

.ph_block .flexbox.-col2.-type02 .ph:nth-of-type(1) {
  width: 54.8%;
}
.ph_block .flexbox.-col2.-type02 .ph:nth-of-type(2) {
  width: 45%;
}

.ph_block .flexbox.-col3 .ph {
  width: 33.2%;
}

.ph_block .flexbox.-ph_txt {
  align-items: center;
  justify-content: space-between;
}

.ph_block .flexbox.-ph_txt .ph {
  width: 45%;
}

.ph_block .flexbox.-ph_txt .txt {
  width: 52%;
}

.ph_block .txt_box {
  padding: 0.50rem 0;
}

.ph_block .txt {
  font-size: 0.18rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: center;
}

.ph_block .txt.-left {
  text-align: left;
}

.footer_ph {
  width: 100%;
  height: 8.70rem;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 0;
}

.footer_ph::before {
  content: "";
  width: 100%;
  height: 6.50rem;
  background: linear-gradient(to bottom, rgba(0,0,0,1) 0%,rgba(0,0,0,0) 100%);
  position: absolute;
  left: 0;
  top: 0;
}

.footer_ph img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

footer {
  height: 4.50rem;
  max-width: 10rem;
  margin: auto;
  position: relative;
  z-index: 1;
}

footer .logo {
  width: 0.85rem;
  margin-left: auto;
  padding-top: 0.50rem;
}

#BackToTop {
  width: 0.80rem;
  height: 0.80rem;
  position: fixed;
  right: 0.40rem;
  bottom: 0.40rem;
  z-index: 2;
}

#BackToTop img {
  display: block;
  opacity: 0.7;
  cursor: pointer;
  transition: opacity 0.3s;
}

#BackToTop:hover img {
  opacity: 1;
}

/* 初期状態ではメインコンテンツを非表示にする */
.main-content {
  opacity: 0;
  transition: opacity 2.5s; /* 1.5秒かけてフェードイン */
}

/* フェードインさせるためのクラス */
.main-content.is-active {
  opacity: 1;
}

/* スプラッシュスクリーンのスタイル */
.splash {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000; /* 背景色 */
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  /* transition: opacity 1.5s; 1秒かけてフェードアウト */
}
