@charset "utf-8";body, html {
  margin: 0;
  padding: 0;
  background-color: #ffffff 
}

.header_inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px;
}

body, html {
overflow-x: hidden; /* 横スクロール防止 */
color:#505050;
}
.menu-link {
  color: inherit;          /* 元の文字色を維持 */
  text-decoration: none;   /* 下線を消す */
  cursor: pointer;         /* クリック時にポインタ表示 */
  transition: opacity 0.3s ease;
}

.menu-link:hover {
  opacity: 0.7;            /* ホバーで少し薄く */
}



*{
  box-sizing: border-box;
}

/* 初期：PC・タブレット用のみ表示 */
.pc-only {
  display: block;
}
.sp-only {
  display: none;
}

.header_list {
    list-style: none;
    display: flex;
    gap: 20px;
    padding: 0;
    text-decoration: none;

}

 html {
    scroll-behavior: smooth;
  }

#MENU {
  scroll-margin-top: 40px; /* ヘッダー高さぶんなどを指定 */
}

.container {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  font-family: 'Noto Sans JP', sans-serif;
}

.logo a {
  display: flex;
  align-items: center;
  padding: 8.5px 0; /* 上下に余白（クリック範囲）を追加 */
  font-size: 20px;
  font-weight: 300;
  margin-top: -1px;
  margin-left: 17.8px;
  text-decoration: none;
  color:#505050;   
  
  transition: opacity 0.4s ease; /* フェードアニメーション */
  cursor: pointer; /* 手のマークにする */


}

.logo a:hover {
  opacity: 0.6; /* 透過度（0に近いほど薄くなる） */
}


.header {
  background-color: #ffff;
  height: 50px;
  display: flex;
  align-items: center;
  padding: 0px 40px;
  z-index: 10;
}

.header_inner {
   display: flex;
   justify-content: space-between;
   align-items: center; 
   width: 100%;
}

.header a{
        border-radius: 12px;          /* 楕円形の形*/
  border: 2px solid transparent; /*枠線（透明にしておく） */
  background-color: transparent; /*背景なし */
  text-decoration: none;
  transition: all 0.3s ease;     /*アニメーション*/
}

.menu_list a {
    display: flex;
    align-items: center;
    padding: 8px 0; 
    font-size: 20px;
    text-decoration: none;
    font-weight: 300;
    margin-right: 17px;
    margin-top: 1px;
    color:#505050;

    /* カーソルを当てたら文字が透過する */
  transition: opacity 0.4s ease; /* フェードアニメーション */
  cursor: pointer; /* 手のマークにする */
}

.menu_list a:hover {
  opacity: 0.6; /* 透過度（0に近いほど薄くなる） */
}


.about_list a {
    display: flex;
    align-items: center;
    padding: 8.5px 0; 
    font-size: 20px;
    text-decoration: none;
    font-weight: 300;
    margin-right: 28px;
    margin-top: 1px;
    color:#505050;
  
    transition: opacity 0.4s ease; /* フェードアニメーション */
    cursor: pointer; /* 手のマークにする */

}


.about_list a:hover {
  opacity: 0.6; /* 透過度（0に近いほど薄くなる） */
}

/* ホバー時（マウスを乗せた時） */
/* a:hover { */
    /* background-color rgb(205, 205, 205) !important; 薄いオレンジ背景 */
  /* color: #302f2e; */
/* } */

.sp-space1 {
  display: none;
 }

#main {
    position: relative;
}

#main picture img {
  display: block;
  width: 100%;
  height: 100%;   
  object-fit: cover;
  z-index: 1;
}

/* 初期状態（PC用を表示、SP用は非表示） */
.heading-pc {
  display: block;

  position: absolute;
  top: 72px; 
  left: 50%; 
  transform: translate(-50%, -50%); 
  font-size: 40px;
  font-weight: 300;
  white-space: nowrap; 
  text-align: center;
  margin: 0;
}
 .heading-sp {
  display: none;
}



h2 {
    font-size: 30px;
    text-align: center;
    font-weight: 300;
    margin-top: 49px;
    margin-left: 0px;
}

