:root {
    --black: #333333;
    --white: #ffffff;
    --gray--very-light: #f5f5f5;
    --pink--primary:#cc0022;
    --pink--pale: #f2d5e1;
    --pink--dusty-light: #fff1f1;
    --pink--very-light: #fff1f1;
    --w--dark: #EFD2CF;
    --green--middle: #65b005;
    --blue--middle: #1492d9;
    --yellow--dark: #c3850b;
    --fs-sp--min10px: clamp(1rem, 3vw, 1.2rem);
    --fs-sp--min11px: clamp(1.1rem, 3.25vw, 1.3rem);
    --fs-sp--min12px: clamp(1.2rem, 3.5vw, 1.4rem);
    --fs-sp--min13px: clamp(1.3rem, 3.75vw, 1.5rem);
    --fs-sp--min14px: clamp(1.4rem, 4.00vw, 1.6rem);
    --fs-sp--min15px: clamp(1.5rem, 4.25vw, 1.7rem)
}

html {
    scroll-behavior: smooth;
    font-size: 62.5%;
    touch-action: manipulation
}

body {
    background-color: #ffffff;
    max-width: 100%;
    width: 100%;
    overflow-x: hidden
}

* {
    margin: 0;
    padding: 0;
    list-style: none;
    text-decoration: none;
    box-sizing: border-box;
    letter-spacing: .04em;
    color: var(--black);
    font-kerning: auto;
    font-family: "Onest", "Noto Sans JP", sans-serif;
    font-feature-settings: "halt";
    font-weight: normal;
    font-weight: 400;
    text-align: justify
}

*::before,
*::after {
    display: block
}

picture,
img {
    display: block;
    width: 100%;
    height: auto
}

iframe {
    aspect-ratio: 16/9;
    background-color: #ccc
}

button {
    background-color: rgba(0, 0, 0, 0);
    border: none;
    cursor: pointer;
    appearance: none;
    display: block
}

a:has(picture),
a:has(img) {
    display: block
}

details summary {
    list-style: none;
    cursor: pointer
}

details summary::-webkit-details-marker {
    display: none
}

table {
    border-collapse: collapse;
    width: 100%
}

:target {
    scroll-margin-top: 100px
}

.ext,
.ext-fff {
    position: relative
}

.ext::after,
.ext-fff::after {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    background-size: cover;
    background-size: contain;
    background-repeat: no-repeat
}

.ext::after {
    background-image: url(../imgs/common/icon/ext.svg)
}


.container,
.row-wide,
.row,
.row-nar {
    margin: 0 auto
}

.container {
    max-width: 1460px
}

.row-wide {
    max-width: 1260px
}

.row {
    max-width: 1260px
}

.row-nar {
    max-width: 1200px
}

@media screen and (min-width: 769px) {

    .container,
    .row-wide,
    .row {
        padding: 0 30px
    }

    .row-nar {
        padding: 0 24px
    }
}

@media screen and (max-width: 768px)and (min-width: 451px) {

    .container,
    .row-wide,
    .row,
    .row-nar {
        padding: 0 20px
    }
}

@media screen and (max-width: 450px) {

    .container,
    .row-wide,
    .row,
    .row-nar {
        padding: 0 15px
    }
}

h1,
h2,
h3 {
    font-feature-settings: "palt"
}

@media screen and (min-width: 769px) {

    h1,
    h2,
    h3 {
        line-height: 100%
    }
}

h2,
h3 {
    color: var(--pink--primary);
    white-space: pre;
    font-weight: 900;
    letter-spacing: .1em;
    text-align: center
}

h2.dot-line,
h3.dot-line {
    display: flex;
    align-items: center
}

