@charset "UTF-8";

/* 共通部分 */
.pc {
    display: none;
}

.container {
  width: 96%;
}

.more-button {
  width: 23.9rem;
  height: 4.6rem;
  z-index: 800;
  position: relative;
}

.more-button p {
  margin-right: 7rem;
  line-height: 4.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.4em;
}

.more-button p::before {
  bottom: 1.84rem;
  left: 9.15rem;
  /*下線の形状*/
  width: 4.3rem;
  height: 0.1rem;
}

.more-button p::after {
  bottom: 2rem;
  left: 13.15rem;
  /*矢印の形状*/
  width: 5px;
  height: 1px;
}

.more-button:hover p:before {
  left: 185%;
}

.more-button:hover p:after {
  left: 250%;
}

/* ヘッダー */
header .header-container {
  width: 96%;
  margin: 1.3rem auto 0;
}

header .header-container a img {
  max-width: 7.8rem;
  height: auto;
}

header .header-container nav.flex a {
  margin-left: 1.25rem;
  font-size: 1.3rem;
  z-index: 500;
}

header .header-container nav.flex a span {
    font-size: 1.3rem;
}

header .header-container nav.flex a:nth-child(4) img {
  width: 2.3rem;
}

/* トップページ */
main .first-view {
  margin-top: 5rem;
  height: 66.8rem;
}

main .first-view h1 img {
  top: 11.5rem;
  width: calc(100% / 375 * 363);
  max-width: 36.3rem;
}

main .first-view .kotei-img li:nth-child(1) img {
  top: 42.7rem;
  right: 0;
  width: calc(100% / 375 * 71);
}

main .first-view .kotei-img li:nth-child(2) img {
  top: 1.7rem;
  left: 6vw;
  width: calc(100% / 375 * 72);
}

main .first-view .kotei-img li:nth-child(3) img {
  top: 44.8rem;
  left: 0;
  width: calc(100% / 375 * 235);
}

main .first-view .kotei-img li:nth-child(4) img {
  top: 8.9rem;
  right: 0.5vw;
  width: calc(100% / 375 * 230);
}

main .first-view .kotei-img li:nth-child(7) img {
  bottom: 0.9rem;
  left: 0;
  width: calc(100% / 375 * 71);
}

main .first-view .kotei-img li:nth-child(8) img {
  width: calc(100% / 375 * 68);
}

main .first-view .kotei-img li:nth-child(9) img {
  bottom: 0.9rem;
  right: 0;
  width: calc(100% / 375 * 72);
}

main .first-view .fuwafuwa-img li:nth-child(1) {
  top: 32.7rem;
  left: 1.3vw;
  width: calc(100% / 375 * 118);
  z-index: 300;
}

main .first-view .fuwafuwa-img li:nth-child(2) {
  top: 0;
  right: 2vw;
  width: calc(100% / 375 * 109);
}

main .first-view .fuwafuwa-img li:nth-child(3) {
  top: 2.3rem;
  right: 37vw;
  width: calc(100% / 375 * 49);
}

main .first-view .fuwafuwa-img li:nth-child(4) {
  top: 50.6rem;
  left: 25vw;
  width: calc(100% / 375 * 47);
  z-index: 300;
}

@media screen and (min-width:490px) and (max-width:800px){
  main .first-view .kotei-img li:nth-child(1) img {
    top: 15.7rem;
  }

  main .first-view .kotei-img li:nth-child(4) img {
    top: 0;
  }

  main .first-view .fuwafuwa-img li:nth-child(1) {
    top: 16.7rem;
  }
}

@media screen and (min-width:801px) {
  main .first-view h1 img {
    top: 5.5rem;
  }

  main .first-view .fuwafuwa-img li:nth-child(1) {
    top: 12.7rem;
  }

  main .first-view .kotei-img li:nth-child(1) img {
    top: 11.7rem;
  }

  main .first-view .kotei-img li:nth-child(3) img {
    top: 33.8rem;
  }

  main .first-view .kotei-img li:nth-child(4) img {
    top: -9.5rem;
  }
}

/* 年賀状セクション */
#top #nenga-section {
  padding: 13.5rem 0 23rem;
}

#top #nenga-section > img:nth-child(1) {
  top: 1.4rem;
  left: -46vw;
  width: 80%;
}

#top #nenga-section > img:nth-child(2) {
  top: 1.4rem;
  left: 6vw;
  width: 8%;
}

