@charset "utf-8";

/* 共通設定
========================================================================== */
html {
    font-size: 62.5%;
    /* 10px */
}

*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    min-width: inherit;
    color: #333;
    font-size: 1.4rem;
    line-height: 1.8;
    font-family: 'Murecho', 'Hiragino Sans', 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
    font-weight: 500;
    letter-spacing: 0.08em;
}

a {
    color: #000;
}

a:hover {
    color: #fa2d2d;
}

img {
    max-width: 100%;
    vertical-align: bottom;
}

ul,
ol {
    list-style: none;
}

h2 {
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 40px;
}

.wrapper {
    width: 1200px;
    margin: 0 auto;
    background-color: #F8F8F8;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
    position: relative;
}

.inner {
    max-width: 1000px;
    margin: 0 auto;
}

.font_red {
    color: #D70C18;
}

.link_arrow {
    background: url("https://nenga.aisatsujo.jp/common/images/ico_arrow_orange-r.png") no-repeat 0 5px;
    padding: 0 0 0 20px;
}

/* タグ
---------------------------------------------------------- */
#tag {
    width: 1px;
    height: 1px;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
}

/* トップに戻るボタン
---------------------------------------------------------- */
.btn_top {
    width:50px;
    height:50px;
    right:2%;
    bottom:4%;
    position: fixed;
    z-index: 1000;
}

.btn_top a {
    position: relative;
    width: 100%;
    height: 100%;
    text-decoration: none;
    background: rgba(0,0,0,0.2);
    border-radius: 5px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.btn_top a::before{
    content: "";
    display: block;
    margin: 0 auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-right:10px solid transparent;
    border-left:10px solid transparent;
    border-bottom:12px solid #fff;
    border-top: 0;
}

@media (hover: hover) and (pointer: fine) {
    .btn_top a:hover {
        opacity: 0.7;
    }
}

/* 汎用コンポーネント
---------------------------------------------------------- */
/* 宛名印刷をもっと知りたい方は */
.further {
    text-align: center;
}

.further-text {
    position: relative;
    font-size: 24px;
    margin-bottom: 16px;
    font-weight: bold;
}

.further-text::before,
.further-text::after {
    content: "";
    display: block;
    width: 4px;
    height: 20px;
    background: #333;
    position: absolute;
    top: 20%;
    bottom: 0;
    margin: auto;
    border-radius: 10px;
}

.further-text::before {
    left: 30.5%;
    transform: rotate(-30deg);
}

.further-text::after {
    right: 30.5%;
    transform: rotate(30deg);
}

/* 数字アイコン */
.num_icon {
    font-family: "korolev", sans-serif;
    position: relative;
    display: block;
    font-size: 22px;
    font-weight: bold;
    width: 32px;
    height: 32px;
    color: #fff;
    background: #D70C18;
    border-radius: 50%;
    text-align: center;
    top: 3px;
    line-height: 35px;
    letter-spacing: 0;
}

/* アイス棒ボタン
---------------------------------------------------------- */
.btn_g {
    width: 480px;
    margin: 0 auto;
}

.btn_g a {
    position: relative;
    display: flex;
    justify-content: center;
    font-size: 28px;
    font-weight: bold;
    color: #fff;
    line-height: 1;
    letter-spacing: 0.05em;
    text-decoration: none;
    border-radius: 44px;
    background-color: #23af3c;
    padding: 28px 0 32px;
    margin: 0 auto;
    box-sizing: border-box;
    transition: opacity .3s;
}

.btn_g a:hover {
    opacity: .7;
    color: #fff;
}

.btn_g-arrow {
    position: relative;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #fff;
    top: 2px;
    right: -6px;
    transition: all .3s;
}

.btn_g-arrow::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 38%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 10px solid #23af3c;
    border-right: 0;
}

/* appeal 共通設定
========================================================================== */
.appeal_container {
    background: #EBDDBA;
    padding: 72px 88px;
    border-radius: 0 0 16px 16px;
}

.appeal_head {
    text-align: center;
    margin-bottom: 28px;
}

.appeal_head-title {
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 28px;
}

.appeal_head-desc {
    font-size: 18px;
}

.appeal_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 98px 32px;
}

.appeal_item {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: calc((100% - 32px) / 2);
    background: #fff;
    padding: 48px 40px;
    border-radius: 12px;
}

.appeal_inner {
    text-align: center;
    margin-bottom: 24px;
}

.appeal_title {
    margin-bottom: 12px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.6em;
}

.appeal_desc {
    font-size: 18px;
}

.appeal_sub {
    display: flex;
    align-items: center;
    font-size: 24px;
    font-weight: bold;
    position: absolute;
    top: -12%;
    left: 37%;
}

