@charset "utf-8";

/* =========================================================
   販売開始お知らせ登録ページ 全体
========================================================= */
.noticeLp {
  max-width: 920px;
  margin: 0 auto;
  padding: 20px 16px 60px;
  color: #3e3128;
  line-height: 1.9;
}

.noticeHero {
  padding: 54px 24px 42px;
  margin-bottom: 36px;
  border: 1px solid #eadfce;
  background: linear-gradient(180deg, #fbf7f1 0%, #fffdf9 100%);
  border-radius: 18px;
  text-align: center;
}

.noticeHero__sub {
  margin: 0 0 10px;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  color: #9a7d5f;
}

.noticeHero__title {
  margin: 0 0 16px;
  font-size: 2rem;
  line-height: 1.4;
  font-weight: 600;
}

.noticeHero__lead {
  margin: 0 auto 24px;
  max-width: 700px;
  font-size: 1.02rem;
}

.noticeHero__cta {
  margin-top: 20px;
}

.noticeBtn {
  display: inline-block;
  padding: 14px 28px;
  /* border-radius: 999px; */
  text-decoration: none;
  transition: opacity 0.25s ease;
}

.noticeBtn:hover {
  opacity: 0.85;
}

.noticeBtn--primary {
  background: #8a5a3b;
  color: #fff !important;
}

.noticeIntro {
  margin-bottom: 44px;
}

.noticeBlock,
.noticeMerit,
.noticeChoice,
.noticeFormWrap,
.noticeFaq {
  margin-bottom: 34px;
  text-align: left;
}

.noticeHeading {
  margin: 0 0 16px;
  font-size: 1.25rem;
  line-height: 1.5;
  color: #4c3728;
  background-color: #f5f1ea;
  padding: 5px 10px;
}

.noticeHeading--center {
  text-align: center;
  background-color: #f5f1ea;
}

.noticeMeritList {
  margin: 0;
  padding-left: 1.2em;
}

.noticeChoice__lead {
  text-align: center;
  margin: 0 0 20px;
  color: #6e5a4b;
}

.noticeCategoryCards {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.noticeCard {
  flex: 1 1 280px;
  background: #fff;
  border: 1px solid #eadfce;
  border-radius: 16px;
  padding: 22px 20px;
  box-shadow: 0 8px 20px rgba(80, 50, 20, 0.04);
}

.noticeCard__title {
  margin: 0 0 12px;
  font-size: 1.15rem;
  color: #7e5637;
  background-color:#FFF !important;
}

.noticeMiniList {
  margin: 0;
  padding-left: 1.2em;
}

/* =========================================================
   フォーム外枠
========================================================= */
.noticeFormWrap {
  /* background: #fcfaf6; */
  border: 1px solid #eadfce;
  border-radius: 18px;
  padding: 28px 20px;
}

.noticeFormHead {
  text-align: center;
  margin-bottom: 24px;
}

.noticeFormHead__lead {
  margin: 0;
  color: #6e5a4b;
}

/* =========================================================
   フォーム初期化
========================================================= */
.noticeLp #mail_form,
.noticeLp #mail_form dl,
.noticeLp #mail_form dt,
.noticeLp #mail_form dd,
.noticeLp #mail_form ul,
.noticeLp #mail_form li,
.noticeLp #mail_form p {
  margin: 0;
  padding: 0;
}

.noticeLp #mail_form {
  width: 100%;
  max-width: 860px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 12px;
  box-sizing: border-box;
}

.noticeLp #mail_form .noticeFormDl {
  padding: 0 20px;
  box-sizing: border-box;
  display: flow-root;
}

.noticeLp #mail_form ul {
  list-style: none;
}

/* =========================================================
   このページでは1カラム固定
========================================================= */
.noticeLp #mail_form .noticeFormDl dt,
.noticeLp #mail_form .noticeFormDl dd {
  float: none;
  width: 100%;
  text-align: left;
  box-sizing: border-box;
}

.noticeLp #mail_form .noticeFormDl dt {
  clear: both;
  border-top: 1px solid #cccccc;
  padding: 15px 0 8px;
  overflow: visible;
  color: #333;
}

