@charset "utf-8";

/* =======================================

	CommonElements

======================================= */
html
{
	scroll-behavior: smooth;
}
body
{
	width: 100%;
	margin: 0 auto 3% auto;
	font-size: 14px;
font-family:  'Libre Baskerville', serif;
	font-weight: 400;
	display:none;
  color: #000000;
}
.cf_sp
{
	display:none;
}
.cf_pc
{
	width: 100%;
}
.wrap
{
	margin: 0 auto 0 auto;
	text-align:center;
}
a:link
{
	color: #000000;
	text-decoration: none;
	font-size: 1em;
font-family:  'Libre Baskerville', serif;
}
a:hover
{
	color: #000;
	text-decoration: underline;
}
a:visited
{
	color: #000000;
}
img
{
	vertical-align:top;
}


	/* ヘッダーメニューPC */
.logo
{
    margin-right: 10px;
}
.language-switcher
{
    position: relative;
}


  /* =======================================

	テキスト

======================================= */

/* リードテキスト */
.lead-text
{
  width: 50%;
  margin: 0 auto;
  font-size: 1.0em;
  letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
  text-align: left;
  display: inline-block;
}


/* セクションタイトル */
.section_title
{
  margin: 0 auto;
  font-size: 1.0em;
    letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
    text-align: left;
     width: 49.5%;
}


/* スタッフクレジットテキスト */
.staff_credit
{
  margin: 0 auto;
  font-size: 1.05em;
  letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
    text-align: left;
  display: inline-block;
  
}


  /* 商品クレジットテキスト */
.item_credit_pc2
{
  margin: 0 auto;
  font-size: 0.8em;
letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
  text-align: left;
  display: inline-block;
   width: 49.5%;
}


/* SP */
@media (max-width:750px)
{
.lead-text
{
  width: 85%;
  margin: 0 auto;
  font-size: 1.25em;
  letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
  text-align: left;
  display: inline-block;
  }

  .section_title
{
    width: 90%;
	font-size: 1.25em;
  }

  

  }
.item_credit_sp
{
  display: block;
  margin: 0 0 0 5%;
  width: 50%;
  font-size: 1.15em;
  letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;
  text-align: left;
}


/* Interview blocks (minimal, no lines) */

/* SP */
@media screen and (max-width: 750px)
{

  /* Interview blocks (minimal, no lines) */
.staff_credit
{
  margin: 0 auto;
  font-size: 1.1em;
  letter-spacing: 0.1em;
  line-height: 2em;
  font-weight: 400;

}

}


/* =========================
   Page Title (H1)
   ========================= */
.page-title
{
  margin: 0 auto 40px;
  text-align: center;
  font-family: 'Libre Baskerville', serif;
  font-weight: 400;
  font-size: 1.4em;
  line-height: 1.4;
  letter-spacing: 0.1em;
}


/* セクション見出し（LINEN HAIRLINE 等） */
.feature-title
{
  margin: 0 auto 20px;
  text-align: center;
  font-family: 'Libre Baskerville', serif;
  font-weight: 400;
  font-size: 1.0em;
  line-height: 1.4;
  letter-spacing: 0.15em;
}


/* 下段（waffle） */
.page-title__sub
{
  display: block;
  margin-top: 10px;
  font-size: 0.7em;
  letter-spacing: 0.15em;
}


/* SP */
@media screen and (max-width: 750px)
{
.page-title
{
    font-size: 1.58em;
    margin-bottom: 28px;
  }
.page-title__sub
{
    font-size: 0.8em;
  }
}


