@charset "utf-8";

:root {
  --themeColor: #FFEAB7;
}

#site_footer_top,
footer#site_footer {
  position: relative;
  z-index: 4;
}

@media screen and (max-width: 1000px) {
  .chatbot-container {
    display: none !important;
  }
}

/*-----------------------------------------
common
-----------------------------------------*/
#campaign {
  position: relative;
  color: #430023;
}
#campaign h1,
#campaign h2,
#campaign h3 {
  margin: 0 auto;
  padding: 0;
  border: 0;
}
#campaign img {
  vertical-align: top;
}
#campaign figure {
  text-align: center;
}
#campaign a {
  color: inherit;
  transition: all .3s;
}
#campaign a:hover {
  text-decoration: none;
  opacity: 0.6;
}
#campaign button {
  width: 100%;
  margin: 0;
  padding: 0;
  color: inherit;
  background: none;
  border: none;
  cursor: pointer;
}

@media screen and (min-width: 1001px) {
  #campaign .for-sp {
    display: none;
  }
}

@media screen and (max-width: 1000px) {
  #campaign .for-pc {
    display: none;
  }
  #campaign .link a {
    font-size: 26px;
  }
}

@media screen and (max-width: 750px) {
  #campaign .link a {
    font-size: 3.467vw;
  }
}

/*-----------------------------------------
layout
-----------------------------------------*/
#campaign .campaign_inner {
  display: flex;
  justify-content: center;
  background: var(--themeColor) url(/img/usr/freepage/2026/2602Valentine/bg_pc.png) repeat-x top center;
  background-attachment: fixed;
}
#campaign .main_frame {
  position: relative;
  width: 36vw;
  max-width: 750px;
  background: #fff;
  box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.15);
}
#campaign .left_frame,
#campaign .right_frame {
	position: sticky;
	top: 100px;
  flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	max-height: calc(100vh - 100px);
	z-index: 2;
}

@media screen and (min-width: 1001px) {
  #campaign .left_frame-wrapper,
  #campaign .right_frame-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 700px;
    background-repeat: no-repeat;
    background-position: center;
  }
  #campaign .left_frame-wrapper {
    margin-bottom: min(50px,calc(50px / 1600px * 100vw));
    background-image: url(/img/usr/freepage/2026/2602Valentine/bg_left_pc.png);
  }
  #campaign .right_frame-wrapper {
    margin-top: min(100px,calc(100px / 1600px * 100vw));
    background-image: url(/img/usr/freepage/2026/2602Valentine/bg_right_pc.png);
  }
}

@media screen and (max-width: 1000px) {
  #campaign .campaign_inner {
    width: 100%;
  }
  #campaign .left_frame {
    display: none;
  }
  #campaign .right_frame {
    display: none;
    position: fixed;
    top: auto;
    bottom: 10px;
    left: 0;
    display: block;
    width: 100%;
    padding: 0;
  }
  #campaign .main_frame {
    width: 100%;
    box-shadow: none;
  }
}

/*-----------------------------------------
left coupon
-----------------------------------------*/
#campaign .left_frame-content {
  position: relative;
  width: 100%;
  max-width: 700px;
  margin: 30px 0 0;
  text-align: center;
  color: #fff;
}
#campaign .left_frame-content .coupon-title {
  position: absolute;
  top: max(-240px,calc(-240px / 1500px * 100vw));
  right: max(70px,calc(70px / 1500px * 100vw));
  width: min(262px,calc(262px / 1500px * 100vw));
}
#campaign .left_frame-content .coupon-subtitle {
  font-family: "Abril Fatface", serif;
  font-weight: 400;
  font-size: min(40px,calc(40px / 1500px * 100vw));
  line-height: 1;
  color: var(--themeColor);
  white-space: nowrap;
}
#campaign .left_frame-content .coupon-text {
  margin: 30px 0 0;
  font-weight: 500;
  font-size: min(15px,calc(15px / 1500px * 100vw));
  letter-spacing: 0.04em;
  line-height: 1.555;
  text-align: center;
}
#campaign .left_frame-content .coupon-text span {
  font-size: min(25px,calc(25px / 1500px * 100vw));
}
#campaign .left_frame-content .coupon-image img {
  width: min(344px,calc(344px / 1500px * 100vw));
}
#campaign .left_frame-content .coupon-notice {
  width: fit-content;
  margin: 0 auto;
  padding-left: 1em;
  text-indent: -1em;
  font-size: min(12px,calc(12px / 1500px * 100vw));
  letter-spacing: 0.04em;
  line-height: 1.666;
  text-align: left;
}


