@charset "utf-8";

:root {
    --txt: #432210;
    /*--c-pink: #e7336e;*/
    --black: #000;

    --white: #fff;
    --yellow: #F7F45F;

    --brown: #552e15;

    --red: #F80505;
    --red-deep: #B50033;
    --beige: #F2EFE3;
    --beige2: #DED5CC;

}

body {
    margin: 0;
    font-weight: 300;
}

@font-face {
    font-family: "NotoSansJP";
    src: url(../font/NotoSansJP-Light.woff) format('woff');
    font-style: normal;
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: "NotoSansJP";
    src: url(../font/NotoSansJP-Medium.woff) format('woff');
    font-style: normal;
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: "NotoSansJP";
    src: url(../font/NotoSansJP-Bold.woff) format('woff');
    font-style: normal;
    font-weight: 700;
    font-display: swap;
}

a:link {
    color: var(--txt);
}

.contents {
    font-family: "NotoSansJP", sans-serif;
    color: var(--txt);
}

.kp-content {
    padding: 1rem 2rem;
}

.w-1200 {
    max-width: 1200px;
    margin: auto;

}

.w-1010 {
    max-width: 1010px;
    margin: auto;
}

.w-500 {
    max-width: 340px;
    margin: auto;
}

.w-700 {
    max-width: 600px;
    margin: auto;
}

/***間隔調整***/
.m-t-1 {
    margin-top: 1rem;
}

.m-t-2 {
    margin-top: 2rem;
}

.m-b-1 {
    margin-bottom: 1rem;
}

.m-t-0 {
    margin-top: 0;
}

.m-tb-1 {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.m-tb-3 {
    margin-top: 3rem;
    margin-bottom: 3rem;
}

.m-w-1 {
    margin-left: 1rem;
    margin-right: 1rem;
}

.m-w-2 {
    margin-left: 2rem;
    margin-right: 2rem;
}

.m-r-1 {
    margin-right: .5em;
    align-self: center;
}

.column-layout {
    margin-top: 1rem;
}

.topic-box {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.topic-box-title {
    text-align: center;
}


#cp1,
#cp2,
#cp3,
#cp4,
#cp5,
#type1000_contact {
    padding: clamp(1em, 5vw, 4em);
}

.a-i-center {
    align-items: center;
}

.img_w50 {
    max-width: 50%;
}

.image-set img {
    width: 100%;
    height: auto;
    display: block;
}

.image_inner {
    margin: 0;
}


/****箱****/
.box-inner {
    margin: 1.5rem;
}

@media screen and (min-width: 768px) {
    .box-inner-inner {
        min-height: 450px;
    }
}

.white-box {
    padding: clamp(1em, 5vw, 3em);
    margin: 0 0 clamp(2em, 5vw, 5em);
    background: #fff;
    color: var(--black);
}

ul.precautions {
    list-style: disc;
    padding-left: 20px;
}

ul.precautions li {
    margin-top: .5em;
}

/****揃え****/
.a-left {
    justify-content: start;
    text-align: left;
}

.a-center {
    text-align: center;
    margin: auto
}

.a-right {
    text-align: right;
}


/****文字****/
.note {
    font-size: clamp(14px, 3vw, 18px);
    font-weight: 300;
    margin-top: .5em;
    line-height: 1.8;
}

.p-small {
    font-size: 14px;
}

.p-medium {
    font-size: clamp(16px, 3vw, 24px);
}

.p-big {
    font-size: 3.5em;
    font-weight: 900;
}

.p-bold {
    font-weight: bold;
}

.p-normal {
    font-weight: normal;
}

.c-red {
    color: var(--red);
}

.c-red-deep {
    color: var(--red-deep);
}

.c-white {
    color: #fff;
}


.text-center {
    text-align: center;
}

.va-bottom {
    vertical-align: middle;
}

.p-date {
    font-size: 1.25em;
}

.small-title {
    font-size: 1.35em;
    text-align: center;
    border-top: 2px dotted var(--blue);
    padding: .5em 0;
    line-height: 1.5;
    font-weight: 900;
    margin-top: 2rem;
    margin-bottom: 0.5rem;
}

.h-90 {
    min-height: 90px;
    display: table;
    width: 100%;
}

.h-120 {
    min-height: 120px;
    display: table;
    width: 100%;
}

.w100 {
    width: 100%;
}


@media print,
screen and (max-width: 768px) {
    .h-90 {
        min-height: auto;
    }

    .h-120 {
        min-height: auto;
    }

    .va-middle {
        vertical-align: middle;
        display: table-cell;
    }
}

/****背景色***/
.bg-white {
    background: rgba(255, 255, 255, .75);
    padding: 2rem 2.5rem;
    border-radius: 10px;
}


/***ボタン****/
.shinagawasyuku-btn {
    width: min(100%, 600px);
    margin: 1rem auto;
    position: relative;
    box-sizing: border-box;
}

a.shinagawasyuku-btn {
    padding: 15px 45px;
    text-align: center;
    font-size: clamp(16px, 3vw, 26px);
    color: var(--yellow);
    background: var(--brown);
    text-decoration: none;
    display: inline-block;
    font-weight: bold;
    transition-duration: .3s;
}

/*
.shinagawasyuku-btn:before,
.shinagawasyuku-btn:after {
    position: absolute;
    content: '';
    top: calc(50% - 1px);
    right: 20px;
    width: 12px;
    height: 3px;
    border-radius: 9999px;
    background-color: #fff;
    transform-origin: calc(100% - 1px) 50%;
}

.shinagawasyuku-btn:before {
    transform: rotate(45deg);
}

.shinagawasyuku-btn:after {
    transform: rotate(-45deg);
}*/

.btn-r,
a.btn-r {
    background: var(--red-deep);
}

.shinagawasyuku-btn:hover,
a.shinagawasyuku-btn:hover,
.btn-img:hover,
a.btn-img:hover {
    opacity: .7;
}

@media print,
screen and (min-width: 768px) {
    .column-media {
        margin-top: .5em;
    }
}

@media print,
screen and (min-width: 768px) {
    .column-media>.column_image[data-image="right"] {
        float: none;
    }
}

@media print,
screen and (min-width: 1024px) {
    .column-media>.column_image[data-image="right"] {
        float: right;
    }
}

.box-2clm {
    display: flex;
    gap: 1rem;
}

.box-2clm .box-2clm-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: .2em;
}

