@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@400;500;700&display=swap');

:root {
  --blue : #3A4C7F;
  --pink : #E95298;
  --brown : #800000;	
}


/* 1) 基本：全セクション非表示 */
.tab-contents > .section_box{ display: none !important; }

/* 2) :target フォールバック（JSオフ時や初期ロード直後の保険） */
.tab-contents > .section_box:target{ display: block !important; }
/* section02がtargetのときだけ、兄弟のsection01を隠す保険（従来のままでOK） */
.tab-contents > #section02:target ~ #section01{ display: none !important; }

/* 3) JSが付ける状態クラスが“最優先”（互いに排他で決定） */
.tab-contents.show-01 > section#section01 { display:block !important; }
.tab-contents.show-02 > section#section02 { display:block !important; }

/* 4) さらに排他を“強制”して事故防止（保険） */
.tab-contents.show-01 > #section02 { display: none !important; }
.tab-contents.show-02 > #section01 { display: none !important; }

/* 5) JS未適用時だけ初期表示（ハッシュなしのとき用） */
.tab-contents:not(.show-01):not(.show-02) > #section01{ display: block !important; }



/* --- ナビの強調は .is-active のみ（:has と初期強調は使わない） --- */
.inpagenav a{
  opacity:.75; filter:saturate(.85); box-shadow:none; transition:.25s;
}
.inpagenav a.is-active{
  opacity:1; filter:none; box-shadow:0 0 14px rgba(233,82,152,.45);
}
.inpagenav li.purple a.is-active{
  box-shadow:0 0 14px rgba(135,206,250,.55);
}



#LPcontent {
  color: var(--brown);
  padding: 50px 20px 100px;
  background: transparent;
}


#LPcontent * {
  box-sizing: border-box;
}
#LPcontent .color {
  color: var(--pink);
}
#LPcontent .color.blue {
  color: var(--blue);
}
#LPcontent section {
  width: min(100%, 1200px);
  margin-inline: auto;
}
#LPcontent .section_box {
  background: #fffcfa;
  border-radius: 54px;
  padding: 60px 60px 81px;
}
#LPcontent .section_box+.section_box {
  margin-top: 80px;
}

#LPcontent .lead_catch .color.blue {
  color: var(--blue) !important;
}


#LPcontent .contents03_title.blue {
  color: #3A4C7F !important;
}

