@charset "UTF-8";

/* 共通部分 */
.sp {
  display: none;
}

.container {
  width: 67%;
}

.more-button {
  width: 26.4rem;
  height: 5.6rem;
}

.more-button p {
  margin-right: 7rem;
  line-height: 5.6rem;
  font-size: 2.4rem;
  letter-spacing: 0.4em;
}

.more-button p::before {
  bottom: 1.84rem;
  left: 12.15rem;
  /*下線の形状*/
  width: 4.3rem;
  height: 0.1rem;
}

.more-button p::after {
  bottom: 2rem;
  left: 16.15rem;
  /*矢印の形状*/
  width: 5px;
  height: 1px;
}

.more-button:hover p:before {
  left: 155%;
}

.more-button:hover p:after {
  left: 198%;
}

/* ヘッダー */
header {
  height: 8.3vh;
}

header .header-container {
  padding: 1.7rem 2.9rem 1.7rem 4.1rem;
}

header .header-container a img {
  width: 15.4rem;
  height: 3rem;
}

header .header-container nav.flex a {
  margin-left: 4.8rem;
  font-size: 2rem;
}

header .header-container nav.flex a span {
  font-size: 2rem;
  font-weight: 400;
}

header .header-container nav.flex a:nth-child(4) img {
  margin-right: 0.65rem;
  width: 3rem;
}

/* トップページ */
main .first-view {
  height: 100vh;
  margin-top: 8.3vh;
}

main .first-view h1 img {
  top: -4.7vh;
  width: calc(100% / 1366 * 642);
  max-width: 64.2rem;
}

main .first-view .kotei-img li:nth-child(1) img {
  top: -0.5vh;
  left: 10.2vw;
  width: calc(100% / 1366 * 88);
}

main .first-view .kotei-img li:nth-child(2) img {
  top: 2.1vh;
  right: 17vw;
  width: calc(100% / 1366 * 119);
}

main .first-view .kotei-img li:nth-child(3) img {
  top: 56vh;
  left: 2vw;
  width: calc(100% / 1366 * 401);
}

main .first-view .kotei-img li:nth-child(4) img {
  top: 17.2vh;
  right: 2vw;
  width: calc(100% / 1366 * 431);
}

main .first-view .kotei-img li:nth-child(7) img {
  bottom: 1.5vh;
  left: 2.4vw;
  width: calc(100% / 1366 * 152);
}

main .first-view .kotei-img li:nth-child(8) img {
  width: calc(100% / 1366 * 149);
}

main .first-view .kotei-img li:nth-child(9) img {
  bottom: 1.5vh;
  right: 2.1vw;
  width: calc(100% / 1366 * 152);
}

main .first-view .fuwafuwa-img li:nth-child(1) {
  top: 16.2vh;
  left: 14vw;
  width: calc(100% / 1336 * 188);
}

main .first-view .fuwafuwa-img li:nth-child(2) {
  top: 31.1vh;
  right: 15.9vw;
  width: calc(100% / 1336 * 176);
}

main .first-view .fuwafuwa-img li:nth-child(3) {
  top: 0.7vh;
  right: 6.3vw;
  width: calc(100% / 1366 * 80);
}

main .first-view .fuwafuwa-img li:nth-child(4) {
  top: 16vh;
  left: 0.8vw;
  width: calc(100% / 1366 * 87);
}

@media screen and (max-width: 1280px) {
  main .first-view h1 img {
    top: 2.3vh;
  }
}

/* 年賀状セクション */
#top #nenga-section {
  padding: 3.6rem 0 10.01rem;
}

#top #nenga-section > img:nth-child(1) {
  top: 9.2rem;
  left: -33%;
  width: 55%;
}

#top #nenga-section > img:nth-child(2) {
  top: 6.8rem;
  left: 4.5%;
  width: 6%;
}

#top #nenga-section > img:nth-child(3) {
  top: 54%;
  right: -12%;
  width: 40%;
}

#top #nenga-section > img:nth-child(4) {
  top: 50.8%;
  right: 11.4%;
  width: 6.3%;
}

#top #nenga-section > img:nth-child(5) {
  bottom: 6.61rem;
  left: -33%;
  width: 55%;
}

#top #nenga-section > img:nth-child(6) {
  bottom: 24.81rem;
  left: 4.5%;
  width: 6%;
}

