/* ============================================
   FV
============================================ */
.top-page_fv {
  position: relative;
  min-height: 600px;
  max-height: 800px;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
	overflow:hidden;
}
@media screen and (max-width: 768px) {
	.top-page_fv {
  min-height: 360px;
		height: 60vh;
	}
}

.top-page_fv__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

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

.top-page_fv__image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.top-page_fv__image video{
	width: 100%;                                                                                                                                         
	height: 100%;                                                        
	object-fit: cover;
}
.top-page_fv__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.top-page_fv__label {
  font-size: 13px;
  letter-spacing: 0.15em;
  color: #888;
  margin-bottom: 16px;
}

.top-page_fv__title {
  font-size: 56px;
  font-weight: 700;
  line-height: 1.4;
	color:#fff;
	text-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 768px) {
.top-page_fv__title {
	font-size: 28px;
	}
}

.top-page_fv__text {
  font-size: 16px;
  line-height: 1.8;
  color: #555;
	margin-top:24px;
  margin-bottom: 40px;
}

.top-page_fv__image-placeholder {
  background: #ddd;
  height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #999;
  font-size: 14px;
}

/* ============================================
   お知らせ
============================================ */
.top-page_news {
  padding: 120px 0 0 0;
}

.top-page_news__list {
  list-style: none;
  padding: 0;
/*   border-top: 1px solid #e0e0e0; */
}

.top-page_news__item {
  border-bottom: 1px solid #9F9F9F;
}

.top-page_news__link {
  display: flex;
  align-items: center;
  gap: 120px;
  padding: 20px;
  text-decoration: none;
  color: #333;
  transition: opacity 0.2s;
}

.top-page_news__link:hover {
  opacity: 0.6;
}

.top-page_news__date {
  font-size: 16px;
  color: #888;
  white-space: nowrap;
  flex-shrink: 0;
}

.top-page_news__cat {
  font-size: 16px;
  border: 1px solid #333;
  padding: 3px 12px;
  white-space: nowrap;
  flex-shrink: 0;
}

.top-page_news__title {
  font-size: 16px;
  line-height: 1.5;
}

/* ============================================
   コンセプト・メッセージ
============================================ */
.top-page_concept {
  padding: 120px 0;
	position:relative;
}
.top-page_concept:after{
	content:"";
	display:block;
	width:100vw;
	height:110vw;
	background:url(../img/top_cocept_bg.png);
		background-size:cover;
	background-position:top center;
	position:absolute;
	left:0;
	bottom:-55%;
	z-index:-1;
}
/* @media screen and (min-width:1650px) {
.top-page_concept:after{
	max-height:1650px;
	bottom:
}
} */
@media screen and (max-width: 768px) {
	.top-page_concept:after{
		height:160vw;
		bottom:-40%;
	background-image:url(../img/top_cocept_bg_sp.png);
	}
}
.top-page_concept__inner {
/*   display: flex;
  align-items: center;
  gap: 80px; */
}

.top-page_concept__image {
  flex: 1;
  flex-shrink: 0;
}

.top-page_concept__image-placeholder {
  background: #ddd;
  height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #999;
  font-size: 14px;
}

.top-page_concept__body {
  flex: 1;
}

.top-page_concept__lead {
  font-size: 24px;
	font-weight:700;
    writing-mode: vertical-rl;
    text-orientation: upright;
    line-height: 1.8;
    margin: 80px auto 0 auto;
    text-shadow: 2px 2px 3px rgba(255, 255, 255, 0.6);
	    height: max-content;
}
.top-page_concept__lead span{
	display:block;
	width:1em;
	height:1em;
}
.top-page_concept__lead i{
	font-style: italic;
	font-weight:700;
}


.top-page_concept__text {
  font-size: 15px;
  line-height: 2;
  color: #555;
  margin-bottom: 40px;
}

/* ============================================
   店舗紹介
============================================ */
.top-page_shop {
  padding: 120px 0 0 0;
}
.top-page_shop .l-inner{
	background:#FFFDF5;
	padding:80px 0 80px 0;
	border-radius: 20px;
}
.top-page_shop__list {
  display: flex;
  flex-direction: row;
  gap: 40px;
padding: 0 40px;
}

