@charset "utf-8";

/* common
======================================= */
.wrapper {
    width: 900px;
    padding: 10px;
    box-sizing: border-box;
}

a,
a:focus,
a:hover {
    text-decoration: none;
}
button { border: none; }

.pc-only { display: block!important; }
.pc-inline-only { display: inline-block!important; }
.sp-only { display: none!important; }
.sp-inline-only { display: none!important; }


.border-radius-5 { border-radius: 5px; }
.border-radius-10 { border-radius: 10px; }
.border-b-radius-10 { border-radius: 0 0 10px 10px; }
.border-radius-25 { border-radius: 25px; }

.w-5 { width: 5%!important; }
.w-10 { width: 10%!important; }
.w-15 { width: 15%!important; }
.w-20 { width: 20%!important; }
/* .w-25 { width: 25%!important; } */
.w-30 { width: 30%!important; }
.w-35 { width: 35%!important; }
.w-40 { width: 40%!important; }
.w-45 { width: 45%!important; }
/* .w-50 { width: 50%!important; } */
.w-55 { width: 55%!important; }
.w-60 { width: 60%!important; }
.w-65 { width: 65%!important; }
.w-70 { width: 70%!important; }
/* .w-75 { width: 75%!important; } */
.w-80 { width: 80%!important; }
.w-85 { width: 85%!important; }
.w-90 { width: 90%!important; }
.w-95 { width: 95%!important; }

.lh-1 { line-height: 110%; }
.lh-2 { line-height: 120%; }
.lh-3 { line-height: 130%; }
.lh-4 { line-height: 140%; }
.lh-5 { line-height: 150%; }
.lh-6 { line-height: 160%; }
.lh-7 { line-height: 170%; }
.lh-8 { line-height: 180%; }
.lh-9 { line-height: 190%; }
.lh-10 { line-height: 200%; }

.ls-1 { letter-spacing: 0.1rem; }
.ls-2 { letter-spacing: 0.2rem; }
.ls-3 { letter-spacing: 0.3rem; }
.ls-4 { letter-spacing: 0.4rem; }
.ls-5 { letter-spacing: 0.5rem; }
.ls-6 { letter-spacing: 0.6rem; }
.ls-7 { letter-spacing: 0.7rem; }
.ls-8 { letter-spacing: 0.8rem; }
.ls-9 { letter-spacing: 0.9rem; }
.ls-10 { letter-spacing: 1.0rem; }

.mt--3 { margin-top: -1rem; }

.mt-0 { margin-top: 0!important; }
.mt-10 { margin-top: 10px!important; }
.mt-20 { margin-top: 20px!important; }
.mt-30 { margin-top: 30px!important; }
.mt-40 { margin-top: 40px!important; }
.mt-50 { margin-top: 50px!important; }
.mt-60 { margin-top: 60px!important; }
.mt-70 { margin-top: 70px!important; }
.mt-80 { margin-top: 80px!important; }
.mt-90 { margin-top: 90px!important; }
.mt-100 { margin-top: 100px!important; }

.mb-0 { margin-bottom: 0!important; }
.mb-10 { margin-bottom: 10px!important; }
.mb-20 { margin-bottom: 20px!important; }
.mb-30 { margin-bottom: 30px!important; }
.mb-40 { margin-bottom: 40px!important; }
.mb-50 { margin-bottom: 50px!important; }
.mb-60 { margin-bottom: 60px!important; }
.mb-70 { margin-bottom: 70px!important; }
.mb-80 { margin-bottom: 80px!important; }
.mb-90 { margin-bottom: 90px!important; }
.mb-100 { margin-bottom: 100px!important; }
.h0 { font-size: medium!important; }

.w-0 { width: 0; }
.w-10px { width: 10px; }
.w-20px { width: 20px; }
.w-30px { width: 30px; }
.w-40px { width: 40px; }
.w-50px { width: 50px; }
.w-60px { width: 60px; }
.w-70px { width: 70px; }
.w-90px { width: 90px; }
.w-100px { width: 100px; }
.w-150px { width: 150px; }
.w-200px { width: 200px; }
.w-250px { width: 250px; }
.w-300px { width: 300px; }
.w-350px { width: 350px; }
.w-400px { width: 400px; }
.w-450px { width: 450px; }
.w-500px { width: 500px; }