#top .container h2 {
  margin-bottom: 9.6rem;
}

#top .container h2 img {
  width: 55%;
}

#top #nenga-section .container #tategaki {
  margin-bottom: 20rem;
}

#top .container h3 {
  margin-bottom: 6.4rem;
  font-size: 2.4rem;
  letter-spacing: 0.15em;
}

#top .container h3::before,
#top .container h3::after {
  bottom: 0.6rem;
  width: 4.2rem;
  height: 5.2rem;
}

#top .container h3::before {
  left: -5.8rem;
}

#top .container h3::after {
  right: -5.8rem;
}

#top #nenga-section .container #tategaki ul {
  margin-bottom: 5.6rem;
}

#top #nenga-section .container #tategaki ul li {
  margin-bottom: 7.6rem;
  margin-right: calc((100% / 5) - 16%);
  width: 16%;
}

#top #nenga-section .container #tategaki ul li:nth-child(5n) {
  margin-right: 0;
}

#top #nenga-section .container #tategaki ul li a p {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  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: 29%;
  margin-bottom: 7.6rem;
}

#top #nenga-section .container #yokogaki ul li:nth-child(3n) {
  margin-right: 0;
}

#top .container ul li a p {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.44;
}

/* カレンダーセクション */
#top #calender-section {
  padding: 10rem 0 40rem;
}

#top #calender-section > img:nth-child(1) {
  top: 9.2rem;
  left: -33%;
  width: 55%;
}

#top #calender-section > img:nth-child(2) {
  width: 6%;
  top: 6.8rem;
  left: 5%;
}

#top #calender-section > img:nth-child(3) {
  width: 40%;
  right: -12.4%;
  bottom: 10.6rem;
}

#top #calender-section > img:nth-child(4) {
  width: 6.3%;
  right: 11.4%;
  bottom: 25.8rem;
}

#top #calender-section .container #a4-size {
  margin-bottom: 20rem;
}

#top #calender-section .container #a4-size ul {
  justify-content: center;
  margin: 0 auto 13.2rem;
  flex-direction: column;
  align-items: center;
}

#top #calender-section .container #a4-size ul li {
  width: 50%;
}

#top #calender-section .container #a4-size ul li:nth-child(2) {
  margin-top: 10rem;
  width: 30%;
}

#top #calender-section .container #postcard-size ul li {
  width: 44.1%;
}

#top #calender-section .container #postcard-size ul li:nth-child(1),
#top #calender-section .container #postcard-size ul li:nth-child(2),
#top #calender-section .container #postcard-size ul li:nth-child(3) {
  margin-bottom: 10rem;
}

/* たてがきタイプページ */
#tategaki-more .container {
  padding: 10.4rem 0 17.6rem;
}

#tategaki-more .container h2 {
  margin-bottom: 6.4rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#tategaki-more .container h2::before,
#tategaki-more .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#tategaki-more .container h2::before {
  left: -5.8rem;
}

#tategaki-more .container h2::after {
  right: -5.8rem;
}

#tategaki-more .container ul {
  margin-bottom: 5.6rem;
}

#tategaki-more .container ul li {
  margin-bottom: 7.6rem;
  margin-right: calc((100% / 5) - 16%);
  width: 16%;
}

#tategaki-more .container ul li:nth-child(5n) {
  margin-right: 0;
}

#tategaki-more .container ul li a p {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

/* よこがきタイプページ */
#yokogaki-more .container {
  padding: 10.4rem 0 17.6rem;
}

#yokogaki-more .container h2 {
  margin-bottom: 6.4rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#yokogaki-more .container h2::before,
#yokogaki-more .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#yokogaki-more .container h2::before {
  left: -5.8rem;
}

#yokogaki-more .container h2::after {
  right: -5.8rem;
}

#yokogaki-more .container ul {
  margin: 0 auto 5.6rem;
  width: 81%;
}

#yokogaki-more .container ul li {
  width: 29%;
  margin-bottom: 7.6rem;
}

#yokogaki-more .container ul li:nth-child(3n) {
  margin-right: 0;
}

#yokogaki-more .container ul li a p {
  margin-top: 1.6rem;
  font-size: 1.6rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

/* 商品詳細ページ */
#content.product .container {
  padding: 16.1rem 0 40rem;
}

