@charset "UTF-8";

:root {
  --color-red: #C33525;
  --color-brown: #4F342B;
  --color-btn: #BD8263;
}

/*-----------------------------------------
  common
-----------------------------------------*/
#gift {
  font-weight: 500;
  color: #333333;
}
#gift h1,
#gift h2,
#gift h3,
#gift h4 {
  padding: 0;
  margin: 0;
  font-weight: inherit;
}
#gift a {
  color: inherit;
  transition: all .3s;
}
#gift a:hover,
#gift a:focus {
  opacity: 0.7;
}
#gift button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
}
#gift .inner {
  max-width: 1230px;
  margin: 0 auto;
  padding: 0 15px;
}
#gift .sub-font {
  font-family: var(--subFont);
}
#gift .gift-title {
  font-size: 30px;
  letter-spacing: 0.08em;
  line-height: 1.466;
  text-align: center;
}
#gift .gift-subtitle {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  margin: 0 0 50px;
  font-size: 25px;
  letter-spacing: 0.08em;
  line-height: 1.44;
}
#gift .gift-subtitle::before,
#gift .gift-subtitle::after {
  content: "";
  display: block;
  flex: 1;
  height: 1px;
  background: #BB8062;
}
#gift .gift-item-list .name {
  margin: 13px 0 0;
  font-size: 16px;
  line-height: 1.625;
  text-align: left;
}
#gift .gift-item-list .price {
  margin: 14px 0 0;
  font-weight: 600;
  font-size: 24px;
  text-align: right;
}
#gift .gift-item-list .price span,
#gift .gift-item-list .price::after {
  font-size: 14px;
}
#gift .gift-btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 386px;
  height: 60px;
  margin: 0 auto;
  font-size: 16px;
  color: #fff;
  background: var(--color-btn);
  border: 2px solid var(--color-btn);
  border-radius: 100px;
}
#gift .gift-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
  transition: all .3s;
}
#gift .gift-btn:hover {
  color: var(--color-btn);
  background: #fff;
  opacity: 1;
}
#gift .gift-btn:hover::after {
  border-color: var(--color-btn);
}
#gift .gift-btn.anchor {
  color: var(--color-red);
  background: #fff;
  border-color: var(--color-red);
}
#gift .gift-btn.anchor::after {
  border-color: var(--color-red);
}
#gift .gift-btn.anchor:hover {
  color: #fff;
  background: var(--color-red);
}
#gift .gift-btn.anchor:hover::after {
  border-color: #fff;
}
#gift .js-tab-frame {
  display: none;
}
#gift .js-tab-frame.active {
  display: block;
}
@media only screen and (min-width: 769px) {
  #gift .for-sp {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  #gift .for-pc {
    display: none;
  }
  #gift .inner {
    padding: 0 24px;
  }
  #gift .gift-title {
    font-size: 24px;
  }
  #gift .gift-subtitle {
    gap: 10px;
    margin: 0 0 25px;
    font-size: 20px;
  }
  #gift .gift-item-list .name {
    margin: 9px 0 0;
    line-height: 1.5;
  }
  #gift .gift-item-list .price {
    margin: 5px 0 0;
  }
  #gift .gift-item-list .price span,
  #gift .gift-item-list .price::after {
    font-size: 13px;
  }
  #gift .gift-btn {
    max-width: 280px;
    height: 50px;
  }
  #gift .gift-btn.anchor {
    font-size: 15px;
    line-height: 1.266;
  }
}