/***楽宴ツアーについて***/
.content {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
}

.content {
    /*本文*/
    height: 0;
    margin-bottom: 10px;
    padding: 0 16px;
    overflow: hidden;
}


.img_r {
    float: right;
    width: 100px;
    margin: -10px -30px 0 20px;
}

.img_r img {
    width: 100%;
    height: auto;
}

@media print,
screen and (min-width: 768px) {
    .img_r {
        width: 120px;
        margin: -70px 0 0 0;
    }
}

@media print,
screen and (min-width: 768px) {
    .sp-on {
        display: none;
    }
}

.pc-on {
    display: none;
}

@media print,
screen and (min-width: 768px) {
    .pc-on {
        display: block;
    }
}


#mainvisual {
    background: var(--red-deep);
}

#cp1 {
    background: var(--beige);
    overflow: hidden;
}

#cp2 {
    background: var(--red-deep);
}

#cp3 {
    background-color: #ffffff;
    background-image: linear-gradient(90deg, #fff57f80 5px, transparent 5px), linear-gradient(#fff57f80 5px, transparent 5px);
    background-position: 10px 10px;
    background-size: 20px 20px;
}

#cp4 {
    background: var(--beige2);
}

#cp5 {
    background: var(--white);
}

#type1000_contact {
    background: var(--beige);
}

/****MV****/
#mainvisual .image-set :is(.image_inner, h1) {
    margin: 0;
}

#mainvisual .image-set .image_inner {
    padding: clamp(1em, 5vw, 5em) 0;
}

#mainvisual .image_inner img {
    width: 100%;
    height: auto;
    display: block;
}

/****景品ゲット****/
#cp1 .topic-box-title {
    position: relative;
    z-index: 1;
}

#cp1 .topic-box .image-set {
    margin-inline: auto;
    margin-bottom: clamp(1em, 5vw, 5em);
    position: relative;
    z-index: 1;
}

#cp1 .topic-box .image-set:nth-of-type(1),
#cp1 .topic-box .image-set:nth-of-type(2) {
    width: min(100%, 800px);
}

#cp1 .topic-box .image-set:nth-of-type(3) {
    margin-bottom: 3em;
    width: min(100%, 900px);
}

