html {
    font-size: 6.39vw;
}

body {
    --body-padding: 1rem;
    --body-padding: 0.8695rem;
}

.orange-box {
    margin: 0 calc(var(--body-padding) * -1);
    padding: 1.3043rem var(--body-padding);
    border-radius: 0;
}

header {
    padding: 1.044rem;
}
header .logo > * {
    height: 1.87rem;
}
header nav > .menu {
    display: block;
    background: url(../img/menu.svg);
    background-size: cover;
    background-repeat: no-repeat;
    aspect-ratio: 32 / 23;
    width: 1.2608rem;
    cursor: pointer;
    z-index: 1001;
}
header nav > ul {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 3.5rem 0.5rem;
    width: 7.54rem;
    gap: 0.5rem;
    transform: translateX(100%) translate(10px);
    transition: .2s linear transform;
    background: rgba(0, 0, 0, .7);
    backdrop-filter: blur(9px);
    font-size: 1rem;
    text-align: center;
    z-index: 1000;
}

html.--menu,
html.--menu body {
    overflow: clip;
    pointer-events: none;
}
html.--menu header nav {
    pointer-events: all;
}
html.--menu header nav > ul {
    transform: translateX(0);
}

header nav > ul a {
    display: block;
    padding: 0.5rem 1rem;
}

.s-plate {
    display: flex;
    flex-direction: column-reverse;
    padding: 0.4348rem 0 1.3043rem;
}
.s-plate .image {
    height: auto;
    transform: rotate(-25deg);
    margin: -1rem -2rem 0 -1rem;
}
.s-plate h1 + .sub {
    font-size: 0.87rem;
}
.s-plate .hint {
    font-size: 0.4348rem;
}

.s-promo {
    padding: 2.6087rem 0;
    font-size: 0.74rem;
}
.s-promo .hint {
    margin-top: 0.87rem;
    font-size: 1.0435rem;
}
.s-products .header {
    flex-direction: column;
    gap: 1.3043rem;
}
.s-products .header .title {
    font-size: 1.5652rem;
}
.s-products nav > ul {
    justify-content: flex-start;
    gap: 0.4348rem;
}
.s-products nav > ul > li {
    padding: 0.4348rem 0.8696rem;
    font-size: 0.7391rem;
}
.s-products .list {
    margin-top: 1.3043rem;
    grid-template-columns: repeat(2, 1fr);
}
.s-products .list .item {
    padding: 0.5652rem;
    padding-bottom: 0.9565rem;
}
.s-products .list .item .title {
    min-height: 1.4347rem;
    font-size: 0.4783rem;
}
.s-products .list .item .price {
    font-size: 0.7391rem;
}
.s-products .list .item .weight {
    font-size: 0.5652rem;
}

.s-combo .image {
    width: 100%;
    background-image: url(../img/combo-m.svg);
    aspect-ratio: 320 / 248;
}
.s-combo .image::before {
    height: 7.2rem;
    left: 0.75rem;
    top: -0.75rem;
}
.s-combo .image::after {
    height: 6.5rem;
    right: 0.7em;
    bottom: -1.3rem;
}
.s-combo .sub {
    flex-direction: column;
    margin-top: 0.8696rem;
}
.s-combo .sub .discount {
    font-size: 2.33rem;
}
.s-combo .sub .expr {
    gap: 0.2609rem;
}
.s-combo .sub .expr .var {
    padding: 0.4783rem 0.7826rem;
    font-size: 0.8261rem;
}

.s-addresses .title {
    font-size: 1.5652rem;
}
.s-addresses .map {
    margin-top: 0.6522rem;
    height: 16rem;
}

footer {
    padding: 1.5217rem 0;
}
footer .logo-m {
    height: 1.8260rem;
}
footer .mapp {
    margin-top: 1.3043rem;
    gap: 0.5217rem;
}
footer .mapp .qr {
    height: 5.6522rem;
    aspect-ratio: 1 / 1;
    padding: 0.4783rem;
}
footer .mapp .qr::before {
    height: 100%;
}
footer .mapp .title {
    font-size: 0.8696rem;
}
footer .mapp .sub {
    font-size: 0.6957rem;
}
footer .copyright {
    margin-top: 1.3043rem;
    font-size: 0.4348rem;
}