@charset "UTF-8";
@media (max-width: 767px) {
  .pc {
    display: none !important; } }

@media (min-width: 768px) {
  .sp {
    display: none !important; } }

body {
  /*
	@include inpc(){
		background: url(/images/special_gift2020/sample_pc.jpg) no-repeat top center;
	}
	@include insp(){
		background: url(/images/special_gift2020/sample_sp.jpg) no-repeat top center;
		background-size: 100%;
	}
	*/ }

.linklogo {
  position: absolute;
  z-index: 99999; }
  @media (min-width: 768px) {
    .linklogo {
      left: 24px;
      top: 21px;
      width: 162px; } }
  @media (max-width: 767px) {
    .linklogo {
      left: 5.8%;
      top: 0.4%;
      width: 43.5%; } }

.firstview {
  background-repeat: no-repeat; }
  @media (min-width: 768px) {
    .firstview {
      background-image: url(/images/special_gift2020/pc/top05.png), url(/images/special_gift2020/pc/top04.png), url(/images/special_gift2020/pc/top03.png), url(/images/special_gift2020/pc/top01.png), url(/images/special_gift2020/pc/top02.png);
      background-position: bottom -6px left -124px, bottom right, top -66px right -26px, top -9px left -95px, top -23px right -9px;
      background-size: 500px auto, 770px auto, 628px auto, 1064px auto, 750px auto;
      height: 100vh;
      min-height: 700px;
      position: relative;
      width: 100%; } }
  @media (max-width: 767px) {
    .firstview {
      background-image: url(/images/special_gift2020/sp/top01.png), url(/images/special_gift2020/sp/top02.png), url(/images/special_gift2020/sp/top03.png), url(/images/special_gift2020/sp/top04.png);
      background-position: top -16px left -42px, top -67px right -96px, bottom -7px right -27px, bottom -5px left -1px;
      background-size: 496px auto, 356px auto, 201px auto, 376px auto;
      padding-bottom: 34.7%;
      padding-top: 34.8%; } }
  @media (min-width: 768px) {
    .firstview__head {
      left: 50%;
      top: 50%;
      position: absolute;
      transform: translate(-512px, -161px);
      width: 505px; } }
  @media (min-width: 768px) and (max-width: 1005px) {
    .firstview__head {
      transform: translate(-100%, -80%);
      width: 49%; } }
  @media (max-width: 767px) {
    .firstview__head {
      margin: 0 auto 5.6%;
      transform: translateX(4px);
      width: 84.4%; } }
  @media (min-width: 768px) {
    .firstview__text {
      left: 50%;
      top: 50%;
      position: absolute;
      transform: translate(-476px, 121px);
      width: 415px; } }
  @media (min-width: 768px) and (max-width: 1005px) {
    .firstview__text {
      transform: translate(-105%, 60%);
      width: 42%; } }
  @media (max-width: 767px) {
    .firstview__text {
      margin-left: 12%;
      margin-bottom: 11.2%;
      width: 83%; } }
  @media (min-width: 768px) {
    .firstview__img {
      left: 50%;
      top: 50%;
      position: absolute;
      transform: translate(98px, -170px);
      max-width: 392px; } }
  @media (min-width: 768px) and (max-width: 1005px) {
    .firstview__img {
      transform: translate(5%, -170px);
      width: 45%; } }
  @media (max-width: 767px) {
    .firstview__img {
      display: block;
      margin-left: 24.4%;
      width: 55%; } }