.noticeLp #mail_form .noticeFormDl dd {
  border-top: none;
  padding: 0 0 20px 0;
}

.noticeLp #mail_form .noticeFormDl dt:first-child,
.noticeLp #mail_form .noticeFormDl dt:first-child + dd {
  border-top: none;
}

/* =========================================================
   見出し内テキスト
========================================================= */
.noticeLp #mail_form .noticeFormDl dt > span {
  display: block;
  font-size: 85%;
  color: #3377ff;
}

.noticeLp #mail_form .noticeFormDl dt > span.required,
.noticeLp #mail_form .noticeFormDl dt > span.optional {
  display: inline-block;
  color: #ffffff;
  padding: 4px 10px;
  margin-right: 10px;
  border-radius: 3px;
  line-height: 1.2;
  font-size: 85%;
  vertical-align: middle;
}

.noticeLp #mail_form .noticeFormDl dt > span.required {
  background: #d9534f;
  border: 1px solid #d43f3a;
}

.noticeLp #mail_form .noticeFormDl dt > span.optional {
  background: #337ab7;
  border: 1px solid #2e6da4;
}

/* =========================================================
   エラー表示
========================================================= */
.noticeLp #mail_form .noticeFormDl dd span.error_blank,
.noticeLp #mail_form .noticeFormDl dd span.error_format,
.noticeLp #mail_form .noticeFormDl dd span.error_match {
  display: block;
  color: #ff0000;
  margin-top: 5px;
  font-size: 0.9rem;
}

/* =========================================================
   入力欄
========================================================= */
.noticeLp #mail_form input[type="text"],
.noticeLp #mail_form input[type="email"],
.noticeLp #mail_form input[type="tel"],
.noticeLp #mail_form textarea,
.noticeLp #mail_form select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  font-size: 100%;
  font-family: inherit;
}

.noticeLp #mail_form input[type="text"],
.noticeLp #mail_form input[type="email"],
.noticeLp #mail_form input[type="tel"] {
  padding: 10px 12px;
  border: 1px solid #cccccc;
  border-radius: 6px;
  background: #fafafa;
  -webkit-appearance: none;
  color: #333;
}

.noticeLp #mail_form textarea {
  display: block;
  min-height: 180px;
  padding: 10px 12px;
  resize: vertical;
  border: 1px solid #cccccc;
  border-radius: 6px;
  background: #fafafa;
  -webkit-appearance: none;
  color: #333;
}

.noticeLp #mail_form input[type="text"]:focus,
.noticeLp #mail_form input[type="email"]:focus,
.noticeLp #mail_form input[type="tel"]:focus,
.noticeLp #mail_form textarea:focus {
  box-shadow: 0 0 5px #55ccff;
  border: 1px solid #55ccff;
  background: #ffffff;
  outline: none;
}

.noticeLp #mail_form input#mail_address,
.noticeLp #mail_form input#mail_address_confirm {
  width: 100%;
  max-width: 100%;
}

/* =========================================================
   説明文・カテゴリ見出し
========================================================= */
.noticeLp .form_note {
  margin: 0 0 14px;
  color: #6a5d53;
  font-size: 0.95rem;
  line-height: 1.8;
}

.noticeLp .noticeCheckGroup {
  margin-bottom: 24px;
}

.noticeLp .form_category {
  margin: 0 0 12px;
  padding-left: 10px;
  border-left: 4px solid #caa46a;
  font-size: 1.08rem;
  color: #6d4d33;
}

/*  背景

.noticeCard{
position:relative;
background-image:url("/shop/mailform-shop/img/peach-bg.JPG");
background-size:cover;
background-position:left center;
background-repeat:no-repeat;
padding:40px;
border-radius:8px;
}

.noticeCard::before{
content:"";
position:absolute;
inset:0;
background:rgba(255,255,255,0.85);
border-radius:8px;
}

.noticeCard > *{
position:relative;
}*/