#MENU h2::after {
  content: ""; /* これがないと擬似要素が表示されない！ */
  display: block;
  width: 49px; /* 線の長さ */
  height: 2px;  /* 線の太さ */
  background-color: rgba(80, 80, 80, 1); 
  margin: 13px auto 0; /* 上下の余白と中央寄せ */
}


.menu_list {
  display: flex;
  justify-content: center;
  gap: 0px;
  box-sizing: border-box;
}

/* 左端 */
.menu_content:first-child {
  margin-right: -5px;
}

/* 右端 */
.menu_content:last-child {
  margin-left: -5px;
}


.menu_content {
  box-sizing: border-box;
  text-align: center;
  overflow: hidden; /* はみ出した画像を隠す */
  max-width: 31%;  /* 親要素に収まるように */
}

.menu_content picture img {
  margin-top: 5px;
  margin-left: 18px;
  width: 89%; /* 任意の幅 */
  /* height: auto; 任意の高さ */
  /* aspect-ratio: 4 / 3; 必要であれば指定 */
  /* object-fit: contain; 縦横比を保ちつつトリミング */
  display: block;
}

.menu_content_title,
.menu_content_cofee,
.menu_content_cake  {
  font-size: 20px;
  font-weight: 400;
  margin-top: 28px;
  list-style-type: none;

}

 .menu_content_text  {
  margin-top: -11px;
  padding-left: 0px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.65;
}

.menu_content_cofee_text1 {
margin-top: -10px;
margin-left: 0px;
font-size: 15px;
font-weight: 400;

}
.menu_content_cofee_text2 {
margin-top: -11px;
margin-left: 0px;
font-size: 15px;
font-weight: 300;
}

.menu_content_cake_text1, .menu_content_cake_text2 {
margin-top: -10px;
margin-left: 0px;
font-size: 15px;
font-weight: 400;
}

.menu_content ul {
  padding-left: 0;
  list-style-type: none;
}

.menu_content ul li {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.7;
  position: relative; /* ← 必須 */
  margin-top: -12px; 
  margin-right: 1px;
}

.ABOUT_spacer {
  height: 23px;
  background-color: #ffffff;
  z-index: 10;
}

.inner_ABOUT {
  padding-left: 20px;
  padding-right: 20px;
}

#ABOUT {
  background-color: rgba(0, 0, 0, 0.05); 

}



.menu_inner {
  margin: 0 auto; /* 中央寄せ */
  padding: 0 23 px; /* 左右の余白 */

}


h3 {
    font-size: 30px;
    text-align: center;
    font-weight: 300;
    margin-top: 39px;
}

#ABOUT h3::after {
  content: ""; /* これがないと擬似要素が表示されない！ */
  display: block;
  width: 49px; /* 線の長さ */
  height: 2px;  /* 線の太さ */
  background-color: rgba(80, 80, 80, 1); 
  margin: 11px auto 0; /* 上下の余白と中央寄せ */
}

.sp-space2 {
 display: none;

}

.about-flex {
  display: flex;
  justify-content: center; 
  align-items: center;
   gap: 0px;
}

.about-text p {
  display: block;
  line-height: 1.5;
  font-size: 22px;
  font-weight: 400;
  position: relative;
  top: 40px;
  margin-top: 0;
  padding-top: 0;
  padding-left: 40px;    /* 右に移動（余白） */

}


.text-under375 {
  display: none;
}

.li-top_sp-only {
  display: none;
}

.li-bottom_sp-only {
  display: none;
}

.pc-only-br {
  display: inline;
margin-left: 10px;
}
/* .pc-only { */
.li-top  {
   gap: 0px;
  line-height: 1.8;
    font-size: 18px;
    font-weight: 300;
    position: relative;    
    top: 33px;
    margin-top: 0;
    margin-left: 0px;      
  list-style-type: none; /* マークなし */
  z-index: 5;
}

.li-bottom {
  line-height: 1.8;
  font-size: 18px;
  font-weight: 300;
  position: relative;
  top: 35px;
  margin-bottom: 0cqi;
  margin-left: 0px;      
  list-style-type: none; /* マークなし */
}