#mv {
  margin-bottom: 60px;
}
#lead {
  margin-bottom: 105px;
}
.lead_catch {
  text-align: center;
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 16px;
  rotate: z 0.05deg;
}
.lead_text {
  text-align: center;
  font-size: 20px;
  margin-bottom: 52px;
  rotate: z 0.05deg;
}
.inpagenav ul {
  display: flex;
  flex-flow: row wrap;
  align-items: stretch;
  gap: 20px;
}
.inpagenav ul li {
  flex: 1;
}
.inpagenav ul li a {
  display: inline-block;
  width: 100%;
  height: 100%;
  background: url(/img/usr/freepage/sideM_SweetBitter/bg_pink.png) no-repeat center top / cover;
  border-radius: 12px;
  padding-block: 20px 28px;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  text-shadow: 0 0 40px #B84151;
  position: relative;
  rotate: z 0.05deg;
}
.inpagenav ul li.purple a {
  background-image: url(/img/usr/freepage/sideM_SweetBitter/bg_purple.png);
  text-shadow: 0 0 40px #3A4C7F;
}
.inpagenav ul li a:before {
  content:"";
  display: inline-block;
  width: 80px;
  height: 66px;
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -50% 66%;
}
.inpagenav ul li.limited a:after {
  content: "オンラインショップ限定";
  display: inline-block;
  position: absolute;
  left: 50%;
  top: 0;
  translate: -50% -50%;
  line-height: 0;
  width: 184px;
  height: 0;
  border-block: 13px solid #FFB1CA;
  border-inline: 8px solid transparent;
  color: #EF0A6A;
  font-size: 13px;
}
h2.section_title {
  width: min(80%, 543px);
  margin-inline: auto;
  margin-bottom: 64px;
  position: relative;
  text-align: center;
}
h3.insection_title {
  width: min(70%, 460px);
  margin-inline: auto;
  margin-bottom: 52px;
  position: relative;
  text-align: center;
}
h2.section_title:before,
h3.insection_title:before {
  content: "";
  display: inline-block;
  height: 0;
  border-block: solid #a03947;
  border-left: solid transparent;
  position: absolute;
  z-index: 1;
}
h2.section_title:before {
  width: 62px;
  border-block-width: 35px;
  border-left-width: 17px;
  left: -48px;
  bottom: -25px;
}
h3.insection_title:before {
  width: 52px;
  border-block-width: 30px;
  border-left-width: 14px;
  left: -40px;
  bottom: -20px;
}
h2.section_title:after,
h3.insection_title:after {
  content: "";
  display: inline-block;
  height: 0;
  border-block: solid #a03947;
  border-right: solid transparent;
  position: absolute;
  z-index: 1;
}
h2.section_title:after {
  width: 62px;
  border-block-width: 35px;
  border-right-width: 17px;
  right: -48px;
  bottom: -25px;
}
h3.insection_title:after {
  width: 52px;
  border-block-width: 30px;
  border-right-width: 14px;
  right: -40px;
  bottom: -20px;
}
.title_inner {
  background: #b84151;
  position: relative;
  z-index: 2;
}
h2.section_title .title_inner {
  padding-block: 20px;
}
h3.insection_title .title_inner {
  padding-block: 15px;
}
.title_inner:before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-right: solid #62232B;
  border-bottom: solid transparent;
  position: absolute;
  left: 0;
}
h2.section_title .title_inner:before {
  border-right-width: 31px;
  border-bottom-width: 25px;
  bottom: -25px;
}
h3.insection_title .title_inner:before {
  border-right-width:26px;
  border-bottom-width: 20px;
  bottom: -20px;
}
.title_inner:after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-left: solid #62232B;
  border-bottom: solid transparent;
  position: absolute;
  right: 0;
}
h2.section_title .title_inner:after {
  border-left-width: 31px;
  border-bottom-width: 25px;
  bottom: -25px;
}
h3.insection_title .title_inner:after {
  border-left-width:26px;
  border-bottom-width: 20px;
  bottom: -20px;
}
h2.section_title .title_inner p {
  display: inline-block;
  padding-inline: 42px;
  background: url(/img/usr/freepage/sideM_SweetBitter/hart_pink.png) no-repeat left center / 19px auto,url(/img/usr/freepage/sideM_SweetBitter/hart_pink.png) no-repeat right center / 19px auto;
}
h3.insection_title .title_inner p {
  display: inline-block;
  padding-inline: 32px;
  background: url(/img/usr/freepage/sideM_SweetBitter/hart_pink.png) no-repeat left center / 16px auto,url(/img/usr/freepage/sideM_SweetBitter/hart_pink.png) no-repeat right center / 16px auto;
}
.title_inner p .shadow {
  color: #fff;
  font-weight: bold;
  text-shadow: 0 0 20px #a03947;
  rotate: z 0.05deg;
}
.title_inner.purple p .shadow {
  color: #3A4C7F;
  font-weight: bold;
  text-shadow: 0 0 20px #3A4C7F;
  rotate: z 0.05deg;
}
h2.section_title .title_inner p .shadow {
  font-size: 24px;
}
h3.insection_title .title_inner p .shadow {
  font-size: 22px;
}
h2.section_title.purple:before,
h2.section_title.purple:after {
  border-top-color: #303f6b;
  border-bottom-color: #303f6b;
}
h2.section_title.purple .title_inner {
  background: #3A4C7F;
}
h2.section_title.purple .title_inner:before,
h2.section_title.purple .title_inner:after {
  border-inline-color: #273356;
}
h2.section_title.purple .title_inner p {
  background: url(/img/usr/freepage/sideM_SweetBitter/hart_blue.png) no-repeat left center / 19px auto,url(/img/usr/freepage/sideM_SweetBitter/hart_blue.png) no-repeat right center / 19px auto;
}
h2.section_title.purple .title_inner p .shadow {
  text-shadow: 0 0 10px #3A4C7F;
}
.title_catch {
  display: inline-block;
  position: relative;
  color: var(--pink);
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 20px;
  rotate: z 0.05deg;
}
.title_catch:before {
  content: "";
  display: inline-block;
  width: 2px;
  height: 22px;
  background: var(--pink);
  rotate: -40deg;
  position: absolute;
  left: -50px;
  bottom: 0;
}
.title_catch:after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 22px;
  background: var(--pink);
  rotate: 40deg;
  position: absolute;
  right: -50px;
  bottom: 0;
}
.section_mv {
  margin-bottom: 32px;
}
.section_lead {
  margin-bottom: 72px;
  text-align: center;
}
.section_lead .subtext {
  font-size: 18px;
  margin-bottom: 16px;
  rotate: z 0.05deg;
}
.section_lead .maintext {
  font-size: 24px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_lead .uline {
  position: relative;
}
.section_lead .uline:before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 2px;
  background: #9E84BB;
  position: absolute;
  left: 0;
  bottom: -4px;
  opacity: .3;
}
.section_lead .price_num {
  font-size: 20px;
  font-weight: bold;
}
.section_lead .price_unit {
  font-size: 16px;
  font-weight: bold;
}
.section_lead .price_tax {
  font-size: 12px;
  font-weight: bold;
}
.section_lead .fwbold {
  font-weight: bold;
}
.section_lead .maintext .color {
  font-size: 30px;
}
.section_lead .maintext .color .sub {
  font-size: 18px;
  font-weight: normal;
}
.section_lead .mainnote {
  color: var(--pink);
  font-size: 14px;
  font-weight: bold;
  margin-top: 20px;
  rotate: z 0.05deg;
}
.section_lead .subnote {
  color: #666;
  font-size: 12px;
  margin-top: 12px;
  rotate: z 0.05deg;
}
.section_content+.section_content {
  margin-top: 72px;
}
.section_content_text {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_content_item {
  text-align: center;
}
.section_content_item .item_name {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 12px;
  rotate: z 0.05deg;
}
.section_content_item .item_img {
  width: min(100%, 722px);
  margin-inline: auto;
}
.section_content_item .item_data {
  font-size: 16px;
  margin-top: 16px;
  rotate: z 0.05deg;
}
.section_content_item .item_note {
  color: #333;
  font-size: 12px;
  margin-top: 9px;
  rotate: z 0.05deg;
}
.section_btn {
  margin-top: 60px;
}
.section_btn a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%,498px);
  margin-inline: auto;
  padding-block: 27px;
  background: #79434A;
  border-radius: 300px;
  box-shadow: 0 0 30px #79434A;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_note {
  width: min(100%, 800px);
  margin-top: 80px;
  margin-inline: auto;
}
h3.note_title {
  border-block: 21px solid #FFB1CA;
  border-inline: 10px solid transparent;
  height: 0;
  margin-bottom: 24px;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  line-height: 0;
  text-shadow: 0 0 20px #EF0A6A88;
}
.note_text p {
  color: #666;
  font-size: 12px;
  padding-left: 1em;
  text-indent: -1em;
  rotate: z 0.05deg;
}
.note_text p:before {
  content: "・";
}