/* =========================================================
   チェックボックス一覧
========================================================= */
.noticeLp .product_check_list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.noticeLp .product_check_list li {
  margin: 0 0 12px;
}

.noticeLp .product_check_list label {
  display: block;
  padding: 12px 14px;
  /* margin: 10px; */
  line-height: 1.7;
  /* border: 1px solid #eadfce; */
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.noticeLp .product_check_list label:hover {
  background: #fffaf1;
  border-color: #d9c1a4;
}

.noticeLp .product_check_list input[type="checkbox"] {
  width: auto;
  height: auto;
  margin-right: 8px;
  margin-top: 0;
  padding: 0;
  vertical-align: middle;
  background: transparent;
  border-radius: 0;
  display: inline-block;
}

.noticeLp .product_check_list span {
  color: #7a6a5d;
  font-size: 0.93rem;
}

/* =========================================================
   注意書き・送信ボタン
========================================================= */
.noticeLp .noticeFormFoot {
  clear: both;
  margin-top: 10px;
  text-align: center!important;
}

.noticeLp .noticeFormNote {
  margin: 0 0 22px;
  color: #6e5a4b;
  font-size: 0.92rem;
  line-height: 1.8;
}

.noticeLp #mail_form p#form_submit {
  width: 100%;
  margin: 0 auto;
  padding: 15px 0 0;
  border-top: 1px solid #a8a8a8;
  text-align: center;
  box-sizing: border-box;
}

.noticeLp #mail_form input#form_submit_button {
  display: inline-block;
  margin: 0 auto;
  padding: 15px 42px;
  border: none;
  border-radius:6px;
  background: #d3d3d3;
  color: #333333;
  font-size: 1rem;
  font-family: inherit;
  -webkit-appearance: none;
  cursor: pointer;
  transition: opacity 0.25s ease;
}

.noticeLp #mail_form input#form_submit_button:hover {
  background:#c0c0c0;
}

/* =========================================================
   FAQ
========================================================= */
.noticeLp .noticeFaqList {
  margin: 0;
}

.noticeLp .noticeFaqList dt {
  margin: 0 0 8px;
  font-weight: 600;
  color: #4c3728;
}

.noticeLp .noticeFaqList dd {
  margin: 0 0 18px;
  color: #5f5248;
}

/* =========================================================
   ローディング
========================================================= */
.noticeLp span.loading {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border-top: 5px solid rgba(255, 255, 255, 0.2);
  border-right: 5px solid rgba(255, 255, 255, 0.2);
  border-bottom: 5px solid rgba(255, 255, 255, 0.2);
  border-left: 5px solid #ffffff;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: load-circle 1s linear infinite;
  animation: load-circle 1s linear infinite;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -30px;
  margin-left: -30px;
}

@-webkit-keyframes load-circle {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes load-circle {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

/* =========================================================
   レスポンシブ
========================================================= */
@media screen and (max-width: 767px) {
  .noticeLp {
    padding: 16px 12px 44px;
  }

  .noticeHero {
    padding: 38px 16px 30px;
    border-radius: 14px;
  }

  .noticeHero__title {
    font-size: 1.6rem;
  }

  .noticeHeading {
    font-size: 1.25rem;
  }

  .noticeFormWrap {
    padding: 22px 14px;
    border-radius: 14px;
  }

  .noticeLp #mail_form .noticeFormDl {
    padding: 0 14px;
  }

  .noticeLp .product_check_list label {
    padding: 12px 10px;
  }

  .noticeLp #mail_form input#form_submit_button {
    width: 100%;
    padding: 15px 20px;
  }
}

/* 開閉アコーディオン */

.noticeCheckGroup summary{
  cursor:pointer;
  list-style:none;
  position:relative;
  padding-right:30px;
}

/* デフォルトの三角を消す */
.noticeCheckGroup summary::-webkit-details-marker{
  display:none;
}

/* ＋マーク */
.noticeCheckGroup summary::after{
  content:"+";
  position:absolute;
  right:0;
  top:0;
  font-size:20px;
  color:#8a5a3b;
}

/* 開いたとき − に */
.noticeCheckGroup[open] summary::after{
  content:"−";
}