.about-img-area {
  max-width: 469px;
  width: 100%;
  margin-left: 27px;
  margin-right: 20px;
  margin-top: 0px;
  text-align: right;
  gap: 25px;
}

.about-img-area picture img {
  max-width: 100%;
  height: 100%;
  margin-right: 20px;

}



.about-item_link {
  all: unset;
  width: 248px;
  height: 53px;
  background: rgba(80, 80, 80, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid transparent;
  transition: all 0.3s ease;
  margin-top: 56px;
  margin-left: 39px;

}

.about-item_link:hover {
  background: white;
  border-color: black;
}

.about-item_link a {
  color: white;
  font-size: 25px;
  font-weight: 300;
  text-decoration: none;
  transition: all 0.3s ease;
}

.about-item_link:hover a {
  color: black;
}


.spacer {
  background-color: rgba(0, 0, 0, 0.05);
  height: 40px; /* ← これが縦の空白 */   
}

#footer {
  width: 100%;
  background-color:rgba(80, 80, 80, 1);
  display: flex;
  justify-content: center;
  align-items: center;
}

.pc_footer_text {
  height: 91px;
  font-size: 20px;
  font-weight: 300;
  margin-top: 11px;
  margin-right: 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         0px;
  display: flex;
  text-decoration: none;
  color: #ffff;
}

.sp_footer_text {
  display: none;
}


@media screen and (max-width: 768px) {
  /* .inner {
  margin: 0 auto;
  padding: 0 55px 0 10px;
  } */

    .pc-only-br {
    display: none;
  }

  .header {
    height: 35px; /* ← スマホ時の縦幅を固定 */
    background-color: #ffffff; /* ここで背景色を設定（例：白） */
    position: relative;
    z-index: 10;
  }

  .header_list li {
    display: none; 
  }


   .logo {
    font-size: 19.5px;
    font-weight: 300;
    margin-top: 25px;
    margin-left: -40px;
  }

  .header_inner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
  
 .sp-space1 {
    display: block;
    height: 16px;
    background-color:rgb(255, 255, 255) ;
  }

  #main picture img {
  height: 550px;   
}


  .menu_inner { 
  /* width: 100%; */
  margin: 0 auto;
  padding: 0 25px 0 10px; 
  /* box-sizing: border-box; */
  }
 


  .menu_content {
    max-width: 100%;
    width: 100%;  /* 念のため明示 */
  }


  .menu_content picture,
  .menu_content img {
    display: block;
    width: 100%;
    height:auto;
  }

  .heading-pc {
    display: none;
  }

  .heading-sp  {
    position: absolute;

    display: block;
    position: absolute;
    top: 18%; /* 画面中央に */
    margin-left: 48%;
    transform: translate(-50%, -50%);
    font-size: 35px;
    font-weight: 300;
    text-align: center;
    white-space: normal;
     white-space: nowrap; /* 改行を禁止して「お好みのブレンドを」を1行に */
    width: 80%;
    line-height: 1.2;
    box-sizing: border-box;
  }
  
.line5 {
  display: block;
}

  .line6 {
  margin-top: 0px; /* 微調整（位置が下がりすぎる場合） */
 margin-left: 14px;
}
  
  .menu_content ul li {
    text-align: center;        /* 左寄せ */
    margin-right: 0;         /* 不要な右マージンを削除 */
    margin-left: 0;          /* 必要に応じて調整 */    /* 左に少し余白を追加して読みやすく */
  }

 
  .menu_content ul li .line1 {
    display: block;
    text-align: left;
    margin-left: 65px;
  }

  .menu_content ul li .line2 {     /* ← これが改行の間を詰めるために重要！ */
    
    display: block;
    text-align: center;
  }

    .menu_content ul li .line3 {
    display: block;
    text-align: left;
    margin-left: 98px;
  }

  .menu_content ul li .line4 {     /* ← これが改行の間を詰めるために重要！ */
    
    display: block;
        text-align: left;
        margin-left: 91px;

  }

.main_top {
background-color: #CECDCE; /* 画像と同じ色にする */
}

h2 {
    margin-top: 45px;
    margin-left: 0px;
}
.menu_latte {
    top: 45px;
   max-width: 100%; 
}