hr {
    margin: 2em auto;
    border: none;
    height: 15px;
    background-image: url(../img/shinagawasyuku2026_cp1_hr.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    display: block;
}

#cp1 .topic-box .image-set:nth-child(3) {
    margin-inline: auto;
    width: min(100%, 900px);
}

#cp1 .note {
    z-index: 1;
    position: relative;
}

/**背景イラスト*/
#cp1 .topic-box {
    position: relative;
}

#cp1 .bgimg {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    height: auto;
}

#cp1 .bgimg img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

#cp1 .bgimg01 {
    left: -50px;
    width: clamp(150px, 30%, 300px);
}

#cp1 .bgimg02 {
    top: 45%;
    width: 150px;
    right: -80px;
}

#cp1 .bgimg03 {
    top: 0;
    transform: translateY(0);
    width: 100px;
    left: -70px;
}

#cp1 .bgimg04 {
    top: 35%;
    width: 150px;
    right: -120px;

}

@media screen and (min-width: 768px) {
    #cp1 .bgimg01 {
        left: -150px;
    }

    #cp1 .bgimg02 {
        width: 250px;
        right: -140px;
    }

    #cp1 .bgimg03 {
        width: 150px;
        left: -100px;
    }

    #cp1 .bgimg04 {
        top: 45%;
        width: clamp(150px, 30%, 200px);
        right: -140px;

    }
}


/****参加方法****/
#cp2 .topic-box-title {
    margin-inline: auto;
    margin-bottom: clamp(1em, 5vw, 3em);
    width: min(100%, 570px);
}

#cp2 .topic-box .image-set {
    display: block;
    margin-top: 0;
}

#cp2 .topic-box h2 {
    position: relative;
    padding-bottom: 2em;
    margin-bottom: 1.5em;
}

#cp2 .topic-box h2::before {
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background-image: repeating-linear-gradient(90deg, var(--red-deep), var(--red-deep) 40px, transparent 40px, transparent 50px);
    background-position: center bottom;
    background-repeat: repeat-x;
    background-size: 100% 5px;
}

@media screen and (max-width: 768px) {
    #cp2 .topic-box h2 {
        margin-bottom: 2em;
    }

    #cp2 .topic-box h2::before {
        background-image: repeating-linear-gradient(90deg, var(--red-deep), var(--red-deep) 20px, transparent 20px, transparent 30px);
    }
}

#cp2 .topic-box:nth-child(2) h2 img,
#cp2 .topic-box:nth-child(3) h2 img {
    max-width: 300px;
    width: 70%;
}

#cp2 .topic-box:nth-child(4) h2 img {
    max-width: 460px;
}

#cp2 .topic-box:nth-child(5) h2 img {
    max-width: 900px;
}

@media screen and (max-width: 1024px) {
    #cp2 .topic-box:nth-child(5) h2 img {
        max-width: 560px;
        width: 85%;
    }
}

.stamp-img {
    margin-inline: auto;
    width: min(100%, 460px);
}

/****店舗の紹介****/
#cp3 .image-set {
    margin-inline: auto;
    width: min(100%, 630px);
}

/****スタンプラリーマップ****/
#cp4 h2 {
    margin-bottom: 1em;
    margin-inline: auto;
    width: min(100%, 760px);
}

/****スタンプラリー参加方法****/
#cp5 .image-set {
    margin-top: 0;
    margin-inline: auto;
    width: min(100%, 900px);
}

#cp5 a {
    transition-duration: .3s;
}

@media (hover: hover) {
    #cp5 a:hover {
        opacity: .7;
    }
}

/****問い合わせ****/

#type1000_contact .contact-box {
    margin: 0 auto;
    width: 100%;
}

@media print,
screen and (min-width: 1024px) {
    .type1000_contact .contact-box {
        width: 990px;
    }
}

#type1000_contact .image-set .image_inner h2 img {
    margin: 0 auto 2em;
    width: min(100%, 296px);
}

#type1000_contact h3 {
    font-size: clamp(1.5em, 5vw, 2em);
    color: var(--black);
    font-weight: bold;
}

#type1000_contact p {
    color: var(--black);
}

#type1000_contact .p-big {
    font-size: clamp(2em, 5vw, 3.5em);
}

#type1000_contact .p-big span {
    font-size: 1.4rem;
}


#type1000_contact .p-medium {
    font-size: clamp(14px, 3vw, 16px);
}

#type1000_contact a {
    text-decoration: none;
    color: var(--black);
    font-weight: bold;
}