/* =========================================
   開閉式カテゴリ
========================================= */
.noticeLp .noticeCheckGroup {
  margin: 0 0 16px;
  border: 1px solid #eadfce;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.noticeLp .noticeCheckGroup + .noticeCheckGroup {
  margin-top: 14px;
}

.noticeLp .noticeCheckGroup summary {
  list-style: none;
  cursor: pointer;
  position: relative;
  padding: 14px 48px 14px 14px;
  margin: 0;
  background: #f5f1ea;
  border-bottom: 1px solid #f5f1ea;
}

.noticeLp .noticeCheckGroup summary::-webkit-details-marker {
  display: none;
}

.noticeLp .noticeCheckGroup summary:hover {
  background: #faf5ee;
}

.noticeLp .form_category {
  border-left: none;
  padding-left: 0;
  font-size: 1.08rem;
  color: #6d4d33;
}

.noticeLp .form_category__label {
  font-weight: 600;
}

.noticeLp .form_category__count {
  margin-left: 10px;
  font-size: 0.9rem;
  color: #8a7768;
}

/* 全選択− */
.check_all_wrap{
background:#f7f7f7;
padding:10px 12px;
border-radius:6px;
margin:10px 0;
font-size:14px;
}

.check_all_wrap label{
cursor:pointer;
font-weight:600;
}

/* ＋ / − */
.noticeLp .noticeCheckGroup summary::after {
  content: "+";
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  line-height: 24px;
  text-align: center;
  border: 1px solid #d9c1a4;
  border-radius: 50%;
  color: #8a5a3b;
  font-size: 18px;
  font-weight: 400;
  box-sizing: border-box;
  background: #fff;
}

.noticeLp .noticeCheckGroup[open] summary::after {
  content: "−";
}

.noticeLp .noticeCheckGroup .product_check_list {
  padding: 14px;
  background: #fff;
}

.noticeLp .noticeCheckGroup .product_check_list li:last-child {
  margin-bottom: 0;
}

/* =========================================
   必須・任意ラベルを疑似要素で表示
========================================= */
.noticeLp #mail_form .noticeFormDl dt.is-required::before,
.noticeLp #mail_form .noticeFormDl dt.is-optional::before {
  display: inline-block;
  padding: 4px 10px;
  margin-right: 10px;
  border-radius: 3px;
  line-height: 1.2;
  font-size: 85%;
  color: #ffffff;
  vertical-align: middle;
}

.noticeLp #mail_form .noticeFormDl dt.is-required::before {
  content: "必須";
  background: #d9534f;
  border: 1px solid #d43f3a;
}

.noticeLp #mail_form .noticeFormDl dt.is-optional::before {
  content: "任意";
  background: #8f8f8f;
  border: 1px solid #7d7d7d;
}

/* 以前の span.required / span.optional 表示は使わない */
.noticeLp #mail_form .noticeFormDl dt > span.required,
.noticeLp #mail_form .noticeFormDl dt > span.optional {
  display: none;
}


/* =========================================
   LINE登録
========================================= */

.noticeLineBox{
background:#f6fbf7;
border:1px solid #d9eadf;
padding:18px;
margin:25px 0;
border-radius:6px;
text-align:center;
}

.noticeLineBtn{
display:inline-block;
background:#06C755;
color:#ffffff;
padding:10px 18px;
border-radius:4px;
text-decoration:none;
margin-top:10px;
font-weight:600;
}

.noticeLineBtn:link,
.noticeLineBtn:visited,
.noticeLineBtn:hover{
color:#ffffff;
}

.noticeLineBox h2{
font-size:20px;
font-weight:700;
color:#3a3a3a;
margin-bottom:10px;
}

/* =========================================
   EX
========================================= */
@charset "utf-8";

/* =========================
   販売開始お知らせLP
========================= */

.saleStartLp{
  max-width: 860px;
  margin: 0 auto;
  padding: 24px 16px 48px;
  color: #4b3428;
  line-height: 1.9;
  font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  background: #fffdf9;
}