.menu_latte picture img {
  /* .menu_latte p { */
  font-size: 20px;
  margin-top: 17px;
  margin-right: 0px;
}

  .menu_latte ul li {
  font-size: 15px;
  margin-top: -13px;
  margin-left: 57px;
}

.menu_latte picture img {
 width: 100%;
}
  .menu_list {
    gap: 10px;
    /* padding: 0 10px;   */
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .menu_coffee picture img {
  width: 100%;
  height: auto;
  display: block;
}
  .menu_coffee picture p {
  font-size: 20px;
  margin-top: 19px;
  margin-right: -1px;
}


  .menu_coffee ul li {
  font-size: 15px;
  margin-top: -14px;
  margin-left: 0px;
}
  .menu_content_cake_text1,
  .menu_content_cake_text2 {
  /* .menu_cake p { */
  font-size: 20px;
  margin-top: 18px;
  margin-right: 0px;
}

  .menu_cake ul li {
  font-size: 15px;
  margin-top: -12px;
  margin-right: -101px;
}

.menu_cake picture img {
  width: 100%;
  height: auto;
  display: block;
}
  .menu_content {
    flex: 1 1 100%;
    max-width: 100%;
  } 
  
  .about-flex {
    flex-direction: column-reverse;
    align-items: flex-start; /* 左寄せにする */

  }

  .about-img-area {
    margin-bottom: 40px;
    max-width: 98%;
    width: 100%;
  }

  .about-img-area picture,
  .about-img-area picture img {
    width: 100%;
    max-width: 100%;
    display: block;
    margin:0 0 0 -10px;
  }

  h3 {
   margin-top: 48px;
}

.about-text ul.li-top {
  max-width: 104%; 
  margin-top: 6px;
  margin-left: -30px;
  text-align: left ;
  overflow-wrap: break-word;

}


.sp-space2{
  display: inline;
}
/* 
.about-img-area picture img {
  width: 100%;
  display:block
} */

#MENU h2::after {
  content: ""; /* これがないと擬似要素が表示されない！ */
  display: block;
  width: 49px; /* 線の長さ */
  height: 2px;  /* 線の太さ */
  background-color: rgba(80, 80, 80, 1); 
  margin: 13px auto 0; /* 上下の余白と中央寄せ */
}


/* .about-item_link {
  display: none;
} */
.about-item_link { 
  width: 300px;
  height: 55px;
  margin: 22px auto 0 auto;
  background: #505050; 
  display: flex;
  align-items: center;   /* 垂直中央揃え */
  justify-content: center; /* 水平方向の中央揃え */
}

.about-item_link a{
  background: none;       /* ボタン自体の背景をなくす */
  border: none;           /* ボーダーをなくす */
  color: hsl(0, 0%, 100%);         /* 文字色を白に */
  font-size: 22px; 
  /* margin-top: 6px; */
  /* margin-left: 3px; */
  cursor: pointer;
}


.spacer {
  background-color: rgba(0, 0, 0, 0.05);
  height: 55px; /* ← これが縦の空白 */
  z-index: 30;
}
}


@media screen and (max-width: 375px) { 
  
  .pc-only {
    display: none;
  }

  .li-top_sp-only,
  .li-bottom_sp-only {
    display: block;
  }

.logo  {
  display: flex;
  align-items: center;
}
  .logo a {
    font-size: 20px;
    text-decoration: none;
      font-size: 20px;
  font-weight: 300;
  margin-top: 2px;
  margin-left: -2px;
    color: #505050;
  }


/* 初期状態（SP用を表示、Pc用は非表示） */
.heading-sp {
  display: block;

  position: absolute;
  top: 100px; 
  left: 48%; 
  transform: translate(-50%, -50%); 
  font-size: 35px;
  /* font-size: clamp(20px, 8vw, 35px); */
  font-weight: 300;
  white-space: nowrap; 
  text-align: center;
  margin: 0;
}
 .heading-pc {
  display: none;
}

 .sp-space1 {
    /* display: block; */
    height: 16px;
    background-color:rgb(255, 255, 255) ;
    z-index: 31;
}

  #main picture img {
    height: 550px;
    object-fit: cover;
    padding-top: 49px;
 }