.top-page_shop__item {
  flex: 1;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
	position:relative;
	border-radius:20px;
}
.top-page_shop__item:after{
	content:"";
	display:block;
	width:100%;
	height:100%;
	background:#000;
	opacity:0.4;
	position:absolute;
	left:0;
	top:0;
	pointer-events:none;
	border-radius:20px;
	z-index: 1;
	transition:all 0.3s;
	
}

.top-page_shop__image {
  width: 100%;
	
}

.top-page_shop__image img,
.top-page_shop__image--empty {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
  background: #ddd;
	object-position: top;
	border-radius:20px;
	
}


.top-page_shop__name {
  font-size: 18px;
  font-weight: 700;
  margin-top: 12px;
	position: absolute;
    bottom: 72px;
    left: 16px;
	color:#fff;
	z-index: 3;
	margin:0;
	
}
.top-page_shop__item .c-btn{
		position: absolute;
    bottom: 24px;
    left: 16px;
	color:#fff;
	width:160px;
	height:32px;
	display:flex;
	align-items:center;
	padding:8px;
	border:solid 1px #fff;
	border-radius:20px;
	z-index: 3;
	font-size:12px;
}
.top-page_shop__item .c-btn:hover{
	background:unset;
}
.top-page_shop__item .c-btn:after{
	content:"→";
	display:block;
	position:absolute;
	right:8px;
	top:0;
	bottom:0;
	margin:auto;
width: fit-content;
    height: fit-content;
}
.top-page_shop__item:hover:after{
	background:#fff;
	transition:all 0.3s;
	opacity:0.1;
}
/* ============================================
   会社概要
============================================ */
.top-page_company {
  padding: 100px 0;
  background: #f9f9f6;
}

.top-page_company__table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 16px;
}

.top-page_company__table th,
.top-page_company__table td {
  padding: 20px 24px;
  text-align: left;
  font-size: 15px;
  border-bottom: 1px solid #e0e0e0;
}

.top-page_company__table th {
  width: 180px;
  color: #888;
  font-weight: 400;
}

.top-page_company__table tbody tr:first-child th,
.top-page_company__table tbody tr:first-child td {
  border-top: 1px solid #e0e0e0;
}

.top-page_company__table td a {
  color: #333;
  text-decoration: none;
}


@media screen and (max-width: 1250px) {
	.top-page_shop .l-inner{
		width: calc(100% - 40px);
	}
}
@media screen and (max-width: 1024px) {
	.top-page_shop__list{
		justify-content:space-between;
		flex-wrap: wrap;
		gap:24px;
	}
	.top-page_shop__item{
		width:calc(50% - 12px);
		flex:unset;
	}
	.top-page_concept__lead {
        font-size: 20px;
    }
}
@media screen and (max-width: 768px) {
	.top-page_concept {
    padding: 60px 0;
}
	.top-page_shop__list {
        gap: 8px;
        padding: 8px;
    }
	.top-page_shop__item {
        width: calc(50% - 4px);
    }
	.top-page_shop__image img, .top-page_shop__image--empty {
		height:180px;
	}
	.top-page_shop__name{
		font-size:16px;
		width: 90%;
		bottom:52px;
		left:0;
		right:0;
		margin:auto;
		text-align:center;
	}
	.top-page_shop__item .c-btn{
		width: 90%;
    height: 28px;
		bottom:12px;
		left:0;
		right:0;
		margin:auto;
	}
.top-page_concept__lead {
        font-size: 18px;
        margin: 40px auto 0 auto;
	}
	.top-page_shop {
    padding: 60px 0 0 0;
}
	.top-page_shop .l-inner {
		    padding: 40px 0 0 0;
	}
	.top-page_news {
    padding: 60px 0 0 0;
}
.top-page_news__link {
	padding: 12px 0;
    flex-direction: column;
    gap: 12px;
    align-items: flex-start;
}
}

@media screen and (max-width: 640px) {
	.top-page_concept__lead {
        font-size: 15px;
    writing-mode: unset;
    text-orientation: unset;
    }
}