#top #nenga-section > img:nth-child(3) {
  top: 96rem;
  right: -23%;
  width: 75%;
}

#top #nenga-section > img:nth-child(4) {
  top: 92.1rem;
  right: 20%;
  width: 12%;
}

#top #nenga-section > img:nth-child(5) {
  display: none;
}

#top #nenga-section > img:nth-child(6) {
  display: none;
}

#top .container h2 {
  margin-bottom: 4.3rem;
}

#top .container h2 img {
  width: 66%;
}

#top #nenga-section .container #tategaki {
  margin-bottom: 18.8rem;
}

#top .container h3 {
  margin-bottom: 4.8rem;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
}

#top .container h3::before,
#top .container h3::after {
  bottom: 0.2rem;
  width: 1.8rem;
  height: 2.2rem;
}

#top .container h3::before {
  left: -3rem;
}

#top .container h3::after {
  right: -3rem;
}

#top #nenga-section .container #tategaki ul {
  margin-bottom: 5.6rem;
}

#top #nenga-section .container #tategaki ul li {
  margin-bottom: 3.6rem;
  width: 26%;
}

#top #nenga-section .container #tategaki ul li:nth-child(3n) {
  margin-right: 0;
}

#top #nenga-section .container #tategaki ul li a p {
  margin-top: 0.8rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

#top #nenga-section .container #yokogaki ul {
  margin: 0 auto 5.6rem;
  width: 81%;
}

#top #nenga-section .container #yokogaki ul li {
  width: 38.3%;
  margin-bottom: 3.7rem;
}

#top #nenga-section .container #yokogaki ul li:nth-child(3n) {
  margin-right: 0;
}

#top .container ul li a p {
  margin-top: 0.8rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
  line-height: 1.44;
}

/* カレンダーセクション */
#top #calender-section {
  padding: 13.6rem 0 37.3rem;
}

#top #calender-section > img:nth-child(1) {
  top: 2.2rem;
  left: -42%;
  width: 77%;
}

#top #calender-section > img:nth-child(2) {
  width: 8%;
  top: 1.5rem;
  left: 5.6%;
}

#top #calender-section > img:nth-child(3) {
  width: 75%;
  right: -25.3%;
  bottom: 17.7rem;
}

#top #calender-section > img:nth-child(4) {
  width: 12.2%;
  right: 20%;
  bottom: 25.6rem;
}

#top #calender-section .container #a4-size {
  margin-bottom: 18.8rem;
}

#top #calender-section .container #a4-size ul {
  justify-content: center;
  margin: 0 auto;
  flex-direction: column;
  align-items: center;
}

#top #calender-section .container #a4-size ul li {
  width: 68%;
}

#top #calender-section .container #a4-size ul li:nth-child(2) {
  margin-top: 3.7rem;
  width: 45%;
}

#top #calender-section .container #postcard-size ul {
  justify-content: center;
}

#top #calender-section .container #postcard-size ul li:nth-child(1) {
  margin-right: 3%;
}

#top #calender-section .container #postcard-size ul li:nth-child(1),
#top #calender-section .container #postcard-size ul li:nth-child(2) {
  margin-bottom: 3.7rem;
  width: 48%;
}

#top #calender-section .container #postcard-size ul li:nth-child(3) {
  margin-right: 19%;
  margin-bottom: 3.7rem;
}

#top #calender-section .container #postcard-size ul li:nth-child(3),
#top #calender-section .container #postcard-size ul li:nth-child(4),
#top #calender-section .container #postcard-size ul li:nth-child(5) {
  width: 33%;
}

/* たてがきタイプページ */
#tategaki-more .container {
  padding: 6rem 0 19.3rem;
}

#tategaki-more .container h2 {
  margin-bottom: 3.4rem;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
}

#tategaki-more .container h2::before,
#tategaki-more .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#tategaki-more .container h2::before {
  left: -3rem;
}

#tategaki-more .container h2::after {
  right: -3rem;
}

#tategaki-more .container ul {
  margin-bottom: 5.6rem;
}

#tategaki-more .container ul li {
  margin-bottom: 3.6rem;
  width: 26%;
}

#tategaki-more .container ul li:nth-child(5n) {
  margin-right: 0;
}

#tategaki-more .container ul li a p {
  margin-top: 0.8rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

/* よこがきタイプページ */
#yokogaki-more .container {
  padding: 6rem 0 19.3rem;
}