.section_product {
  width: min(100%,704px);
  margin-inline: auto;
  text-align: center;
}
.section_product+.section_product {
  margin-top: 80px;
}

.product_title {
  margin-bottom: 20px;
  display: inline-block;
}
.product_title.limited {
  padding-inline: 150px;
  min-height: 65px;
}
.product_data {
  font-size: 16px;
  rotate: z 0.05deg;
}
.product_data .tax {
  font-size: 12px;
}
.product_btn {
  display: flex;
  margin-top: auto; 
  margin-bottom: 28px;
  padding-top: 12px;
  text-align: center;	
}
.product_btn a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%,360px);
  margin-inline: auto;
  padding-block: 20px;
  background: #79434A;
  border-radius: 300px;
  box-shadow: 0 0 5px #79434A;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  rotate: z 0.05deg;
}

.product_btn.purple {
  display: flex;
  margin-top: auto; 
  margin-bottom: 28px;
  padding-top: 12px;
  text-align: center;	
}
.product_btn.purple a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%,360px);
  margin-inline: auto;
  padding-block: 20px;
  background: #3A4C7F;
  border-radius: 300px;
  box-shadow: 0 0 5px #3A4C7F;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer {
  margin-top: 80px;
  padding-top: 72px;
  background: url(/img/usr/freepage/sideM_SweetBitter/wave.png) no-repeat center top / contain;
}

.section_footer_blue{
  margin-top:80px;
  padding-top:72px;
  background:url(/img/usr/freepage/sideM_SweetBitter/wave_blue.png) no-repeat center top / contain;
}