#MENU h2::after {

  margin-top: 9px;
}


  /* menu_contentの幅を広げる */
  .menu_content {
    max-width: 100%;
    width: 100%;
  }


  /* カフェラテ画像 */
  .menu_latte picture img {
  width: 317px;
  height: 250px; /* 高さを自動計算（または height: 160px; など指定してもOK） */
  margin: -44px 20px auto;
  /* margin-top: -45px; */
  /* width: 310px; 任意の幅 */
  /* height: 253px; 任意の高さ    */
  /* object-fit: cover; トリミングしつつきれいに表示 */
  display: block;
  }
.menu_content_title {
  font-size: 20px;
  margin-left: 0px;
  margin-top: 18px;
}
.menu_content_text {
  font-size: 15px;
  margin-left: 1px;
  margin-top: -12px;
}

 
.menu_latte {    
    height: 500px;
    width: 100%;
    /* max-width: 310px; */
    object-fit: cover;
    padding-top: 50px;
    margin-right: 0px;
  }

.menu_inner {
  padding: 0 10px; /* スマホ時の余白確保。お好みで */
  box-sizing: border-box;
}

.menu_coffee img {
  width: 100%;
  height: auto;
  display: block;
  top: 0px;
  left: 0px;
  object-fit: cover; /* 必要に応じて切り取り表示 */
  max-width: 100%; /* コンテナよりはみ出さないように */
  margin-top: 0px;
  margin-left: 0px;
  object-fit: cover; /* 必要に応じて切り取り表示 */
  max-width: 100%; /* コンテナよりはみ出さないように */

 }  
.menu_coffee picture img {
  margin-top: 1px;
  margin-right: 0px;
  width: 317px; /* 任意の幅 */
  height: 247px; /* 任意の高さ */   
}

.menu_content_cofee {
  margin-top: 19px;
  margin-left: 0px;
}

.menu_cake picture img {
  margin-top: -9px;
  margin-left: 25px;
  width: 317px; /* 任意の幅 */
  height: 258px; /* 任意の高さ */
}

.menu_content_cake  {
  margin-top: 19px;
  margin-left: 10px;
}
.menu_content_cake_text1, 
.menu_content_cake_text2 {
  font-size: 15px;
  margin-top: -11px;
  margin-left: 12px;
}




  .about-img-area {
    margin: 1px auto 0;        /* 上に余白、左右中央揃え */
    text-align: center;         /* 中央寄せ */
    max-width: 93%;             /* コンテナ幅を狭くする */
  }

  .about-img-area picture img {
    width: 100%;                /* コンテナにフィット */
    height: auto;               /* アスペクト比を保つ */
    object-fit: cover;          /* 必要に応じて切り抜き調整 */
    margin-top: 0px;
    margin-left: 10px;
  
  }
    /* .about-text p { */
  /* max-width: 106%;  */
  /* margin-top: 29px; */
  /* margin-left: -33px; */
  /* text-align: center; */
  /* overflow-wrap: break-word; */
/* }     */

/* .pc-btn-submit {
  display: none;
} */
.about-item_link {
  width: 313px;
  height: 55px;
  position: relative;
  top: 15px;
  margin: 0px auto; /* 上に26px、左右はauto、下は0 */
  margin-left: 10px;
  background: #505050; 
  display: flex;
  align-items: center;   /* 垂直中央揃え */
  justify-content: center; /* 水平方向の中央揃え */
}

.about-item_link a {
  background: none;       /* ボタン自体の背景をなくす */
  border: none;           /* ボーダーをなくす */
  color: hsl(0, 0%, 100%);         /* 文字色を白に */
  font-size: 25px; 
  margin-top: -1px;
  margin-left: 0px;
  cursor: pointer;
}

.text-over375 {
    display: none;
  }

 .about-text p {
  display: none;
 }

 .text-under375 {
  display: block;
  width: 98%;
  word-break: break-word;
  font-size: 22px;
   /* font-size: clamp(18px, 1vw, 22px); */
   position: relative;
   top:29px;
  margin-top: 0;
  margin-left: 10px;
  text-align: left;
     word-break: break-word;
    overflow-wrap: break-word;
    white-space: normal;

}