h2.dot-line::before,
h2.dot-line::after,
h3.dot-line::before,
h3.dot-line::after {
    content: "";
    width: auto;
    width: 100%;
    background-image: radial-gradient(#e5afc7 30%, transparent 30%)
}

h2.flower,
h3.flower {
    display: flex;
    flex-direction: column;
    align-items: center
}

h2.flower::before,
h3.flower::before {
    content: "";
    background-image: url(../img/common/icon/flower--ylw.svg);
    background-size: cover
}

h2.flowers,
h3.flowers {
    display: flex;
    justify-content: center;
    align-items: center
}

h2.flowers::before,
h2.flowers::after,
h3.flowers::before,
h3.flowers::after {
    content: "";
    background-image: url(../img/common/icon/flower--ylw.svg);
    background-size: cover
}

@media screen and (min-width: 769px) {

    h2.dot-line,
    h3.dot-line {
        gap: 16px
    }
    
    h2.flower,
    h3.flower {
        gap: 8px
    }

    h2.flower::before,
    h3.flower::before {
        width: 20px;
        height: 20px
    }

    h2.flowers,
    h3.flowers {
        gap: 12px
    }

    h2.flowers::before,
    h2.flowers::after,
    h3.flowers::before,
    h3.flowers::after {
        width: 18px;
        height: 18px
    }
}

@media screen and (max-width: 768px) {

    h2.dot-line,
    h3.dot-line {
        gap: clamp(8px, 2.5vw, 12px)
    }


    h2.flower,
    h3.flower {
        gap: clamp(6px, 1.5vw, 8px);
        line-height: 140%
    }

    h2.flower::before,
    h3.flower::before {
        width: clamp(15px, 4vw, 18px);
        height: clamp(15px, 4vw, 18px)
    }

    h2.flowers,
    h3.flowers {
        gap: clamp(8px, 2vw, 10px)
    }

    h2.flowers::before,
    h2.flowers::after,
    h3.flowers::before,
    h3.flowers::after {
        width: clamp(15px, 4vw, 18px);
        height: clamp(15px, 4vw, 18px)
    }
}

@media screen and (min-width: 769px) {
    .dots {
        background-size: 12px 12px
    }
}

@media screen and (max-width: 768px) {
    .dots {
        background-size: 8px 8px
    }
}

.bg--pale {
    background-color: var(--pink--pale)
}

.bg--pale.dots {
    background-image: radial-gradient(#ecc4d4 30%, transparent 30%)
}

.bg--dusty {
    background-color: var(--pink--dusty-light)
}

.bg--dusty.dots {
    background-image: radial-gradient(#f1dbe3 30%, transparent 30%)
}

@media screen and (max-width: 768px) {
    .bg--dusty.dots {
        background-image: radial-gradient(#f6e1e9 30%, transparent 30%)
    }
}

.bg--light {
    background-color: var(--pink--very-light)
}

.bg--light.dots {
    background-image: radial-gradient(#f7e8ef 30%, transparent 30%)
}

.btn {
    margin: 0 auto
}

.btn a {

    color: #333333;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    font-weight: 400;
    border-radius: 1.2rem;
    transition: .3s;
    border: solid 1px #777777;
}

.btn a::after {
    content: "";
    background-image: url(../id-tokyo_c/imgs/ext.svg);
    transition: inherit;
    background-size: cover
}

.btn a::before {
    display: none
}

.btn:hover:after {
    background: #ffffff;
    opacity: 1;
    position: relative; 
}

a[href*="tel:"]{
    color: #333;
    text-decoration: none;
    pointer-events: none;
  }
  
  @media screen and (max-width: 640px) {
    a[href*="tel:"]{
      color: #0000ff;
      text-decoration: underline;
      pointer-events: auto;
    }
  }

@media screen and (min-width: 769px) {
    .btn {
        width: min(270px, 100%);
        padding: 6px;
    }

    .btn a {
        font-size: 1.4rem;
        height: 50px;
        gap: 6px;
        box-shadow: 0 3px 1px -2px rgba(0, 0, 0, .2), 0 2px 2px 0 rgba(0, 0, 0, .14), 0 1px 5px 0 rgba(0, 0, 0, .12);
    }

    .btn a::after {
        width: 12px;
        height: 12px;
        
    }
}

@media screen and (min-width: 769px)and (hover: hover) {
    .btn a:hover {
        text-decoration: underline;
    }
}

@media screen and (max-width: 768px) {
    .btn {
        width: min(460px, 100%);
        padding: 32px 26px;
    }

    .btn a {
        height: clamp(56px, 15vw, 80px);
        font-size: clamp(1.5rem, 4vw, 2.2rem);
        box-shadow: 4px 4px 0 #e9e9e9;
        gap: 4px;
        padding-left: 10px;

    }

    .btn a::after {
        width: 10px;
        height: 10px
    }
}

@media screen and (max-width: 768px)and (hover: hover) {
    .btn a:hover {
        transform: translate(4px, 4px);
        box-shadow: 0 0 0 #e9e9e9
    }
}

@media screen and (min-width: 769px) {
    .bg--pale .btn a {
        box-shadow: 5px 5px 0 #efd0dd
    }
}

@media screen and (min-width: 769px)and (hover: hover) {
    .bg--pale .btn a:hover {
        box-shadow: 0 0 0 #efd0dd
    }
}

@media screen and (min-width: 769px) {
    .bg--pale.dots .btn a {
        box-shadow: 5px 5px 0 #ecc4d4
    }
}

@media screen and (min-width: 769px)and (hover: hover) {
    .bg--pale.dots .btn a:hover {
        box-shadow: 0 0 0 #ecc4d4
    }
}

@media screen and (min-width: 769px) {
    .bg--light .btn a {
        box-shadow: 5px 5px 0 #efd0dd
    }
}

@media screen and (min-width: 769px)and (hover: hover) {
    .bg--light .btn a:hover {
        box-shadow: 0 0 0 #efd0dd
    }
}

@media screen and (max-width: 768px) {
    .bg--pale .btn a {
        box-shadow: 4px 4px 0 #efd0dd
    }
}

@media screen and (max-width: 768px)and (hover: hover) {
    .bg--pale .btn a:hover {
        box-shadow: 0 0 0 #efd0dd
    }
}

@media screen and (max-width: 768px) {
    .bg--pale.dots .btn a {
        box-shadow: 4px 4px 0 #ecc4d4
    }
}

@media screen and (max-width: 768px)and (hover: hover) {
    .bg--pale.dots .btn a:hover {
        box-shadow: 0 0 0 #ecc4d4
    }
}

@media screen and (max-width: 768px) {
    .bg--light .btn a {
        box-shadow: 4px 4px 0 #efd0dd
    }
}

@media screen and (max-width: 768px)and (hover: hover) {
    .bg--light .btn a:hover {
        box-shadow: 0 0 0 #efd0dd
    }
}

.header {
    width: 100%;
    background-color: #fbfbfb;
    z-index: 9999
}

.header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%
}

.header--stick {
    position: fixed;
    top: 0;
    z-index: 9998;
    transform: translateY(-100%);
    transition: .5s;
    opacity: 0
}

.header--stick.is-visible {
    transform: none;
    opacity: 1
}

.header--stick .header__inner {
    gap: 22px;
    gap: clamp(16px, 1.56vw, 22px)
}

.header--stick .header__exts {
    display: none
}

.header--stick .header__shop a {
    font-weight: 500
}

.header__logo {
    display: flex;
    margin: auto 0
}

.header__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: end
}

.header__inner a {
    font-weight: 500
}

@media(hover: hover) {
    .header__inner a:not(:has(img))::before {
        background-color: var(--pink--primary)
    }
}

.header__inner li a {
    color: var(--pink--primary)
}

.header__nav {
    width: 100%
}

.header__nav ul {
    display: flex;
    align-items: center
}

.header__nav a {
    letter-spacing: 0
}

.header__exts ul {
    display: flex;
    align-items: center;
    height: 100%
}

.header__exts .ext {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px
}

.header__exts .ext::after {
    background-image: url(../img/common/icon/ext--prm.svg)
}

.header__shop a {
    background-color: var(--pink--primary);
    color: #fff;
    border-radius: 10vw;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: pre;
    gap: 6px;
    font-size: clamp(1.4rem, 1.37vw, 1.7rem);
    transition: .4s;
    letter-spacing: 0
}

@media(hover: hover) {
    .header__shop a:hover {
        background-color: #c2004c;
        opacity: 1
    }
}

@media screen and (min-width: 1301px) {
    header__logo {
        height: clamp(56px, 5.47vw, 65px)
    }

    .header--stick {
        height: clamp(94px, 9.18vw, 104px)
    }

    .header--stick .header__inner {
        flex-wrap: nowrap;
        align-items: center
    }

    .header--stick .header__inner a {
        font-weight: 500
    }

    .header--stick .header__nav ul {
        gap: clamp(14px, 1.5vw, 24px)
    }

    .header--stick .header__exts {
        display: none
    }

    .header--stick .header__shop {
        order: 3
    }

    .header--stick .header__shop a {
        font-size: clamp(1.4rem, 1.08vw, 1.5rem);
        padding: 0 clamp(22px, 1.69vw, 32px);
        height: clamp(50px, 3.85vw, 54px)
    }

    .header__inner {
        column-gap: clamp(22px, 2.15vw, 36px);
        row-gap: clamp(10px, .98vw, 18px)
    }

    .header__inner a {
        font-size: clamp(1.3rem, 1.08vw, 1.5rem)
    }

    .header__nav {
        order: 3
    }

    .header__nav ul {
        justify-content: end;
        gap: clamp(14px, 2vw, 32px)
    }

    .header__exts {
        order: 1
    }

    .header__exts ul {
        gap: clamp(16px, 1.56vw, 24px)
    }

    .header__shop {
        order: 2
    }

    .header__shop a {
        padding: 0 clamp(24px, 2.34vw, 32px);
        height: clamp(48px, 4.69vw, 56px)
    }

    .header__btn {
        display: none
    }
}

@media screen and (max-width: 1300px) {
    /*
    #header {
        position: sticky;
        top: 0
    }
*/
    .header .container {
        position: relative
    }

    .header a::before {
        display: none
    }

    .header.is-active .header__nav {
        top: 88px;
        animation: header-nav .2s ease-in forwards;
        opacity: 0;
        background-color: rgba(255, 255, 255, .5)
    }

    @keyframes header-nav {
        0% {
            opacity: 0;
            z-index: 1
        }

        100% {
            opacity: 1;
            z-index: 1
        }
    }

    .header__inner {
        width: 100%;
        padding-left: 16px;
        align-items: center;
        flex-wrap: nowrap
    }

    .header__nav {
        position: absolute;
        left: 0;
        right: 0;
        top: -100vw;
        z-index: -1;
        overscroll-behavior: contain;
        overflow-y: scroll;
        display: flex;
        height: calc(100vh - 88px)
    }

    .header__nav::before {
        content: "";
        width: 1px;
        height: calc(100vh - 88px + 1px)
    }

    .header__nav>ul {
        width: 100%;
        display: flex;
        flex-direction: column
    }

    .header__nav>ul>li a,
    .header__nav>ul .header__exts a {
        display: flex;
        justify-content: center
    }

    .header__nav>ul>li {
        width: 100%;
        text-align: center
    }

    .header__nav>ul>li:nth-of-type(odd) {
        background-color: var(--pink--very-light)
    }

    .header__nav>ul>li:nth-of-type(even) {
        background-color: #fff
    }

    .header__exts {
        width: 100%;
        background-color: #fff
    }

    .header__exts ul {
        flex-direction: row;
        justify-content: center
    }

    .header__exts ul li {
        display: flex;
        align-items: center
    }

    .header__exts ul li:first-of-type {
        flex-direction: row-reverse;
        justify-content: end
    }

    .header__exts ul li:first-of-type::before {
        content: "";
        width: 1px;
        background-color: var(--pink--primary)
    }

    .header__exts ul li:last-of-type {
        justify-content: start
    }

    .header__btn {
        width: 44px;
        height: 44px
    }

    .header__btn button {
        width: 100%;
        height: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 7px
    }

    .header__btn span {
        display: block;
        width: 30px;
        height: 2px;
        background-color: var(--pink--primary);
        border-radius: 5vw;
        transition: .3s
    }

    .header__btn span:first-of-type {
        transform-origin: left top
    }

    .header__btn span:last-of-type {
        transform-origin: left bottom
    }

    .header__btn.is-active span:first-of-type {
        transform: translateY(4px) rotate(20deg)
    }

    .header__btn.is-active span:nth-of-type(2) {
        opacity: 0
    }

    .header__btn.is-active span:last-of-type {
        transform: translateY(-4px) rotate(-20deg)
    }

    .header__exts ul li:first-of-type::before {
        content: "";
        width: 1px;
        height: 20px;
        background-color: var(--pink--primary)
    }
}

@media screen and (max-width: 1300px)and (min-width: 769px) {
    .header__inner {
        justify-content: end;
        gap: 16px
    }

    .header__inner a {
        font-size: 14px
    }

    .header__logo {
        height: 56px
    }

    .header__nav>ul>li:first-of-type::before {
        height: 20px
    }

    .header__nav>ul>li a {
        padding: 22px 0
    }

    .header__exts a {
        padding: 22px 16px
    }

    .header__shop a {
        height: 52px;
        padding: 0 24px
    }
}

@media screen and (max-width: 768px) {
    /*
    .header {
        height: clamp(66px, 16.5vw, 80px)
    }
*/
    .header.is-active .header__nav {
        top: clamp(66px, 16.5vw, 80px)
    }

    .header__logo {
        height: clamp(42px, 10.5vw, 48px)
    }

    .header__logo img {
        height: 100%;
        width: auto
    }

    .header__inner {
        gap: clamp(6px, 1.5vw, 16px)
    }

    .header__inner a {
        font-size: var(--fs-sp--min13px)
    }

    .header__shop a {
        height: clamp(34px, 8.5vw, 48px);
        font-size: var(--fs-sp--min12px);
        padding: clamp(16px, 4vw, 24px)
    }

    .header__nav {
        top: -100vh;
        height: calc(100vh - clamp(66px, 16.5vw, 80px));
        height: calc(100svh - clamp(66px, 16.5vw, 80px))
    }

    .header__nav::before {
        height: calc(100vh - clamp(66px, 16.5vw, 80px) + 1px);
        height: calc(100svh - clamp(66px, 16.5vw, 80px) + 1px)
    }

    .header__nav>ul>li a {
        padding: 24px 0
    }

    .header__exts a {
        padding: 24px 16px
    }

    .header__exts .ext {
        gap: 4px
    }
}

@media screen and (max-width: 450px) {
    .header .container {
        padding: 0 8px 0 14px
    }

    .header__inner {
        padding-left: 0
    }
}

footer {
    background-color: var(--pink--primary);
    padding-bottom: 0
}

footer .row {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 1144px
}

footer>span {
    display: block;
    text-align: center
}

@media(hover: hover) {
    footer a:not(:has(img))::before {
        background-color: var(--black);
        background-color: #b5adb0
    }
}

.footer__site a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%
}

.footer__site a img {
    height: 100%
}

.footer__map {
    width: 100%;
    display: flex;
    align-items: start
}

.footer__map>span {
    display: block;
    width: 1px;
    height: 240px;
    background-color: var(--black);
    opacity: .6
}

.footer__map a {
    font-size: min(1.4rem, 14px);
    display: inline-flex;
    align-items: center;
    gap: 6px
}

.footer__map a::after {
    content: "";
    width: 10px;
    height: 10px;
    background-size: contain;
    background-image: url(../img/common/icon/arrow.svg)
}

.footer__quality {
    width: min(474px, 100%);
    background-color: #fbfbfb;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.footer__quality div p {
    line-height: 156%
}

.footer__quality div span {
    display: inline-block;
    width: 100%;
    line-height: 100%;
    text-align: right
}

.footer__nav {
    column-gap: clamp(60px, 5.86vw, 80px);
    grid-template-rows: repeat(7, 1fr)
}

.footer__shop {
    column-gap: 64px;
    grid-template-rows: repeat(6, 1fr)
}

.footer__company {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px
}

.footer__company p {
    text-align: center;
    font-size: min(1.4rem, 14px);
    line-height: 170%
}

.footer__exts ul {
    display: flex;
    align-items: center
}

.footer__exts .ext {
    display: flex;
    align-items: center
}

.footer__exts .ext::after {
    background-image: url(../img/common/icon/ext.svg);
    background-size: cover;
    background-size: contain;
    background-repeat: no-repeat
}

@media screen and (min-width: 769px)and (max-width: 1040px) {
    .footer__map>span {
        display: none
    }
}

@media screen and (min-width: 769px) {
    footer>span {
        font-size: 1.2rem
    }

    footer .row {
        padding: 56px 72px 0
    }

    .footer__map {
        justify-content: space-between;
        margin-top: 56px
    }

    .footer__map>ul {
        display: grid;
        grid-auto-flow: column;
        row-gap: 24px
    }

    .footer__quality {
        width: min(474px, 100%);
        margin: 40px auto;
        padding: 0 24px;
        height: 104px;
        border-radius: 4px;
        gap: 10px
    }

    .footer__quality img {
        width: 72px
    }

    .footer__quality div p {
        font-size: 1.4rem
    }

    .footer__quality div span {
        font-size: 1.2rem;
        text-align: right;
        margin-top: 8px
    }

    .footer__exts {
        margin-top: 48px;
        margin-bottom: 32px
    }

    .footer__exts ul {
        gap: 24px
    }

    .footer__exts a {
        font-size: 1.3rem
    }

    .footer__exts .ext {
        gap: 3px
    }

    .footer__exts .ext::after {
        height: 14px;
        width: 14px
    }
}

@media screen and (max-width: 768px) {
    footer>span {
        font-size: 1rem;
        padding: 0 10px
    }

    .footer__site {
        height: clamp(48px, 12vw, 65px);
        margin-top: clamp(32px, 10vw, 56px)
    }

    .footer__map {
        flex-direction: column;
        gap: clamp(32px, 8vw, 40px);
        max-width: 660px;
        margin-top: 32px
    }

    .footer__map a {
        font-size: var(--fs-sp--min12px)
    }

    .footer__map>span {
        width: 100%;
        height: 1px
    }

    .footer__map>ul {
        gap: clamp(20px, 6vw, 26px) 10px
    }

    .footer__nav {
        display: flex;
        flex-direction: column
    }

    .footer__shop {
        display: grid;
        grid-auto-flow: column;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(7, 1fr);
        width: 100%
    }

    .footer__shop li:first-of-type {
        grid-column: 1/4
    }

    .footer__quality {
        margin-top: clamp(32px, 8.89vw, 48px);
        margin-bottom: clamp(32px, 8.89vw, 48px);
        padding-top: 16px;
        padding-bottom: 18px;
        padding-right: clamp(14px, 4.89vw, 24px);
        padding-left: clamp(14px, 4.89vw, 24px);
        justify-content: start;
        gap: 16px
    }

    .footer__quality img {
        width: clamp(48px, 12.44vw, 72px)
    }

    .footer__quality div {
        width: 100%
    }

    .footer__quality div p {
        font-size: min(1.3rem, 2.5vw)
    }

    .footer__quality div span {
        font-size: calc(min(1.3rem, 2.5vw)*.8)
    }

    .footer__company a {
        height: clamp(30px, 7.56vw, 48px);
        display: flex;
        justify-content: center;
        align-items: center
    }

    .footer__company a img {
        height: 100%
    }

    .footer__company p {
        font-size: min(2.5vw, 1.4rem)
    }

    .footer__exts {
        margin-top: clamp(24px, 4vw, 24px);
        margin-bottom: clamp(20px, 6vw, 32px)
    }

    .footer__exts ul {
        gap: 8px clamp(18px, 4vw, 24px);
        flex-wrap: wrap
    }

    .footer__exts a {
        font-size: var(--fs-sp--min11px)
    }

    .footer__exts a::after {
        height: var(--fs-sp--min11px);
        width: var(--fs-sp--min11px)
    }

    .footer__exts .ext {
        gap: 3px
    }
}

@media screen and (max-width: 450px) {
    .footer__quality {
        gap: 8px
    }

    .footer__quality div p {
        font-size: min(1.2rem, 2.45vw)
    }

    .footer__quality div span {
        font-size: calc(min(1.2rem, 2.4vw)*.85)
    }
}

.about__features ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px
}

.about__features li {
    background-color: #fff;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 0 24px 24px;
    position: relative
}

.about__features li .indicator {
    width: 40px;
    height: 40px;
    margin: 0 auto;
    position: relative;
    top: -16px
}

.about__features li .main-img {
    height: 136px;
    margin: 0 auto 4px
}

.about__features li .name {
    text-align: center;
    font-size: 2rem;
    line-height: 100%;
    color: var(--pink--primary);
    letter-spacing: .07em;
    letter-spacing: .1em
}

.about__features li p:not(.name) {
    text-align: left;
    font-size: 1.3rem;
    line-height: 171%
}

@media screen and (min-width: 769px) {
    .about__features li .name {
        font-weight: 700
    }
}

@media screen and (max-width: 768px) {
    .about__features ul {
        display: flex;
        flex-direction: column;
        gap: clamp(24px, 6vw, 32px)
    }

    .about__features li {
        background-color: rgba(0, 0, 0, 0);
        padding: 0
    }

    .about__features li .indicator,
    .about__features li .main-img {
        display: none
    }

    .about__features li .name {
        font-weight: 900;
        text-align: left;
        display: grid;
        grid-template-columns: clamp(17px, 4.5vw, 20px) auto;
        align-items: center;
        gap: clamp(5px, 1.5vw, 8px);
        font-size: clamp(1.7rem, 4.5vw, 2rem)
    }

    .about__features li .name::before {
        content: "";
        width: clamp(17px, 4.5vw, 20px);
        height: clamp(17px, 4.5vw, 20px);
        background-image: url(../img/common/icon/flower--ylw.svg);
        background-size: cover
    }

    .about__features li p:not(.name) {
        font-size: var(--fs-sp--min12px)
    }

    .about__features li p:not(.name) br {
        display: none
    }
}

.voice__list {
    width: 100%
}

.voice__list img {
    width: 100%
}

@media screen and (min-width: 769px) {
    .voice__list {
        margin-top: 40px
    }

    .voice__list ul {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 26px 32px
    }

    .voice__list .swiper-button {
        display: none
    }
}

@media screen and (max-width: 768px) {
    .voice .att {
        font-size: clamp(1rem, 2.5vw, 1.3rem);
        margin-top: clamp(6px, 2vw, 10px)
    }

    .voice__list {
        max-width: 100%;
        overflow: hidden;
        position: relative;
        margin-top: clamp(22px, 5.5vw, 40px)
    }

    .voice__list img {
        max-width: 500px;
        margin: 0 auto
    }

    .voice__list .swiper-slide {
        padding: 0 calc(clamp(30px, 7.5vw, 44px)/2)
    }

    .voice__list .swiper-button {
        width: 44px;
        width: clamp(30px, 7.5vw, 44px);
        height: 44px;
        height: clamp(30px, 7.5vw, 44px);
        background-color: var(--pink--pale);
        border-radius: 50vw
    }

    .voice__list .swiper-button img {
        width: 32%
    }

    .voice__list .swiper-button::after {
        display: none
    }

    .voice__list .swiper-button-prev {
        left: 0
    }

    .voice__list .swiper-button-prev img {
        transform: rotate(180deg)
    }

    .voice__list .swiper-button-next {
        right: 0
    }
}

.faq__list {
    display: flex;
    flex-direction: column
}

.faq__list details {
    border-radius: 12px;
    background-color: var(--gray--very-light)
}

.faq__list details div {
    line-height: 173%;
    overflow: hidden;
    max-height: 0
}

.faq__list details div a {
    color: var(--pink--primary);
    text-decoration: underline
}

.faq__list details div a::before {
    display: none
}

@media(hover: hover) {
    .faq__list details div a:hover {
        text-decoration: none
    }
}

.faq__list details[open] summary::before,
.faq__list details[open] summary::after {
    transform: rotate(45deg)
}

.faq__list summary {
    font-weight: 700;
    font-size: 1.6rem;
    letter-spacing: .07em;
    position: relative;
    color: var(--pink--primary)
}

.faq__list summary:before,
.faq__list summary::after {
    content: "";
    background-color: var(--pink--primary);
    position: absolute;
    transition: .3s
}

.faq__list summary::before {
    width: 16px;
    height: 2px;
    right: 0;
    top: 23px;
    margin-top: 4px
}

.faq__list summary::after {
    height: 16px;
    width: 2px;
    top: 16px;
    right: 7px;
    margin-top: 4px
}

@media screen and (min-width: 769px) {
    .faq__list {
        gap: 16px
    }

    .faq__list details {
        padding: 16px 32px
    }

    .faq__list details[open] {
        padding-bottom: 32px
    }

    .faq__list details div {
        font-size: 1.5rem
    }

    .faq__list details summary {
        padding-top: 16px;
        padding-bottom: 16px;
        padding-right: 28px
    }
}

@media screen and (max-width: 768px) {
    .faq__list {
        gap: clamp(10px, 3vw, 16px)
    }

    .faq__list details {
        padding: clamp(8px, 2.25vw, 16px) clamp(16px, 4.5vw, 32px)
    }

    .faq__list details div {
        font-size: var(--fs-sp--min12px)
    }

    .faq__list details[open] {
        padding-bottom: clamp(16px, 4.5vw, 32px)
    }

    .faq__list summary {
        font-size: var(--fs-sp--min13px);
        padding-top: clamp(8px, 2.25vw, 16px);
        padding-bottom: clamp(8px, 2.25vw, 16px);
        padding-right: calc(clamp(12px, 2.67vw, 16px) + 6px)
    }

    .faq__list summary::before {
        width: clamp(12px, 2.67vw, 16px);
        top: calc(clamp(8px, 2.25vw, 16px) + clamp(12px, 2.67vw, 16px)/2 + 2px);
        margin-top: 0
    }

    .faq__list summary::after {
        height: clamp(12px, 2.67vw, 16px);
        top: calc(clamp(8px, 2.25vw, 16px) + 3px);
        right: calc(clamp(12px, 2.67vw, 16px)/2 - 1px);
        margin-top: 0
    }
}

#backToTop {
    background-color: var(--black);
    position: fixed;
    right: clamp(20px, 1.67vw, 40px);
    bottom: clamp(20px, 1.67vw, 40px);
    width: clamp(72px, 5.28vw, 84px);
    height: clamp(70px, 5.14vw, 80px);
    z-index: 9998;
    border-radius: 6px;
    display: flex;
    justify-content: center;
    align-items: center
}

