.p-lunch{
    overflow: unset;
}

.p-lunch__fv {
    padding-left: var(--pi);
    position: relative;
    z-index: 2;
    @media(max-width: 768px){
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding-top: 40px;
    }
}

.p-lunch__fv-heading {
    position: absolute;
    top:  calc(100%* 120 / 698);
    left: var(--pi);
    @media(max-width: 768px){
        position: relative;
        top: unset;
        left: unset;
    }
}

.p-lunch__fv-text {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.p-lunch__fv-text span {
    width: fit-content;
    font-size: max((100vw* 20/ 1440),16px);
    display: block;
    padding: 4px 16px;
    background-color: var(--acc);
    color: var(--white);
    font-family: var(--heading-font);
    font-weight: 600;
    line-height: 1.4;
}

.p-lunch__fv-ttl {
    margin-top: clamp(20px,(100vw* 40/ 1440),40px);
    font-size: max((100vw* 60/ 1440),32px);
    font-weight: 700;
    line-height: 1.2;
    font-family: var(--kaisei-opti);

    span {
        color: var(--acc);
    }
}

.p-lunch__fv-image {
    width:  calc(100%* 1080 / 1416);
    margin-left: auto;
    @media(max-width: 768px){
        width: 100%;
    }
}

.p-lunch__cta {
    position: relative;
    padding-block: clamp(100px,(100vw* 160/ 1440),160px) 40px;
    background-color: var(--main);
    margin-top: clamp(-60px,(100vw* -104/ 1440),-104px);
}

.p-lunch__cta-image01 {
    width: calc(100% * 108 / 1440);
    aspect-ratio: 108 / 170;
    position: absolute;
    top: clamp(-28px,(100vw* -80/ 1440),-80px);
    left:  calc(100%* 120 / 1440);
    @media(max-width: 768px){
        top: 72px;
        left: 10px;
    }
}

.p-lunch__cta-image02 {
    width: calc(100% * 166 / 1440);
    aspect-ratio: 166 / 86;
    position: absolute;
    top: 100%;
    left: calc(100%* 584 / 1440);
    translate: 0 10px;
    @media(max-width: 768px){
        left: unset;
        right: 5px;
        top: 97%;
        translate: 0;
    }
    @media(min-width: 1920px){
        left: calc(100%* 1000 / 1920);
    }
}

.p-lunch__inner {
    max-width: var(--width-inner);
    padding-inline: var(--pi);
    margin-inline: auto;
}

.p-lunch__cta-ttl {
    font-family: var(--heading-font);
    font-size: clamp(28px,(100vw* 36/ 1440),36px);
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: 1.8px;
    text-align: center;
    color: var(--cta);
    @media(max-width: 768px){
        font-size: 22px;
    }
}

.p-lunch__cta-contents {
    margin-top: 28px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap:  calc(100%* 48 / 1200);
    @media(max-width: 1200px){
        flex-direction: column;
        align-items: center;
        gap: 36px;
        margin-top: 40px;
    }
}

.p-lunch__cta-left {

}

.p-lunch__cta-ttlSecondly {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 1px;
    @media(max-width: 768px){
        font-size: 18px;
    }
}

.p-lunch__cta-text {
    margin-top: 20px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.8px;
    @media(max-width: 1200px){
        text-align: center;
        margin-top: 16px;
    }
    @media(max-width: 768px){
        font-size: 15px;
        text-align: left;
    }
}

.p-lunch__cta-right {
    display: flex;
    gap: 20px;
    @media(max-width: 500px){
        flex-direction: column;

    }
}

.p-lunch__cta-btn a {
    text-align: center;
    padding: 20px 28px;
    color: var(--white);
    font-weight: 700;
    font-size: 20px;
    color: var(--white);
    border-radius: 40px;
    border: 1px solid var(--main);
    box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.25);
    @media(max-width: 768px){
        font-size: 18px;
        padding: 12px 20px;
    }
}