#yokogaki-more .container h2 {
  margin-bottom: 3.4rem;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
}

#yokogaki-more .container h2::before,
#yokogaki-more .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#yokogaki-more .container h2::before {
  left: -3rem;
}

#yokogaki-more .container h2::after {
  right: -3rem;
}

#yokogaki-more .container ul {
  justify-content: space-around;
  margin: 0 auto 5.6rem;
  width: 81%;
}

#yokogaki-more .container ul li {
  width: 38.3%;
  margin-bottom: 3.7rem;
}

#yokogaki-more .container ul li:nth-child(3n) {
  margin-right: 0;
}

#yokogaki-more .container ul li a p {
  margin-top: 0.8rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

/* 商品詳細ページ */
#content.product .container {
  padding: 0 0 17.65rem;
  width: 100%;
}

#content.product .container .storycontent #itempage {
  flex-direction: column;
}

#content.product .container .storycontent #itempage #img-box {
  width: 100%;
}

#content.product .item-img-main img {
  min-width: 37.5rem;
}

#content.product .item-img-thumb {
  margin-top: 0.4rem;
  margin-right: -5px;
  margin-left: -5px;
}

#content.product .item-img-thumb .thumbnail-item {
  width: 12%;
  margin-left: 0.5rem;
}

#content.product .container .storycontent #itempage .item-img-box .slick-arrow {
  width: 3rem;
  height: 3rem;
}

#content.product .container .storycontent #itempage .item-img-box .slick-prev {
  left: 0.3rem;
}

#content.product .container .storycontent #itempage .item-img-box .slick-next {
  right: 0.3rem;
}

#content.product
  .container
  .storycontent
  #itempage
  .item-img-box
  .slick-arrow:before {
  width: 3rem;
  height: 3rem;
}

#content.product .container .storycontent #itempage .item-cart {
  width: 96%;
  margin: 4.4rem auto 0;
  background-color: transparent;
}

#content.product .container .storycontent #itempage .item-cart h2 {
  margin-bottom: 1.6rem;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
  line-height: 1.5;
}

#content.product .container .storycontent #itempage table.skumulti th {
  font-size: 1.2rem;
  letter-spacing: 0.08em;
}

#content.product .container .storycontent #itempage table.skumulti td.skudisp {
  font-size: 2rem;
  letter-spacing: 0.15em;
}

#content.product .container .storycontent #itempage .skuform .skuquantity {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.product
  .container
  .storycontent
  #itempage
  table.item_option
  td
  select {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.product
  .container
  .storycontent
  #itempage
  table.skumulti
  td.button
  input[type="submit"] {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.product .container .storycontent #itempage .item-cart .detail {
  margin: 8.8rem 0 0 0;
}

#content.product .container .storycontent #itempage .item-cart .detail .about {
  padding-bottom: 4.05rem;
}

#content.product .container .storycontent #itempage .item-cart .detail h3 {
  margin-bottom: 1.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.product .container .storycontent #itempage .item-cart .detail p {
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 2;
}

#content.product
  .container
  .storycontent
  #itempage
  .item-cart
  .detail
  .accordion-area {
  margin: 4.05rem 0 0 0;
}

#content.product
  .container
  .storycontent
  #itempage
  .item-cart
  .detail
  .accordion-area
  li {
  margin-bottom: 4.05rem;
}

#content.product
  .container
  .storycontent
  #itempage
  .item-cart
  .detail
  .accordion-area
  li:first-child
  .box {
  padding-bottom: 1.95rem;
}

@media screen and (max-width:420px) {
  #content.product .container .storycontent #itempage .skuform {
    overflow-x: scroll;
  }
}

/* カートページ */
#content.cart .container {
  padding: 6rem 0 17.6rem;
  width: 100%;
}

#content.cart .container h2 {
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#content.cart .container h2::before,
#content.cart .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#content.cart .container h2::before {
  left: -3rem;
}

#content.cart .container h2::after {
  right: -3rem;
}

#content.cart .container #cart .flex {
  width: 96%;
  margin: auto;
}

#content.cart .container #cart .cart_page_title {
  padding-top: 2.4rem;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
}

#content.cart .container #cart .upbutton input {
  padding: 1.1rem 1.45rem;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.cart .container #cart .scroll {
  overflow-x: scroll;
}

#content.cart .container #cart table#cart_table {
  width: 91.6rem;
}