.section_footer .footer_btn a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%, 498px);
  margin-inline: auto;
  padding-block: 27px;
  background: #B84151;
  border-radius: 300px;
  box-shadow: 0 0 5px #B84151;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer .footer_btn.blue a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%, 498px);
  margin-inline: auto;
  padding-block: 27px;
  background: #4782C1;
  border-radius: 300px;
  box-shadow: 0 0 5px #4782C1;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer .copy {
  text-align: center;
  margin-top: 28px;
  color: #666;
  font-size: 12px;
  rotate: z 0.05deg;
}


@media only screen and (min-width: 768px) {

#LPcontent {
  background-color: transparent !important;
  background-image: url("/img/usr/freepage/sideM_SweetBitter/bg_pc_common.jpg") !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center top !important;
}
	
  #LPcontent .sp {
    display: none;
  }
	
.product_btn {
  display: flex;
  margin-top: auto; 
  margin-bottom: 28px;
  padding-top: 12px;
  text-align: center;	
}
.product_btn a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%,360px);
  margin-inline: auto;
  padding-block: 20px;
  background: #79434A;
  border-radius: 300px;
  box-shadow: 0 0 5px #79434A;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  rotate: z 0.05deg;
}

.product_btn.purple {
  display: flex;
  margin-top: auto; 
  margin-bottom: 28px;
  padding-top: 12px;
  text-align: center;	
}
.product_btn.purple a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%,360px);
  margin-inline: auto;
  padding-block: 20px;
  background: #3A4C7F;
  border-radius: 300px;
  box-shadow: 0 0 5px #3A4C7F;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer {
  margin-top: 80px;
  padding-top: 72px;
  background: url(/img/usr/freepage/sideM_SweetBitter/wave.png) no-repeat center top / contain;
}
.section_footer .footer_btn a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%, 498px);
  margin-inline: auto;
  padding-block: 27px;
  background: #B84151;
  border-radius: 300px;
  box-shadow: 0 0 20px #B84151;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer .footer_btn.blue a {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  width: min(100%, 498px);
  margin-inline: auto;
  padding-block: 27px;
  background: #add8e6;
  border-radius: 300px;
  box-shadow: 0 0 20px #add8e6;
  text-decoration: none;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  rotate: z 0.05deg;
}
.section_footer .copy {
  text-align: center;
  margin-top: 28px;
  color: #666;
  font-size: 12px;
  rotate: z 0.05deg;
}	
	
.section_btn a,
.product_btn a,
.section_footer .footer_btn a { transition: .4s; }
.section_btn a:hover,
.product_btn a:hover,
.section_footer .footer_btn a:hover { box-shadow: 0 0 30px transparent; }

  .inpagenav ul li a{
    transition: .4s;
    &:hover {
    box-shadow: 0 0 10px #79434A;
  }
  }
  .inpagenav ul li.purple a:hover {
    box-shadow: 0 0 10px #3A4C7F;
  }

  .lightbox{
    translate: 0 calc(50dvh - 50%);
  }
  #mv {
    margin-bottom: 40px;
  }
  #mv h1 {
    margin-inline: -24px;
  }
  #lead {
    margin-bottom: 90px;
  }
  .lead_catch {
    font-size: 25px;
    line-height: 1.8;
    margin-bottom: 24px;
  }
  .lead_catch .color {
    font-size: 25px;
  }
  .lead_text {
    font-size: 24px;
    line-height: 1.8;
    margin-bottom: 68px;
  }
  .inpagenav ul {
    gap: 9px;
  }
  .inpagenav ul li a {
    border-radius: 16px;
    padding-block: 30px 42px;
    font-size: 24px;
  }
  .inpagenav ul li a:before {
    width: 88px;
    height: 72px;
  }
  .inpagenav ul li.limited a:after {
    width: 188px;
    border-block-width: 17px;
    font-size: 14px;
  }
  #LPcontent .section_box {
    border-radius: 40px;
    padding: 48px 24px 80px;
  }
  h2.section_title {
    margin-bottom: 76px;
  }
  h2.section_title .title_inner p,
  h2.section_title.purple .title_inner p {
    padding-inline: 52px;
    background-size: 28px auto;
  }
  h3.insection_title .title_inner p {
    padding-inline: 40px;
    background-size: 22px auto;
  }
  h2.section_title .title_inner p .shadow {
    font-size: 28px;
  }
  h3.insection_title .title_inner p .shadow {
    font-size: 24px;
  }
  .section_lead {
    margin-bottom: 64px;
  }
  .section_lead .subtext {
    font-size: 24px;
    line-height: 1.8;
    margin-bottom: 34px;
  }
  .section_lead .uline:before {
    height: 4px;
  }
  .section_lead .price_num,
  .section_lead .price_unit,
  .section_lead .price_tax {
    font-size: 24px;
    font-weight: bold;
  }
  .section_lead .maintext {
    font-size: 28px;
  }
  .section_lead .maintext .color {
    font-size: 36px;
  }
  .section_lead .maintext .color .sub {
    font-size: 20px;
  }
  .section_lead .mainnote {
    text-align: left;
    font-size: 22px;
    margin-top: 32px;
  }
  .section_lead .subnote {
    color: #666;
    text-align: left;
    font-size: 19px;
    margin-top: 50px;
  }
  .section_content+.section_content {
    margin-top: 64px;
  }
  .section_content_text {
    font-size: 28px;
    line-height: 1.8;
  }
  .section_content_item .item_name {
    font-size: 28px;
    margin-bottom: 24px;
  }
  .section_content_item .item_data {
    font-size: 24px;
    margin-top: 24px;
  }
  .section_content_item .item_note {
    font-size: 20px;
    margin-top: 10px;
  }
  .section_btn {
    margin-top: 50px;
  }
  .section_btn a {
    width: 100%;
    padding-block: 30px;
    font-size: 32px;
  }
  h3.note_title {
    border-block-width: 32px;
    border-inline-width: 20px;
    font-size: 24px;
  }
  .note_text p {
    font-size: 20px;
  }
  .section_product {
    padding-inline: 32px;
  }
  .section_product+.section_product {
    margin-top: 64px;
  }  
  .product_title {
    margin-bottom: 16px;
    display: inline-block;
  }
  .product_title.limited {
    padding-inline: 180px 0;
    min-height: 80px;
    background-size: 120px auto;
  }
  .product_data {
    font-size: 20px;
  }
  .product_data .tax {
    font-size: 16px;
  }
  
}