#backToTop img {
    width: 20px;
    height: 20px;
    margin-bottom: 6px
}

#backToTop.is-hidden {
    opacity: 0;
    z-index: -1
}

.tracking-banner {
    position: fixed;
    right: clamp(20px, 1.67vw, 40px);
    bottom: clamp(20px, 1.67vw, 40px);
    width: 220px;
    height: 220px;
    z-index: 9998
}

.tracking-banner img {
    width: 100%;
    height: auto
}

.cmn__search-shop--stick a p {
    text-align: center
}

@media screen and (max-width: 768px) {
    #backToTop {
        right: 20px;
        bottom: 20px;
        width: clamp(44px, 14.5vw, 72px);
        height: clamp(44px, 14.5vw, 72px);
        border-radius: 4px
    }

    #backToTop img {
        width: 30%;
        height: auto;
        margin-bottom: 5%
    }

    .tracking-banner {
        right: clamp(4px, 1.25vw, 8px);
        bottom: clamp(6.25rem, 3.571rem + 13.39vw, 10rem);
        width: clamp(12.5rem, 10.268rem + 11.16vw, 15.625rem);
        height: clamp(12.5rem, 10.268rem + 11.16vw, 15.625rem)
    }
}

.cmn__search-shop--stick {
    position: fixed;
    z-index: 9998;
    right: 0
}