#content.product .container .storycontent #itempage #img-box {
  width: 55%;
}

#content.product .item-img-thumb {
  margin-top: 0.4rem;
  margin-right: -5px;
  margin-left: -5px;
}

#content.product .item-img-thumb .thumbnail-item {
  width: 29%;
  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 {
  padding: 2.4rem 3.2rem 15.85rem 3.2rem;
  width: 43%;
}

#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:1430px) {
  #content.product .container .storycontent #itempage .skuform {
    overflow-x: scroll;
  }
}

/* カートページ */
#content.cart .container {
  padding: 10.4rem 0 17.6rem;
}

#content.cart .container h2 {
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#content.cart .container h2::before,
#content.cart .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#content.cart .container h2::before {
  left: -5.8rem;
}

#content.cart .container h2::after {
  right: -5.8rem;
}

#content.cart .container #cart .flex {
  margin-bottom: 0.8rem;
}

#content.cart .container #cart .cart_page_title {
  padding-top: 3.2rem;
  font-size: 2rem;
  letter-spacing: 0.15em;
}

#content.cart .container #cart .upbutton input {
  padding: 1.1rem 2.45rem;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.cart .container #cart table#cart_table {
  margin-bottom: 5.6rem;
}

#content.cart .container #inside-cart .send input[type="submit"] {
  margin: 0 auto 1.6rem;
  padding: 1.1rem 0;
  width: 20%;
  max-width: 18.6rem;
}

#content .container #wc_cart .nocart-text {
  padding-top: 5.2rem;
  font-size: 2rem;
  letter-spacing: 0.15em;
}

#content .container #inside-cart .no_cart {
  margin: 5.6rem 0 8.8rem;
}

#content .container #wc_cart img {
  max-width: 91.6rem;
}

#content .container #wc_cart .nocart-link {
  width: 20%;
  max-width: 18.6rem;
}

/* お客様情報入力ページ */
#content.customer .container {
  padding: 10.4rem 0 17.6rem;
}

#content.customer .container h2 {
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#content.customer .container h2::before,
#content.customer .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#content.customer .container h2::before {
  left: -5.8rem;
}

#content.customer .container h2::after {
  right: -5.8rem;
}

#content.customer .container .cart_page_title {
  margin: 2.8rem 0 0;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
}

#content.customer .container form > p {
  margin-top: 0.4rem;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
}

#content.customer .container #customer-info .send {
  padding-top: 7.3rem;
}

#content.customer .container #customer-info .send input.to_deliveryinfo_button {
  margin: 0 auto 1.6rem;
  width: 20%;
  max-width: 18.6rem;
}

/* 配送・支払いフォーム */
#content.delivery .container {
  padding: 10.4rem 0 17.6rem;
}

#content.delivery .container h2 {
  margin-bottom: 2.8rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#content.delivery .container h2::before,
#content.delivery .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#content.delivery .container h2::before {
  left: -5.8rem;
}

#content.delivery .container h2::after {
  right: -5.8rem;
}

#content.delivery .container .post > p {
  margin-bottom: 0.8rem;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
}

#content.delivery .container #delivery-info .send {
  margin: 8.8rem 0 0 0;
}

#content.delivery .container #delivery-info .send input {
  width: 20%;
  max-width: 18.6rem;
}

#content.delivery .container #delivery-info .send input:nth-child(3) {
  margin: 0 auto 2.7rem;
}

/* 注文確認画面 */
#content.confirm .container {
  padding: 10.4rem 0 17.6rem;
}

#content.confirm .container h2 {
  margin-bottom: 2.8rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#content.confirm .container h2::before,
#content.confirm .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#content.confirm .container h2::before {
  left: -5.8rem;
}

#content.confirm .container h2::after {
  right: -5.8rem;
}

#content.confirm .container #info-confirm > p,
#content.confirm .container #info-confirm > p a,
#content.confirm .container #info-confirm .confiem_notice {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
}

#content.confirm .container #info-confirm #confirm_table {
  margin: 4.4rem 0 0 0;
}

#content.confirm .container #info-confirm #confirm_table h3 {
  font-size: 2.4rem;
  letter-spacing: 0.2em;
}

#content.confirm .container #cart {
  margin-top: 5.6rem;
}

#content.confirm .container #cart > p {
  margin-bottom: 0.8rem;
  font-size: 2rem;
  letter-spacing: 0.15em;
}