.appeal_sub::before,
.appeal_sub::after {
    content: "";
    display: block;
    width: 4px;
    height: 20px;
    background: #333;
    position: absolute;
    top: 20%;
    bottom: 0;
    margin: auto;
    border-radius: 10px;
}

.appeal_sub::before {
    left: -15%;
    transform: rotate(-30deg);
}

.appeal_sub::after {
    right: -15%;
    transform: rotate(30deg);
}

/* appeal内設定
---------------------------------------------------------- */
/* 緑ボタン */
.appeal .btn_g {
    width: 304px;
}

.appeal .btn_g a {
    font-size: 22px;
    padding: 16px 0 20px;
    border-radius: 40px;
}

.appeal .btn_g-arrow {
    width: 22px;
    height: 22px;
    top: 1px;
}

.appeal .btn_g-arrow::after {
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 9px solid #23af3c;
}

/* appeal個別設定
---------------------------------------------------------- */
/* flow */
.num_icon.-flow {
    position: absolute;
    top: -4%;
    left: 45%;
}

/* merit */
.appeal_container.-merit {
    padding-top: 114px;
}

.appeal_desc.-merit {
    text-align: left;
}

.num_icon.-merit {
    margin-left: 4px;
    width: 28px;
    height: 28px;
    font-size: 21px;
    line-height: 31px;
    background: #333;
    color: #EBDDBA;
    top: 2px;
}




/* header
========================================================================== */
.header {
    position: relative;
}
.header_mv {
    padding-top:75px;
}
.header_mv img{
    width: 100%;
}
.header_logo {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 2%;
    left: 2%;
}
.logo_text {
    font-family: 'Meiryo', sans-serif;
    font-size: 11px;
    letter-spacing: 0.05em;
}

.header_logo-link {
    width: 290px;
    line-height: 1em;
}

.header_logo-images {
    width: 100%;
}

/* entrance
========================================================================== */
.entrance {
    position: relative;
    margin: 104px auto;
    text-align: center;
    max-width: 922px;
}

.entrance_title {
    margin-bottom: 52px;
    font-size: 40px;
    font-weight: bold;
    line-height: 1.8em;
}

.entrance_desc {
    font-size: 20px;
    font-weight: 500;
    text-align: justify;
}

/* campaign
========================================================================== */
.campaign {
    margin-bottom: 120px;
}

.campaign_container {
    position: relative;
    margin-bottom: 100px;
    padding: 72px 80px 72px 298px;
    background: #fff;
    overflow: hidden;
    border-radius: 16px;
}

.campaign_container::before {
    content: "";
    background: url("https://nenga.aisatsujo.jp/group_common/images/hagaki/hagaki_kansei_address.webp") 0 0 no-repeat;
    background-size: contain;
    width: 270px;
    height: 400px;
    position: absolute;
    top: 88px;
    left: -4%;
    box-shadow: 6px 6px 24px rgba(0, 0, 0, .16)
}

.campaign_box {
    margin-bottom: 28px;
}

.campaign_desc,
.campaign_caution,
.campaign_table {
    margin-left: 6%;
}

.campaign_title {
    display: flex;
    gap: 0 8px;
    align-items: center;
    margin-bottom: 20px;
    font-size: 32px;
    font-weight: bold;
    letter-spacing: 0.1em;
}

.campaign_desc {
    font-weight: normal;
    margin-bottom: 16px;
    font-size: 18px;
    line-height: 1.8em;
}

.campaign_text-bold {
    font-size: 26px;
    font-weight: bold;
    letter-spacing: 0.1em;
}

.campaign_caution {
    font-size: 14px;
}
.campaign_bold {
    font-weight: bold;
}

/* 料金テーブル */
.campaign_table {
    width: 574px;
    font-size: 16px;
    margin-bottom: 16px;
    border-top: 1px solid #C9C9C9;
    border-bottom: 1px solid #C9C9C9;
}

.campaign_table-upper {
    border-bottom: 1px dotted #C9C9C9;
}

.campaign_table th,
td {
    height: 48px;
    text-align: center;
    font-weight: bold;
}

.campaign_table-price {
    font-size: 18px;
    color: #D70C18;
}

.campaign_period {
    text-align: center;
    font-weight: bold;
}
.campaign_period dt {
    font-size: 32px;
}
.campaign_period dd {
    font-size: 30px;
}

/* entrance
========================================================================== */
.flow {
    margin-bottom: 120px;
}

.flow_container {
    padding-top: 72px;
    background: #fff;
    border-radius: 16px;
}

.flow_step {
    padding: 0 80px;
    margin-bottom: 48px;
}