.cmn__search-shop--stick a {
    display: flex
}

@media screen and (min-width: 769px) {
    .cmn__search-shop--stick {
        top: 200px;
        width: clamp(64px, 5vw, 80px)
    }

    .cmn__search-shop--stick a {
        width: 100%;
        background-color: #0076e5;
        writing-mode: vertical-lr;
        flex-direction: row;
        align-items: center;
        padding: 24px 0 32px;
        border-top-left-radius: 24px;
        border-bottom-left-radius: 24px;
        gap: 8px;
        padding-left: 8px
    }
}

@media screen and (min-width: 769px)and (hover: hover) {
    .cmn__search-shop--stick a:hover {
        opacity: 1;
        background-color: #0056d8
    }
}

@media screen and (min-width: 769px) {
    .cmn__search-shop--stick img {
        width: 24px;
        height: 24px
    }

    .cmn__search-shop--stick p {
        writing-mode: inherit;
        font-size: clamp(2.2rem, 1.6vw, 2.6rem);
        font-weight: 900;
        color: #fff;
        margin-left: -8px
    }
}

@media screen and (max-width: 768px) {
    .cmn__search-shop--stick {
        left: 0;
        bottom: 0;
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, 1fr)
    }

    .cmn__search-shop--stick a {
        font-weight: 900;
        position: relative;
        align-items: center;
        justify-content: center;
        text-align: center
    }

    .cmn__search-shop--stick a::after {
        content: "";
        background-size: cover
    }

    .cmn__search-shop--stick a:first-of-type {
        border: 2px solid #0071db;
        border: 2px solid #0d75d5;
        color: #0071db;
        color: #0d75d5;
        background-color: #fafdff;
        background-color: #f4f6f8;
        background-image: url(../img/common/icon/phone.svg);
        background-repeat: no-repeat;
        background-position: -4px -4px;
        order: 2
    }

    .cmn__search-shop--stick a:first-of-type::after {
        background-image: url(../img/common/icon/arrow--tel.svg)
    }

    .cmn__search-shop--stick a:nth-of-type(2) {
        background-color: #0071db;
        background-color: #146aba;
        color: #fff;
        border: 2px solid #fff;
        padding-top: 1%;
        order: 1
    }

    .cmn__search-shop--stick a:nth-of-type(2)::after {
        background-image: url(../img/common/icon/arrow--fff.svg)
    }

    .cmn__search-shop--stick a p {
        font-weight: inherit;
        font-size: inherit
    }

    .cmn__search-shop--stick a p span {
        font-weight: 700
    }

    .cmn__search-shop--stick a p,
    .cmn__search-shop--stick a span {
        color: inherit;
        line-height: 110%
    }
}