.contents01_wrap {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  gap: 60px;
  .postar {
    width: min(100%,450px);
    .poster_img {
      margin-bottom: 16px;
    }
    .poster_text {
      .title {
        margin-bottom: 8px;
        font-size: 16px;
        font-weight: bold;
      }
      .price {
        font-size: 16px;
        .tax {
          font-size: 12px;
        }
      }
    }
  }
  .text {
    width: min(100%,540px);
    margin: 0;
    text-align: left;
    font-size: 16px;
    line-height: 2;
  }
}

#LPcontent #contents03 {
  background: url(/img/usr/freepage/sidem10th_vote/line03.png) repeat-x center top / 13.5px 12px, url(/img/usr/freepage/sidem10th_vote/contents_bg_pc.png) no-repeat center top / cover;
  padding-block: 72px 30px;
  text-align: center;
}
.contents03_tab ol {
  display: flex;
  flex-flow: row wrap;
  align-items: stretch;
  gap: 8px;
}
.contents03_tab ol li {
  flex: 1;
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  height: 82px;
  background: #fff9;
  padding-top: 8px;
  color: #EF0A6A;
  font-size: 28px;
  font-weight: bold;
  line-height: 1;
  opacity: .7;
  position: relative;
  &.active {
    background: #fffc;
    opacity: 1;
    &:before {
      content: "";
      display: inline-block;
      width: 24px;
      height: 30px;
      background: url(/img/usr/freepage/sidem10th_vote/tab_mark.png) no-repeat center / contain;
      translate: -50% -50%;
      position: absolute;
      left: 50%;
      top: 0;
    }
  }
  .date {
    font-size: 20px;
    line-height: 1.5;
  }
}

.contents03_wrap {
  width: min(100%, 1044px);
  margin-inline: auto;
  &+.contents03_wrap {
    margin-top: 60px;
    padding-top: 40px;
    border-top: 1px solid;
    border-image: linear-gradient(90deg, #80610033 0%, #ceba2133 70%, #41320233 100%) 1;
  }
}

.contents03_title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-bottom: 28px;
  margin-top: 28px;	
  color: #a01e28;
  font-size: 25px; 
}
.contents03_title:before,
.contents03_title:after {
  content: "";
  display: inline-block;
  width: 60px;
  height: 13px;
  background: url(/img/usr/freepage/sideM_SweetBitter/title_bg.png) no-repeat center / contain;
}