/*-----------------------------------------
navi
-----------------------------------------*/
@media screen and (min-width: 1001px) {
  #campaign .navi-list {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  #campaign .navi-list li a {
    position: relative;
    display: flex;
    align-items: center;
    margin: -6px 0;
    padding-right: min(56px,calc(56px / 1500px * 100vw));
  }
  #campaign .navi-list li a::before {
    content: "";
    display: block;
    width: min(133px,calc(133px / 1500px * 100vw));
    height: min(119px,calc(119px / 1500px * 100vw));
    margin: 0 -8px 0 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
  }
  #campaign .navi-list li a::after {
    content: "";
    position: absolute;
    bottom: -8px;
    right: 0;
    width: min(125px,calc(125px / 1500px * 100vw));
    height: min(120px,calc(120px / 1500px * 100vw));
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
  }
  #campaign .navi-list li:nth-child(1) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_01_pc.png);
  }
  #campaign .navi-list li:nth-child(1) a::after {
    background-image: url(/img/usr/freepage/2026/2602Valentine/nav_item_01_pc.png);
  }
  #campaign .navi-list li:nth-child(2) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_02_pc.png);
  }
  #campaign .navi-list li:nth-child(2) a::after {
    background-image: url(/img/usr/freepage/2026/2602Valentine/nav_item_02_pc.png);
  }
  #campaign .navi-list li:nth-child(3) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_03_pc.png);
  }
  #campaign .navi-list li:nth-child(3) a::after {
    background-image: url(/img/usr/freepage/2026/2602Valentine/nav_item_03_pc.png);
  }
  #campaign .navi-list li a span {
    display: block;
    width: min(270px,calc(270px / 1500px * 100vw));
    padding: 0 0 min(8px,calc(8px / 1500px * 100vw));
    font-weight: bold;
    font-size: min(23px,calc(23px / 1500px * 100vw));
    letter-spacing: 0.1em;
    line-height: 1.38;
    border-bottom: 2px solid #ffceb5;
  }
}

@media screen and (max-width: 1000px) {
  #campaign .navi-list {
    max-width: 750px;
    padding: 0 min(20px,calc(20px / 750px * 100vw));
    margin: 0 auto;
    display: flex;
    gap: min(10px,calc(10px / 750px * 100vw));
  }
  #campaign .navi-list li {
    width: calc((100% - (min(10px,calc(10px / 750px * 100vw)) * 2))/3);
  }
  #campaign .navi-list li a {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: min(130px,calc(130px / 750px * 100vw));
    background: #7f2c2c;
    border-radius: 10px;
  }
  #campaign .navi-list li a::before {
    content: "";
    position: absolute;
    top: max(-46px,calc(-46px / 750px * 100vw));
    left: 0;
    right: 0;
    width: min(114px,calc(114px / 750px * 100vw));
    height: min(104px,calc(104px / 750px * 100vw));
    margin: auto;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
  }
  #campaign .navi-list li:nth-child(1) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_01_sp.png);
  }
  #campaign .navi-list li:nth-child(2) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_02_sp.png);
  }
  #campaign .navi-list li:nth-child(3) a::before {
    background-image: url(/img/usr/freepage/2026/2602Valentine/icon_num_03_sp.png);
  }
  #campaign .navi-list li a span {
    font-weight: bold;
    font-size: min(24px,calc(24px / 750px * 100vw));
    letter-spacing: 0.1em;
    line-height: 1.25;
    color: #fff;
    text-align: center;
  }
}

/*-----------------------------------------
main
-----------------------------------------*/
#campaign #sec_main .message {
  padding: min(72px,calc(72px / 750px * 100vw)) 0;
  font-size: min(24px,calc(24px / 750px * 100vw));
  letter-spacing: 0.1em;
  line-height: 1.833;
  text-align: center;
}

@media screen and (min-width: 1001px) {
  #campaign #sec_main .message {
    font-size: min(24px,calc(24px / 2080px * 100vw));
  }
}

