/* main共通
====================================================*/
.box_note_wrap {
    width: 100%;
    max-width: 840px;
    margin: 0 auto;
}
.box_note {
    background: #fffff9;
    text-align: left;
    width: 100%;
    margin: 3rem 0;
    box-shadow: 4px 4px 8px rgb(228, 228, 228);
}
@media screen and (max-width: 840px) {
    .box_note {
        margin: 1rem 0;
    }
}
.box_note_ttl {
    position: relative;
    display: inline-block;
    padding: 1em 2em;
    background: #009b97;
    color: #fff;
    font-weight: bold;
    top: 20px;
    left: -10px;
}
.box_note_ttl::before {
    position: absolute;
    content: "";
    top: 100%;
    left: 0;
    border: none;
    border-bottom: solid 10px transparent;
    border-right: solid 10px rgb(187, 187, 187);
    /* border-right: solid 10px rgb(149, 158, 155); */
}
.box_note_txt {
    margin: 0 1rem;
    border-left: 10px dotted rgb(237, 237, 237);
    /* border-left: 10px dotted rgb(0, 0, 0, 0.1); */
}
.box_note_txt-in {
    background-color: #fffff9;
    /* background-color: #eaf5f9; */
    background-image: linear-gradient(
            90deg,
            rgba(255, 246, 230, 0) 0%,
            rgba(255, 246, 230, 0) 50%,
            #fffff9 0%,
            #fffff9 100% /* #eaf5f9 0%,
            #eaf5f9 100% */
        ),
        linear-gradient(
            180deg,
            rgba(237, 119, 128, 0) 0%,
            rgba(237, 119, 128, 0) 95%,
            #c9a07e 100% /* #27acd9 100% */
        );
    background-size: 8px 100%, 100% 1.9rem;
    line-height: 1.9rem;
    margin: 0 1rem;
    padding: 2rem 0.5rem 1.5rem;
}
.box_note_txt-in em {
    background: linear-gradient(transparent 60%, #ffadad 60%);
    font-weight: bold;
    font-size: clamp(1rem, 0.9091rem + 0.4545vw, 1.25rem);
}
.box_note_txt-in-float {
    width: 30%;
    float: left;
    margin-right: 1rem;
}
.box_note_txt-in-float2 {
    width: 50%;
    float: left;
    margin-right: 1rem;
}
.box_note_txt-in-floatr {
    width: 30%;
    float: right;
    margin-right: 1rem;
}
.box_note_txt-in-floatr2 {
    width: 50%;
    float: right;
    margin-right: 1rem;
}
.box_note_txt-in::after {
    /* floatを指定した親要素に対してclearfix */
    content: "";
    clear: both;
    display: block;
}
.box_note_txt-in-float img {
    width: 100%;
}
.box_note_txt-in-float2 img {
    width: 100%;
}
.box_note_txt-in-floatr img {
    width: 100%;
}
.box_note_txt-in-floatr2 img {
    width: 100%;
}
.box_note_txt-in-link {
    color: #276bd9;
}
.box_note_watermark {
    background-size: 100px;
    background-repeat: no-repeat;
    background-position: 100% 100%;
}

.box_note_txt-in-flex {
    width: calc(50% - 2rem);
}
@media screen and (max-width: 500px) {
    .box_note_txt-in-flex {
        width: 100%;
    }
}

.box_note-envmanual {
    width: 30%;
    display: block;
    margin: auto;
    padding: 1rem 0;
}
.box_note-envmanual:hover {
    opacity: 0.7;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
@media screen and (max-width: 500px) {
    .box_note-envmanual {
        width: 60%;
    }
}

/* 特定商取引法に基づく表記
====================================================*/
.tokushoho {
    max-width: 1000px;
    margin: 0 auto;
    padding: 50px 10px;
}
@media screen and (max-width: 500px) {
    .tokushoho {
        padding: 20px 10px;
    }
}
.tokushoho h1 {
    text-align: left;
    font-weight: bold;
    margin-bottom: 0.5em;
    border-left: 4px solid #009b97;
    padding-left: 0.5em;
}
.tokushoho table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}
.tokushoho table th {
    width: 30%;
    background: #e6fffe;
    border: 1px solid #ccc;
    box-sizing: border-box;
    padding: 15px;
    vertical-align: middle;
    font-weight: bold;
    text-align: left;
}
.tokushoho table td {
    background: #fff;
    border: 1px solid #ccc;
    box-sizing: border-box;
    padding: 15px;
    vertical-align: top;
    text-align: left;
}
@media all and (max-width: 767px) {
    .tokushoho table th,
    .tokushoho table td {
        display: block;
        width: 100%;
        border-bottom: none;
    }
    .tokushoho table tr:last-child td:last-child {
        border-bottom: 1px solid #ccc;
    }
}

/* プライバシーポリシー
====================================================*/
.privacy {
    max-width: 1000px;
    margin: 0 auto;
    padding: 50px 10px;
}
@media screen and (max-width: 500px) {
    .privacy {
        padding: 20px 10px;
    }
}
.privacy h1 {
    text-align: left;
    font-weight: bold;
    margin-bottom: 0.5em;
    border-left: 4px solid #009b97;
    padding-left: 0.5em;
}
.privacy-wrap {
    text-align: left;
}
.privacy-wrap h4 {
    margin-top: 2rem;
    margin-bottom: 0.5em;
    border-left: 4px solid #009b97;
    padding-left: 0.5em;
}
.privacy-close {
    margin-top: 1rem;
    text-align: right;
}

/* 運営事務局
====================================================*/
.about-office {
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px 10px 50px;
}
.about-office h2 img {
    width: 80%;
}
.about-office h3 {
    padding: 0.4em 2em;
    color: black;
    font-weight: 900;
    background: #dbfffe;
    text-align: center;
}
.about-office h4 img {
    width: 90%;
}
.about-office .balloon {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    padding: 7px 10px;
    width: 90%;
    color: #555;
    font-size: 16px;
    background: #009b97;
    border-radius: 15px;
}

.about-office .balloon:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #009b97;
}

.about-office .balloon p {
    margin: 0;
    padding: 0;
    color: #fff;
}
.about-office p {
    text-align: center;
    margin: clamp(0.5rem, 0.3182rem + 0.9091vw, 1rem) auto;
    font-size: clamp(0.875rem, 0.5221rem + 1.7647vw, 1.625rem);
    color: black;
    font-weight: bold;
    line-height: initial;
}
.about-office p a {
    text-align: center;
    margin: 1rem auto;
    font-size: clamp(0.875rem, 0.5221rem + 1.7647vw, 1.625rem);
    color: #009b97;
    font-weight: bold;
    line-height: initial;
}
.about-office p img {
    width: 50%;
}
.about-office .office-box {
    border: 9px solid #009b97;
    padding: 3rem;
    width: 70%;
    margin: 0 auto;
}
.about-office .office-box p {
    font-size: clamp(0.875rem, 0.8295rem + 0.2273vw, 1rem);
}
.about-office .office-box p img {
    width: 90%;
}
@media all and (max-width: 767px) {
    .about-office .office-box {
        border: 5px solid #009b97;
        padding: 1rem;
        width: 90%;
        margin: 0 auto;
    }
}