.contents03_title.blue {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-bottom: 28px;
  margin-top: 28px;	
  color: #3A4C7F;
  font-size: 25px; 
}
.contents03_title.blue:before,
.contents03_title.blue:after {
  content: "";
  display: inline-block;
  width: 60px;
  height: 13px;
  background: url(/img/usr/freepage/sideM_SweetBitter/title_bg_blue.png) no-repeat center / contain;
}

.contents03_title:after {
  rotate: y 180deg;
}
.info {
  margin-bottom: 48px;
  .info_text {
    margin-bottom: 22px;
    dt {
      margin-bottom: 16px;
      font-size: 20px;
      font-weight: bold;
    }
    dd {
      font-size: 25px;
      font-weight: bold;
    }
  }
  .info_note {
    font-size: 15px;
  }
}

#LPcontent .kaisei {
  font-family:  "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
  font-weight: 700;
}
.links ul {
  display: flex;
  flex-flow: row wrap;
  align-items: stretch;
  justify-content: center;
  gap: 12px;

  li {
    flex: 0 0 calc((100% - 48px) / 5 - .1px);
    box-sizing: border-box;

    a {
      display: inline-block;
      width: 100%;
      height: 100%;
      border: 1px solid #AC3F45;
      border-radius: 8px;
      padding-block: 20px;
      padding-right: 48px;
      padding-left: 48px;
      text-decoration: none;
      color: #AC3F45;
      font-size: 20px;
      text-align: center;
      position: relative;

      /* ♥ テキスト前のハート */
      &:before {
        content: "";
        width: 18px;
        height: 18px;
        display: inline-block;
        background: no-repeat center / contain; /* 画像は各 li で差し替え */
        position: absolute;
        left: 18px;
        top: 50%;
        transform: translateY(-50%);
      }

      /* → 右側の矢印（既存） */
      &:after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 18px;
        background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213.2%22%20height%3D%229.7%22%20viewBox%3D%220%200%2013.2%209.7%22%3E%20%3Cpath%20d%3D%22M201.3%2C2585.205l6%2C8%2C6-8%22%20transform%3D%22translate(-200.7%20-2584.755)%22%20fill%3D%22none%22%20stroke%3D%22%23a01e2f%22%20stroke-width%3D%221.5%22%2F%3E%20%3C%2Fsvg%3E') no-repeat center / contain;
        position: absolute;
        right: 26px;
        top: 50%;
        transform: translateY(-50%);
      }
    }
  }

  /* 1〜5番目にそれぞれ別画像を割り当てる例 */
  li:nth-child(1) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_kyosuke.png');
  }
  li:nth-child(2) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_hideo.png');
  }
  li:nth-child(3) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_kuro.png');
  }
  li:nth-child(4) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_ren.png');
  }
  li:nth-child(5) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_amehiko.png');
  }
}

.links.purple ul {
  display: flex;
  flex-flow: row wrap;
  align-items: stretch;
  justify-content: center;
  gap: 12px;

  li {
    flex: 0 0 calc((100% - 48px) / 5 - .1px);
    box-sizing: border-box;

    a {
      display: inline-block;
      width: 100%;
      height: 100%;
      border: 1px solid #3A4C7F;
      border-radius: 8px;
      padding-block: 20px;
      padding-right: 48px;
      padding-left: 48px;
      text-decoration: none;
      color: #3A4C7F;
      font-size: 20px;
      text-align: center;
      position: relative;

      /* ♥ テキスト前のハート */
      &:before {
        content: "";
        width: 18px;
        height: 18px;
        display: inline-block;
        background: no-repeat center / contain; /* 画像は各 li で差し替え */
        position: absolute;
        left: 18px;
        top: 50%;
        transform: translateY(-50%);
      }

      /* → 右側の矢印（既存） */
      &:after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 18px;
        background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213.2%22%20height%3D%229.7%22%20viewBox%3D%220%200%2013.2%209.7%22%3E%20%3Cpath%20d%3D%22M201.3%2C2585.205l6%2C8%2C6-8%22%20transform%3D%22translate(-200.7%20-2584.755)%22%20fill%3D%22none%22%20stroke%3D%22%233A4C7F%22%20stroke-width%3D%221.5%22%2F%3E%20%3C%2Fsvg%3E') no-repeat center / contain;
        position: absolute;
        right: 26px;
        top: 50%;
        transform: translateY(-50%);
      }
    }
  }

  /* 1〜5番目にそれぞれ別画像を割り当てる例 */
  li:nth-child(1) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_pierre.png');
  }
  li:nth-child(2) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_seiji.png');
  }
  li:nth-child(3) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_nao.png');
  }
  li:nth-child(4) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_michio.png');
  }
  li:nth-child(5) a:before {
    background-image: url('/img/usr/freepage/sideM_SweetBitter/hart_ryo.png');
  }
}