/*-----------------------------------------
coupon
-----------------------------------------*/
#campaign #sec_coupon {
  padding: min(160px,calc(160px / 750px * 100vw)) min(75px,calc(75px / 750px * 100vw)) min(70px,calc(70px / 750px * 100vw));
  background: #ffe5d7 url(/img/usr/freepage/2026/2602Valentine/bg_coupon.png) no-repeat center top / 100%;
}
#campaign #sec_coupon .coupon-container {
  position: relative;
  padding: min(170px,calc(170px / 750px * 100vw)) min(20px,calc(20px / 750px * 100vw)) min(20px,calc(20px / 750px * 100vw));
  background: #fff;
  border-radius: 400px 400px 20px 20px;
}
#campaign #sec_coupon .coupon-title {
  position: absolute;
  top: max(-60px,calc(-60px / 750px * 100vw));
  left: 0;
  right: 0;
  margin: auto;
  width: min(262px,calc(262px / 750px * 100vw));
}
#campaign #sec_coupon .coupon-text {
  font-size: min(26px,calc(26px / 750px * 100vw));
  letter-spacing: 0.1em;
  line-height: 1.7;
  text-align: center;
}
#campaign #sec_coupon .coupon-text span {
  display: block;
  margin: min(35px,calc(35px / 750px * 100vw)) 0 0;
  font-weight: bold;
  font-size: min(32px,calc(32px / 750px * 100vw));
  line-height: 1;
}
#campaign #sec_coupon .coupon-img {
  margin: min(30px,calc(30px / 750px * 100vw)) 0 0;
}
#campaign #sec_coupon .coupon-about {
  margin: min(35px,calc(35px / 750px * 100vw)) 0 0;
  padding: 0 min(20px,calc(20px / 750px * 100vw));
  background: #f7f6f2;
  border-radius: 20px;
}
#campaign #sec_coupon .coupon-about-btn {
  position: relative;
  padding: min(36px,calc(36px / 750px * 100vw)) 0;
  font-weight: bold;
  font-size: min(28px,calc(28px / 750px * 100vw));
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
}
#campaign #sec_coupon .coupon-about-btn::before,
#campaign #sec_coupon .coupon-about-btn::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: min(10px,calc(10px / 750px * 100vw));
  width: min(24px,calc(24px / 750px * 100vw));
  height: min(4px,calc(4px / 750px * 100vw));
  margin: auto;
  background: #430023;
  transition: all .3s;
}
#campaign #sec_coupon .coupon-about-btn::after {
  transform: rotate(90deg);
}
#campaign #sec_coupon .coupon-about-btn.active::after {
  transform: rotate(180deg);
}
#campaign #sec_coupon .coupon-about-content {
  display: none;
}
#campaign #sec_coupon .coupon-about-list {
  padding: 0 0 min(26px,calc(26px / 750px * 100vw));
}
#campaign #sec_coupon .coupon-about-list li {
  padding-left: 1.3em;
  text-indent: -1.3em;
  font-size: min(22px,calc(22px / 750px * 100vw));
  letter-spacing: 0.04em;
  line-height: 1.36;
}