.flow_title {
    margin-bottom: 28px;
    font-size: 24px;
    font-weight: bold;
    text-align: center;
}

.flow_step-list {
    display: flex;
    justify-content: space-between;
    column-gap: 40px;
}

.flow_step-item {
    text-align: center;
    position: relative;
}

.flow_step-item::after {
    position: absolute;
    content: '';
    top: 30%;
    left: -18%;
    width: 0;
    height: 0;
    border-left: 20px solid #D70C18;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
}

.flow_step-item:first-child:after {
    content: none;
}

.flow_step-text {
    margin-top: 16px;
    font-size: 18px;
    font-weight: bold;
}

.flow_step-link {
    font-weight: normal;
    text-decoration: underline;
}

/* merit
========================================================================== */
.merit {
    margin-bottom: 120px;
}

.merit_container {
    background: #fff;
    padding-top: 72px;
    border-radius: 16px;
    letter-spacing: 0.1em;
}

.merit_box {
    padding: 0 88px;
    margin-bottom: 72px;
}

.merit_list {
    display: flex;
    flex-direction: column;
    gap: 72px 0;
}

.merit_item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0 32px;
}
.merit_item::before{
	content: "";
    display: block;
    width: 120px;
    height: 120px;
}
.merit_item.-merit01::before {
/*    content: "";
    display: block;
    width: 98px;
    height: 120px;*/
    background: url("https://nenga.aisatsujo.jp/group_common/images/cam_atena/img_merit01.webp") no-repeat center/contain;
}

.merit_item.-merit02::before {
/*    content: "";
    display: block;
    width: 107px;
    height: 123px;*/
    background: url("https://nenga.aisatsujo.jp/group_common/images/cam_atena/img_merit02.webp") no-repeat center/contain;
}

.merit_item.-merit03::before {
/*    content: "";
    display: block;
    width: 107px;
    height: 107px;*/
    background: url("https://nenga.aisatsujo.jp/group_common/images/cam_atena/img_merit03.webp") no-repeat center/contain;
}

.merit_sub {
    font-family: "korolev", sans-serif;
    color: #D70C18;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: -8px;
}

.merit_sub span {
    font-size: 24px;
    margin-left: 4px;
}

.merit_title {
    margin-bottom: 12px;
    font-size: 24px;
    font-weight: bold;
}

.merit_desc {
    font-size: 18px;
    line-height: 1.4em;
}

/* security
========================================================================== */
.security {
    margin-bottom: 120px;
}

.security_container {
    padding: 72px 88px;
    background: #fff;
    border-radius: 16px;
}

.security_box {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.security_title {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 4px;
    text-align: center;
}

.security_desc {
    width: 692px;
    font-size: 18px;
    letter-spacing: 0.08em;
    text-align: justify;
}

.security_link img {
    width: 112px;
    height: 112px;
}

.security_caution a{
    font-size: 16px;
}

/* voice
========================================================================== */
.voice .swiper-button-prev,.voice .swiper-button-next {
    display: block;
}
.voice .swiper-pagination{
    display: none;
}
.voice {
    margin-bottom:120px;
}

.voice_container {
    padding:72px 0 88px;
    margin-bottom: 120px;
    border-radius: 16px;
    background: #fff;
    overflow: hidden;
}

.voice_text {
    font-size:18px;
    margin-bottom:24px;
    text-align: center;
}

.voice img {
    width: 590px;
    margin: 20px 0;
    border-radius:16px;
    box-shadow: 0 0 24px rgb(0 0 0 / 16%);
}
.voice .swiper-horizontal{
    padding: 0 8.3%;
}
.voice_slider-item {
    padding: 0 40px;
}
.voice .swiper-wrapper {
    padding: 0;
}
/* swiper アイコン設定 */
.swiper-horizontal {
    position: relative;
}
.swiper-button-prev,.swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 0);
}
.swiper-button-next,.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 0);
}
.swiper-button-next, .swiper-button-prev {
    width: 30px;
    height: 30px;
}
.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after,
.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after {
    content: ''!important;
    width: 100%;
    height: 100%;
}
.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after {
    background:url("https://nenga.aisatsujo.jp/group_common/component/images/ico_next.png") 0 0 no-repeat;
    background-size: contain;
}
.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after {
    background:url("https://nenga.aisatsujo.jp/group_common/component/images/ico_prev.png") 0 0 no-repeat;
    background-size: contain;
}
.swiper-button-prev, .swiper-rtl .swiper-button-next, .swiper-button-next, .swiper-rtl .swiper-button-prev, .swiper-button-prev::before, .swiper-rtl .swiper-button-next:before, .swiper-button-next:before, .swiper-rtl .swiper-button-prev:before {
    content: "";
    display: inline-block;
    width:32px;
    height: 32px;
    background: var(--color-sub);
    border-radius: 50%;
}
.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after, .swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    background: none;
    display: inline-block;
    width:12px;
    height:12px;
    margin-left: auto;
    border-bottom: 3px solid #ffffff;
    border-right: 3px solid #ffffff;
    transform: rotate(135deg);
    position: absolute;
    top: 10px;
}
.swiper-button-prev {
    left: 20.6%;
}
.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    left:12px;
}
.swiper-button-next{
    right: 20.6%;
}
.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    transform: rotate(315deg);
    right:12px;
}