.p-lunch__cta-reserve a{
    background-color: var(--cta);
}
.p-lunch__cta-line {
    position: relative;

    span {
        color: #73706C;
        font-size: 14px;
        font-weight: 400;
        position: absolute;
        bottom: -12px;
        right: 0;
        translate: 0 100%;
    }
}
.p-lunch__cta-line a {
    background-color: #27A434;
}

/* -------------------------------------
p-lunch__intro
--------------------------------------- */
.p-lunch__intro {
    padding-block: clamp(64px, (100vw*80/1440), 80px) clamp(100px, (100vw*140/1440), 140px);
}

.p-lunch__intro-ttl {
    font-family: var(--heading-font);
    font-size: clamp(28px, (100vw*40/1440), 40px);
    font-weight: 600;
}

.p-lunch__intro-subTtl {
    display: block;
    font-family: var(--heading-font);
    font-size: 20px;
    font-weight: 400;
    margin-top: 8px;

}

.p-lunch__intro-desc {
    margin-top: 20px;
    line-height: 1.6;
    font-weight: 700;
}

.p-lunch__intro-contents {
    margin-top: 48px; 
    display: flex;
    flex-direction: column;
    gap: clamp(80px, (100vw*120/1440), 120px);
    @media(max-width: 768px){
        gap: 64px;
        margin-top: 80px;
    }
}

.p-lunch__intro-item {
    display: flex;
    gap:  calc(100%* 44 / 1200);
    align-items: flex-start;
    position: relative;
    @media(max-width: 768px){
        flex-direction: column;
        gap: 40px;
    }
}

.p-lunch__intro-item:nth-child(even) {
    flex-direction: row-reverse;
    @media(max-width: 768px){
        flex-direction: column;
    }
}

.p-lunch__intro-text {
    flex: 1;
    padding-top: 68px;
    @media(max-width: 768px){
        padding-top: 0;
    }
}

.p-lunch__intro-image {
    width: calc(100% * 600 / 1200);
    aspect-ratio: 600 / 604;
    position: sticky;
    top: 0;
    @media(max-width: 768px){
        width: 100%;
    }
}

.p-lunch__intro-itemTtl {
    position: relative;
    z-index: 2;
}

.p-lunch__intro-num {
    position: absolute;
    top: -40px;
    left: 0;
    z-index: -1;
    @media(max-width: 1024px){
        top: -28px;
    }
}

.p-lunch__intro-numText {
    font-size: clamp(48px, (100vw*80/1440), 80px);
    font-family: var(--herrvonmuellerhoff);
    color: var(--acc);
    line-height: 1;
}

.p-lunch__intro-numSub {
    font-family: var(--herrvonmuellerhoff);
    font-size: clamp(20px, (100vw*24/1440), 24px);
    color: var(--acc);
    display: inline-block;
    vertical-align: top;
    padding-top: 1em;
    margin-left: 14px;
    @media(max-width: 1024px){
        padding-top: 0.5em;
        margin-left: 8px;
    }
}

.p-lunch__intro-mainTtl {
    display: block;
    font-family: var(--heading-font);
    font-size: clamp(28px, (100vw*32/1440), 32px);
    font-weight: 700;
    line-height: 1.5;
    padding-left: 20px;
    @media(max-width: 768px){
        font-size: 23px;
        padding-left: 4px;
    }
}

.p-lunch__intro-descBlock {
    margin-top: 56px;
    @media(max-width: 768px){
        margin-top: 32px;
    }
}

.p-lunch__intro-descBlock h4 {
    font-family: var(--heading-font);
    font-size: clamp(20px, (100vw*22/1440), 22px);
    font-weight: 600;
    margin-bottom: 16px;
    line-height: 1.6;
    margin-top: 40px;

    span {
        color: var(--acc);
    }
}
.p-lunch__intro-descBlock h4:first-child {
    margin-top: 0;
}

.p-lunch__intro-descBlock p {
    margin-top: 16px;
    line-height: 1.6;
    font-weight: 700;
}


/* -------------------------------------
p-lunch__menu
--------------------------------------- */
.p-lunch__menu {
    background-color: var(--white);
    position: relative;
    @media(max-width: 768px){
        padding-block: 40px;
    }
}

