﻿@charset "utf-8";

:root{
  --en:'Inter';
  --orangeColer:#EA7401;
  --grayColor:#9C9C9C;
  --whiteColor:#fff;
  --bgColor:#FBFBFB;
  --bglightOrange:#FDFBF4;
}


/* 共通 */
.contents{
    width: 100%;
  max-width: 960px;

}

br.sp{
  display: none;
}



/* 英語共通タイトル */

h3.enFont{
  font-family: var(--en);
  color: var(--orangeColer);
  line-height: 1;
  font-size: 2rem;
  letter-spacing: 3.2px;
  text-align: center;
  font-weight: 600;
}

h3.enFont span{
  color: var(--grayColor);
  font-size: 1rem;
}


@media screen and (min-width:600px) and ( max-width:1023px) {
/* メインビジュアル タブレット */
div#mainImg{
  width: 100vw;
}
}

/* メインビジュアル タブレット */
@media screen and (max-width: 640px) {
  div#spMainImg {
    background: url("../img/top/spMainImg.jpg") 0 0 / cover no-repeat;
  }
  div#mainImgArea {
    margin-bottom: 40px;
  }
}

/* ビジョン */
.p-vision__contents{
  background-color: var(--bgColor);
  padding: 40px 0;
}

.p-visionCopy__wrap{
  margin-top: 40px;
  text-align: center;
}

.p-visionCopy__bold{
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1;
}

.p-visionCopy__nomal{
  font-size: 0.875rem;
  margin: 16px 0;
  line-height: 1;
}

/* ミッション */

.p-mission__contents{
  padding: 40px 0 50px;
}

.p-missionCopy__wrap{
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 2;
  text-align: center;
  margin-top: 40px;
}

/* おいしさを約束 */
.p-promise__wrap{
  position: relative;
  border: solid 1px var(--orangeColer);
  margin-top: 70px;
  padding: 70px 10px 10px;
}

.p-promise__title{
  position: absolute;
  box-sizing: border-box;
  top: 0;
  left: 50%;
  transform: translate(-50%,-50%);
  z-index: 1;
  background-color: var(--whiteColor);
  padding: 0 15px;
  font-size: 1.25rem;
  font-weight: 600;
  text-align: center;
  color: var(--orangeColer);
  line-height: 1;
  letter-spacing: 3.2px;
}

.p-promise__title span{
  color: #000;
  font-size: 1rem;
  line-height: 1;
  margin-top: 7px;
  display: block;
}

.p-promise__itemBox{
  text-align: center;
}

.p-promise__itemTitle{
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 2;
}

.p-promise__itemTitle.-orange{
  color: var(--orangeColer);
}

.p-promise__itemTitle:not(:first-child){
  margin-top: 20px;
}

.p-promise__itemText{
  font-size: 0.875rem;
  line-height: 1;
  margin-top: 8px;
  /* position: relative;
  display: inline; */
}

/* .p-promise__itemText::before{
  content: "";
  position: absolute;
  background-color: #000;
  height: 1px;
  width: 15px;
  top:6px;
  left: -20px;
} */

.p-promise__itemText.-fontSize{
  font-size: 1rem;
}

.p-message__title{
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  margin: 20px 0 16px;
}

.p-message__text{
  text-align: center;
}


/* オレンジ背景 */
.l-bg__lightOrange{
  background-color: var(--bglightOrange);
  padding: 10px 0;
  margin-top: 20px;
}



/* バリュー */
.p-value__contents{
  background-color: var(--bgColor);
  padding: 40px 0;
}

.p-value__mainCopy{
  color: var(--orangeColer);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 2;
  text-align: center;
  margin-top: 40px;
}

.p-value__copyText{
  text-align: center;
  margin-top: 24px;
  font-size: 0.875rem;
  line-height: 1.5
}

.p-copyText.-b{
  margin-top: 20px;
}

.p-copyText span{
  font-weight: 600;
}

/* お店 */

.p-shop__wrap{
  display: flex;
  flex-wrap: wrap;
  gap: 50px 20px;
  justify-content: space-between;
  margin-top: 80px;
}