/*-----------------------------------------
  fv
-----------------------------------------*/
#gift .sec-fv {
  position: relative;
  padding: 10px 15px 0;
  text-align: center;
  z-index: 1;
}
#gift .sec-fv::before {
  content: "";
  position: absolute;
  bottom: -178px;
  left: 50%;
  transform: translateX(-50%);
  width: 1675px;
  height: 1011px;
  background: url(/img/usr/freepage/gift/bg_01_pc.png) no-repeat center / contain;
  z-index: -1;
}
#gift .sec-fv .fv-mv img {
  border-radius: 25px;
}
#gift .sec-fv .fv-lead {
  margin: 84px 0 0;
  padding: 164px 0 0;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 2.25;
  color: var(--color-brown);
  background: url(/img/usr/freepage/gift/icon_lead.png) no-repeat center top / 110px;
}
#gift .sec-fv .fv-lead span {
  display: block;
  margin: 0 0 10px;
  font-weight: bold;
  font-size: 23px;
  line-height: 1.478;
  color: var(--color-red);
}
#gift .sec-fv .fv-nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 25px;
  margin: 52px 0 0;
}
#gift .sec-fv .fv-nav ul li {
  width: calc((100% - (25px*3))/4);
  max-width: 200px;
}
#gift .sec-fv .fv-nav ul li a {
  position: relative;
  display: block;
  padding: 100px 20px 48px;
  background: #fff;
  border: 1px solid var(--color-red);
  border-radius: 20px;
}
#gift .sec-fv .fv-nav ul li a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 22px;
  width: 16px;
  height: 13px;
  background: var(--color-red);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  transform: translateX(-50%);
  transition: all .3s;
}
#gift .sec-fv .fv-nav ul li a span {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: calc(2em*1.25);
  font-weight: bold;
  font-size: 20px;
  line-height: 1.25;
  color: var(--color-red);
}
@media only screen and (min-width: 769px) {
  #gift .sec-fv .fv-nav ul li.noshi a {
    background: url(/img/usr/freepage/gift/icon_noshi.png) no-repeat center top 20px / 56px;
  }
  #gift .sec-fv .fv-nav ul li.wrapping a {
    background: url(/img/usr/freepage/gift/icon_wrapping.png) no-repeat center top 16px / 68px;
  }
  #gift .sec-fv .fv-nav ul li.howto a {
    background: url(/img/usr/freepage/gift/icon_howto.png) no-repeat center top 23px / 97px;
  }
  #gift .sec-fv .fv-nav ul li a:hover::after {
    bottom: 18px;
  }
}
@media only screen and (max-width: 768px) {
  #gift .sec-fv {
    padding: 10px 8px 0;
  }
  #gift .sec-fv::before {
    bottom: -41vw;
    width: 100%;
    height: 265vw;
    background-image: url(/img/usr/freepage/gift/bg_01_sp.png);
  }
  #gift .sec-fv .fv-mv img {
    border-radius: 15px;
  }
  #gift .sec-fv .fv-lead {
    margin: 60px 0 0;
    padding: 123px 0 0;
    font-size: 16px;
    line-height: 2;
    background-size: 79px;
  }
  #gift .sec-fv .fv-lead span {
    margin: 0 0 18px;
    font-size: clamp(20px,6.15vw,24px);
    line-height: 1.58;
  }
  #gift .sec-fv .fv-nav ul {
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin: 45px 0 0;
  }
  #gift .sec-fv .fv-nav ul li {
    width: 90%;
    max-width: 280px;
    padding-top: 18px;
  }
  #gift .sec-fv .fv-nav ul li a {
    display: flex;
    align-items: center;
    height: 60px;
    padding: 0 30px 0 85px;
    border-radius: 9px;
  }
  #gift .sec-fv .fv-nav ul li a::before {
    content: "";
    position: absolute;
    top: -18px;
  }
  #gift .sec-fv .fv-nav ul li.noshi a::before {
    left: 20px;
    width: 49px;
    height: 64px;
    background: url(/img/usr/freepage/gift/icon_noshi.png) no-repeat center / contain;
  }
  #gift .sec-fv .fv-nav ul li.wrapping a::before {
    left: 14px;
    width: 60px;
    height: 68px;
    background: url(/img/usr/freepage/gift/icon_wrapping.png) no-repeat center / contain;
  }
  #gift .sec-fv .fv-nav ul li.howto a::before {
    left: 12px;
    width: 68px;
    height: 65px;
    background: url(/img/usr/freepage/gift/icon_howto.png) no-repeat center / contain;
  }
  #gift .sec-fv .fv-nav ul li a::after {
    top: 50%;
    right: 20px;
    left: auto;
    bottom: auto;
    width: 12px;
    height: 10px;
    transform: translateY(-50%);
  }
  #gift .sec-fv .fv-nav ul li a span {
    display: block;
    min-height: unset;
    font-size: 16px;
    line-height: 1.25;
  }
}