@media screen and (max-width: 768px)and (min-width: 451px) {
    .cmn__search-shop--stick {
        gap: clamp(8px, 1.78vw, 16px);
        bottom: clamp(8px, 1.78vw, 16px);
        padding: 0 clamp(10px, 2.22vw, 20px)
    }

    .cmn__search-shop--stick a {
        border-radius: 6px;
        height: 80px;
        font-size: clamp(1.7rem, 3.78vw, 2.2rem);
        padding: 0 clamp(10px, 2.22vw, 24px);
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2)
    }

    .cmn__search-shop--stick a::after {
        width: 12px;
        height: 12px;
        right: 20px;
        position: absolute
    }

    .cmn__search-shop--stick a:first-of-type {
        background-size: 88px
    }

    .cmn__search-shop--stick a p span {
        font-size: clamp(1.2rem, 2.89vw, 1.7rem)
    }
}

@media screen and (max-width: 450px) {
    .cmn__search-shop--stick {
        gap: clamp(4px, 1.25vw, 8px);
        padding: 0 clamp(4px, 1.25vw, 8px);
        bottom: clamp(4px, 1.25vw, 8px)
    }

    .cmn__search-shop--stick a {
        border-radius: 4px;
        height: clamp(54px, 16.88vw, 72px);
        font-size: clamp(1.3rem, 3.78vw, 1.7rem);
        padding: 0 clamp(10px, 3.25vw, 14px);
        box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2)
    }

    .cmn__search-shop--stick a::after {
        width: 10px;
        width: clamp(8px, 2.22vw, 10px);
        height: 10px;
        height: clamp(8px, 2.22vw, 10px);
        right: 8px;
        right: clamp(4px, 1.78vw, 8px);
        position: absolute
    }

    .cmn__search-shop--stick a:first-of-type {
        background-size: calc(clamp(54px, 16.88vw, 72px) + 8px)
    }

    .cmn__search-shop--stick a p span {
        font-size: clamp(.9rem, 2.81vw, 1.4rem)
    }

    .cmn__search-shop--stick a p,
    .cmn__search-shop--stick a span {
        line-height: 130%
    }
}