/* div.shop{
  float: none;
  margin: 0;
  width: calc(50% - 10px); 
  max-width: 460px;        
  box-sizing: border-box; 
} */

div.shop {
    float: none;
    margin: 0;
    width: calc(50% - 10px);
    max-width: 460px;
    box-sizing: border-box;
    /* height: calc(220vh / 9.6); */
    aspect-ratio: 16 / 9;
}

div.shop a{
    display: flex;
    height: 100%;
    flex-direction: column;
}

div.shop div.textArea{
  margin-top: auto;
}

div.shop div.textArea p{
  padding: 15px 8px;
}

/* div#Nikumabushi-shi{
  background: no-repeat left top / 460px url(../img/top/dummy.png);
} */

div#sShin{
  background: no-repeat left bottom/460px url(../img/top/shinImg.jpg);
}

div#sGyusyo-shin{
  background: no-repeat left bottom / 460px url(../img/top/gyusyo-shinImg.jpg);
}

div#Nikumabushi-shi{
    background: no-repeat left bottom / 100% url(../img/top/NikumabushiImg.webp);
}

/* 会社概要 */
.p-company__wrap{
  display: flex;
  gap: 40px;
}

div#hardData{
  float: none;
  width: 100%;
  margin: 80px 0;
  /* padding: 0 10px; */
  box-sizing: border-box;
}

.p-company,
.p-history{
width:calc((100% - 40px)/2);
}


/* マップ */
div#mapArea{
  float: none;
  width: 100%;
}

div#mapArea ul{
  text-align: center;
}

div#mapArea ul li:before{
  content: none;
}


/* タブレット幅 レスポンシブ対応 */
@media screen and (max-width: 959px) {
  body {
    min-width: auto;
  }
}


@media screen and (max-width: 820px) {

/* VISION*/
.p-vision__contents{
  padding: 40px 10px;
}

.p-visionCopy__bold{
  font-size: 1.125rem;
  line-height: 1.5;
}

/* MISSION */
.p-mission__contents{
  padding: 40px 10px 50px;
}

.p-missionCopy__wrap{
  font-size: 1rem;
}

/* おいしさを約束 */

.p-promise__wrap{
  padding: 70px 5px 5px;
}
.p-promise__title {
  font-size: 1rem; 
  max-width: 90vw; 
  white-space: normal;
  transform: translate(-50%, -35%); /* 中央上寄りに */
  line-height: 1.4; /* 行間少しゆったり */
  width: 100%;
  padding: 5px;
}

.p-promise__title span {
  font-size: 0.75rem;
  line-height: 1.4;
}

.p-promise__itemTitle{
  font-size: 1.125rem;
}

.p-promise__itemText{
  font-size: 0.75rem;
  line-height: 1.2;
}
.p-promise__itemText.-fontSize{
  font-size: 0.875rem;
}
.p-message__title{
  font-size: 0.875rem;
}
.p-message__text{
   font-size: 0.75rem;
}

/* VALUE */
.p-value__contents{
    padding: 40px 10px;
}
.p-value__copyText{
  font-size: 0.75rem;
}

/* お店 */
.p-shop__wrap{
  justify-content: center;
  padding: 0 10px;
}

  /* 会社概要 */
div#hardData{
  padding: 0 10px;
}

/* マップ */
div#map{
  padding: 0 10px;
}

div#mapArea ul{
  padding-left: 0;
  text-indent: 0;
}

}

/* スマホのみ */
@media screen and (max-width: 767px) {
br.sp{
  display: block;
}

.p-visionCopy__wrap{
  margin-top: 20px;
}

.p-visionCopy__nomal{
  line-height: 1.5;
}

.p-missionCopy__wrap{
  margin-top: 20px;
}

.p-promise__wrap{
  margin-top: 50px;
}

.p-value__mainCopy{
  margin-top: 20px;
}

div.shop {
  width: 100%;
}

.p-shop__wrap{
  gap: 30px 20px;
}

div#hardData{
  margin: 60px 0;
}

.p-company__wrap{
  flex-direction: column;
}

.p-company, .p-history{
  width: 100%;
  margin: 0 auto;
}
}