/*-----------------------------------------
  noshi
-----------------------------------------*/
#gift .sec-noshi {
  padding: 120px 0 198px;
  text-align: center;
  background: url(/img/usr/freepage/gift/bg_02_pc.png) no-repeat center bottom -120px;
}
#gift .sec-noshi > .gift-title {
  padding-top: 126px;
  background: url(/img/usr/freepage/gift/text_noshi.png) no-repeat center top, url(/img/usr/freepage/gift/icon_noshi.png) no-repeat center top 40px / 56px;
}
#gift .sec-noshi .noshi-lead {
  padding: 28px 15px 0;
  font-size: 18px;
  line-height: 1.944;
  color: var(--color-brown);
}
#gift .sec-noshi .noshi-item {
  max-width: 1400px;
  margin: 75px auto 0;
  padding: 38px 15px 45px;
  background: #FFFCF4;
  border-radius: 20px;
}
#gift .sec-noshi .noshi-item .gift-title {
  padding-top: 110px;
  font-size: 25px;
  background: url(/img/usr/freepage/gift/text_item.png) no-repeat center top, url(/img/usr/freepage/gift/icon_item.png) no-repeat center top 28px / 56px;
}
#gift .sec-noshi .noshi-item .gift-item-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  max-width: 1200px;
  margin: 30px auto 40px;
}
#gift .sec-noshi .noshi-item .gift-item-list li {
  width: calc((100% - (20px*3))/4);
}
#gift .sec-noshi .noshi-contents {
  margin: 100px 0 0;
}
#gift .sec-noshi .noshi-contents-inner {
  max-width: 1110px;
  margin: 0 auto;
}
#gift .sec-noshi .noshi-list {
  display: flex;
  justify-content: center;
  gap: 25px;
  margin: 36px 0 0;
}
#gift .sec-noshi .noshi-list li {
  width: calc((100% - 25px)/2);
  max-width: 530px;
  padding: 40px 25px 30px;
  border: 1px solid #333333;
  border-radius: 20px;
}
#gift .sec-noshi .noshi-list li .text dt {
  margin: 5px 0 0;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.444;
}
#gift .sec-noshi .noshi-list li .text dd {
  margin: 8px;
  font-size: 16px;
}
#gift .sec-noshi .noshi-text {
  margin: -20px 0 0;
  font-size: 16px;
  line-height: 2;
  color: var(--color-brown);
}
/* about */
#gift .sec-noshi .about .noshi-list img {
  max-width: 380px;
}
#gift .sec-noshi .about .noshi-about-text {
  margin: 50px 0 0;
  font-size: 18px;
  line-height: 1.666;
  color: #333333;
}
#gift .sec-noshi .about .noshi-about-text .notice {
  margin: 14px 0 0;
  font-size: 15px;
  line-height: 1.866;
}
/* kinds */
#gift .sec-noshi .kinds .noshi-kinds-tab {
  display: flex;
  justify-content: center;
  gap: min(35px,2.845vw);
}
#gift .sec-noshi .kinds .noshi-kinds-tab li {
  width: 45%;
  max-width: 450px;
}
#gift .sec-noshi .kinds .noshi-kinds-tab li button {
  width: 100%;
  padding: 16px 0;
  font-size: 18px;
  text-align: center;
  background: #fff;
  border: 1px solid #E3E3E3;
  border-bottom: none;
}
#gift .sec-noshi .kinds .noshi-kinds-tab li.active button {
  font-weight: bold;
  color: #fff;
  background: #333333;
}
#gift .sec-noshi .kinds .noshi-kinds-tab + .noshi-kinds-container {
  padding: 45px 15px 55px;
  border: 1px solid #333333;
  border-radius: 15px;
}
#gift .sec-noshi .kinds .noshi-kinds-tab + .noshi-kinds-container > .noshi-kinds-frame {
  max-width: 1030px;
  margin: 0 auto;
}
#gift .sec-noshi .kinds .noshi-kinds-head {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 35px;
}
#gift .sec-noshi .kinds .noshi-kinds-head li button {
  position: relative;
  padding: 0 min(45px,3.658vw);
  font-size: clamp(15px,1.46vw,18px);
  line-height: 1.444;
  color: #8B8B8B;
  white-space: nowrap;
}
#gift .sec-noshi .kinds .noshi-kinds-head li:not(:first-child) button::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1px;
  height: 30px;
  background: #333333;
  transform: translateY(-50%);
}
#gift .sec-noshi .kinds .noshi-kinds-head li.active button {
  font-weight: bold;
  color: #333333;
}
#gift .sec-noshi .kinds .noshi-kinds-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
#gift .sec-noshi .kinds .noshi-kinds-list li {
  width: calc((100% - (20px*4))/5);
}
#gift .sec-noshi .kinds .noshi-kinds-list li .text {
  margin: 15px 0 0;
  font-size: 16px;
}
/* covertype */
#gift .sec-noshi .covertype .noshi-list img {
  max-width: 250px;
}
/* nameprint */
#gift .sec-noshi .nameprint .noshi-nameprint-list {
  display: flex;
  gap: 13px;
  margin: 45px 0 0;
}
#gift .sec-noshi .nameprint .noshi-nameprint-list .text {
  margin: 15px 0 0;
  font-size: 16px;
}
#gift .sec-noshi .nameprint .noshi-nameprint-about {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 55px 0 0;
}
#gift .sec-noshi .nameprint .noshi-nameprint-about .img {
  width: 35%;
  max-width: 295px;
}
#gift .sec-noshi .nameprint .noshi-nameprint-about .text {
  width: 65%;
  max-width: 610px;
  padding: 30px 25px 40px;
  text-align: left;
  border: 1px solid #BD8263;
  border-radius: 20px;
}
#gift .sec-noshi .nameprint .noshi-nameprint-about .text dt {
  margin: 20px 0 0;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.444;
}
#gift .sec-noshi .nameprint .noshi-nameprint-about .text dd {
  margin: 5px 0 0;
  font-size: 16px;
}
#gift .sec-noshi .nameprint .noshi-nameprint-head {
  padding: 0 0 0 9px;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.444;
  border-left: 5px solid #BD8263;
}
/* paper */
#gift .sec-noshi .paper {
  margin-bottom: 75px;
}
#gift .sec-noshi .paper .noshi-paper-list {
  display: flex;
  justify-content: center;
  gap: 13px;
  margin: -22px 0 0;
}
#gift .sec-noshi .paper .noshi-paper-list img {
  width: 268px;
}
#gift .sec-noshi .paper .noshi-paper-list .text {
  margin: 15px 0 0;
  font-size: 16px;
}
@media only screen and (max-width: 768px) {
  #gift .sec-noshi {
    padding: 100px 0 120px;
    background-image: url(/img/usr/freepage/gift/bg_02_sp.png);
    background-position: center bottom -60px;
  }
  #gift .sec-noshi > .gift-title {
    padding-top: 100px;
    background-position: center top,center top 26px;
    background-size: 100px,45px;
  }
  #gift .sec-noshi .noshi-lead {
    padding: 15px 0 0;
    font-size: 16px;
    line-height: 1.75;
  }
  #gift .sec-noshi .noshi-item {
    margin: 45px 8px 0;
    padding: 40px 20px 45px;
  }
  #gift .sec-noshi .noshi-item .gift-title {
    padding-top: 85px;
    font-size: 20px;
    background-position: center top,center top 20px;
    background-size: 100px,45px;
  }
  #gift .sec-noshi .noshi-item .gift-item-list {
    gap: 16px 10px;
    margin: 25px auto 40px;
  }
  #gift .sec-noshi .noshi-item .gift-item-list li {
    width: calc((100% - 10px)/2);
  }
  #gift .sec-noshi .noshi-contents {
    margin: 65px 0 0;
  }
  #gift .sec-noshi .noshi-list {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
  #gift .sec-noshi .noshi-list li {
    width: 100%;
    padding: 25px 10px 20px;
    border-radius: 8px;
  }
  #gift .sec-noshi .noshi-list li .text dt {
    font-size: 16px;
    line-height: 1.5;
  }
  #gift .sec-noshi .noshi-list li .text dd {
    margin: 0;
    font-size: 15px;
    line-height: 1.86;
  }
  #gift .sec-noshi .noshi-text {
    margin: -10px 0 0;
    line-height: 1.75;
    color: #333333;
    text-align: left;
  }
  /* about */
  #gift .sec-noshi .about .noshi-list img {
    max-width: 250px;
  }
  #gift .sec-noshi .about .noshi-about-img {
    width: 330px;
    margin: -8px auto 0;
  }
  #gift .sec-noshi .about .noshi-about-text {
    margin: 20px 0 0;
    font-size: 16px;
    line-height: 1.75;
    text-align: left;
  }
  #gift .sec-noshi .about .noshi-about-text .notice {
    margin: 5px 0 0;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 2;
    opacity: 0.73;
  }
  /* kinds */
  #gift .sec-noshi .kinds .noshi-kinds-tab {
    gap: 0;
    border-bottom: 1px solid #333;
  }
  #gift .sec-noshi .kinds .noshi-kinds-tab li {
    width: 50%;
  }
  #gift .sec-noshi .kinds .noshi-kinds-tab li button {
    padding: 14px 0;
    font-size: 14px;
  }
  #gift .sec-noshi .kinds .noshi-kinds-tab + .noshi-kinds-container {
    padding: 32px 14px 35px;
    border-radius: 0;
  }
  #gift .sec-noshi .kinds .noshi-kinds-head {
    justify-content: flex-start;
    gap: 8px;
    margin: 0 0 30px;
    overflow-x: auto;
  }
  #gift .sec-noshi .kinds .noshi-kinds-head li {
    flex-shrink: 0;
  }
  #gift .sec-noshi .kinds .noshi-kinds-head li button {
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 120px;
    height: 50px;
    padding: 0 10px;
    font-size: 14px;
    line-height: 1.428;
    color: #707070;
    border: 1px solid #333333;
    border-radius: 30px;
  }
  #gift .sec-noshi .kinds .noshi-kinds-head li:not(:first-child) button::before {
    content: none;
  }
  #gift .sec-noshi .kinds .noshi-kinds-list {
    gap: 20px 10px;
  }
  #gift .sec-noshi .kinds .noshi-kinds-list li {
    width: calc((100% - 10px)/2);
  }
  #gift .sec-noshi .kinds .noshi-kinds-list li .text {
    margin: 5px 0 0;
    font-size: 14px;
  }
  /* covertype */
  #gift .sec-noshi .covertype .noshi-list img {
    max-width: 170px;
  }
  /* nameprint */
  #gift .sec-noshi .nameprint .noshi-nameprint-list {
    flex-wrap: wrap;
    gap: 20px 10px;
    margin: 40px 0 0;
    padding: 0 14px;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-list li {
    width: calc((100% - 10px)/2);
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-list .text {
    margin: 5px 0 0;
    font-size: 14px;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-about {
    flex-direction: column;
    margin: 40px 0 0;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-about .img {
    width: 100%;
    max-width: 220px;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-about .text {
    width: 100%;
    padding: 20px 15px;
    border-radius: 10px;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-about .text dt {
    margin: 15px 0 0;
    font-size: 16px;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-about .text dd {
    font-size: 14px;
    line-height: 1.428;
  }
  #gift .sec-noshi .nameprint .noshi-nameprint-head {
    padding: 0 0 0 8px;
    font-size: 14px;
    line-height: 1.5;
  }
  /* paper */
  #gift .sec-noshi .paper {
    margin-bottom: 55px;
  }
  #gift .sec-noshi .paper .noshi-paper-list {
    gap: 5px;
    margin: 0 0 0;
  }
  #gift .sec-noshi .paper .noshi-paper-list .text {
    margin: 9px 0 0;
    font-size: 14px;
  }
}

/*-----------------------------------------
  wrapping
-----------------------------------------*/
#gift .sec-wrapping {
  position: relative;
  padding: 120px 0 100px;
  background: #FFFAF2;
}
#gift .sec-wrapping::before {
  content: "";
  position: absolute;
  top: max(-160px,-13vw);
  right: max(-140px,-11.38vw);
  width: min(710px,58vw);
  height: min(610px,50vw);
  background: url(/img/usr/freepage/gift/bg_ribbon_01_pc.png) no-repeat center / contain;
}
#gift .sec-wrapping::after{
  content: "";
  position: absolute;
  bottom: max(-140px,-11.38vw);
  left: max(-146px,-11.86vw);
  width: min(630px,51.5vw);
  height: min(780px,63.5vw);
  background: url(/img/usr/freepage/gift/bg_ribbon_02_pc.png) no-repeat center / contain;
}
#gift .sec-wrapping .inner > .gift-title {
  padding-top: 140px;
  background: url(/img/usr/freepage/gift/text_wrapping.png) no-repeat center top, url(/img/usr/freepage/gift/icon_wrapping.png) no-repeat center top 36px / 80px;
}
#gift .sec-wrapping .wrapping-lead {
  margin: 26px 0 0;
  font-size: 18px;
  line-height: 2.11;
  text-align: center;
}
#gift .sec-wrapping .wrapping-item {
  margin: 95px 0 120px;
}
#gift .sec-wrapping .wrapping-item .gift-title {
  padding: 117px 0 0;
  background: url(/img/usr/freepage/gift/text_item.png) no-repeat center top, url(/img/usr/freepage/gift/icon_gift.png) no-repeat center top 27px / 85px;
}
#gift .sec-wrapping .wrapping-item .gift-item-list {
  display: flex;
  gap: 10px;
  margin: 30px 0 0;
  padding-bottom: 20px;
}
#gift .sec-wrapping .wrapping-item .gift-item-list li {
  flex: 1;
  position: relative;
  display: flex;
  gap: 10px;
  padding: 15px 10px 70px;
  background: #fff;
  border-radius: 10px;
}
#gift .sec-wrapping .wrapping-item .gift-item-list li.candy {
  flex: 2;
}
#gift .sec-wrapping .wrapping-item .gift-item-list li img {
  border-radius: 10px;
}
#gift .sec-wrapping .wrapping-item .gift-item-list .gift-btn {
  position: absolute;
  left: 50%;
  bottom: -20px;
  transform: translateX(-50%);
  width: 94%;
  max-width: 280px;
  font-size: clamp(12px,1.3vw,16px);
}
#gift .sec-wrapping .wrapping-item .notice {
  margin: 35px 0 0;
  font-size: 15px;
  text-align: center;
}
#gift .sec-wrapping .gift-subtitle {
  margin: 80px 0 0;
}
#gift .sec-wrapping .gift-subtitle::before,
#gift .sec-wrapping .gift-subtitle::after {
  background: var(--color-red);
}
#gift .sec-wrapping .wrapping-list {
  display: flex;
  justify-content: center;
  gap: 13px;
  margin: 30px 0 0;
  text-align: center;
}
#gift .sec-wrapping .wrapping-list li img {
  width: 268px;
  border: 1px solid var(--color-red);
  border-radius: 15px;
}
#gift .sec-wrapping .wrapping-list li .name {
  margin: 15px 0 0;
  font-size: 16px;
  line-height: 1.5;
}
@media only screen and (max-width: 768px) {
  #gift .sec-wrapping {
    padding: 80px 0 75px;
  }
  #gift .sec-wrapping::before {
    top: -70px;
    right: 0;
    width: 190px;
    height: 240px;
    background-image: url(/img/usr/freepage/gift/bg_ribbon_01_sp.png);
  }
  #gift .sec-wrapping::after{
    bottom: -75px;
    left: 0;
    width: 164px;
    height: 180px;
    background-image: url(/img/usr/freepage/gift/bg_ribbon_02_sp.png);
  }
  #gift .sec-wrapping .inner > .gift-title {
    padding-top: 116px;
    background-position: center top,center top 28px;
    background-size: 120px,64px;
  }
  #gift .sec-wrapping .wrapping-lead {
    margin: 8px 0 0;
    font-size: 16px;
    line-height: 1.75;
  }
  #gift .sec-wrapping .wrapping-item {
    margin: 46px 0 70px;
  }
  #gift .sec-wrapping .wrapping-item .gift-title {
    padding: 80px 0 0;
    font-size: 20px;
    background-position: center top,center top 20px;
    background-size: 100px,56px;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list {
    flex-direction: column;
    gap: 60px;
    margin: 18px -6px 0;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list li {
    padding: 10px 10px 35px;
    border-radius: 5px;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list li:not(.candy) a {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list li:not(.candy) a .img,
  #gift .sec-wrapping .wrapping-item .gift-item-list li:not(.candy) a .detail {
    flex: 1;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list li img {
    border-radius: 5px;
  }
  #gift .sec-wrapping .wrapping-item .gift-item-list .gift-btn {
    bottom: -20px;
    height: 40px;
    max-width: 240px;
    font-size: 14px;
  }
  #gift .sec-wrapping .wrapping-item .notice {
    margin: 15px 0 0;
    font-size: 14px;
    letter-spacing: -0.025em;
  }
  #gift .sec-wrapping .gift-subtitle {
    margin: 45px 0 0;
  }
  #gift .sec-wrapping .wrapping-list {
    gap: 5px;
    margin: 15px 0 0;
  }
  #gift .sec-wrapping .wrapping-list li img {
    width: 220px;
    border-radius: 5px;
  }
  #gift .sec-wrapping .wrapping-list li .name {
    margin: 8px 0 0;
    font-size: 14px;
    line-height: 1.428;
  }
  #gift .sec-wrapping .wrapping-list.card .name,
  #gift .sec-wrapping .wrapping-list.image .name {
    width: 300px;
    text-align: left;
  }
}