/* マージンクラス */
.bm5
{ margin-bottom: 0.5em; }
.bm10
{ margin-bottom: 1em; }
.bm15
{ margin-bottom: 1.5em; }
.bm20
{ margin-bottom: 2em; }
.bm30
{ margin-bottom: 3em; }
.bm40
{ margin-bottom: 4em; }
.bm50
{ margin-bottom: 7em; }
.bm60
{ margin-bottom: 10em; }
.bm70
{ margin-bottom: 12em; }
.bm100
{ margin-bottom: 15em; }
.bm100a
{ margin-bottom: 15em; border-bottom: #a5a5a5 solid 0.8px; width: 5%; margin-left: auto; margin-right: auto; }
.bm200
{ margin-bottom: 25em; }
.bm50a
{ margin-bottom: 7em; border-bottom: #d5d5d5 solid 0.5px; width: 3%; margin-left: auto; margin-right: auto; }


/* フェードイン */
.fadein
{
  opacity: 0;
  transition: opacity 0.6s ease-in-out;
}
.fadein.active
{
  opacity: 1;
}
.cf_image_yoko img
{
	width:50%;
	max-width:100%;
}

.fab-image-pair
{
  display: flex;
  gap: 8px;
  width: 50%;
  margin: 0 auto;
}

.fab-image-pair img
{
  flex: 1;
  width: 50%;
  max-width: 100%;
}


  /* SP */
@media screen and (max-width: 750px)
{
.cf_image_yoko img
{
	width:90%;
	max-width:100%;
}

.fab-image-pair
{
  flex-direction: column;
  width: 90%;
  gap: 20px;
}

.fab-image-pair img
{
  width: 100%;
}

.item_credit_pc2
{
  display: block;
  margin: 0 0 0 5%;
  width: 90%;
  font-size: 0.95em;
}

}


/* =======================================

	FOOTER

======================================= */
footer
{
    width:100%;
    max-width:1200px;
	margin:0 auto 0 auto;
}


/* =========================
   Footer bar (one-row layout)
   ========================= */
.footer-bar
{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 32px;
  box-sizing: border-box;
  border-top: 1px solid #ccc;
}
.footer-bar__left
{
  display: flex;
  align-items: center;
  gap: 20px;
}
.footer-bar__left a
{
  font-size: 0.78em;
  letter-spacing: 0.1em;
  color: #000;
  text-decoration: none;
}
.footer-bar__left a:hover
{
  text-decoration: underline;
}
.footer-ig-icon
{
  width: 18px;
  height: 18px;
  display: block;
  vertical-align: middle;
}
.footer-bar__right
{
  font-size: 0.78em;
  letter-spacing: 0.1em;
  color: #000;
}
@media screen and (max-width: 750px)
{
.footer-bar
{
    padding: 22px 28px;
  }
.footer-bar__left a
{
    font-size: 1.1em;
  }
.footer-bar__right
{
    font-size: 1.1em;
  }
.footer-ig-icon
{
    width: 24px;
    height: 24px;
  }
}


 /* ===========================================
	スマートフォン系 748 - 
=========================================== */
@media screen and (max-width: 750px)
{
body
{
	width:750px;
	margin: 0 auto 0 auto;
	padding:0 0 0 0 ;
font-family:  'Libre Baskerville', serif;
  	text-align:center;
  	font-size:18px;
	display:none;
}
.cf_sp
{
	display:block;
}
.cf_pc
{
	display:none;		
}
a:link
{
	color: #000000;
	text-decoration: none;
}
a:hover
{
	color: #959595;
	text-decoration: underline;
}


/* =======================================

	HEADER

======================================= */
header
{ 
	z-index: 9999;
	padding:0 0 0 0;
	margin:0 auto 0 auto;
	text-align:center;
	width:100%;
}


/* =======================================

	FOOTER

======================================= */
footer
{
	width:100%;
	margin:0 auto 0 auto;
}

}


/* =========================
   Header row layout (PC/SP)
   ========================= */
.fixed-header
{
	position: fixed;
    top: 0;
    left: 0;
    right: 0;
  z-index: 10000;
}


/* SP */
@media screen and (max-width: 750px)
{
.header-content--sp
{
    padding: 28px 28px 12px;
    padding-top: calc(28px + env(safe-area-inset-top));
    gap: 12px;
    min-height: 64px;
    box-sizing: border-box;
  }
.logo--sp .brand-logo
{
    height: 25px;             /* SPは存在感を少し上げる */
    max-width: 52vw;          /* はみ出し防止 */
  }
.logo--sp .logo__link
{
    padding-top: 9px;  /* SPだけ少し多め、好みで */
  }

}


/* =========================
   Header right group
   ========================= */
.header-right
{
  display: flex;
  align-items: center;
  gap: 24px;
}
.header-shop-link,
a.header-shop-link:link,
a.header-shop-link:visited
{
  font-size: 14px;
  letter-spacing: 0.08em;
  color: #fff !important;
  text-decoration: none;
  line-height: 1;
  opacity: 0.8;
  transition: color 0.3s, opacity 0.3s;
}
.header-shop-link:hover
{
  opacity: 1;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
body.is-scrolled .header-shop-link,
body.is-scrolled a.header-shop-link:link,
body.is-scrolled a.header-shop-link:visited
{
  color: #000 !important;
  text-decoration-color: #000;
}
@media screen and (max-width: 750px)
{
.header-shop-link
{
    font-size: 20px;
  }
}


/* =========================
   Language switcher underline rule
   ========================= */

/* 共通 */
.language-switcher
{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Libre Baskerville', serif;
  letter-spacing: 0.08em;
  line-height: 1;
}
.language-switcher .lang,
.language-switcher .lang-sep
{
  color: #000;
}


/* 現在言語（下線なし・リンクでない） */
.language-switcher .lang.is-current
{
  text-decoration: none;
  opacity: 1;
  cursor: default;
}


/* リンク側：常時下線あり */
.language-switcher a.lang
{
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  opacity: 0.8;
}


/* hover時は少しだけ濃く */
.language-switcher a.lang:hover
{
  opacity: 1;
}


/* サイズ */
.language-switcher--pc
{
  font-size: 14px;
}
@media screen and (max-width: 750px)
{
.language-switcher--sp
{
    font-size: 20px;
  }
}


/* =========================
   Language switcher color change (white → black)
   ========================= */

/* 初期状態：白（FV上） */
.language-switcher .lang,
.language-switcher .lang-sep
{
  color: #fff;
}


/* 下線も白に */
.language-switcher a.lang
{
  text-decoration-color: #fff;
}


/* スクロール後：黒 */
body.is-scrolled .language-switcher .lang,
body.is-scrolled .language-switcher .lang-sep
{
  color: #000;
}
body.is-scrolled .language-switcher a.lang
{
  text-decoration-color: #000;
}


/* =========================
   SP header scrim (AFTER scroll)
   ========================= */
@media screen and (max-width: 750px)
{

  /* 初期状態：背景なし（FV） */
.fixed-header
{
    background-color: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    transition: background-color 0.3s ease, backdrop-filter 0.3s ease;
  }

  /* スクロール後：白の網掛けを表示 */
body.is-scrolled .fixed-header
{
    background-color: rgba(255, 255, 255, 0.65);
    backdrop-filter: saturate(120%) blur(2px);
    -webkit-backdrop-filter: saturate(120%) blur(2px);
  }
}
.header-content
{
  display:flex;
  justify-content:space-between;
  align-items:center;

  height:72px;   /* ←これが超重要（60〜80で好み） */
  padding:0 32px;
  box-sizing:border-box;
}
@media screen and (max-width:750px)
{
.header-content
{
    height:84px;
    padding:0 24px;
  }
}


/* ロゴリンク */
.logo__link
{
  display: flex;
  align-items: center;
  line-height: 0;
  padding-top: 20px;
}


/* PC：ロゴをしっかり見えるサイズへ */
.logo--pc .brand-logo
{
  height: 44px;          /* 23px → 44px（ここで調整） */
  width: auto;
  max-width: 520px;      /* 併記ロゴが長いので少し余裕 */
}


/* SP：ついでにバランス良く */
@media screen and (max-width: 750px)
{
.logo--sp .brand-logo
{
    height: 34px;        /* 25px → 34px（ここで調整） */
    width: auto;
    max-width: 70vw;
  }
}


/* ===== Force logo size (PC/SP) ===== */
.header-content--pc .logo--pc .brand-logo
{
  height: 28px !important;
  width: auto !important;
  max-width: 520px !important;
}
@media screen and (max-width: 750px)
{
.header-content--sp .logo--sp .brand-logo
{
    height: 27px !important;
    width: auto !important;
    max-width: 70vw !important;
  }
}
.brand-logo
{
  display: block;
  width: auto;
  height: 34px;
  filter: brightness(0) invert(1);
  transition: filter .35s ease;
}


/* スクロール後：黒に戻す */
body.is-scrolled .brand-logo
{
  filter: none;
}


/* =========================
   Look Side Navigation (PC only)
   ========================= */
.look-side-nav
{
  position: fixed;
  left: 32px;
  top: 130px;
  z-index: 9000;
  display: flex;
  flex-direction: column;
  gap: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
body.is-scrolled .look-side-nav
{
  opacity: 1;
  pointer-events: auto;
}
.look-side-nav__item
{
  display: block;
  font-family: 'Libre Baskerville', serif;
  font-size: 0.75em !important;
  letter-spacing: 0.18em;
  color: #aaa;
  text-decoration: none;
  position: relative;
  padding-left: 22px;
  transition: color 0.3s;
  line-height: 1;
}
.look-side-nav__item::before
{
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 1px;
  background: #ccc;
  transition: width 0.3s ease, background 0.3s ease;
}
.look-side-nav__item:hover,
.look-side-nav__item.is-active
{
  color: #555;
  text-decoration: none;
}
.look-side-nav__item:hover::before,
.look-side-nav__item.is-active::before
{
  width: 22px;
  background: #555;
}
.look-anchor
{
  display: block;
  height: 0;
  visibility: hidden;
  scroll-margin-top: 90px;
}
@media screen and (max-width: 750px)
{
.look-side-nav
{
    display: none;
  }
}


/* =========================
   Item Pickup Grid
   ========================= */
.item-pickup
{
  width: 100%;
  padding: 8em 0 6em;
  text-align: center;
}
.item-pickup__inner
{
  display: inline-block;
  width: 60%;
  text-align: left;
}
.item-pickup__grid
{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 52px 28px;
}
.item-pickup__cell a
{
  display: block;
  text-decoration: none;
  color: #000;
}
.item-pickup__cell img
{
  width: 100%;
  height: auto;
  display: block;
  transition: opacity 0.3s ease;
}
.item-pickup__cell a:hover img
{
  opacity: 0.75;
}
.item-pickup__name
{
  font-family: 'Libre Baskerville', serif;
  font-size: 0.78em;
  letter-spacing: 0.06em;
  line-height: 1.7;
  margin: 10px 0 3px;
  font-weight: 400;
}
.item-pickup__price
{
  font-family: 'Libre Baskerville', serif;
  font-size: 0.78em;
  letter-spacing: 0.06em;
  margin: 0;
  font-weight: 400;
}


/* SP */
@media screen and (max-width: 750px)
{
.item-pickup
{
    padding: 6em 0 5em;
  }
.item-pickup__inner
{
    width: 88%;
  }
.item-pickup__grid
{
    grid-template-columns: repeat(2, 1fr);
    gap: 44px 20px;
  }
.item-pickup__name
{
    font-size: 1.0em;
    margin-top: 12px;
  }
.item-pickup__price
{
    font-size: 1.0em;
  }
}