#content.confirm .container #info-confirm .send {
  margin-top: 8.8rem;
}

#content.confirm .container #info-confirm .send input:nth-child(2) {
  margin: 0 auto 2.7rem;
  width: 100%;
  max-width: 18.6rem;
}

/* 確定画面 */
#content.completion .container {
  padding: 10.4rem 0 17.6rem;
}

#content.completion .container h2 {
  margin-bottom: 5.2rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#content.completion .container h2::before,
#content.completion .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#content.completion .container h2::before {
  left: -5.8rem;
}

#content.completion .container h2::after {
  right: -5.8rem;
}

#content.completion .container h3 {
  margin-bottom: 5.6rem;
  font-size: 2rem;
  letter-spacing: 0.15em;
}

#content.completion .container #cart_completion .send a {
  margin: 8.8rem auto 0;
  max-width: 18.6rem;
  width: 20%;
}

/* 料金表 */
#price .container {
  padding: 10.45rem 0 17.69rem;
}

#price .container h2 {
  margin-bottom: 7.6rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#price .container h2::before,
#price .container h2::after {
  width: 4.2rem;
  height: 5.2rem;
}

#price .container h2::before {
  left: -5.8rem;
}

#price .container h2::after {
  right: -5.8rem;
}

#price .container .nenga p {
  margin-bottom: 0.84rem;
  font-size: 2.4rem;
  letter-spacing: 0.15em;
}

#price .container .nenga .flex .img-box:nth-child(1) {
  margin-right: 7%;
}

#price .container .calender {
  margin-top: 25.25rem;
}

#price .container .calender p {
  margin-bottom: 0.85rem;
  font-size: 2.4rem;
  letter-spacing: 0.15em;
}

/* 会社概要ページ */
#company .container {
  padding: 10.45rem 0 0;
}

#company .container h2 {
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#company .container > a,
#company .container .address p,
#company .container .contact p {
  font-size: 2.4rem;
  letter-spacing: 0.2em;
}

#company .container .address {
  margin: 5.2rem 0;
}

#company .container .contact {
  margin-bottom: 10.45rem;
}

#company .map-box {
  margin-bottom: 17.6rem;
}

/* プライバシーポリシー */
#privacy .container {
  padding: 10.4rem 0 24rem;
}

#privacy .container h2 {
  margin-bottom: 3.6rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#privacy .container > p,
#privacy .container dl dd,
#privacy .container dl dd ul li,
#privacy .container dl dd p {
  font-size: 2.4rem;
  letter-spacing: 0.15em;
}

#privacy .container dl {
  margin: 14rem 0 0;
}

#privacy .container dl dt {
  margin-bottom: 3.6rem;
  font-size: 3.6rem;
  letter-spacing: 0.2em;
}

#privacy .container dl dd {
  margin: 0 0 0 3.5rem;
}

#privacy .container dl dd:not(:nth-of-type(7)) {
  margin-bottom: 6.8rem;
}

#privacy .container dl dd ul {
  margin-top: 1.3rem;
}

#privacy .container dl dd ul li {
  margin-left: 3.2rem;
}

#privacy .container dl dd ul li:not(:last-child) {
  margin-bottom: 0.8rem;
}

#privacy .container dl dd ul li::before {
  left: -3.2rem;
  width: 0.8rem;
  height: 0.8rem;
}

#privacy .container dl dd p:first-child {
  margin-top: 2.8rem;
}

#privacy .container dl dd p:not(:last-child) {
  margin-bottom: 0.8rem;
}

/* フッター */
footer {
  padding-bottom: 12px;
}

footer .container {
  padding-top: 17.9rem;
  margin: 0 auto 15.7rem;
}

footer .container a img {
  width: 18.6rem;
}

footer .container ul:nth-of-type(1) li:nth-child(4) {
  margin-top: 6.6rem;
}

footer .container ul li {
  margin: 0 0 2rem 4rem;
}

footer .container ul li a {
  font-size: 2rem;
  letter-spacing: 0.15em;
  line-height: 1.5;
}

footer .container ul li.big-midasi {
  margin: 0 0 2.4rem 0;
}

footer .copyright {
  font-size: 1.2rem;
  letter-spacing: 0.15em;
  line-height: 1.5;
}