/*-----------------------------------------
  howto
-----------------------------------------*/
#gift .sec-howto {
  padding: 102px 0 100px;
  background: url(/img/usr/freepage/gift/bg_03_pc.png) no-repeat center top -164px;
}
#gift .sec-howto .gift-title {
  padding-top: 126px;
  background: url(/img/usr/freepage/gift/text_howto.png) no-repeat center top, url(/img/usr/freepage/gift/icon_howto.png) no-repeat center top 34px / 97px;
}
#gift .sec-howto .howto-tab {
  display: flex;
  justify-content: center;
  margin: 40px 0 0;
}
#gift .sec-howto .howto-tab li {
  width: 45%;
  max-width: 450px;
}
#gift .sec-howto .howto-tab li button {
  width: 100%;
  padding: 16px 0;
  font-size: 18px;
  text-align: center;
  background: #fff;
  border: 1px solid rgb(195,54,37,0.19);
}
#gift .sec-howto .howto-tab li.active button {
  font-weight: bold;
  color: #fff;
  background: var(--color-red);
  border-color: #E3E3E3;
}
#gift .sec-howto .howto-container {
  max-width: 1110px;
  margin: 35px auto 0;
}
#gift .sec-howto .howto-list {
  display: flex;
  flex-wrap: wrap;
  gap: 60px 30px;
}
#gift .sec-howto .howto-list li {
  width: calc((100% - 30px)/2);
}
#gift .sec-howto .howto-list .title {
  margin: 0 0 10px;
  font-weight: bold;
  font-size: 18px;
  text-align: center;
}
#gift .sec-howto .howto-list .title span {
  color: var(--color-red);
}
#gift .sec-howto .howto-list img {
  border: 1px solid #CCCCCC;
  border-radius: 10px;
  box-sizing: content-box;
}
#gift .sec-howto .howto-list .text {
  margin: 10px 0 0;
  font-size: 16px;
  color: var(--color-brown);
}
@media only screen and (max-width: 768px) {
  #gift .sec-howto {
    padding: 100px 0 100px;
    background: url(/img/usr/freepage/gift/bg_03_sp.png) no-repeat left top / 140px,
    url(/img/usr/freepage/gift/bg_04_sp.png) no-repeat right bottom -45px / 128px;
  }
  #gift .sec-howto .gift-title {
    padding-top: 105px;
    background-position: center top,center top 26px;
    background-size: 146px,78px;
  }
  #gift .sec-howto .howto-tab {
    margin: 35px 0 0;
    border-bottom: none
  }
  #gift .sec-howto .howto-tab li {
    width: 50%;
  }
  #gift .sec-howto .howto-tab li button {
    padding: 14px 0;
    font-size: 14px;
  }
  #gift .sec-howto .howto-tab li.active button {
    font-weight: bold;
    color: #fff;
    background: var(--color-red);
    border-color: var(--color-red);
  }
  #gift .sec-howto .howto-container {
    max-width: 500px;
    margin: 30px auto 0;
  }
  #gift .sec-howto .howto-list {
    gap: 70px;
  }
  #gift .sec-howto .howto-list li {
    width: 100%;
  }
  #gift .sec-howto .howto-list .title {
    font-size: 16px;
  }
  #gift .sec-howto .howto-list img {
    border-radius: 5px;
  }
  #gift .sec-howto .howto-list .text {
    margin: 15px 0 0;
    font-size: 14px;
    line-height: 1.428;
  }
}