.links.purple ul {
  display: flex;
  flex-flow: row wrap;
  align-items: stretch;
  justify-content: center;	
  gap: 12px;

  li {

    flex: 0 0 calc((100% - 48px) / 5 - .1px);
    box-sizing: border-box;    /* はみ出しガード */


    a {
      display: inline-block;
      width: 100%;
      height: 100%;
      border: 1px solid #3A4C7F;
      border-radius: 8px;
      padding-block: 20px;
      padding-right: 48px;
      padding-left: 48px;
      text-decoration: none;
      color: #3A4C7F;
      font-size: 15px;
      text-align: center;
      position: relative;

      /* ♥ テキスト前のハート */
      &:before {
        content: "";
        width: 18px;
        height: 18px;
        display: inline-block;
        background: url('/img/usr/freepage/sideM_SweetBitter/hart_pink.png') no-repeat center / contain;
        position: absolute;
        left: 18px;
        top: 50%;
        transform: translateY(-50%);
      }

      /* → 右側の矢印（既存） */
      &:after {
        content: "";
        display: inline-block;
        width: 12px;
        height: 18px;
        background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213.2%22%20height%3D%229.7%22%20viewBox%3D%220%200%2013.2%209.7%22%3E%20%3Cpath%20d%3D%22M201.3%2C2585.205l6%2C8%2C6-8%22%20transform%3D%22translate(-200.7%20-2584.755)%22%20fill%3D%22none%22%20stroke%3D%22%233A4C7F%22%20stroke-width%3D%221.5%22%2F%3E%20%3C%2Fsvg%3E') no-repeat center / contain;
        position: absolute;
        right: 26px;
        top: 50%;
        transform: translateY(-50%);
      }
    }
  }
}

.contents03_product ul {

  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 80px;


  li {
    width: 245px;
  }
}


/* 1) li を縦Flexにして「画像→名前→ボタン」の縦積みにする */
.contents03_product ul > li{
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* 2) ボタンを常に下へ押し下げる（カード内で位置固定） */
.contents03_product ul > li .product_btn{
  margin-top: auto;
}

/* 3)（任意）商品名とボタンの間隔はここで統一 */
.contents03_product ul > li .product_btn{
  padding-top: 12px;
}


.product_img {
  margin-bottom: 16px;
}

.product_name{
  font-size: 16px;
  margin: 0; 
  text-align: center;
  line-height: 1.4;
}




@media only screen and (min-width: 768px) {
  a[rel="lightbox"] {
    position: relative;
    &:before {
      content:"";
      display: inline-block;
      width: 32px;
      height: 32px;
      background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23888888%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22lucide%20lucide-zoom-in%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%2F%3E%3Cline%20x1%3D%2221%22%20x2%3D%2216.65%22%20y1%3D%2221%22%20y2%3D%2216.65%22%2F%3E%3Cline%20x1%3D%2211%22%20x2%3D%2211%22%20y1%3D%228%22%20y2%3D%2214%22%2F%3E%3Cline%20x1%3D%228%22%20x2%3D%2214%22%20y1%3D%2211%22%20y2%3D%2211%22%2F%3E%3C%2Fsvg%3E') no-repeat center / 24px #fff;
      box-shadow: 0px 0px 3px #888;
      border-radius: 300px;
      position: absolute;
      right: 10px;
      bottom: 10px;
      z-index: 1;
      transition: .3s;
      opacity: 0;
    }
    &:hover:before {
      opacity: .8;
    }
  }
  .product_btn a {
    transition: .3s;
    &:hover {
      opacity: .7;
    }
  }
  .links a {
    transition: .3s;
    &:hover {
      box-shadow: inset 0 0 10px 0px #AC3F45;
    }
  }
  .links.purple a {
    transition: .3s;
    &:hover {
      box-shadow: inset 0 0 10px 0px #3A4C7F;
    }
  }
}