.products {
  background: url(/images/special_gift2020/common/bg.jpg) repeat-y top center; }
  @media (min-width: 768px) {
    .products {
      background-size: 100%;
      border-top: solid 9px #c1056a;
      padding-bottom: 83px; } }
  @media (max-width: 767px) {
    .products {
      border-top: solid 5px #c1056a;
      padding-bottom: 8.8%;
      padding-top: 0.2%; } }
  @media (min-width: 768px) {
    .products__upper {
      align-items: center;
      display: flex;
      justify-content: center;
      margin-bottom: 96px;
      padding: 40px 6.4% 0 3%; } }
  @media (min-width: 768px) {
    .products__logo {
      max-width: 575px;
      margin-right: 5.5%; } }
  @media (max-width: 767px) {
    .products__logo {
      display: block;
      margin: 0 auto 9.5%;
      width: 94%; } }
  @media (min-width: 768px) {
    .products__info {
      padding-top: 69px; } }
  @media (min-width: 768px) {
    .products__head {
      max-width: 474px;
      margin-bottom: 25px; } }
  @media (max-width: 767px) {
    .products__head {
      margin: 0 auto 6%;
      width: 73%; } }
  .products__text {
    font-size: 16px;
    line-height: 36px;
    text-align: left; }
    @media (max-width: 767px) {
      .products__text {
        padding: 0 5%;
        margin-bottom: 12%; } }
  .products__lower {
    background-color: #fff;
    border: solid 1px #e4006e;
    position: relative; }
    @media (min-width: 768px) {
      .products__lower {
        padding: 71px 44px 20px;
        margin: 0 auto 23px;
        max-width: 989px;
        width: 98%; } }
    @media (max-width: 767px) {
      .products__lower {
        margin: 0 auto 5.5%;
        width: 88%; } }
  .products__subhead {
    position: absolute; }
    @media (min-width: 768px) {
      .products__subhead {
        left: calc( 50% - 128px);
        top: -15px;
        width: 258px; } }
    @media (max-width: 767px) {
      .products__subhead {
        left: 10.5%;
        top: -1.2%;
        width: 79%; } }
  @media (min-width: 768px) {
    .products__list {
      display: flex;
      flex-wrap: wrap; } }
  @media (max-width: 767px) {
    .products__list {
      padding: 6.5% 4.8% 3.6%; } }
  .products__li {
    display: flex; }
    @media (min-width: 768px) {
      .products__li {
        width: 50%; } }
    @media (max-width: 767px) {
      .products__li {
        border-bottom: solid 1px #e4006e;
        justify-content: space-between;
        padding: 6% 0 7% 4.4%; } }
    @media (min-width: 768px) {
      .products__li:nth-of-type(1) {
        border-bottom: solid 1px #e4006e;
        border-right: solid 1px #e4006e;
        justify-content: flex-start;
        padding-bottom: 4.2%;
        padding-left: 9px; }
        .products__li:nth-of-type(1) .products__copytxt {
          width: 92%; } }
    @media (max-width: 767px) {
      .products__li:nth-of-type(1) .products__copytxt {
        width: 95%; } }
    @media (min-width: 768px) {
      .products__li:nth-of-type(2) {
        border-bottom: solid 1px #e4006e;
        justify-content: flex-end;
        padding-bottom: 4.2%;
        padding-left: 15px; }
        .products__li:nth-of-type(2) .products__copytxt {
          width: 100%; } }
    @media (max-width: 767px) {
      .products__li:nth-of-type(2) .products__copytxt {
        width: 96%; } }
    @media (min-width: 768px) {
      .products__li:nth-of-type(3) {
        border-right: solid 1px #e4006e;
        justify-content: flex-start;
        padding-bottom: 2%;
        padding-left: 9px;
        padding-top: 4%; }
        .products__li:nth-of-type(3) .products__copytxt {
          width: 55%; } }
    @media (max-width: 767px) {
      .products__li:nth-of-type(3) .products__copytxt {
        width: 54%; } }
    @media (min-width: 768px) {
      .products__li:nth-of-type(4) {
        justify-content: flex-end;
        padding-bottom: 2%;
        padding-left: 15px;
        padding-top: 4%; }
        .products__li:nth-of-type(4) .products__copytxt {
          width: 55%; } }
    @media (max-width: 767px) {
      .products__li:nth-of-type(4) {
        border-bottom: none; }
        .products__li:nth-of-type(4) .products__copytxt {
          width: 54%; } }
  @media (min-width: 768px) {
    .products__img {
      margin-right: 4.5%;
      width: 32%; } }
  @media (max-width: 767px) {
    .products__img {
      width: 34%; } }
  .products__item {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left; }
    @media (min-width: 768px) {
      .products__item {
        width: 60%; } }
    @media (max-width: 767px) {
      .products__item {
        padding-top: 4%;
        width: 61%; } }
  .products__copy {
    display: block;
    /*
		height: 72px;
		*/ }
  .products__name {
    font-weight: bold; }
    @media (min-width: 768px) {
      .products__name {
        font-size: 14px;
        line-height: 1.5em; } }
    @media (max-width: 767px) {
      .products__name {
        font-size: 10px;
        line-height: 1.5em; } }
  .products__item-link {
    display: inline-block; }
    @media (min-width: 768px) {
      .products__item-link {
        margin-top: 10%;
        width: 198px; } }
    @media (max-width: 767px) {
      .products__item-link {
        margin-top: 6%;
        width: 77.5%; } }
  .products__notice {
    font-size: 10px;
    text-align: center; }
    @media (max-width: 767px) {
      .products__notice {
        line-height: 1.8em; } }