@media screen and (min-width: 1001px) {
  #campaign #sec_coupon {
    padding: min(160px,calc(160px / 2080px * 100vw)) min(75px,calc(75px / 2080px * 100vw)) min(70px,calc(70px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-container {
    padding: min(170px,calc(170px / 2080px * 100vw)) min(20px,calc(20px / 2080px * 100vw)) min(20px,calc(20px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-title {
    top: max(-60px,calc(-60px / 2080px * 100vw));
    width: min(262px,calc(262px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-text {
    font-size: min(26px,calc(26px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-text span {
    font-size: min(32px,calc(32px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-about-btn {
    font-size: min(28px,calc(28px / 2080px * 100vw));
  }
  #campaign #sec_coupon .coupon-about-list li {
    font-size: min(22px,calc(22px / 2080px * 100vw));
  }
}

/*-----------------------------------------
notice
-----------------------------------------*/
#campaign #sec_notice {
  padding: min(70px,calc(70px / 750px * 100vw)) min(20px,calc(20px / 750px * 100vw));
}
#campaign #sec_notice .notice-container {
  padding: min(50px,calc(50px / 750px * 100vw)) min(20px,calc(20px / 750px * 100vw)) min(30px,calc(30px / 750px * 100vw));
  background: #f7f6f2;
  border-radius: 20px;
}
#campaign #sec_notice h2{
  width: fit-content;
  margin: 0 auto 15px;
  padding-left: min(53px,calc(53px / 750px * 100vw));
  font-family: "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  font-size: min(30px,calc(30px / 750px * 100vw));
  letter-spacing: 0.1em;
  color: #7f2c2c;
  background: url(/img/usr/freepage/2026/2602Valentine/icon_notice.png) no-repeat left center / min(33px,calc(33px / 750px * 100vw));
}
#campaign #sec_notice .notice-text {
  font-size: min(24px,calc(24px / 750px * 100vw));
  letter-spacing: 0.04em;
  line-height: 1.4166;
}
#campaign #sec_notice .notice-text a {
  text-decoration: underline;
}

@media screen and (min-width: 1001px) {
  #campaign #sec_notice {
    padding: min(70px,calc(70px / 2080px * 100vw)) min(20px,calc(20px / 2080px * 100vw));
  }
  #campaign #sec_notice .notice-container {
    padding: min(50px,calc(50px / 2080px * 100vw)) min(20px,calc(20px / 2080px * 100vw)) min(30px,calc(30px / 2080px * 100vw));
  }
  #campaign #sec_notice h2{
    padding-left: min(53px,calc(53px / 2080px * 100vw));
    font-size: min(30px,calc(30px / 2080px * 100vw));
    background-size: min(33px,calc(33px / 2080px * 100vw));
  }
  #campaign #sec_notice .notice-text {
    font-size: min(24px,calc(24px / 2080px * 100vw));
  }
}

/*-----------------------------------------
lineup
-----------------------------------------*/
#campaign #sec_lineup h2 {
  margin: 34px 0 46px;
  font-family: "Abril Fatface", serif;
  font-weight: 400;
  font-size: min(90px,calc(90px / 750px * 100vw));
  line-height: 1;
  text-align: center;
  color: #7f2c2c;
}
#campaign #sec_lineup .link-contents {
  position: relative;
}
#campaign #sec_lineup .link-btn {
  position: absolute;
  bottom: min(36px,calc(36px / 750px * 100vw));
  left: 50%;
  transform: translateX(-50%);
}
#campaign #sec_lineup .link-btn a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(600px,calc(600px / 750px * 100vw));
  height: min(110px,calc(110px / 750px * 100vw));
  font-weight: bold;
  font-size: min(36px,calc(36px / 750px * 100vw));
  letter-spacing: 0.1em;
  color: #fff;
  background: #e50611;
  border-radius: 100px;
  box-shadow: 0px 1px 20px 0px rgba(0, 0, 0, 0.3);
}
#campaign #sec_lineup .link-btn a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(0deg, #000, #fff);
  border-radius: 100px;
  mix-blend-mode: soft-light;
}
#campaign #sec_lineup .link-btn a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: min(40px,calc(40px / 750px * 100vw));
  width: min(18px,calc(18px / 750px * 100vw));
  height: min(20px,calc(20px / 750px * 100vw));
  margin: auto;
  background: #fff;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
#campaign #sec_lineup #lineup03 .link-btn {
  bottom: min(45px,calc(45px / 750px * 100vw));
  left: auto;
  right: min(60px,calc(60px / 750px * 100vw));
  transform: none;
}
#campaign #sec_lineup #lineup03 .link-btn a {
  width: min(420px,calc(420px / 750px * 100vw));
}

@media screen and (min-width: 1001px) {
  #campaign #sec_lineup h2 {
    font-size: min(90px,calc(90px / 2080px * 100vw));
  }
  #campaign #sec_lineup .link-btn {
    bottom: min(36px,calc(36px / 2080px * 100vw));
  }
  #campaign #sec_lineup .link-btn a {
    width: min(600px,calc(600px / 2080px * 100vw));
    height: min(110px,calc(110px / 2080px * 100vw));
    font-size: min(36px,calc(36px / 2080px * 100vw));
  }
  #campaign #sec_lineup .link-btn a::after {
    right: min(40px,calc(40px / 2080px * 100vw));
    width: min(18px,calc(18px / 2080px * 100vw));
    height: min(20px,calc(20px / 2080px * 100vw));
  }
  #campaign #sec_lineup #lineup03 .link-btn {
    bottom: min(45px,calc(45px / 2080px * 100vw));
    right: min(60px,calc(60px / 2080px * 100vw));
  }
  #campaign #sec_lineup #lineup03 .link-btn a {
    width: min(420px,calc(420px / 2080px * 100vw));
  }
}