@charset "utf-8";
/* CSS Document */
html {
  overflow-y: scroll;
}
#contents {
  background-color: #f8cb00;
  margin: 0;
}
@media (max-width: 736px) {
  div#contents {
    background-color: #f8cb00;
  }
}
/*===============================================
●共通
===============================================*/
#torotama_cp picture img {
  width: 100%;
  height: auto;
}
/* --- Key Visual Section (Responsive & Tight Layout) --- */
.kv-section {
  width: 100%;
  aspect-ratio: 1200 / 630;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  overflow: hidden;
  margin-bottom: 0px;
  position: relative;
}
.kv-section picture {
  display: flex;
  justify-content: center;
  width: 100%;
  height: auto;
  align-items: flex-end;
}
.kv-image {
  width: auto;
  max-width: 100%;
  max-height: 100%;
  animation: dropAndPoyon 1.2s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  opacity: 0;
  transform-origin: bottom center;
}
/* --- Responsive (SP Breakpoint: 736px) --- */
@media screen and (max-width: 736px) {
  /* --- KV Adjustment for SP --- */
  .kv-section {
    width: 100vw;
    height: auto;
    aspect-ratio: 1 / 1;
    max-height: none;
    padding-bottom: 0;
    margin: 5px -15px 0 -15px;
  }
  .kv-section picture {
    height: 100%;
  }
  .kv-image {
    width: 100%;
    height: auto;
  }
}
/* --- Drop & Poyon Animation Keyframes --- */
@keyframes dropAndPoyon {
  0% {
    /* PC画像は大きいので落下距離の調整 */
    transform: translateY(-500px) scaleY(1.1) scaleX(0.9);
    opacity: 0;
    animation-timing-function: ease-in;
  }
  40% {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
  50% {
    /* 大きな画像なので歪みは少し控えめにすると上品です */
    transform: translateY(10px) scaleY(0.85) scaleX(1.1);
    animation-timing-function: ease-out;
  }
  65% {
    transform: translateY(-10px) scaleY(1.05) scaleX(0.95);
  }
  80% {
    transform: translateY(0) scaleY(0.98) scaleX(1.02);
  }
  100% {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}
/* --- Scroll Animation Classes --- */
.js-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.js-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}
#torotama_cp .tit_area {
  position: relative;
  width: calc(100vw - 0.7%);
  margin: 0 calc(50% - 50vw);
  background-color: #fef5ce;
  padding-top: 4%;
  padding-bottom: 1px;
}
#torotama_cp .light_bg {
  width: calc(100vw - 0.7%);
  margin: 0 calc(50% - 50vw);
  background-color: #fef5ce;
  padding-top: 1px;
  padding-bottom: 4%;
  background-image: linear-gradient(360deg, rgba(252, 201, 0, 1), rgba(254, 245, 206, 1) 99%);
}
@media (max-width: 736px) {
  #torotama_cp .tit_area {
    position: relative;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    background-color: #fef5ce;
    padding-top: 4%;
    padding-bottom: 1px;
  }
  #torotama_cp .light_bg {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    background-color: #fef5ce;
    padding-top: 1px;
    padding-bottom: 4%;
    background-image: linear-gradient(360deg, rgba(252, 201, 0, 1), rgba(254, 245, 206, 1) 99%);
  }
}
#torotama_cp h1 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 900;
  font-style: normal;
  text-align: center;
  font-size: clamp(1.8rem, 1.007rem + 1.72vw, 2.3rem);
  line-height: 1.3;
  color: #e60811;
  text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
  position: relative;
  z-index: 100 !important;
}
#torotama_cp .h1_sub {
  text-align: center;
  color: #333;
  font-size: clamp(1rem, 0.683rem + 0.69vw, 1.2rem);
  margin: .6rem 0 2rem;
  position: relative;
  z-index: 100 !important;
}
#torotama_cp .custom-shape-divider-top-1766127340 {
  position: absolute;
  top: 0px;
  left: 0;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  z-index: 1;
}
#torotama_cp .custom-shape-divider-top-1766127340 svg {
  position: relative;
  display: block;
  width: calc(100% + 1.3px);
  height: 150px;
  transform: rotateY(180deg);
  z-index: 1;
}
@media (max-width: 736px) {
  #torotama_cp .custom-shape-divider-top-1766127340 svg {
    height: 90px;
  }
}
#torotama_cp .custom-shape-divider-top-1766127340 .shape-fill {
  fill: #f8cb00;
  z-index: -100;
}
/* --- 見出しのレイアウト設定 --- */
.egg-title {
  color: #e60811;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 900;
  font-style: normal;
  margin-top: 0rem;
  margin-bottom: 1rem;
  text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
  font-size: clamp(1.4rem, 0.924rem + 1.03vw, 2rem);
  display: flex; /* 横並びにする */
  align-items: center; /* 上下中央揃え */
  justify-content: center; /* 左右中央揃え */
  gap: 15px; /* 文字と卵の間隔 */
}
/* --- ゆで卵アイコン（見出し用にサイズ調整版） --- */
.egg-title .boiled-egg {
  /* 文字サイズに合わせて大きさを変える（ここでは文字の0.8倍） */
  width: 1.4em;
  height: 1.4em;
  background-color: #fff;
  border-radius: 50% 55% 50% 50%; /* 少し形を不揃いに調整 */
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: inset -0.05em -0.05em 0.15em rgba(0, 0, 0, 0.05), 0.02em 0.05em 0.1em rgba(0, 0, 0, 0.1);
  /* 縮小しても形が崩れないようflex-shrinkを指定 */
  flex-shrink: 0;
}
/* --- 黄身の部分 --- */
.egg-title .boiled-egg::before {
  content: "";
  /* 白身に対して55%くらいの大きさ */
  width: 55%;
  height: 55%;
  background-color: #ffcc00;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #ffeb3b, #ff9800);
  box-shadow: inset -0.02em -0.02em 0.05em rgba(0, 0, 0, 0.1);
}
/* --- Layout Container --- */
#torotama_cp {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 0px;
}
/* --- Section Titles --- */
.section-title {
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 30px;
  color: #e67e22; /* たまごの黄身イメージ */
  border-bottom: 2px solid #e67e22;
  padding-bottom: 10px;
  display: inline-block;
}
.section-wrapper {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center; /* タイトル中央寄せ用 */
  margin-bottom: 4%;
}
/* --- Card Styles (Common) --- */
.item-card {
  width: 100%;
  /*background-color: #fef5ce;  指定背景色 */
  background-image: linear-gradient(360deg, rgba(252, 201, 0, 1), rgba(254, 245, 206, 1) 50%);
  border-radius: 20px;
  border: 5px solid #f8cb00;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}
.item-image, .item-imageS {
  width: 100%;
  object-fit: cover;
  border-radius: 10px;
}
.item-meta {
  width: 100%;
  display: flex;
  align-items: center;
  margin-top: 5px;
  font-size: 1rem;
  font-weight: 500;
}
.new {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  font-size: 0.9rem;
  color: #108730;
  border: 1px solid #108730;
  border-radius: 50px;
  padding: 0 1rem 0 0;
}
.release-date {
  font-size: 1rem;
  color: #e60811;
  background-color: #fff;
  border: 1px solid #e60811;
  font-weight: 500;
  border-radius: 50px;
  padding: .2rem 1rem .3rem;
  margin-right: 10px;
}
.new-date {
  line-height: 1;
  font-size: 1rem;
  color: #fff;
  font-weight: 500;
  background-color: #108730;
  border-radius: 50px;
  padding: .5rem 1rem;
  margin-right: 10px;
}
.renew {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  font-size: 0.9rem;
  color: #DB350B;
  border: 1px solid #DB350B;
  border-radius: 50px;
  padding: 0 1rem 0 0;
}
.renew-date {
  line-height: 1;
  font-size: 1rem;
  color: #fff;
  font-weight: 500;
  background-color: #DB350B;
  border-radius: 50px;
  padding: .5rem 1rem;
  margin-right: 10px;
}
.item-name {
  color: #c20010;
  font-size: 1.4rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 900;
  font-style: normal;
}
.item-price {
  font-size: 1.1rem;
  font-weight: bold;
  color: #333;
  margin-bottom: 5px;
}
.item-desc {
  font-size: 0.95rem;
  margin-bottom: 10px;
}
.item-desc > span {
  font-size: 88%;
}
/* --- Maker Comment Styles (Updated) --- */
.maker-comment {
  background-color: #fff;
  border: 2px dotted #f5a400;
  padding: 10px;
  border-radius: 10px;
  font-size: 1rem;
  position: relative;
  margin-top: auto; /* カード下部に配置 */
}
/* 以前の ::before を削除し、h4用のスタイルを追加 */
.maker-comment h4 {
  margin: 0 0 5px 0; /* 余白調整 */
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  line-height: 1.4;
}
.maker-comment h4 {
  margin: 0 0 5px 0; /* 余白調整 */
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  line-height: 1.4;
  display: flex; /* 横並びにする */
  align-items: le; /* 上下中央揃え */
  justify-content: center; /* 左右中央揃え */
  gap: 5px; /* 文字と卵の間隔 */
}
.maker-comment p {
  margin: 0;
  font-size: clamp(0.85rem, 0.771rem + 0.17vw, 0.9rem);
  line-height: 1.5;
}
/* --- ゆで卵アイコン（見出し用にサイズ調整版） --- */
.maker-comment .boiled-egg {
  /* 文字サイズに合わせて大きさを変える（ここでは文字の0.8倍） */
  width: 1.4em;
  height: 1.4em;
  background-color: #fff;
  border-radius: 50% 55% 50% 50%; /* 少し形を不揃いに調整 */
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: inset -0.05em -0.05em 0.15em rgba(0, 0, 0, 0.05), 0.02em 0.05em 0.1em rgba(0, 0, 0, 0.1);
  /* 縮小しても形が崩れないようflex-shrinkを指定 */
  flex-shrink: 0;
}
/* --- 黄身の部分 --- */
.maker-comment .boiled-egg::before {
  content: "";
  /* 白身に対して55%くらいの大きさ */
  width: 55%;
  height: 55%;
  background-color: #ffcc00;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #ffeb3b, #ff9800);
  box-shadow: inset -0.02em -0.02em 0.05em rgba(0, 0, 0, 0.1);
}
/* --- Grid Layouts --- */
/* お弁当 (PC: 2カラム) */
.grid-bento {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  text-align: left;
}
/* 惣菜 (PC: 3カラム) */
.grid-souzai {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  text-align: left;
}
/* --- Manufacturer Section --- */
.maker-section {
  background-color: #fef5ce;
  border-top: 4px solid #fef5ce;
  padding: 40px 0 20px;
  margin-top: 0px;
}
.maker-info-wrapper {
  max-width: 1200px;
  display: grid;
  grid-template-columns: 300px 1fr; /* ロゴ幅固定 + テキスト可変 */
  gap: 40px;
  align-items: center;
  background-color: #fff;
  padding: 30px;
  margin: 0 auto 20px;
  border-radius: 8px;
  border: 2px dotted #f5a400;
  box-sizing: border-box;
}
.maker-logo img {
  width: 100%;
  height: auto;
  border: 1px solid #ddd; /* ロゴの境界をわかりやすく */
}
.maker-text h2 {
  font-size: 1.3rem;
  margin-bottom: 15px;
}
.maker-text p {
  text-align: left;
}
.maker-url {
  display: inline-block;
  margin-top: 15px;
  font-weight: bold;
}
/* --- Responsive (SP Breakpoint: 736px) --- */
@media screen and (max-width: 736px) {
  /* お弁当 & 惣菜 共通で1カラム */
  .grid-bento, .grid-souzai {
    grid-template-columns: 1fr;
    gap: 20px;
    margin: 0 15px;
  }
  .grid-souzai .item-imageS {
    width: 80%;
    margin: 0 auto;
  }
  /* メーカー紹介 1カラム */
  .maker-info-wrapper {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 20px;
  }
  .maker-logo {
    max-width: 200px;
    margin: 0 auto;
  }
  .container {
    padding: 0px 15px;
  }
  .section-title {
    font-size: 1.5rem;
  }
}
.aten {
  font-size: 0.8rem;
  color: #666;
  text-align: center;
  margin: 0;
  padding: 0;
}
.aten::before {
  content: "※";
}
.kome-list {
  list-style: none;
  padding-left: 0;
}
.kome-list li {
  position: relative;
  padding-left: 1.5em;
  margin-top: .6rem;
  color: #666;
  font-size: 0.85rem;
  line-height: 0.8;
}
.kome-list li::before {
  content: "※";
  position: absolute;
  left: 0;
  top: 0;
}
#torotama_cp .marker {
  font-weight: 600;
  text-decoration: #e60811 wavy underline;
}
/*===============================================
●pc.css 画面の横幅が737px以上
===============================================*/
@media screen and (min-width: 737px) {
  #torotama_cp {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0 1rem;
  }
  #torotama_cp .pc-none {
    display: none;
  }
  .youtube {
    width: 70%;
    margin: 20px auto 10px;
    padding: 1rem 1rem .7rem;
    aspect-ratio: 16 / 9;
    position: relative;
    border-radius: 20px;
    border: 5px solid #f8cb00;
  }
  .youtube iframe {
    width: 100%;
    height: 100%;
  }
}
/*===============================================
●sp.css 画面の横幅が7364pxまで
===============================================*/
@media screen and (max-width: 736px) {
  #torotama_cp .sp-none {
    display: none;
  }
  #torotama_cp {
    width: 100%;
    margin: 0px auto;
    margin-top: -54px;
  }
  .youtube {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 0px;
    height: 0;
    overflow: hidden;
    margin: 20px 0 50px;
  }
  .youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}