.h-1rem { height: 1rem; }
.h-2rem { height: 2rem; }
.h-3rem { height: 3rem; }
.h-4rem { height: 4rem; }
.h-5rem { height: 5rem; }
.h-6rem { height: 6rem; }
.h-7rem { height: 7rem; }
.h-8rem { height: 8rem; }
.h-9rem { height: 9rem; }
.h-10rem { height: 10rem; }


/* 全体
=========================================== */

body {
    color: #4C4948;
    font-family: "Roboto", "BIZ UDGothic", serif;
    font-weight: 400;
    font-style: normal;
}
.e-font {
    font-family: "Roboto", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-variation-settings: "wdth" 100;
}
a,
a:focus,
a:hover {
    color: #4C4948;
}

.bg-gray { background: #666; }
.bg-lightgray { background: #F5F5F5; }
.bg-pastelgray { background: #AAA; }
.bg-white { background: #fff; }
.bg-black { background: #363636; }
.bg-orange { background: #F5945A; }
.bg-pastelorange { background: #FEF2EB; }
.bg-lightblue { background: #AFCAE7;}
.bg-pastelblue { background: #D8E7FF;}
.bg-paleblue { background: #F3F8FF;}
.bg-ivory { background: #F7F5F2;}
.bg-navy { background: #0A2864;}


.text-white { color: #fff!important; }
.text-red { color: #F04B01!important; }
.text-orange { color: #F59459!important; }
.text-lightblack { color: #4C4948; }
.text-lightgray { color: #939393; }
.text-green { color: #6DB932!important; }

a.text-white { color: #fff; }
a.text-navyblue { color: #003B8E; }
a.text-lightblue { color: #B8E0EC; }
a.text-paleblue { color: #CCD8E8; }
a.text-pastelblue { color: #6D80BB; }
a.text-lightblack { color: #4C4948; }
a.text-green { color: #6DB932; }

.border-lightblack { border: 3px solid #4C4948; }


.form-text {
    border-radius: 5px;
    border: 1px solid #AAAAAA;
}
/* ラジオボタンのカスタマイズ */
.radio-orange {
    appearance: none;
    -webkit-appearance: none;
    width: 1rem;
    height: 1rem;
    border: 2px solid #363636;
    border-radius: 50%;
    outline: none;
    cursor: pointer;
}
.radio-orange:checked {
    border-color: #363636;
    background-color: #fff;
    position: relative;
}
.radio-orange:checked::after {
    content: '';
    width: 0.5rem;
    height: 0.5rem;
    background: #F59459; /* オレンジの中心点 */
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
}

.button-white-small {
    background: #fff;
    border: 2px solid #4C4948;
    border-radius: 8px;
    font-weight: bold;
    color: #4C4948;
    padding: 5px 25px;
}

.line-black {
    background: #363636;
    height: 3px;
    margin: 30px auto 30px;
    border-radius: 2px;
}



/* login ログインページ
=========================================== */
.wrap-bg {
    width: 80%;
    height: auto;
    margin-top: 100px;
    padding: 100px 120px;
}
.logo-margin {
    margin-bottom: 50px;
}
.login-button{
    width: 330px;
}
.step-block {
    width: 320px;
}
.step4-block {
    width: 450px;
}
.step-number {
    background: #F7D090;
    width: 32px;
    height: 32px;
    line-height: 32px;
    border-radius: 50%;
    margin: 0 auto;
}
.step-number-on {
    background: #F5945A;
}
.step-bar {
    content: "";
    width: 60px;
    border-top: 2px solid #F7D090;
    margin-top: -20px;
}
.step-bar-on {
    border-top: 2px solid #F5945A;
}
.rule-box {
    border: 1px solid #AAAAAA;
    height: 160px;
    overflow-y: scroll;
}
.check-orange input[type="checkbox"],
.check-orange input[type="radio"] {
    position: relative;
    content: "";
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 1px solid #AAAAAA;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    margin-right: 5px;
    vertical-align: -4px;
}
.check-orange input[type="checkbox"]:checked:before,
.check-orange input[type="radio"]:checked:before {
    position: absolute;
    content: "";
    width: 20px;
    height: 20px;
    top: -1px;
    left: -1px;
    border: 1px solid #F5945A;
    border-radius: 50%;
    background-color: #F5945A;
}
.check-orange input[type="checkbox"]:checked:after,
.check-orange input[type="radio"]:checked:after {
    display: block;
    position: absolute;
    content: "";
    width: 11px;
    height: 7px;
    border-bottom: 2px solid;
    border-left: 2px solid;
    border-color: #fff;
    transform: rotate(-45deg);
    top: 50%;
    left: 4px;
    margin-top: -5px;
}
#email-form {
    width: 50%;
}
#regist-inner {
    width: 360px;
}
#regist-wide {
    width: 500px;
}
.password-ok {
    position: relative;
    display: inline-block;
    content: "";
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #38CBE4;
    margin-left: 5px;
    vertical-align: -4px;
}
.password-ok:after {
    display: block;
    position: absolute;
    content: "";
    width: 11px;
    height: 7px;
    border-bottom: 2px solid;
    border-left: 2px solid;
    border-color: #fff;
    transform: rotate(-45deg);
    top: 50%;
    left: 4px;
    margin-top: -5px;
}
#eyeIcon,
#eyeIcon2 {
    top: 47% !important;
    right: 10px !important;
}
#eyeIcon.small_form,
#eyeIcon2.small_form {
    top: 54% !important;
}
.file-upload {
    display: inline-block;
    color: #F5945A;
    cursor: pointer;
}
.file-upload:hover {
    opacity: .9;
}
.file-upload input {
    display: none;
}
.balloon,
.balloon-up {
    position: relative;
    display: inline-block;
    background: #fff;
    border-radius: 5px;
    box-shadow: 0px 5px 15px -5px #ababab;
}
.balloon:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 30px;
    border: 10px solid transparent;
    border-top: 10px solid #fff;
}
.balloon-up:before {
    content: "";
    position: absolute;
    top: -20px;
    left: 30px;
    border: 10px solid transparent;
    border-bottom: 10px solid #fff;
}
.up-image {
    width: 45%;
}


/* サロン
=========================================== */
.step-blue .step-number {
    background: #D9E4EF;
}
.step-blue .step-number-on {
    background: #AFCAE7;
}
.step-blue .step-bar {
    border-top: 2px solid #D9E4EF;
}
.step-blue .step-bar-on {
    border-top: 2px solid #AFCAE7;
}

/* 管理画面 mangement-view
=========================================== */
#management-view {
    min-width: 1200px;
}
#management-header {
    z-index: 100;
    height: 90px;
}
#management-content {
    margin-top: 90px;
}
#management-leftheader {
    position: relative;
    padding-left: 55px;
}
#management-leftheader,
#management-leftside {
    width: 20%;
    max-width: 360px;
    min-width: 300px;
}
#management-leftside {
    top: 90px;
    height: calc(100vh - 90px);
    z-index: 50;
}
#management-logo {
    width: 90px;
}
#management-maincontent {
    margin-left: 20%;
    min-height: calc(100vh - 90px);
    position: relative;
}
.image-circle {
    border-radius: 50%;
    width: 45px;
    height: 45px;
    object-fit: cover;
}
.image-circle-big {
    width: 120px;
    height: 120px;
}
#menu-title {
    font-size: 22px;
}
.menu-item {
    font-size: 22px;
}
.menu-item-on {
    background: #D8E7FF;
    border-radius: 10px;
}
.menu-item-on a.text-white {
    color: #4C4948!important;
}
#menu-logout {
    margin-top: 100px;
}
.button-logout {
    border: solid 2px #fff;
    border-radius: 10px;
    padding: 15px;
}
.button-assistqr {
    border: solid 2px #fff;
    border-radius: 10px;
    padding: 9px;
    background: #fff;
    line-height: 120%;
}
#management-breadcrumb,
.management-subtitle {
    width: 80%;
    margin: 40px auto 5px;
}
#management-breadcrumb .arrow-r {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-top: 2px solid #4C4948;
    border-right: 2px solid #4C4948;
    transform: translateY(-50%) rotate(45deg);
    margin: 0 10px;
}
#management-block,
.management-block {
    width: 80%;
    margin: 0 auto;
    padding: 40px 50px;
    border-radius: 15px;
}
.management-inner {
    width: 80%;
    margin: 0 auto;
    padding: 0 50px;
}
.management-wide {
    width: 80%;
    margin: 0 auto;
    padding: 0;
}




/* QA
=========================================== */
.qa-link {
    width: 47.5%;
    border: 2px solid #4C4948;
    border-radius: 10px;
    position: relative;
    font-weight: bold;
    padding: 11px 20px;
    margin-bottom: 20px;
    background: #fff;
}
.qa-link::after {
    content: "";
    position: absolute;
    right: 20px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-top: 2px solid #4C4948;
    border-right: 2px solid #4C4948;
    transform: translateY(-50%) rotate(45deg);
}
.qa-title {
    color: #F5945A;
    border-bottom: 2px solid #F5945A;
}
.qa-item .arrow-b {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-top: 2px solid #4C4948;
    border-right: 2px solid #4C4948;
    transform: translateY(-50%) rotate(135deg);
    margin: 0 10px;
}
.qa-item .qa-item-q[aria-expanded="true"] .arrow-b {
    transform: translateY(-50%) rotate(315deg); 
}
.qa-item .arrow-b {
    transition: transform 0.3s ease-in-out;
}
.qa-more {
    margin: 100px 0 20px 10px;
}
.qa-more a {
    padding-bottom: 3px;
    border-bottom: 1px solid #4C4948;
}
.qa-item .qa-item-q { 
    padding: 23px 29px 23px 29px !important;
}
.qa-item .qa-item-center {
    padding-left: 29px !important;
    padding-right: 29px !important;
}
.qa-item .qa-item-a {
    padding-left: 29px !important;
    padding-right: 29px !important;
}

@media (max-width: 767px) {
    .qa-item .qa-item-q {
        padding: 14px 5px 14px 16px !important;
    }
    .qa-item .qa-item-center {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
    .qa-item .qa-item-a {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}



.secretariat-news,
.secretariat-review {
    padding-left: 0;
}
.secretariat-news li,
.secretariat-review li {
    padding: 15px 15px;
    border-bottom: 1px solid #f3f3f3;
}
.secretariat-review li:first-child {
    border-top: 1px solid #f3f3f3;
}
.secretariat-news.rental_copy li {
    padding: 10px 15px;
}
.news-day {
    display: inline-block;
    width: 180px;
    font-weight: bold;
}
.amount-sales {
    width: 18%;
    min-width: 150px;
    margin-top: 25px;
    margin-bottom: -25px;
}
.amount-sales .price {
    font-size: 32px;
}
.amount-kin {
    width: 18%;
    min-width: 150px;
}
.amount-input {
    width: 100%;
    border: 1px solid #ababab;
}
.amout-en {
    right: 0.8rem;
}
.amount-request {
    width: 150px;
    margin-top: 22px;
    padding: 7px 5px;
    border: 1px solid #4C4948;
}
.amaount-note {
    margin-top: 5px;
    margin-left: 23%;
    font-size: 12px;
}
.button-account {
    color: #fff;
    display: block;
    border-radius: 5px;
    background: #9FBAD8;
    padding: 8px 5px;
    width: 35%;
    margin: 22px 0 0;
    text-align: center;
}
.button-account img {
    width: 14px;
    margin: 0 0 6px 6px;
}

.modal-content {
    border: 2px solid #4C4948;
    border-radius: 30px;
    background: #F5F5F5;
    text-align: center;
    padding: 60px 60px 40px;
    width: 500px;
    box-sizing: border-box;
}
.btn-edit img,
.btn-delete img {
    width: 0.9rem;
    vertical-align: -2px;
}

.form-credit {
    border: 1px solid #4C4948;
    border-radius: 10px;
}
.form-credit input[type="text"] {
    border: none;
    background: none;
    padding: 15px 5px;
}
.form-credit input[type="text"]:focus {
    outline: none;
}
.border-lightgray {
    background: #f3f3f3;
    height: 2px;
}

/* カレンダー
=========================================== */
.calendar-month {
    width: 360px;
    margin: 0 auto 15px;
    font-size: 28px;
    text-align: center;
    position: relative;
}
.calendar-month span {
    font-size: 22px;
}
.calendar-month .calendar-month-left img,
.calendar-month .calendar-month-right img   {
    width: auto;
    height: 100%;
    position: absolute;
    top: 0;
}
.calendar-month .calendar-month-left img  {
    left: 0;
}
.calendar-month .calendar-month-right img  {
    right: 0;
}
.calendar-table {
    width: 100%;
    background: #fff;
    border-collapse: collapse;
}
.calendar-table th {
    text-align: center;
    width: calc(100% / 7);
}
.calendar-table th,
.calendar-table td {
    border: 1px solid #AAA;
    padding: 10px 5px;
    box-sizing: border-box;
}

.calendar-table th:first-child,
.calendar-table td:first-child {
    color: #F04B01;
}
.calendar-table th:last-child,
.calendar-table td:last-child {
    color: #527AFF;
}
.calendar-table .calendar-day {
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
    line-height: 1.5rem;
    border-radius: 50%;
    margin-bottom: 3px;
}
.calendar-table .calendar-day.today {
    background: #363636;
    color: #fff;
    text-align: center;
}
.calendar-mirror,
.calendar-assist {
    background: #76AFFA;
    border-radius: 3px;
    padding: 2px 6px;
    font-size: 0.8rem;
    font-weight: bold;
    margin-bottom: 5px;
    display: block;
}
.calendar-assist {
    background: #F66E02;
}
.calendar-mirror.reserved {
    background: #2c6bbe;
    color: #fff !important;
}
.calendar-assist {
    background: #F66E02;
}
.calendar-assist.reserved {
    background: #c35600;
    color: #fff;
}
.calendar-black {
    background: #fff;
    color: #363636;
    padding: 2px;
    margin-right: 5px;
}
.calendar-table th:first-child,
.calendar-table td:first-child {
    color: #F04B01;
}
.calendar-table th:last-child,
.calendar-table td:last-child {
    color: #527AFF;
}
.calendar-table td:first-child .calendar-mirror,
.calendar-table td:first-child .calendar-assist,
.calendar-table td:last-child .calendar-mirror,
.calendar-table td:last-child .calendar-assist {
    color: #4C4948;
}
.schedule-assist,
.schedule-mirror {
    background: #76AFFA;;
    width: 85%;
    margin: 0 auto 10px;
    border-radius: 10px;
    padding: 15px 15px;
    font-size: 18px;
}
.schedule-assist {
    background: #F66E02;
}
.schedule-black {
    background: #fff;
    color: #363636;
    padding: 2px;
    margin-right: 5px;
}





.calendar-table .calendar-select-number .form-select {
    background-color: #F5F5F5;
}
.calendar-table .calendar-select-number-on .form-select {
    background-color: #FDE6CE;
}
ul.salon-form {
    padding-left: 0;
}
.copy_button {
    padding: 11px 20px;
}

#management-tab-blue {
    position: absolute;
    bottom: 0;
    left: 20%;
    width: 250px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    background: #76AFFA;
    color: #fff;
    padding: 5px;
    border-radius: 10px 10px 0 0;
}
#management-tab-blue.tab-orange {
    background: #F66E02;
}

@media screen and (max-width:1500px) {
    #management-tab-blue {
        left: 300px;
    }
}

.li-underbar li {
    border-bottom: 1px solid #e0e0e0;
}
.li-underbar li:last-child {
    border-bottom: none;
}

.calendar-confirm .calendar-confirm-label {
    position: absolute;
}
.calendar-confirm td {
    position: relative;
    height: 70px;
    background: #F5F5F5;
}

.calendar-confirm td.calendar-confirm-select {
    background: #fff;
}

.calendar-confirm .calendar-select-number {
    position: absolute;
    bottom: 5px;
    right: 5px;
    width: 1.5rem;
    height: 1.5rem;
    text-align: center;
    color: #aaa;
}
.calendar-confirm .calendar-select-number {
    line-height: 1.5rem;
}

.calendar-confirm .calendar-confirm-select .calendar-select-number {
    background: #76AFFA;
    border-radius: 50%;
    color: #fff;
}
.a-underline {
    text-decoration: underline;
}

.past-recruitment-list .news-day {
    display: inline-block;
    font-weight: normal;
}
.past-recruitment-list .news-title {
    display: inline-block;
}


.salon-slide01 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.salon-slide01 .salon-slide-item {
    width: 32%;
    margin-bottom: 15px;
}
.salon-slide01::after {
    content: "";
    display: block;
    width: 32%;
}
.salon-slide01 .salon-slide-item img {
    width: 100%;
}
.salon-slide01 .slick-dots li {
    margin: 0 0;
}
.salon-slide01 .slick-dots li button:before {
    font-size: 10px;
    line-height: 30px;
    width: 30px;
    height: 30px;
}
.salon-slide01 .slick-dots li.slick-active button:before {
    color: #F79303;
}

a.a-strong {
    color: #F04B01!important;
    text-decoration: underline;
}
.select-treatment {
    background: #F5F5F5;
    border-radius: 5px;
    height: 80px;
    width: 100%;
    padding: 3%;
    box-sizing: border-box;
}
.review-day {
    display: inline-block;
    width: 180px;
}
.review-name {
    display: inline-block;
    width: 110px;
}
.review-title {
    font-weight: bold;
}

.member-image {
    width: 15%;
}
.member-info {
    width: 55%;
}
.member-sns {
    width: 25%;
}
.member-sns img {
    width: 20%;
    margin: 10px 0 10px 5%;
}

.management-wide .salon-slide-staff {
    width: 80%;
}
.salon-slide-staff .slick-track {
    display: flex;
    gap: 10px;
}
.salon-slide-staff.slide-not-enough .slick-track {
    width: auto!important;
}
.salon-slide-staff .slick-slide {
    height: auto!important;
}
.salon-slide-staff .slide-staff {
    background: #fff;
    border-radius: 10px;
    padding: 20px 15px;
    position: relative;
    display: flex !important;
    flex-direction: column;
    width: calc((100% - 60px) / 5) !important;
    margin: 0 !important;
}
.salon-slide-staff .slide-staff-image {
    width: 45%;
    display: block;
    margin: 0 auto 10px;
}
.salon-slide-staff .slide-staff-name {
    text-align: center;
}
.salon-slide-staff .slide-staff-star {
    width: 60%;
    margin: 3px auto 1px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.salon-slide-staff .slide-staff-star img {
    width: 17%;
}
.salon-slide-staff .slide-staff-rank {
    height: 20px;
    margin: 5px auto 7px;
}
.salon-slide-staff .slide-staff-rank img {
    height: 100%;
    width: auto;
    margin: 0 auto 0;
}
.slide-staff-skill {
    width: 96%;
    margin: 5px auto;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 5px 3%;
    flex: 1;
}
.slide-staff-skill img {
    width: 48.5%;
}
.slide-staff-check {
    position: absolute;
    width: 20%;
    top: 14px;
    right: 5%;
}
.slide-staff-check img {
    width: 100%;
}

.salon-slide-staff .slick-prev {
    left: -3px;
    z-index: 1;
}

.salon-slide-staff .slick-next {
    right: -3px;
    z-index: 1;
}
.salon-slide-staff .slick-prev:before,
.salon-slide-staff .slick-next:before {
    font-size: 30px;
    color: #373737;
    opacity: 1;
}
.notice-count {
    background: #F66E02;
    color: #fff;
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    text-align: center;
    line-height: 1.5rem;
}
.notice-talk {
    display: inline-block;
    background: #F04B01;
    color: #fff;
    width: 1.8rem;
    height: 1.8rem;
    line-height: 1.8rem;
    border-radius: 50%;
    text-align: center;
    font-size: 80%;
    margin-left: 15px;
}

.day-select {
    padding-left: 12%;
}
.day-calendar {
    left: 4%;
    padding-bottom: 3px;
}

/* Datepickerのスタイルカスタマイズ */
.ui-datepicker {
    background: #fff;
    border: 1px solid #ddd;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    width: 300px;
    padding: 10px;
}
.ui-datepicker .ui-datepicker-header {
    background: none;
    border: none;
    padding: 5px;
}
.ui-datepicker .ui-datepicker-title {
    color: #333;
}
.ui-datepicker th {
    background: #f5f5f5;
    padding: 7px;
}
.ui-datepicker td {
    padding: 3px;
}
.ui-datepicker td span, .ui-datepicker td a {
    text-align: center;
    padding: 5px;
}

.ui-datepicker-week-end:first-child a,
.ui-datepicker-week-end:first-child span {
    color: #F04B01;
}
.ui-datepicker-week-end:last-child a,
.ui-datepicker-week-end:last-child span {
    color: #527AFF;
}


.management-block .notice-talk {
    display: block;
    background: #F59459;
    margin: 10px auto 0;
}
.message-block {
    position: relative;
    display: flex;
    flex-direction: column;
    height: calc(100vh - 220px);
    min-height: 500px;
}
.message-box {
    overflow-y: auto;
    padding-bottom: 80px;
    display: flex;
    flex-direction: column-reverse;
}
.message-send-block {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    padding: 10px 50px;
}
.message-send-block form {
    width: 100%;
}
.message-send-block textarea {
    flex: 1;
    height: 50px;
    margin-right: 1%;
    border: none;
    border-radius: 3px;
    background: #F5F5F5;
    border: #F5F5F5 1px solid;
    box-sizing: border-box;
    padding: 12px 1%;
}
.message-send-block textarea::placeholder {
    color: #AAAAAA;
}
.message-send-block textarea:hover,
.message-send-block textarea:focus {
    border: #AAAAAA 1px solid;
    outline: #AAAAAA 1px solid;
}
.button-plus,
.button-clip {
    margin-right: 1%;
    border-radius: 3px;
    padding: 0;
}
.button-plus img,
.button-clip img {
    width: 50px;
    height: 50px;
}
.button-send {
    background: #363636;
    color: #fff;
    width: 20%;
    border-radius: 3px;
    position: relative;
    padding-right: 25px;
}
.button-send:after {
    position: absolute;
    right: 15px;
    content: "";
    background: url(../../images/salon/icon_send.png)no-repeat;
    background-size: contain;
    width: 18px;
    height: 18px;
    top: 50%;
    transform: translateY(-50%);
}
.message-day {
    padding: 5px 30px;
    background: #F5F5F5;
    border-radius: 5px;
    color: #666666;
    margin: 30px auto;
    display: table;
    position: relative;
    text-align: center;
}

.message-me {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    margin-bottom: 30px;
    gap: 10px;
}
.message-time {
    font-size: 12px;
    color: #666;
    text-align: center;
    white-space: nowrap;
    align-self: flex-end;
    margin-bottom: 5px;
    order: 1;
}

.message-text {
    max-width: 70%;
    order: 2;
}
.message-text-box {
    background: rgba(56, 203, 228, .2);
    color: #4C4948;
    padding: 16px 35px;
    border-radius: 10px;
    font-family: "BIZ UDGothic", serif;
    position: relative;
    margin-right: 15px;
    min-height: 44px;
}
.message-text-box:after {
    content: '';
    position: absolute;
    right: -10px;
    top: 10px;
    width: 0;
    height: 0;
    border-left: 10px solid rgba(56, 203, 228, .2);
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
}
.message-acount-icon {
    width: 40px;
    height: 40px;
    order: 3;
    align-self: flex-start;
    border-radius: 50%;
    overflow: hidden;
}
.message-acount-icon img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}
.message-you {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    margin-bottom: 20px;
    gap: 10px;
}
.message-you .message-acount-icon {
    order: 1;
    margin-top: 20px;
}
.message-you .message-text {
    order: 2;
}
.message-you .message-text .message-text-box {
    background: #EDEDED;
    margin-right: 0;
    margin-left: 15px;
}
.message-you .message-text .massage-text-name {
    margin-left: 15px;
}
.message-you .message-text-box:after {
    left: -10px;
    right: auto;
    border-left: none;
    border-right: 10px solid #EDEDED;
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
}
.message-you .message-time {
    order: 3;
}


.message-item {
    background-color: #42ce7842;
    border-radius: 25px;
    padding: 22px 130px 22px 45px;
    position: relative;
    margin-bottom: 10px;
}

.message-item.unread {
    background-color: #d8e7ff7c;
}

.message-item__img {
    min-width: 77px;
    min-height: 77px;
    max-width: 77px;
    max-height: 77px;
    margin-right: 21px;
    border-radius: 50%;
    overflow: hidden;
}

.message-item__img img {
    max-width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
}

.message-item__content {
    max-width: 100%;
}

.message-item__history {
    position: absolute;
    top: 25px;
    right: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

.message-item__count {
    width: 30px;
    height: 30px;
    background-color: #4C4948;
    color: white;
    border-radius: 50%;
}

.read-status {
    display: none;
}

@media (max-width: 1024px) {
    .message-item {
        /*
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        */
        padding: 20px 30px;
    }
    .message-item__history {
        right: 30px;
    }
    .read-status {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        font-size: 12px;
        padding-top: 30px;
    }
    .read-status a {
        margin-right: 20px;
        font-weight: bold;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
            -ms-flex-direction: row;
                flex-direction: row;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
    }
    .read-status .unread {
        width: 15px;
        height: 15px;
        line-height: 1;
        background-color: #4C4948;
        border-radius: 50%;
        margin-left: 5px;
        font-size: 10px;
        color: white;
        font-weight: 500;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
    }    
}

@media (max-width: 767px) {
    .message-item {
        padding: 15px;
    }
    .message-item:nth-child(3) {
        margin-top: 15px;
    }
    .message-item__history {
        right: 15px;
        -webkit-box-align: end;
            -ms-flex-align: end;
                align-items: flex-end;
    }
    .message-item__count {
        margin-top: 5px;
        width: 25px;
        height: 25px;
    }
}






.assist_comingsoon {
    position: absolute;
    left: 2%;
    top: 2%;
    width: 96%;
    height: 95%;
    margin: auto;
    background: #ff6f00c4;
    border-radius: 12px;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 36px;
}
.salon_footer_menu {
}


@media (max-width: 767px) {
    .sp_footer_spacer {
        padding-bottom: calc(202 / 267 * 50vw + 20px - 56px);
    }
    .assist_comingsoon {
        font-size: 22px;
    }
    .mirror_left {
        position: fixed !important;
        width: 50% !important;
        bottom: 54px;
        left: -8px;
        display: block;
        margin-bottom: 0 !important;
        z-index: 9;
    }
    .assist_right {
        position: fixed !important;
        width: 50% !important;
        bottom: 54px;
        right: -8px;
        display: block;
        margin-bottom: 0 !important;
        z-index: 9;
    }
    .assist_right img {
        width: 100%;
        height: auto;
    }
}


.button-shop-login {
    border: solid 2px #4C4948;
    border-radius: 10px;
    padding: 15px;
}

.qa-header {
    width: 80%;
    margin: 0 auto;
}
@media screen and (max-width: 768px) {
    .qa-header {
        width: 94%;
        padding: 40px 10px;
    }
}

/* 20250704 追加
======================================= */

.w-23 {
    width: 23%;
}
.data-block .day-select {
    padding-left: 20%;
}
.data-block-title {
    color: #F5945A;
    border-bottom: 2px solid #AAA;
}

/* コンテキストメニューのスタイル */
.chat-context-menu {
    position: fixed;
    background: white;
    border: 1px solid #ccc;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 9999;
    min-width: 120px;
    padding: 4px 0;
    display: none;
}

.chat-context-menu-item {
    padding: 8px 16px;
    cursor: pointer;
    font-size: 14px;
    color: #333;
    transition: background-color 0.2s;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    display: flex;
    align-items: center;
}

.chat-context-menu-item:hover {
    background-color: #f5f5f5;
}

.chat-context-menu-item.delete {
    color: #dc3545;
}

.chat-context-menu-item.delete:hover {
    background-color: #fff5f5;
}

.amount-box-small {
    width: 80%;
    margin: 0 auto;
    font-size: 12px;
}

#reservedModal.modal {
    --bs-modal-width: 600px;
}
#reservedModal .modal-content {
    width: 600px;
    padding: 60px 20px 40px;
}
.pc_reserved_cancel_btn_box {
    display: block;
}
.sp_reserved_cancel_btn_box {
    display: none;
}

/*
@media (max-width: 767px) {
    #reservedModal .modal-content {
        width: 90%;
        padding: 20px;
    }
}*/