@media screen and (max-width: 768px)and (min-width: 451px) {
    body:has(.cmn__search-shop--stick) footer {
        padding-bottom: calc(80px + clamp(10px, 2.22vw, 20px) + clamp(44px, 14.5vw, 72px) + 36px)
    }

    body:has(.cmn__search-shop--stick) #backToTop {
        bottom: calc(80px + clamp(10px, 2.22vw, 20px) + 18px);
        right: clamp(10px, 2.22vw, 20px)
    }

    body:not(:has(.cmn__search-shop--stick)) footer {
        padding-bottom: calc(clamp(44px, 14.5vw, 72px) + 44px)
    }
}

@media screen and (max-width: 450px) {
    body:has(.cmn__search-shop--stick) footer {
        padding-bottom: calc(clamp(40px, 13vw, 70px) + clamp(44px, 14.5vw, 72px) + 10px + 24px)
    }

    body:has(.cmn__search-shop--stick) #backToTop {
        bottom: clamp(68px, 19.56vw, 88px);
        right: 10px
    }
}

body:has(.special) footer {
    padding-bottom: 24px
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    position: relative;
    bottom: 0;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: start
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet,
.swiper-pagination-custom .swiper-pagination-bullet,
.swiper-pagination-fraction .swiper-pagination-bullet {
    margin: unset;
    border: 1px solid var(--pink--primary);
    background-color: rgba(0, 0, 0, 0);
    opacity: 1
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet[aria-current],
.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet[aria-current],
.swiper-pagination-custom .swiper-pagination-bullet[aria-current],
.swiper-pagination-fraction .swiper-pagination-bullet[aria-current] {
    background-color: var(--pink--primary)
}

@media screen and (min-width: 769px) {

    .swiper-horizontal>.swiper-pagination-bullets,
    .swiper-pagination-bullets.swiper-pagination-horizontal,
    .swiper-pagination-custom,
    .swiper-pagination-fraction {
        gap: 8px
    }

    .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
    .swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet,
    .swiper-pagination-custom .swiper-pagination-bullet,
    .swiper-pagination-fraction .swiper-pagination-bullet {
        width: 10px;
        height: 10px
    }
}

@media screen and (max-width: 768px) {

    .swiper-horizontal>.swiper-pagination-bullets,
    .swiper-pagination-bullets.swiper-pagination-horizontal,
    .swiper-pagination-custom,
    .swiper-pagination-fraction {
        gap: clamp(6px, 1.33vw, 8px)
    }

    .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
    .swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet,
    .swiper-pagination-custom .swiper-pagination-bullet,
    .swiper-pagination-fraction .swiper-pagination-bullet {
        width: clamp(7px, 1.78vw, 10px);
        height: clamp(7px, 1.78vw, 10px)
    }
}

.swiper-notification {
    display: none
}

@media screen and (min-width: 769px) {
    .show_sp {
        display: none !important
    }
}

@media screen and (max-width: 768px) {
    .show_pc {
        display: none !important
    }
}

@media screen and (min-width: 451px) {
    .show_sp-nar {
        display: none !important
    }
}

/*# sourceMappingURL=common.css.map */