.p-lunch__rectangle-top {
    translate: 0 22%;
}
.p-lunch__rectangle-bottom {
    translate: 0 -22%;
}

.p-lunch__menu-parson03 {
    width: calc(100% * 106 / 1440);
    aspect-ratio: 106 / 200;
    max-width: 106px;
    position: absolute;
    top: 0;
    left:  calc(100%* 733 / 1440);
    translate: 0  calc(100%* -152 / 200);
}
.p-lunch__menu-parson04 {
    width: calc(100% * 212 / 1440);
    aspect-ratio: 212 / 190;
    max-width: 212px;
    position: absolute;
    bottom: 0;
    left:  calc(100%* 120 / 1440);
    translate: 0  calc(100%* 140 / 190);
    z-index: 2;
}

.p-lunch__menu-ttl {
    font-family: var(--heading-font);
    font-size: clamp(28px, (100vw*40/1440), 40px);
    font-weight: 600;
}

.p-lunch__menu-subTtl {
    display: block;
    font-family: var(--heading-font);
    font-size: 20px;
    margin-top: 8px;
    letter-spacing: 0.8px;
}

.p-lunch__menu-desc {
    margin-top: 20px;
    line-height: 1.6;
    font-weight: 700;
}

.p-lunch__menu-list {
    display: flex;
    flex-direction: column;
    gap: clamp(80px, (100vw*120/1440), 120px);
    margin-top: 56px;
    @media(max-width: 768px){
        gap: 64px;
    }
}

.p-lunch__menu-item {
    display: flex;
    align-items: flex-start;
    gap:  calc(100%* 46 / 1200);
    @media(max-width: 1080px){
        flex-direction: column;
        gap: 32px;
    }
}

.p-lunch__menu-info {
    width:  calc(100%* 344 / 1200);
    padding-top: clamp(20px,(100vw* 56 / 1440),56px);
    @media(max-width: 1080px){
        padding-top: 0;
        width: 100%;
    }
}

.p-lunch__menu-name {
    font-family: var(--heading-font);
    font-size: clamp(24px, (100vw*32/1440), 32px);
    font-weight: 700;
    @media(max-width: 1080px){
        font-size: 32px;
    }
    @media(max-width: 768px){
        font-size: 24px;
    }
}

.p-lunch__menu-name span {
    color: var(--acc);
}

.p-lunch__menu-text {
    line-height: 1.6;
    margin-top: 20px;
    font-weight: 700;
}

.p-lunch__menu-price {
    font-size: 20px;
    font-family: var(--kaisei-opti);
    font-weight: 400;
    letter-spacing: 2px;
    margin-top: 32px;
}

.p-lunch__menu-img {
    width:  calc(100%* 420 / 1200);
    position: relative;
    z-index: 1;
    @media(max-width: 1080px){
        width: 60%;
    }
    @media(max-width: 960px){
        width: 50%;
    }
    @media(max-width: 768px){
        width: 95%;
    }

    img {
        height: auto;
        aspect-ratio: 420 / 349;
    }
}


.p-lunch__menu-details {
    width: 385px;
    background-color: var(--acc);
    color: var(--base);
    padding: 20px 20px 20px clamp(60px, (100vw*80/1440), 80px);
    position: absolute;
    bottom: -20px;
    left: calc(100% * 380 / 420);
    z-index: -1;
    @media(max-width: 1080px){
        left: calc(100% * 400 / 420);
    }
    @media(max-width: 768px){
        width: 105%;
        padding: 40px 20px 20px 20px;
        position: relative;
        bottom: unset;
        top: -24px;
        left: 10px;
    }
}