.li-top pc-only {
  display: none;
}

.li-top_sp-only { 
/* .sp-only { */
  line-height: 1.85;
  font-size: clamp(12px, 5vw, 18px);
  word-wrap: break-word;             /* 単語を途中で折り返す */
  position: relative;
  top: 23px;
  margin-top: 0px;
  margin-left: -30px;
  text-align: left ;
  /* overflow-wrap: break-word; */
}


.li-bottom pc-only {
  display: none;
}

.li-bottom_sp-only {
  line-height: 1.8;
  /* font-size: 18px; */
  font-size: clamp(12px, 5vw, 18px);
  word-wrap: break-word;             /* 単語を途中で折り返す */
  position: relative;
  top: 22px;
  margin-top: 0px;
  text-align: left !important;
  overflow-wrap: break-word;
  margin-left: -30px;
}

/* .abaout-text .pc-only-br p { */
    /* display: none; */
  /* } */

.pc_footer_text {
  display: none;
}

.spacer {
  background-color: rgba(0, 0, 0, 0.05);
  height: 65px; /* ← これが縦の空白 */
  z-index: 30;
}
.pc_footer_text {
  display: none;
}
.sp_footer_text {
  height: 91px;
  font-size: 16.5px;
  padding-top: 14px;
  margin-right: 0px;
  display: flex;
  text-decoration: none;
  color: #ffff;
}


}

@media screen and (max-width: 1080px) and (min-width: 769px) {
  .about-flex {
    align-items: flex-start; /* 上端で揃える */
  }

  .about-img-area {
    margin-top: 0; /* 画像が下にずれないように */
  }

  .about-text p {
    margin-top: -22px; /* テキストの上余白をリセット */
    padding-top: 0;
  }
}

@media screen and (max-width: 1079px) and (min-width: 377px) {
    .pc-only-br {
        display: none;
    }


    .about-text {
    padding-left: 0; /* ← 左の余白をリセット */
    padding-right: 0;
    width: 100%; /* ← 画面幅に合わせる */
    box-sizing: border-box;
  }

 .about-text p {
  text-align: left;      /* 左揃えにする */
  padding-left: 7%; 
  word-break: break-word;

  padding-right: 2%;
 }
 
  .about-text ul,
  .about-text li {
    padding-left: 4%;      /* 写真左端と合わせるための余白（調整可） */
    padding-right: 2%;
  }
  .about-item_link {
  padding-left: 4%;      /* 写真左端と合わせるための余白（調整可） */
    padding-right: 4%;
  }
}
@media screen and (max-width: 374px) {
/* 初期状態（SP用を表示、Pc用は非表示） */
.heading-sp {
  display: block;
  font-size: clamp(20px, 8vw, 35px);
  font-weight: 300;
  white-space: nowrap; 
  text-align: center;
}

 .menu_inner { 
  margin: 0 auto;
  padding: 0 25px 0 10px; 
  }


 .menu_content picture img {
  width: 100%;
  height: auto;
  display: block;
}

.about-text {
    padding-left: 0; /* ← 左の余白をリセット */
    padding-right: 0;
    width: 100%; /* ← 画面幅に合わせる */
    box-sizing: border-box;
  }

  .about-text p,
  .about-text ul,
  .about-text li {
    text-align: left;      /* 左揃えにする */
    padding-left: 0;       /* もし余白があれば左の余白をリセット */
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    font-size: 18px; /* 必要なら少し小さく */
    line-height: 1.6;
    word-break: break-word; /* 長い文でも折り返す */
  }

  .li-top_sp-only,
  .li-bottom_sp-only {
    display: block; /* ← SP専用文を表示 */
  }

  .pc-only {
    display: none; /* ← PC用は非表示にする */
  }
  
br {
    display: none;
  }
  .about-text ul,
  .about-text li {
    padding-left: 2%;      /* 写真左端と合わせるための余白（調整可） */
    padding-right: 2%;
  }
 
  .about-item_link {
    width: 100%;
    margin-left: 0;
  }

 .about-item_link a {
    font-size: 20px;
  }

}