/* category
========================================================================== */
.category {
    margin-bottom: 200px;
}

.category_list {
    display: flex;
    flex-wrap: wrap;
    gap:32px;
    justify-content: center;
}

.category_item {
    position: relative;
    width: calc((100% - 32px) / 2);
    height: 184px;
}

.category_item::before {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 160px;
    left: 0;
    bottom: 0;
    outline: 4px solid transparent;
    border-radius: 10px;
    transition: .2s all linear;
}

.category_inner {
    padding-top: 24px;
    overflow: hidden;
}

.category_link {
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    padding: 28px 0 26px 32px;
    border-radius: 10px;
    text-decoration: none;
    background: #fff;
    transition: .3s all;
    height: 160px;
}

.category_title {
    display: block;
    font-size: 28px;
    font-weight: bold;
    text-align: left;
    margin-bottom: 16px;
    line-height: 1.2;
}

.category_desc {
    display: block;
    position: relative;
    font-size: 22px;
    font-weight: bold;
    text-align: left;
}

.category_desc::before {
    content: "";
    position: absolute;
    width: 24px;
    height: 24px;
    background-color: #fff;
    border-radius: 50%;
    top: 52%;
    left: 164px;
    transform: translateY(-50%);
}

.category_desc::after {
    position: absolute;
    content: "";
    top: 52%;
    left: 173px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 8px solid #ffffff;
    border-right: 0;
}

/* はがき設定 */
.category_link::before {
    content: "";
    display: block;
    position: absolute;
    bottom: -14px;
    right: 36px;
    width: 128px;
    height: 190px;
    box-shadow: 5px 5px 10px rgba(0 0 0 / 16%);
    transform: scale(1);
    -webkit-transform: scale(1);
    transition: .2s all linear;
}

.category_link:hover::before {
    transform: scale(1.07);
    -webkit-transform: scale(1.07);
    opacity: 1;
}

/* カテゴリ別設定
------------------------------------------------ */
.category_item:hover::before {
    outline: 4px solid var(--color-sub);
    outline-offset: 1px;
}
.category_desc::before {
    background: var(--color-sub);
}
.category_link:hover{
    color:#333333;
}
/* 写真フレームタイプ */
.category_link.-photo_yofu::before {
    background: url("https://nenga.aisatsujo.jp/images/items/W01P201b.jpg") no-repeat top center;
    background-size: 100%;
}

/* 写真フレームタイプ */
.category_link.-photo_wafu::before {
    background: url("https://nenga.aisatsujo.jp/images/items/W01P401b.jpg") no-repeat top center;
    background-size: 100%;
}
/* デザインタイプ */
.category_link.-design::before {
    background: url("https://nenga.aisatsujo.jp/images/items/W01C201b.jpg") no-repeat top center;
    background-size: 100%;
}



/* footer
========================================================================== */
.footer {
    position: relative;
    padding-top: min(calc(470 * 100vw / 1200), 470px);
}

.footer_inner {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
}

/* object */
.footer_obj {
    position: absolute;
}

.footer_obj.footer_rabbit-01 {
    top: 70px;
    left: 225px;
    width: 200px;
}

.footer_obj.footer_rabbit-02 {
    top: 54px;
    right: 185px;
    width: 200px;
}

/* パンくずリスト */
.bread_list {
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 0;
    padding: 0;
}

.bread_item {
    font-size: 1.2rem;
    letter-spacing: .02em;
}

.bread_item:not(:last-child)::after {
    padding: 0 10px;
    content: ">";
}

.bread_item a:hover {
    text-decoration: underline;
}

.copyright {
    font-size: 1.2rem;
    letter-spacing: .07em;
    text-align: center;
    margin: 0;
}

.copyright_link {
    text-decoration: underline;
}

.copyright_link:hover {
    text-decoration: none;
}

.bread_copy {
    background: var(--color-main);
    padding: 20px 0;
}

.bread_copy p,
.bread_copy li,
.bread_copy a {
    color: #fff;
}