.saleStartHero{
  text-align: center;
  padding: 34px 18px 28px;
  margin-bottom: 22px;
  background: linear-gradient(180deg, #fff8f3 0%, #fffdf9 100%);
  border: 1px solid #f0e2d8;
  border-radius: 18px;
}

.saleStartHero__sub{
  margin: 0 0 10px;
  font-size: 14px;
  color: #9b6b53;
  letter-spacing: .08em;
}

.saleStartHero h1{
  margin: 0 0 16px;
  font-size: 34px;
  line-height: 1.45;
  color: #5e3825;
  font-weight: bold;
}

.saleStartHero__lead{
  margin: 0;
  font-size: 16px;
  color: #5c4a40;
}

.saleStartBox{
  background: #fff;
  border: 1px solid #eee1d7;
  border-radius: 16px;
  padding: 28px 22px;
  margin-bottom: 18px;
  */box-shadow: 0 6px 18px rgba(90, 58, 36, 0.04);*/
}

.saleStartBox h2{
  margin: 0 0 14px;
  font-size: 25px;
  line-height: 1.5;
  color: #6a3f2a;
}

.saleStartBox h3{
  margin: 0 0 14px;
  font-size: 20px;
  background-color: #f8ede4;
  color: #35251D;
}

.saleStartLabel{
  display: inline-block;
  margin: 0 0 10px;
  padding: 4px 10px;
  background: #f8ede4;
  color: #9b5e3f;
  border-radius: 999px;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: .08em;
}

.saleStartBox--line{
  background: #fffefb;
}

.lineCta{
  margin: 22px 0 0;
  text-align: center;
}

.lineCta a{
  display: inline-block;
  min-width: 280px;
  padding: 14px 24px;
  background: #06C755;
  color: #fff !important;
  text-decoration: none;
  font-size: 18px;
  font-weight: bold;
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(6, 199, 85, 0.22);
}

.lineCta a:hover{
  opacity: 0.9;
}

.saleStartMerit{
  margin: 0;
  padding: 0;
  list-style: none;
}

.saleStartMerit li{
  position: relative;
  padding: 0 0 0 1.4em;
  margin: 0 0 10px;
}

.saleStartMerit li:before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #b56b4b;
  font-weight: bold;
}

.seasonGrid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.seasonCard{
  background: #fffaf5;
  border: 1px solid #f1e1d4;
  border-radius: 14px;
  padding: 18px 16px;
}

.seasonCard dl{
  margin: 0;
}

.seasonCard dt{
  margin: 12px 0 4px;
  font-weight: bold;
  color: #7c4a31;
}

.seasonCard dt:first-child{
  margin-top: 0;
}

.seasonCard dd{
  margin: 0;
  color: #5c4a40;
}

.seasonNote{
  margin: 14px 0 0;
  font-size: 13px;
  color: #7f7167;
}

.saleStartBox--mail{
  background: #fff;
}

.mailLead{
  margin: 0 0 18px;
}

.mailFormArea{
  margin-top: 10px;
}

.saleStartFoot{
  margin-top: 18px;
  padding: 18px 12px 0;
  text-align: center;
  font-size: 13px;
  color: #7d6a5f;
}

.spOnly{
  display: none;
}

/* =========================
   SP
========================= */
@media screen and (max-width: 767px){

  .saleStartLp{
    padding: 16px 12px 38px;
  }

  .saleStartHero{
    padding: 28px 14px 24px;
    border-radius: 14px;
  }

  .saleStartHero h1{
    font-size: 28px;
  }

  .saleStartHero__lead{
    font-size: 15px;
  }

  .saleStartBox{
    padding: 22px 16px;
    border-radius: 14px;
  }

  .saleStartBox h2{
    font-size: 22px;
  }

  .saleStartBox h3{
    font-size: 18px;
  }

  .seasonGrid{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .lineCta a{
    display: block;
    min-width: auto;
    width: 10
	0%;
    box-sizing: border-box;
    font-size: 17px;
    padding: 14px 16px;
  }

  .spOnly{
    display: inline;
  }
}