@media only screen and (max-width: 767px) {
    #LPcontent {
    padding: 0 24px 80px;
    background: transparent;
  }
	.product_btn {
    margin-top: 32px;
    margin-bottom: 32px;	  
  }
  .product_btn a {
    width: min(100%, 524px);
    padding-block: 24px;
    font-size: 24px;
  }
  .product_btn.purple a {
    width: min(100%, 524px);
    padding-block: 24px;
    font-size: 24px;
  }	
  .section_footer {
    margin-top: 64px;
    padding-top: 92px;
    background-image: url(/img/usr/freepage/sideM_SweetBitter/wave_sp.png);
  }
  .section_footer_blue{
    margin-top:64px;
    padding-top:92px;
    background-image:url(/img/usr/freepage/sideM_SweetBitter/wave_sp_blue.png);
  }

  .section_footer .footer_btn a {
    width: 100%;
    padding-block: 30px;
    font-size: 32px;
  }
  .section_footer .copy {
    margin-top: 40px;
    font-size: 20px;
  }
  .contents03_inner {
    padding-inline: 40px;
  }
  .contents03_title {
    font-size: 36px;
    gap: 8px;
    margin-bottom: 40px;
  }
  .contents03_title:before, .contents03_title:after {
    width: 80px;
    height: 18px;
  }
  .info {
    margin-bottom: 56px;
    .info_text {
      margin-bottom: 24px;
      dt,dd {
        font-size: 28px;
      }
    }
    .info_note {
      font-size: 20px;
    }
  }
 .links ul {
    justify-content: center; 
    gap: 16px;
    li {
      flex: initial;
      width: calc(50% - 8px);
      a {
        border: 2px solid #AC3F45;
        border-radius: 16px;
        padding-right: 28px;
        font-size: 22px;
      }
    }
  }
.links.purple ul {
    justify-content: center;
    gap: 16px;
    li {
      flex: initial;
      width: calc(50% - 8px);
      a {
        border: 2px solid #3A4C7F;
        border-radius: 16px;
        padding-right: 28px;
        font-size: 22px;
      }
    }
  }	
  .contents03_wrap {
    &+.contents03_wrap {
        margin-top: 64px;
        padding-top:56px;
        border-top: 2px solid;
    }
  }
  .contents03_product ul,
  .contents03_product.-col3 ul {
    gap: 40px 26px;
    li {
      width: calc(50% - 13px);
      display: flex;
      flex-flow: column wrap;
      align-content: center;
      justify-content: space-between;
      align-items: stretch;
    }
  }
  .contents03_product.-col3 ul {
    width: auto;
  }
  .product_img a {
    position: relative;
    &:before {
      content: "";
      display: inline-block;
      width: 48px;
      height: 48px;
      background: url(data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23888888%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22lucide%20lucide-zoom-in%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%2F%3E%3Cline%20x1%3D%2221%22%20x2%3D%2216.65%22%20y1%3D%2221%22%20y2%3D%2216.65%22%2F%3E%3Cline%20x1%3D%2211%22%20x2%3D%2211%22%20y1%3D%228%22%20y2%3D%2214%22%2F%3E%3Cline%20x1%3D%228%22%20x2%3D%2214%22%20y1%3D%2211%22%20y2%3D%2211%22%2F%3E%3C%2Fsvg%3E) no-repeat center / 30px #fff;
      box-shadow: 0px 0px 3px #888;
      border-radius: 300px;
      position: absolute;
      right: 10px;
      bottom: 10px;
      opacity: .8;
    }
  }
  .product_name {
    font-size: 24px;
    margin-bottom: 16px;
  }
  .product_btn a {
    width: 100%;
    height: 76px;
    font-size: 24px;
  }
}

  #LPcontent {
    background-color: transparent !important;
    background-image: url("/img/usr/freepage/sideM_SweetBitter/bg_sp_common.jpg") !important;
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: center top !important;
  }
  }


/* =========================================
   LP全体の背景を共通画像（PC/SP別）で統一
   ========================================= */

/* PC（768px以上） */
#LPcontent {
  background-color: transparent !important;
  background-image: url("/img/usr/freepage/sideM_SweetBitter/bg_pc_common.jpg") !important; /* ←PC用に差し替え */
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center top !important;
}

/* SP（〜767px） */
@media only screen and (max-width: 767px) {
  #LPcontent {
    background-color: transparent !important;
    background-image: url("/img/usr/freepage/sideM_SweetBitter/bg_sp_common.jpg") !important; /* ←SP用に差し替え */
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: center top !important;
  }
}

