#calender {
    background-color: #fff;
    color: #000;
    box-sizing: border-box;
    font-family: sans-serif;
    font-size: clamp(10px, 4.7vw, 45px);
    /* max-width: 800px; */
    aspect-ratio: 1 / 0.58;

    /* border: 1px solid #888; */

    position: relative;
}
#calender.is-larger {
    aspect-ratio: 1 / 0.62;
}
#calender button {
    background-color: #fff;
    border-style: none;
    padding: 0;
    cursor: pointer;
}

#calender .calender__container {
    width: 100%;
    aspect-ratio: 32 / 16;
    /* margin-bottom: 8%; */
    border: 1px solid #ccc;

    position: relative;

    transition: all 0.1s ease-out;
}
#calender .calender__container.is-larger {
    aspect-ratio: 32 / 17;
}

#calender .calender__nav {
    position: absolute;
    z-index: 2;
    margin-top: 4.17%;
    left: 50%;
    transform: translateX(-50%);

    width: 100%;
    aspect-ratio: 16.46 / 1;
    /* padding: 0 3%; */

    display: flex;
    justify-content: space-between;
    align-items: center;
}

#calender .calender__yearmonthflex {
    position: absolute;
    z-index: 1;
    margin-top: 4.17%;
    left: 50%;
    transform: translateX(-50%);

    width: 100%;
    aspect-ratio: 16.46 / 1;

    display: flex;
    justify-content: space-between;
    align-items: center;
}

#calender .calender__yearmonthleft, #calender .calender__yearmonthright{
    width: 50%;
    height: 100%;

    font-size: 0.48em;
    text-align: center;

    display: flex;
    justify-content: center;
    align-items: center;
}

#calender__toprevmonth,
#calender__tonextmonth,
#calender__showprev,
#calender__shownext {
    font-size: 0.7em;
}
#calender__toprevmonth,
#calender__showprev {
    margin-left:5% ;
}

#calender__tonextmonth,
#calender__shownext {
    margin-right: 5%;
}


#calender .calender__weekareaflex {
    position: absolute;
    margin-top: 13.37%;
    left: 50%;
    transform: translateX(-50%);

    width: 100%;
    aspect-ratio: 41.82 / 1;

    display: flex;
    justify-content: space-around;
}
#calender .calender__weekarea {
    width: 37.66%;

    display: flex;
    justify-content: space-around;
    align-items: center;
}

#calender .calender__weekarea p {
    width: 100%;

    font-size: 0.24em;
    text-align: center;
}


#calender .calender__dategridcontainer {
    position: absolute;
    margin-top: 17%;
    left: 50%;
    transform: translateX(-50%);

    width: 100%;
    height: auto;

    display: flex;
    justify-content: space-around;
    align-items: flex-start;
}
#calender .calender__dategridcontainer.is-noevents {
    pointer-events: none;
}

#calender .calender__dategrid {
    width: 37.66%;
    height: auto;

    display: grid;
    gap: 0;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}
#calender .calender__dategrid > * {
    min-width: 0;
}
#calender .calender__dategrid.is-hidden {
    display: none;
}

#calender .calender__dategriditem {
    position: relative;

    width: 100%;
    aspect-ratio: 1 / 1.1;

    font-size: 0.48em;
    text-align: center;

    box-sizing: border-box;
    margin: 0;
    border-radius: 7%;

    transition: all 0.1s ease-in-out;
}
#calender .calender__dategriditem[value=""] {
    pointer-events: none;
}

/* 土曜 日曜 休日 過去の日付 オーバーレンジ 予約不可 操作日 選択された日付 TEL の順で上書き */
#calender .is-saturday {
    color: rgb(80, 175, 230);
}
#calender .is-sunday {
    color: red;
}
#calender .is-holiday {
    color: red;
}
#calender .is-previous {
    color: #777;
    pointer-events: none;
}
#calender .is-overrange {
    border-radius: 0;
    border-color: #d1d1d8;
    background-color: #d1d1d8;
    pointer-events: none;
}
#calender .is-disable {
    border-radius: 0;
    border-color: #d1d1d8;
    background-color: #d1d1d8;
    pointer-events: none;
}
#calender .is-today {
    border-color: #fff;
    background-color: #fff;
    text-decoration: underline;
    pointer-events: none;
}
#calender .is-selected{
    background-color: #fff;
}
#calender .is-selected::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    width: 80%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background-color: rgba(142, 134, 220, 0.3);
}
#calender .is-TEL {
    border-radius: 0;
    border-color: #d1d1d8;
    background-color: #d1d1d8;
    pointer-events: none;
    z-index: 2;
}
#calender .is-TEL::after {
    content: 'TEL';
    font-size: 0.5em;
    position: absolute;
    top: 70%;
    left: 50%;
    transform: translateX(-50%);
}