#content.cart .container #cart table.total-price {
  margin-top: 2rem;
}

#content.cart .container #cart .total-price .price {
  font-size: 1.2rem;
}

#content.cart .container #cart .total-price tfoot .price {
  font-size: 1.2rem;
}

#content.cart .container #cart .total-price .headline {
  font-size: 0.8rem;
}

#content.cart .container #cart .quantity input {
  margin-right: 0.8rem;
}

#content.cart .container #inside-cart .send {
  margin-top: 14.1rem;
}

#content.cart .container #inside-cart .send input[type="submit"] {
  margin: 0 auto 3.2rem;
  padding: 1.1rem 0;
  width: 96%;
}

#content .container #wc_cart .nocart-text {
  padding-top: 5.2rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
}

#content .container #inside-cart .no_cart {
  margin: 1.6rem 0 9.6rem;
}

#content .container #wc_cart img {
  max-width: 91.6rem;
}

#content .container #wc_cart .nocart-link {
  width: 96%;
}

/* お客様情報入力ページ */
#content.customer .container {
  padding: 6rem 0 17.6rem;
}

#content.customer .container h2 {
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#content.customer .container h2::before,
#content.customer .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#content.customer .container h2::before {
  left: -3rem;
}

#content.customer .container h2::after {
  right: -3rem;
}

#content.customer .container .cart_page_title {
  margin: 2.8rem 0 0;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}

#content.customer .container #customer-info tr td span.member_furigana {
  display: flex;
}

#content.customer .container form > p {
  margin-top: 0.8rem;
  font-size: 1rem;
  letter-spacing: 0.08em;
}

#content.customer .container input, #content.customer .container select {
  font-size: 1rem;
}

#content.customer .container #customer-info .send {
  padding-top: 9.6rem;
}

#content.customer .container #customer-info .send input.to_deliveryinfo_button {
  margin: 0 auto 1.6rem;
  width: 100%;
}

/* 配送・支払いフォーム */
#content.delivery .container {
  padding: 6rem 0 17.6rem;
}

#content.delivery .container h2 {
  margin-bottom: 2.8rem;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#content.delivery .container h2::before,
#content.delivery .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#content.delivery .container h2::before {
  left: -3rem;
}

#content.delivery .container h2::after {
  right: -3rem;
}

#content.delivery .container .post > p {
  margin-bottom: 0.8rem;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}

#content.delivery .container #delivery-info .send {
  margin: 9.6rem 0 0 0;
}

#content.delivery .container #delivery-info .send input {
  width: 100%;
}

#content.delivery .container #delivery-info .send input:nth-child(3) {
  margin: 0 auto 2.7rem;
}

/* 注文確認画面 */
#content.confirm .container {
  padding: 6rem 0 18.7rem;
}

#content.confirm .container h2 {
  margin-bottom: 2.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#content.confirm .container h2::before,
#content.confirm .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#content.confirm .container h2::before {
  left: -3rem;
}

#content.confirm .container h2::after {
  right: -3rem;
}

#content.confirm .container #info-confirm > p,
#content.confirm .container #info-confirm > p a,
#content.confirm .container #info-confirm .confiem_notice {
  text-align: left;
  font-size: 1rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.confirm .container #info-confirm #confirm_table {
  margin: 2.4rem 0 0 0;
}

#content.confirm .container #info-confirm #confirm_table h3 {
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}

#content.confirm .container #info-confirm #confirm_table th {
  white-space: nowrap;
}

#content.confirm .container #confirm_table td {
  font-size: 1rem;
}

#content.confirm .container #cart {
  margin-top: 2rem;
}

#content.confirm .container #cart > p {
  margin-bottom: 0.8rem;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}

#content.confirm .container #cart .scroll {
  overflow-x: scroll;
}

#content.confirm .container #cart table#cart_table {
  width: 55rem;
}

#content.confirm .container #cart table#cart_table th {
  font-size: 1.2rem;
}

#content.confirm .container #cart table#cart_table thead tr:first-child th {
  font-size: 0.8rem;
  font-weight: 400;
}

#content.confirm .container #cart td {
  font-size: 1rem;
}

#content.confirm .container #cart .num,
#content.confirm .container #cart .subtotal,
#content.confirm .container #cart .unitprice,
#content.confirm .container #cart .quantity {
  font-size: 1rem;
}