.info {
  overflow: hidden;
  text-align: center; }
  @media (min-width: 768px) {
    .info {
      border-top: solid 9px #c1056a;
      padding: 71px 0 140px;
      margin-bottom: 84px; } }
  @media (max-width: 767px) {
    .info {
      border-top: solid 4px #c1056a;
      padding: 17.5% 0 16.5%;
      margin-bottom: 10%; } }
  .info__container {
    border: solid 3px #c8b568;
    margin: 0 auto;
    position: relative; }
    @media (min-width: 768px) {
      .info__container {
        max-width: 1105px;
        padding: 121px 1% 144px 7.7%;
        width: 98%; } }
    @media (max-width: 767px) {
      .info__container {
        width: 89%; } }
  @media (min-width: 768px) {
    .info__content {
      width: 332px; } }
  @media (max-width: 767px) {
    .info__content {
      padding-bottom: 21.2%;
      padding-top: 28.6%; } }
  .info__head {
    display: inline-block; }
    @media (min-width: 768px) {
      .info__head {
        margin-bottom: 25px;
        width: 332px; } }
    @media (max-width: 767px) {
      .info__head {
        margin-bottom: 14%;
        width: 81.7%; } }
  .info__text {
    font-size: 16px;
    line-height: 28px;
    margin-bottom: 7px; }
  .info__price {
    color: #c1056a;
    font-size: 26px;
    font-weight: bold;
    line-height: 38px;
    margin-bottom: 39px; }
  .info__anc {
    display: block;
    margin: 0 auto;
    width: 255px; }
    .info__anc_mg {
      margin-top: 13px; }
      @media (min-width: 768px) {
        .info__anc_mg {
          margin-bottom: 45px; } }
      @media (max-width: 767px) {
        .info__anc_mg {
          margin-bottom: 10%; } }
  .info__text-anc {
    display: inline-block;
    position: relative;
    text-decoration: underline;
    z-index: 9999; }
    @media (min-width: 768px) {
      .info__text-anc {
        cursor: pointer; }
        .info__text-anc:hover {
          opacity: 0.7; } }
  @media (min-width: 768px) {
    .info__img01 {
      top: 154px;
      left: calc( 50% + 43px);
      min-width: 330px;
      position: absolute;
      width: 35.4%; } }
  @media (max-width: 767px) {
    .info__img01 {
      margin-bottom: 11%;
      width: 59.3%; } }
  .info__img02 {
    top: 81px;
    left: calc( 50% + 49px);
    min-width: 300px;
    position: absolute;
    width: 33.1%; }
  .info__img03 {
    position: absolute; }
    @media (min-width: 768px) {
      .info__img03 {
        right: -122px;
        top: -62px;
        width: 44.3%; } }
    @media (max-width: 767px) {
      .info__img03 {
        right: -17%;
        top: -6.3%;
        width: 74%; } }
  .info__img04 {
    position: absolute; }
    @media (min-width: 768px) {
      .info__img04 {
        bottom: -112px;
        left: -122px;
        width: 41.1%; } }
    @media (max-width: 767px) {
      .info__img04 {
        bottom: -7.6%;
        left: -15.1%;
        width: 68.4%; } }