.p-lunch__menu-details ul {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.p-lunch__menu-details li {
    font-family: var(--heading-font);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.6;
    @media(max-width: 768px){
        font-size: 16px;
    }
}

.p-lunch__blockImage {
    margin-top: 80px;
    aspect-ratio: 1440 / 480;
}

/* -------------------------------------
p-lunch__voice & p-lunch__question
--------------------------------------- */
.p-lunch__voice{
    margin-top: 120px;
    @media(max-width: 768px){
        margin-top: 80px;
    }
}

.p-lunch__question {
    margin-top: 80px;
    @media(max-width: 768px){
        margin-top: 64px;
    }
}



.p-lunch__voice-ttl, 
.p-lunch__question-ttl {
    font-family: var(--heading-font);
    font-size: clamp(28px, (100vw*40/1440), 40px);
    font-weight: 600;
}

.p-lunch__voice-subTtl, .p-lunch__question-subTtl {
    display: block;
    font-family: var(--heading-font);
    font-size: 20px;
    margin-top: 8px;
    letter-spacing: 0.8px;
}

.p-lunch__voice-list, 
.p-lunch__question-list {
    display: flex;
    flex-direction: column;
    gap: 32px;
    margin-top: 56px;
    max-width: 1080px;
    margin-inline: auto;
    @media(max-width: 768px){
        gap: 16px;
    }
}

.p-lunch__voice-item, 
.p-lunch__question-item {
    background-color: var(--white);
    border: 1px solid var(--acc);
    border-radius: 8px;
    padding: 24px;
}

/* p-lunch__voice */
.p-lunch__voice-text {
    font-weight: 700;
    line-height: 1.6;
    font-size: 16px;
    @media(max-width: 768px){
        font-size: 15px;
    }
}

.p-lunch__voice-source {
    display: block;
    text-align: right;
    font-size: 12px;
    font-weight: 400;
    margin-top: 16px;
}

/* p-lunch__question */
.p-lunch__question-q {
    font-weight: 700;
    font-size: 24px;
    @media(max-width: 768px){
        font-size: 20px;
    }
}

.p-lunch__question-a {
    font-weight: 700;
    font-size: 16px;
    margin-top: 20px;
    line-height: 1.6;
    @media(max-width: 768px){
        margin-top: 16px;
    }
}

/* -------------------------------------
p-lunch__lineUp
--------------------------------------- */
.p-lunch__lineUp {
    margin-top: 120px;
    position: relative;
    @media(max-width: 768px){
        margin-top: 80px;
    }
}

.p-lunch__lineUp-image {
    width: calc(100% * 115.6 / 1440);
    aspect-ratio: 115.6 / 144.8;
    position: absolute;
    top: -49px;
    right:  calc(100%* 120 / 1440);
}

.p-lunch__lineUp-ttl {
    font-family: var(--heading-font);
    font-size: clamp(28px, (100vw*40/1440), 40px);
    font-weight: 600;
}

.p-lunch__lineUp-subTtl {
    display: block;
    font-family: var(--heading-font);
    font-size: 20px;
    margin-top: 8px;
    letter-spacing: 0.8px;
}

.p-lunch__lineUp-slider {
    padding-top: 56px!important;
}

.swiper-slide {
    height: auto!important;
}


.swiper-button-prev {
    width: 48px!important;
    height: 48px!important;
    top: 0px!important; 
    left:  calc(100%* 1000 / 1440)!important;
    translate: 0 50%;
    @media(max-width: 960px){
        left:  calc(100%* 800 / 1440)!important;
    }
    @media(max-width: 768px){
        width: 32px!important;
        height: 32px!important;
        translate: 0 80%;
    }
    &::after{
        content: ""!important;
        width: 48px;
        aspect-ratio: 1;
        background-image: url(../images/lunch/slide-arrowToLeft.svg);
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        @media(max-width: 768px){
            width: 32px;
            height: 32px;
        }
    }

}

.swiper-button-next {
    width: 48px!important;
    height: 48px!important;
    top: 0px!important; 
    right:  calc(100%* 288 / 1440)!important;
    translate: 0 50%;
    @media(max-width: 960px){
        right:  calc(100%* 100 / 1440)!important;
    }
    @media(max-width: 768px){
        width: 32px!important;
        height: 32px!important;
        translate: 0 80%;
    }
    &::after{
        content: ""!important; 
        width: 48px;
        aspect-ratio: 1;
        background-image: url(../images/lunch/slide-arrowToRight.svg);
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        display: block;
        position: absolute;
        top: 0; 
        left: right;
        @media(max-width: 768px){
            width: 32px;
            height: 32px;
        }
    }
}