#content.confirm .container #cart th.aright, #content.confirm .container #cart td.aright {
  font-size: 1.2rem;
}

#content.confirm .container #info-confirm .send {
  margin-top: 9.6rem;
}

#content.confirm .container #info-confirm .send input:nth-child(2) {
  margin: 0 auto 2.7rem;
  width: 100%;
}

/* 確定画面 */
#content.completion .container {
  padding: 6rem 0 17.6rem;
  width: 100%;
}

#content.completion .container h2 {
  margin-bottom: 5.2rem;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#content.completion .container h2::before,
#content.completion .container h2::after {
  width: 1.8rem;
  height: 1.2rem;
}

#content.completion .container h2::before {
  left: -3rem;
}

#content.completion .container h2::after {
  right: -3rem;
}

#content.completion .container h3 {
  margin-bottom: 1.6rem;
  font-size: 1rem;
  letter-spacing: 0.15em;
}

#content.completion .container #cart_completion .send a {
  margin: 9.6rem auto 0;
  width: 96%;
}

/* 料金表 */
#price .container {
  padding: 6rem 0 17.69rem;
}

#price .container h2 {
  margin-bottom: 5.2rem;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#price .container h2::before,
#price .container h2::after {
  width: 1.8rem;
  height: 2.2rem;
}

#price .container h2::before {
  left: -3rem;
}

#price .container h2::after {
  right: -3rem;
}

#price .container .nenga p {
  margin-bottom: 0.8rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
}

#price .container .nenga .flex {
  flex-direction: column;
}

#price .container .nenga .flex .img-box:nth-child(1) {
  margin-bottom: 8.84rem;
}

#price .container .nenga .flex .img-box img {
  margin: auto;
}

#price .container .calender {
  margin-top: 20.24rem;
}

#price .container .calender p {
  margin-bottom: 0.8rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
}

/* 会社概要ページ */
#company .container {
  padding: 6.05rem 0 0;
}

#company .container h2 {
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#company .container > a,
#company .container .address p,
#company .container .contact p {
  font-size: 1rem;
  letter-spacing: 0.2em;
}

#company .container .address {
  margin: 2.4rem 0;
}

#company .container .contact {
  margin-bottom: 6.05rem;
}

#company .map-box {
  margin-bottom: 8.1rem;
}

#company .map-box iframe {
  height: 18.1rem;
}

/* プライバシーポリシー */
#privacy .container {
  padding: 5.6rem 0 17.7rem;
}

#privacy .container h2 {
  margin-bottom: 1.6rem;
  font-size: 1.8rem;
  letter-spacing: 0.2em;
}

#privacy .container > p,
#privacy .container dl dd,
#privacy .container dl dd ul li,
#privacy .container dl dd p {
  font-size: 1rem;
  letter-spacing: 0.15em;
}

#privacy .container dl {
  margin: 5.6rem 0 0;
}

#privacy .container dl dt {
  margin-bottom: 1.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
}

#privacy .container dl dd:not(:nth-of-type(7)) {
  margin-bottom: 3.6rem;
}

#privacy .container dl dd ul {
  margin-top: 1.3rem;
}

#privacy .container dl dd ul li {
  margin-left: 1.4rem;
}

#privacy .container dl dd ul li:not(:last-child) {
  margin-bottom: 0.8rem;
}

#privacy .container dl dd ul li::before {
  left: -1.4rem;
  width: 0.4rem;
  height: 0.4rem;
}

#privacy .container dl dd p:first-child {
  margin-top: 0.8rem;
}

#privacy .container dl dd p:not(:last-child) {
  margin-bottom: 0.4rem;
}

/* フッター */
footer {
  padding-bottom: 0.45rem;
}

footer .container {
  padding-top: 10.7rem;
  margin: 0 auto 11.45rem;
}

footer .container ul:nth-of-type(1) {
  margin-left: 2.3rem;
}

footer .container > a {
  width: 16%;
}

footer .container a img {
  width: 100%;
}

footer .container ul:nth-of-type(1) li:nth-child(4) {
  margin-top: 2.85rem;
}

footer .container ul li {
  margin: 0 0 1.6rem 1.5rem;
}

footer .container ul li a {
  font-size: 1.1rem;
  letter-spacing: 0.15em;
  line-height: 1.5;
}

footer .container ul li.big-midasi {
  margin: 0 0 1.6rem 0;
}

footer .copyright {
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  line-height: 1.5;
}