/*****************************
母の日専用
*****************************/
.mothorsday {
  background-repeat: no-repeat;
  position: relative; }
  @media (min-width: 768px) {
    .mothorsday {
      background-image: url(/images/special_gift2020/common/product.png), url(/images/special_gift2020/mothersday/pcback01.svg), url(/images/special_gift2020/mothersday/pcback02.svg), url(/images/special_gift2020/mothersday/pcback03.png);
      background-position: right 74px bottom 23px, top left, top right, bottom -69px left;
      background-size: 220px auto, auto, auto, auto;
      height: 718px;
      padding-top: 69px; } }
  @media (max-width: 767px) {
    .mothorsday {
      background-image: url(/images/special_gift2020/mothersday/pcback01.svg), url(/images/special_gift2020/mothersday/pcback02.svg);
      background-position: top left -17px, top right;
      background-size: 220px auto, 117px auto;
      overflow: hidden;
      padding-bottom: 36.1%;
      padding-top: 26%; } }
  @media (min-width: 768px) {
    .mothorsday__text01 {
      left: 50%;
      position: absolute;
      top: 90px;
      transform: translateX(-51.1%);
      width: 518px; } }
  @media (max-width: 767px) {
    .mothorsday__text01 {
      margin: 0 auto 7.7%;
      width: 81%; } }
  @media (min-width: 768px) {
    .mothorsday__head {
      margin: 0 auto 42px;
      max-width: 689px;
      width: 95%; } }
  @media (max-width: 767px) {
    .mothorsday__head {
      margin: 0 auto 7%;
      width: 93%; } }
  @media (min-width: 768px) {
    .mothorsday__box {
      align-items: center;
      display: flex;
      justify-content: space-between;
      margin: 0 auto;
      max-width: 983px;
      width: 98%; } }
  @media (min-width: 768px) {
    .mothorsday__img {
      max-width: 433px; } }
  @media (max-width: 767px) {
    .mothorsday__img {
      margin: 0 auto 14%;
      width: 82.5%; } }
  .mothorsday__content {
    text-align: left; }
    @media (min-width: 768px) {
      .mothorsday__content {
        padding-top: 10px; } }
  @media (min-width: 768px) {
    .mothorsday__subhead {
      margin-bottom: 23px; } }
  @media (max-width: 767px) {
    .mothorsday__subhead {
      margin: 0 auto 9%;
      width: 74%; } }
  .mothorsday__p {
    font-size: 16px;
    line-height: 36px; }
    @media (max-width: 767px) {
      .mothorsday__p {
        padding: 0 4%; } }
    @media (min-width: 768px) {
      .mothorsday__p_mg {
        margin: 36px 0 21px; } }
    @media (max-width: 767px) {
      .mothorsday__p_mg {
        margin: 9% 0 3%; } }
  .mothorsday__small {
    font-size: 10px;
    line-height: 1em; }
    @media (max-width: 767px) {
      .mothorsday__small {
        padding: 0 4%;
        margin-bottom: 13.7%; } }
  @media (max-width: 767px) {
    .mothorsday__product {
      margin: 0 auto;
      width: 59%; } }
  @media (max-width: 767px) {
    .mothorsday__rose {
      bottom: -2.8%;
      left: 0;
      position: absolute;
      width: 85.5%; } }
  .mothorsday + .info {
    background: url(/images/special_gift2020/common/bg.jpg) repeat-y top center; }
    @media (min-width: 768px) {
      .mothorsday + .info {
        background-size: 100%;
        padding-bottom: 79px; } }
    @media (max-width: 767px) {
      .mothorsday + .info {
        padding-bottom: 12.5%; } }

/*****************************
モーダル
*****************************/
#overlay {
  position: fixed;
  left: 0px;
  top: 0px;
  width: 100%;
  height: 100%;
  z-index: 9900;
  opacity: 0.6;
  background-color: #888888;
  display: none; }

#component {
  position: fixed;
  top: 10%;
  left: 0;
  right: 0;
  display: none;
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
  background: #fff;
  text-align: center;
  height: 80%;
  z-index: 9999; }
  #component .cinner {
    padding: 5%;
    width: 100%;
    height: 100%;
    overflow: scroll; }
  #component .m_close_button {
    display: inline-block;
    width: 260px;
    line-height: 50px;
    background: #8e8e8e;
    color: #fff;
    font-size: 1.5em;
    cursor: pointer;
    margin: 0 auto; }
    #component .m_close_button_mb {
      margin-bottom: 50px; }
  #component h2 {
    font-size: 18px;
    font-weight: normal;
    color: #666666;
    text-align: center; }
  #component .component_inner {
    margin: 50px 0;
    padding: 50px 0;
    border-top: 1px solid #e6e6e6;
    border-bottom: 1px solid #e6e6e6;
    text-align: left; }
    #component .component_inner p {
      line-height: 1.6;
      color: #666666;
      padding-bottom: 20px;
      font-size: 14px;
      font-size: 1.4rem; }
  #component .m_close {
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    height: 50px;
    background: url(/images/premium/close.png) no-repeat 0 0;
    cursor: pointer; }

.inner .breadcrumb {
  background-color: #fff;
  border: none;
  text-align: left; }

/*# sourceMappingURL=style.css.map */