#calender .calender__resetmodal {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;

    width: 100%;
    height: 100%;

    background-color: #FBF5E5D6;
}
#calender .calender__resetmodal.is-displaynone {
    display: none;
}
#calender #calender__resetbtn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    width: 40%;
    aspect-ratio: 4.5 / 1;

    border-radius: 8px;

    color: #fff;
    background-color: rgb(7, 208, 255);
    font-size: 0.6em;
    font-family: serif;
    font-weight: 700;
    text-align: center;
}

#calender .calender__selecteddateflex {
    /* position: absolute; */
    /* bottom: 0; */
    /* left: 0; */

    font-size: 0.45em;
    font-family: serif;

    width: 100%;
    aspect-ratio: 12 / 1;

    display: flex;
    justify-content: space-around;
}
#calender .calender__checkindate, #calender .calender__checkoutdate{
    width: 50%;

    padding: 0 2%;

    display: flex;
    justify-content: space-between;
    align-items: center;
}
#calender .calender__selecteddateflex p {
    /* font-size: 0.8em; */
    font-size: 1.5rem;
}
#calender .calender__checkininput--display, #calender .calender__checkoutinput--display {
    width: 35%;
    border-style: none;
    /* font-size: 0.8em; */
    font-size: 1.3rem;
    text-align: center;

    height: 28px;
    pointer-events: none;
}

#calender__shownext,
#calender__showprev {
  display: none;
}

/* hoverは、hover可能な端末のみ */
@media (hover: hover) and (pointer: fine) {
    #calender #calender__toprevmonth:hover, #calender #calender__tonextmonth:hover{
        color: #777;
    }

    #calender .calender__dategriditem:hover {
        color: #fff;
        background-color: #333;
    }

    #calender #calender__resetbtn:hover {
        color: rgb(7, 208, 255);
        background-color: #fff;
        border: solid 2px rgb(7, 208, 255);
    }
}

@media screen and (max-width: 1520px) {
    #calender .calender__selecteddateflex p {
        font-size: 1.5vw;
    }
    #calender .calender__checkininput--display, #calender .calender__checkoutinput--display {
        font-size: 1.3vw;
    }
}
@media screen and (max-width: 1200px) {
    #calender .calender__selecteddateflex p {
        font-size: 2vw;
    }
    #calender .calender__checkininput--display, #calender .calender__checkoutinput--display {
        font-size: 1.8vw;
    }
}
@media screen and (max-width: 700px) {
    #calender{
        font-size: clamp(10px, 6vw, 45px);
    }

    #calender #calender__resetbtn {
        width: 50%;
    }

    #calender .calender__selecteddateflex p {
        font-size: 0.9rem;
    }
    #calender .calender__checkininput--display, #calender .calender__checkoutinput--display {
        font-size: 1rem;
    }

    #calender__shownext,
    #calender__showprev {
      display: block;
    }

    .sp-hidden {
      display: none !important;
    }

    #calender .calender__container {
      aspect-ratio: 1 / 1 !important;
    }

    #calender .calender__container.is-larger {
      aspect-ratio: 35 / 40 !important;
    }

    #calender .calender__weekarea {
      width: 100%;
    }
    #calender .calender__dategrid {
      width: 100%;
    }

    #calender .calender__yearmonthleft,
    #calender .calender__yearmonthright {
      width: 100%;
  }
}
@media screen and (max-width: 600px) {
    #calender {
        aspect-ratio: 1 / 0.65;
    }
    #calender .calender__selecteddateflex {
        height: 60px;
    }
    #calender .calender__checkindate, #calender .calender__checkoutdate {
        flex-direction: column;
        justify-content: flex-start;

    }
    #calender .calender__selecteddateflex p {
        width: 100%;
        text-align: left;
        padding: 5px 0;
        margin: 0;
    }
    #calender .calender__checkininput--display, #calender .calender__checkoutinput--display {
        width: 100%;
        text-align: right;
    }
}
@media screen and (max-width: 500px) {
    #calender {
        font-size: clamp(10px, 7vw, 45px);
    }
}
/* 701px 以上：sp-hidden を無効化 */
@media screen and (min-width: 701px) {
  .sp-hidden {
    display: initial !important;
  }
  #calender__tonextmonth {
    display: block !important;
  }
}