@charset "UTF-8";

:root {
    --primary: #6D95D3;
    --primary-light: #EDF1F9;
    --primary-dark: #4D6C9C;
    --secondary: #A68EAF;
    --light-blue: #B1C3E6;
    --danger: #E54646;
    --gray: #ddd;
    --gray-2: #ccc;
    --gray-3: #555;
    --light-gray:#F7F7F7;
    --light-gray-2:#EFEFEF;
    --light-gray-3:#E4E4E4;
    --dark:#333;
    --white: #fff;
    --pink: #E54662;
    --pink-2: #E87080;
    --pink-3: #EB939D;
    --light-pink: #F6D7DA;
}

html, body {
    margin: 0;
}

html {
    font-size: 62.5%;
    scroll-behavior: smooth;
    scroll-padding-top: 8rem;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-size: 1.6rem;
    font-weight: 400;
    background-color: var(--light-gray);
}

ol{
    padding-left: 1.5em;
}

img{
    max-width: 100%;
}

a:hover,
.card a:hover{
    opacity: 0.5;
}

.list-disc li{
    padding-left: 1em;
    text-indent: -1em;
}

.list-disc li::before{
    content: "・";
}

.alert-danger{
    color: var(--danger);
}

.text-primary-dark{
    color: var(--primary-dark);
}

.text-gray{
    color: var(--gray);
}

.text-pink{
    color: var(--pink);
}

.text-decoration-underline{
    text-decoration: underline!important;
}

.text-indent{
    padding-left: 1em;
    text-indent: -1em;
}

.text-medium{
    font-weight: 500;
}

.bg-primary-light{
    background-color: var(--primary-light);
}

.bg-light-gray{
    background-color: var(--light-gray)!important;
}

.bg-light-pink{
    background-color: var(--light-pink)!important;
}

.bg-danger{
    background-color: var(--danger);
}

.heading-h1{
    margin: 3rem 0 2rem;
    padding: 0;
}

.heading-h1 span{
    display: inline-block;
    padding: 0 0 0 4rem;
    line-height: 1.3;
    color: var(--primary-dark);
    font-size: 2.8rem;
    font-weight: 500;
}

.heading-h1 span::after{
    content: "";
    position: absolute;
    top: 52%;
    bottom: auto;
    left: 0;
    transform: translateY(-50%);
    width: 3rem;
    height: 1.4rem;
    background: linear-gradient(90deg, var(--pink-3) 0%, var(--light-blue) 100%);
    border-radius: 1rem;
}

.heading-second{
    margin: 2rem 0 1.2rem;
    color: var(--primary-dark);
    font-size: 2rem;
    font-weight: 500;
}

h3{
    font-size: 1.6rem;
}

.heading-bar {
    position: relative;
    padding-left: 1.5rem;
    border: none;
}

.heading-bar:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    display: block;
    width: 0.5rem;
    height: calc(100% - 0.8rem);
    background-color: var(--primary);
    border-radius: 0.5rem;
}

.heading-dashed{
    margin: 2rem 0 1.5rem;
    padding-bottom: 0.8rem;
    color: var(--primary-dark);
    border-bottom: 0.2rem dashed var(--light-blue);
}

a.link-arrow{
    position: relative;
    padding-left: 1.2rem;
}

a.link-arrow::before{
    content: "";
    position: absolute;
    top: 52%;
    left: 0;
    transform: translateY(-50%);
    display: inline-block;
    width: 0.635rem;
    height: 1.149rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_arrow.svg) no-repeat;
    background-size: contain;
}

a.anchor-link-arrow{
    position: relative;
    display: inline-block;
    padding-left: 1.5rem;
}

a.anchor-link-arrow:after{
    content: "";
    position: absolute;
    top: 51%;
    right: 0;
    transform: translateY(-50%) rotate(90deg);
    display: inline-block;
    width: 0.642rem;
    height: 1.1rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_arrow_2.svg) no-repeat;
    background-size: contain;
}

#wrapper{
    display: block;
    overflow: visible;
    flex: none;
    padding-bottom: 5rem;
}

.separator-line:not(:first-of-type){
    padding-top: 1rem;
}

.separator-line:not(:last-of-type){
    padding-bottom: 1rem;
    border-bottom: 0.1rem solid var(--gray-2);
}

@media (max-width: 991.98px) {
    html {
        scroll-padding-top: 6rem;
    }

    .heading-h1{
        margin: 2rem 0;
    }

    .heading-h1 span{
        font-size: 2.5rem;
    }
}

/* flex */
.gap5{
    gap: 0.5rem;
}

.gap10{
    gap: 1rem;
}

.gap15{
    gap: 1.5rem;
}

.gap20{
    gap: 2rem;
}

/* fontsize */
.fs-10 {
    font-size: 1rem !important;
}

.fs-12 {
    font-size: 1.2rem !important;
}

.fs-14 {
    font-size: 1.4rem !important;
}

.fs-16 {
    font-size: 1.6rem !important;
}

.fs-18 {
    font-size: 1.8rem !important;
}

.fs-20 {
    font-size: 2rem !important;
}

.fs-22 {
    font-size: 2.2rem !important;
}

.fs-25 {
    font-size: 2.5rem !important;
}

/* row column */
.container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl {
    padding-left: 1rem;
    padding-right: 1rem;
}
.row{
    margin-right: -0.75rem;
    margin-left: -0.75rem;
}

.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-auto, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-sm-auto, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-md-auto, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-lg-auto, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl, .col-xl-auto{
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

/* card */
.card{
    background-color: var(--white);
    border-radius: 0.5rem;
    box-shadow: none;
}

.card-padding,
.card-window .card-body{
    padding: 3rem;
}

.card-title{
    margin-bottom: 2rem;
    color: var(--primary);
    text-align: center;
    font-size: 1.8rem;
    font-weight: 700;
}

.reset-card{
    width: calc(100% + 6rem);
    height: calc(100% + 6rem);
    margin: -11.5rem 0 0 -3rem;
    padding: 0;
    background-color: var(--light-gray);
    border: none;
}

@media (min-width: 992px) {
    .card-form{
        padding: 4rem 6rem;
    }
}

@media (max-width: 991.98px) {
    .card-padding,
    .card-window .card-body{
        padding: 2rem;
    }

    .reset-card{
        width: calc(100% + 4rem);
        height: calc(100% + 4rem);
        margin: -9.5rem 0 0 -2rem;
    }
}

/* form */
.register-form .form-group{
    display: flex;
    flex-direction: column;
    margin-bottom: 2rem;
}

.form-control{
    border: 0.1rem solid var(--gray-2);
}

.form-group .form-control{
    padding: 0 1rem;
}

.form-check-input[type="checkbox"] + label{
    padding-left: 2.2rem;
}

.form-check-input[type="checkbox"] + label::before{
    top: 50%;
    transform: translateY(-50%);
}

.form-check-input[type="checkbox"]:checked + label::after{
    top: calc(50% - 0.65rem);
    left: 0.52rem;
    width: 0.5rem;
    height: 1rem;
}

.was-validated .form-control:invalid, .form-control.is-invalid,
.was-validated .form-control:invalid:focus, .form-control.is-invalid:focus,
.was-validated .custom-select:invalid, .custom-select.is-invalid,
.was-validated .custom-select:invalid:focus, .custom-select.is-invalid:focus,
.was-validated .custom-control-input:invalid ~ .custom-control-label::before, .custom-control-input.is-invalid ~ .custom-control-label::before,
.was-validated .custom-control-input:invalid:focus:not(:checked) ~ .custom-control-label::before, .custom-control-input.is-invalid:focus:not(:checked) ~ .custom-control-label::before,
.was-validated .custom-file-input:invalid ~ .custom-file-label, .custom-file-input.is-invalid ~ .custom-file-label,
.was-validated .custom-file-input:invalid:focus ~ .custom-file-label, .custom-file-input.is-invalid:focus ~ .custom-file-label{
    border-color: var(--pink);
}

.was-validated .form-check-input:invalid ~ .form-check-label, .form-check-input.is-invalid ~ .form-check-label,
.was-validated .custom-control-input:invalid ~ .custom-control-label, .custom-control-input.is-invalid ~ .custom-control-label{
    color: var(--pink);
}

.btn-outline-danger:hover,
.btn-outline-danger:not(:disabled):not(.disabled):active, .btn-outline-danger:not(:disabled):not(.disabled).active, .show > .btn-outline-danger.dropdown-toggle,
.alert-danger {
    background-color: var(--light-pink);
}

.was-validated .form-control:invalid:focus, .form-control.is-invalid:focus {
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--pink) 25%, transparent);
    box-shadow: 0 0 0 0.2rem rgba(229, 70, 98, 0.25);
}

.required,
.optional{
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 3.5rem;
    height: 2rem;
    margin-top: 0.3rem;
    line-height: 1;
    font-size: 1rem;
    font-weight: 500;
    color: var(--white);
}

.required{
    background-color: var(--pink-2);
}

.optional{
    background-color: var(--primary);
}

.form-control-confirm{
    width: auto;
    min-height: 1.6em;
    margin: 0;
    font-size: 1.4rem;
}

.lower-level{
    padding-left: 1em!important
}

.form-label label{
    color: var(--gray-3);
}

.form-confirm-btn-group{
    margin-top: 5rem;
}

/* table */
.table-default{
    border: none;
    border-radius: 0;
}

.table-default tbody th{
    color: var(--dark);
    font-weight: 500;
}

.table-default tbody tr:first-of-type{
    padding-top: 1.4rem;
}

.column-table td,
.column-table th{
    border: none!important;
}


@media (min-width: 768px) {
    .table-default tbody th,
    .table-default tbody td,
    .my-page-card .table-default tr:nth-child(1) > th,
    .my-page-card .table-default tr:nth-child(1) > td{
        padding: 1.2rem 2.4rem;
        border-top: 0.1rem solid var(--gray-2)!important;
    }

    .my-page-card .table-default tr:last-of-type > th,
    .my-page-card .table-default tr:last-of-type > td{
        border-bottom: 0.1rem solid var(--gray-2)!important;
    }

    .table-default tbody th{
        padding-top: 1.2rem;
    }

    .table-default tbody tr:last-of-type th,
    .table-default tbody tr:last-of-type td{
        border-bottom: 0.1rem solid var(--gray-2)!important;
    }
}

@media (max-width: 767.98px) {
    .table-default,
    .table-default tbody{
        display: block;
    }

    .table-default tr{
        display: flex;
        flex-direction: column;
    }

    .table-default th,
    .table-default td{
        border:none;
    }

    .table-default td{
        padding: 1.4rem 1.4rem 2rem;
    }

    .table-default tbody th{
        padding: 1rem 1.4rem;
        max-width: none;
        background-color: var(--primary-light);
    }

    .my-page-card .table-default tbody th{
        width: 100%!important;
        max-width: none;
    }
}

/* btn */
button.btn{
    width: 100%;
}

.btn,
.specified-btn{
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 37rem;
    margin: 0 auto;
    padding: 1.2rem 4rem 1.3rem;
    font-size: 1.8rem;
}

.btn:after,
.specified-btn:after{
    content: "";
    position: absolute;
    top: 51%;
    right: 1.8rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 1.687rem;
    height: 1.643rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_btnarrow.svg) no-repeat;
    background-size: contain;
}

.btn-outline-primary{
    color: var(--primary)!important;
    border: 0.1rem solid var(--primary);
}

.btn-outline-primary::after{
    content: "";
    position: absolute;
    top: 51%;
    right: 1.8rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 1.687rem;
    height: 1.643rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_btnarrow_2.svg) no-repeat;
    background-size: contain;
}

.btn-outline-primary:hover{
    background-color: var(--primary-light);
    opacity: 1;
}

.btn-favorite{
    color: var(--primary)!important;
    background-color: var(--white);
    border: 0.15rem solid var(--primary);
}

.btn-favorite span{
    position: relative;
    display: inline-block;
    padding-left: 2rem;

}

.btn-favorite span::before{
    content: "";
    position: absolute;
    top: 51%;
    left: 0;
    transform: translateY(-50%);
    display: block;
    width: 1.6rem;
    height: 1.5rem;
    background: url(/general/img/icon_heart_3.svg) no-repeat;
    background-size: contain;
}

.btn-favorite.active span::before{
    background: url(/general/img/icon_heart_2.svg) no-repeat;
    background-size: contain;
}

.btn-favorite:hover{
    opacity: 1;
}

#action{
    position: fixed;
    bottom: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    width: 100%;
    height: auto;
    padding: 1.5rem;
    transition: opacity 0.5s ease, visibility 0.5s;
    opacity: 1;
    visibility: visible;
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 200;
}

#action.is-hidden {
    opacity: 0;
    visibility: hidden;
}

#action .btn{
    margin: 0;
    min-width: 0;
}

#action .btn:after{
    display: none;
}

.under-btn-group{
    text-align: center;
    margin-top: 5rem;
}

.btn-no-arrow:after{
    display: none;
}

@media (max-width: 991.98px) {
    #action{
        height: 6rem;
        gap: 1rem;
    }

    #action .btn{
        border-radius: 0.5rem;
    }
}

/* アコーディオン */
.js-accordion-header{
    position: relative;
    cursor: pointer;
    padding: 1.4rem 5.8rem 1.4rem 1.4rem;
}

.js-accordion-header::before,
.js-accordion-header::after {
    content: "";
    position: absolute;
    top: 2.5rem;
    right: 1.4rem;
    background-color: var(--primary-dark);
    transition: transform 0.3s ease, opacity 0.3s ease;
    border-radius: 0.2rem;
}

.js-accordion-header::before{
    top: 1.7rem;
    right: 2.2rem;
    width: 0.2rem;
    height: 1.8rem;
}

.js-accordion-header::after {
    width: 1.8rem;
    height: 0.2rem;
}

.js-accordion-header.open::before{
    transform: translateY(-50%) rotate(90deg) scaleY(0); 
    opacity: 0;
}

.js-accordion-header.is-open::after {
    transform: translateY(-50%) rotate(0deg); 
}

.js-accordion-inner{
    display: none;
    padding: 0 1.4rem 1.4rem 1.4rem;
}

/* slick */
.slick{
    visibility: hidden;
}
.slick.slick-initialized{
    visibility: visible;
}

.slick .card{
    margin: 0.5rem 1rem;
}

.slick .slick-prev,
.slick .slick-next{
    top: 13rem;
    width: 4rem;
    height: 4rem;
    background-color: var(--primary);
    box-shadow: none;
}

.slick .slick-prev{
    left: -1rem;
}

.slick .slick-next{
    right: -1rem;
}

.slick .slick-prev::before,
.slick .slick-next::before{
    content: "";
    top: 1.4rem;
    left: 1.7rem;
    transform: none;
    display: inline-block;
    width: 0.899rem;
    height: 1.481rem;
    background: url(/general/img/icon_arrow_3.svg) no-repeat;
    background-size: contain;
    border: none;
    opacity: 1;
}

.slick .slick-prev::before{
    left: 1.4rem;
    transform: scaleX(-1);
}

.slick-dots{
    margin-top: 1.5rem;
}

.slick-dots li button:before{
    color: var(--white);
    opacity: 1;
}

/* ----------------------------
header
---------------------------- */
header{
    position: sticky;
    top: 0;
    z-index: 1000;
    width: 100%;
}

header.scrolled{
    box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2);
}

.navbar-brand{
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0;
}

.navbar-brand img{
    max-height: 3rem;
}

.nav-right-link{
    align-items: center;
}

.nav-right .icon-heart{
    display: inline-block;
    width: 2rem;
    height: 1.768rem;
    background-image: url('/general/img/icon_heart.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.nav-right .icon-form{
    display: inline-block;
    width: 1.9rem;
    height: 1.8rem;
    background-image: url('/general/img/icon_form.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.nav-right .icon-login{
    display: inline-block;
    width: 1.8rem;
    height: 1.8rem;
    background-image: url('/general/img/icon_login.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: -0.2rem center;
}

.nav-right .icon-logout{
    display: inline-block;
    width: 1.76rem;
    height: 1.8rem;
    background-image: url('/general/img/icon_logout.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.nav-right .icon-pen{
    display: inline-block;
    width: 2.056rem;
    height: 2.053rem;
    background-image: url('/general/img/icon_pen.svg');
    background-size: contain;
    background-repeat: no-repeat;
}

.navbar-toggler{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.7rem;
    padding: 0.7rem 0.75rem 0.4rem;
}

.navbar-toggler > div{
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.navbar-toggler p{
    margin: -0.2rem 0 0;
    color: var(--primary-dark);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05rem
    
}

.navbar-toggler span{
    width: 2.6rem;
    height: 0.2rem;
    margin: 0;
    background-color: var(--primary-dark);
    border-radius: 0.5rem;
}

.navbar-toggler span:nth-child(1) {
    margin-top: 0;
}

.navbar-toggler:not(.collapsed) span:nth-child(1) {
    transform: translate(6%, -33%) rotate(32deg);
}

.navbar-toggler:not(.collapsed) span:nth-child(3) {
    transform: translate(6%, 33%) rotate(-32deg);
}

.nav-right-item{
    position: relative;
    background-color: var(--primary-light);
}

.nav-right-link p{
    color: var(--primary-dark);
    font-weight: 700;
}

.navbar-expand-lg .navbar-nav .nav-link{
    color: var(--primary);
    font-size: 1.4rem;
    font-weight: 500;
}

.navbar-expand-lg .navbar-nav .nav-link:hover{
    opacity: 0.7;
}

@media (min-width: 992px) {
    .navbar{
        gap: 2.5rem;
        height: 6rem;
    }

    .navbar-brand{
        margin-left: 2rem;
    }
    
    .navbar-nav{
        gap: 3rem;
    }

    .nav-item{
        height: 7rem;
        margin: 0;
    }

    .nav-item:hover::after {
        display: none;
    }

    .nav-right{
        gap: 0.2rem;
    }

    .nav-right-link{
        width: 6rem;
        height: 6rem;
    }

    .nav-right-item:hover{
        background-color: var(--light-gray);
        opacity: 1;
    }

    .nav-right-item-1,
    .nav-right-item-2,
    .nav-right-item-3{
        background-color: var(--primary-light);
    }

    .nav-right-item span{
        margin-top: 0.8rem;
    }

    .navbar-expand-lg .navbar-nav .nav-link{
        height: auto;
    }

    .nav-right-link p{
        margin-top: 0.4rem;
        font-size: 1rem;
    }
}

@media (max-width: 991.98px) {
    .navbar{
        height: 4.5rem;
    }
    
    .nav-right {
        height: 100%;
        right: 4.8rem;
    }

    .nav-right-item {
        width: 5.5rem;
        margin: 0 0.1rem;
        padding: 0.6rem 0.1rem 0.4rem;
    }

    .navbar-nav{
        border-top: 0.1rem solid var(--light-blue);
        padding: 0 1rem;
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1);
    }

    .nav-right-link p {
        margin-top: 0.2rem;
    }

    .navbar-expand-lg .navbar-nav .nav-link{
        padding: 1.5rem;
        font-weight: 700;
    }

    .nav-item{
        border: none;
    }

    .navbar-nav .nav-item:not(:last-of-type) {
        border-bottom: 0.2rem dashed var(--gray-2);
    }
}

/* ----------------------------
footer
---------------------------- */
footer{
    margin-top: auto!important;
}

.footer-bottom{
    padding: 0;
    background-color: var(--gray);
}

.footer-bottom-1{
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6rem 3rem;
}

.footer-bottom-logo{
    width: 80%;
    max-width: 25rem;
    margin: 0;
}

.footer-bottom-menu{
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    width: 36rem;
    margin: 0;
    font-weight: 500;
}

.footer-bottom-menu a{
    width: 14.5rem;
    margin: 0;
    color: var(--primary-dark);
    font-size: 1.3rem;
}

.footer-bottom-menu a[target="_blank"] span{
    position: relative;
    padding: 0 2.5rem 0 0.5rem;
}

.footer-bottom-menu a[target="_blank"] span::after{
    content: "";
    position: absolute;
    top: 0.3rem;
    right: 0.5rem;
    display: inline-block;
    width: 1.193rem;
    height: 1.186rem;
    background: url(/general/img/icon_external.svg) no-repeat;
    background-size: contain;
}

.footer-bottom-2{
    padding: 3rem 4rem;
    border-top: 0.4rem solid var(--light-gray);
}

.footer-certification{
    display: flex;
    gap: 5rem;
}

.footer-certification a{
    display: flex;
    align-items: center;
    color: var(--gray-3);
}

.footer-certification a:hover{
    text-decoration: none;
    opacity: 0.7;
}

.footer-certification-sentence{
    margin: 0;
    padding-left: 1rem;
    word-break: break-all;
}

.footer-certification-1 img{
    display: inline-block;
    margin: 0 0.8rem;
}

.copyright{
    display: block;
    margin: 3rem 0 0;
    padding: 0;
    text-align: center;
    color: var(--gray-3);
    font-size: 1rem;
}

#pagetop{
    z-index: 100;
}

@media (min-width: 992px) {
    .footer-certification img{
        width: auto;
        max-height: 5rem;
    }

    .footer-bottom{
        position: relative;
    }

    .footer-bottom-menu{
        width: 41rem;
    }

    .copyright{
        position: absolute;
        bottom: 1rem;
        right: 3rem;
    }
}

@media (max-width: 991.98px) {
    footer{
        margin-top: 5rem;
    }

    .footer-bottom-menu{
        padding-left: 3rem;
    }

    .footer-bottom-1{
        display: flex;
        flex-direction: column-reverse;
        align-items: center;
        padding: 3rem 3rem 2rem;
    }

    .footer-certification{
        flex-direction: column;
        gap: 1.5rem;
        max-width: 32.6rem;
        margin: 0 auto;
    }

    .footer-bottom-logo{
        max-width: 20rem;
        margin: 3rem 0 0.5rem;
    }

    .copyright{
        margin: 0;
        padding-bottom: 1rem;
    }
}

/* ----------------------------
breadcrumb
---------------------------- */
.breadcrumb{
    margin: 0;
    padding: 1rem 2rem;
    font-size: 1.2rem;
}

.breadcrumb a{
    color: var(--dark);
    font-weight: 400;
}

/* ----------------------------
TOP
---------------------------- */
.top-container{
    padding-top: 1rem;
}

.top .card{
    padding: 3rem;
}

.top .heading-h1{
    justify-content: start;
}

@media (max-width: 991.98px) {
    .top .card{
        padding: 2rem;
    }
}

/* mv */
.mv{
    display: flex;
    justify-content: center;
    width: 100%;
    font-size: 0;
}

.mv-wrapper {
    position: relative;
    display: inline-block;
    width: 100%;
    height: 44.6rem;
    overflow: hidden;
}

.mv-main-img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    object-fit: cover;
}

.mv-logomark{
    position: absolute;
    top: 15rem;
    left: 88%;
    transform: translateX(-50%);
    width: 18.9rem;
    height: 13.3rem;
}

.mv-contents{
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 5rem;
    left: 72%;
    transform: translateX(-50%);
    width: max-content;
}

.mv-contents-inner{
    position: relative;
}

.mv-text-1{
    color: var(--pink);
    line-height: 1.3;
    font-size: 3.8rem;
    font-weight: 500;
}

.mv-text-1 span {
  text-shadow: 0.2rem 0.2rem 0.4rem var(--white);
}

.mv-text-1-small{
    display: inline-block;
    max-width: 5.5rem;
    font-size: 3rem;
}

.mv-text-1-medium{
    font-size: 3.6rem;
}

.mv-text-1-large{
    display: inline-block;
    font-size: 4.8rem;
}

.mv-text-1-large span{
    display: inline-block;
    margin-left: -1rem;
    text-shadow: 
     0.2rem 0.2rem 0 var(--white),
     0.2rem -0.2rem 0 var(--white),
    -0.2rem -0.2rem 0 var(--white),
     0.2rem 0rem 0 var(--white),
    -0.2rem 0rem 0 var(--white),
     0 0.2rem 0 var(--white),
     0 -0.2rem 0 var(--white);
     -webkit-text-stroke: 0.2rem var(--white);
     paint-order: stroke fill;
}

.mv-text-2{
    position: relative;
    margin: 2rem 0 3rem;
    color: var(--primary-dark);
    font-size: 1.7rem;
    font-weight: 700;
    text-shadow: 0.2rem 0.2rem 0.4rem var(--white);
}

.mv-text-2 ul{
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.mv-text-2 li{
    position: relative; 
    padding-left: 2.7rem;
}

.mv-text-2 li::before{
    content: "";
    position: absolute;
    top: 0.5rem;
    left: 0;
    display: inline-block;
    width: 2rem;
    height: 2rem;
    background: url('/general/img/icon_check.svg') no-repeat;
    background-size: contain;
    text-shadow: 0.2rem 0.2rem 0.4rem var(--white);
}

.mv-cv-btn-area{
    width: 47rem;
}

.mv-cv-btn{
    display: flex;
    width: 100%;
    height: 6rem;
    max-width: none;
    margin: 0;
    padding: 0;
    transition: all 0.4s ease-in-out;    
}

.mv-cv-btn:hover {
    transform: scale(1.05);
}

.mv-cv-btn::after{
    display: none;
}

.mv-cv-btn-1{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding-left: 5rem;
    color: var(--primary-dark)!important;
    background-color: var(--white);
    border-top: 0.2rem solid var(--primary);
    border-left: 0.2rem solid var(--primary);
    border-bottom: 0.2rem solid var(--primary);
    border-radius: 0.5rem 0 0 0.5rem;
}

.mv-cv-btn-1 span{
    position: relative;
    padding-left: 4.4rem;
}

.mv-cv-btn-1 span::before{
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    display: inline-block;
    width: 3.8rem;
    height: 2.8rem;
    background: url('/general/img/logomark.svg') no-repeat;
    background-size: contain;
}

.mv-cv-btn-2{
    position: relative;
    display: block;
    width: 6.5rem;
    height: 100%;
    color: var(--white);
    background-color: var(--primary);
    border-top: 0.2rem solid var(--primary);
    border-right: 0.2rem solid var(--primary);
    border-bottom: 0.2rem solid var(--primary);
    border-radius: 0 0.5rem 0.5rem 0;
}

.mv-cv-btn-2::after{
    content: "";
    position: absolute;
    top: 51%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-block;
    width: 1.687rem;
    height: 1.643rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_btnarrow.svg) no-repeat;
    background-size: contain;
}


.btn.mv-cv-btn-2{
    color: var(--dark)!important;
}

.mv-note{
    padding: 0.2rem 0 0 1.2em;
    text-indent: -1em;
    font-size: 1.2rem;
}

.mv-search{
    padding: 1.8rem 0 3.6rem;
}

.mv-search .container{
    position: relative;
}

.mv-search-form .form-group input.form-control,
.mv-search-form .form-group select.form-control{
    display: block;
    width: 100%;
    height: 5.4rem;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0 2rem 0 1.6rem;
    text-align: center;
    font-size: 16px;
    border: none;
    border-radius: 0.5rem;
    cursor: pointer;
}

.mv-search-form .form-group input.form-control:read-only,
.mv-search-form .form-group select.form-control:read-only{
    background-color: var(--white);
}

.mv-search-form .form-group input.form-control::placeholder,
.mv-search-form .form-group select.form-control::placeholder{
    color: var(--dark);
    font-size: 1.4rem;
    font-weight: 500;
}

.mv-search-form .form-group-1{
    position: relative;
    cursor: pointer;
}

.mv-search-form .form-group-1::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.4rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 0.642rem;
    height: 1.1rem;
    background: url('/general/img/icon_arrow.svg') no-repeat;

    pointer-events: none;
}

.mv-search-form i{
    color: var(--primary-dark);
}

.mv-search-form .btn{
    width: 20rem;
    min-width: auto;
    padding: 1rem 2rem 1.1rem;
}

.mv-search-form .btn span{
    position: relative;
    padding-left: 2rem;
}

.mv-search-form .btn span::before{
    content: "";
    position: absolute;
    top: 52%;
    left: 0;
    transform: translateY(-50%);
    display: inline-block;
    width: 1.758rem;
    height: 1.758rem;
    background: url('/general/img/icon_search.svg') no-repeat;
    background-size: contain;
}

.mv-search-form .btn::after{
    display: none;
}

@media (min-width: 992px) {
    .mv-main-img {
        min-width: 192rem;
    }

    .mv-text-1{
        margin-bottom: 1rem;
    }

    .mv-search-vacancies{
        position: absolute;
        top: 1.8rem;
        right: 0;
    }

    .mv-search .form-group-1{
        width: calc((100% - 3rem - 16rem) / 2);
    }

    .mv-search-btn{
        width: 16rem;
    }
}

@media (max-width: 991.98px) {
    .mv{
        height: 60rem;
        background-color: var(--white);
    }

    .mv-wrapper {
        height: 46.4rem;
    }

    .mv-contents{
        top: 0.5rem;
        left: 50%;
    }
    
    .mv-logomark{
        display: none;
    }

    .mv-texts{
        transform: scale(0.8);
        white-space: nowrap;
    }
    .mv-text-1{
        transform: scale(0.5);
        line-height: 1.3;
    }

    .mv-text-2{
        max-width: 35.5rem;
        margin: 20rem auto 0;
        text-shadow: 
        0.2rem 0.05rem 0 rgba(255,255,255,0.4),
        0.05rem -0.05rem 0 rgba(255,255,255,0.4),
        -0.05rem -0.05rem 0 rgba(255,255,255,0.4),
        0.05rem 0rem 0 rgba(255,255,255,0.4),
        -0.05rem 0rem 0 rgba(255,255,255,0.4),
        0 0.05rem 0 rgba(255,255,255,0.4),
        0 -0.05rem 0 rgba(255,255,255,0.4);
        -webkit-text-stroke: 0.05rem rgba(255,255,255,0.4);
        paint-order: stroke fill;
    }

    .mv-text-2 ul{
        gap: 0.5rem;
    }

    .mv-text-2 li{
        padding-left: 1.7rem;
        font-size: 1.3rem;
    }

    .mv-text-2 li::before{
        width: 1.3rem;
        height: 1.3rem;
    }

    .mv-cv-btn-area{
        max-width: 35rem;
        margin: 1.5rem auto;
    }

    .mv-cv-btn{
        width: 100%;
    }

    .mv-note{
        padding: 0.5rem 0.5rem 0 1.2em;
    }

    .mv-search{
        display: block;
        padding: 0.5rem 0 3rem;
    }

    .mv-search-form > .d-flex{
        flex-wrap: wrap;
        row-gap: 2rem;
        column-gap: 1rem;
    }

    .mv-search-form i{
        display: inline-block;
    }

    .mv-search .form-group{
        flex: 1;
        font-size: 1.8rem;
    }

    .mv-search-btn{
        width: 100%;
        flex: 1 1 100%;
        font-size: 1.8rem;
    }
}

/* search-modal */
.search-modal-body{
    padding: 2rem 1rem 8rem;
}

.search-modal-body .search-accordion-cat .tag-selected{
    top: 1.3rem;
}

.search-modal .close{
    right: 2rem;
    width: 2rem;
    height: 2rem;
    margin: 0;
    padding: 0;
}

.search-modal .close-inner{
    position: relative;
}

.search-modal .close span {
    position: absolute;
    top: 0;
    left: 0;
    width: 2rem;
    height: 0.2rem;
    margin: 0;
    background-color: var(--primary);
    border-radius: 0.2rem;
}

.search-modal .close span:nth-child(1) {
    transform: rotate(45deg);
}

.search-modal .close span:nth-child(2) {
    transform: rotate(-45deg);
}

.search-modal .modal-title{
    color: var(--primary-dark);
}

.modal-header{
    height: 7rem;
    justify-content: center;
    padding: 2rem 3.5rem 2rem 1.2rem;
    background-color: var(--light-gray);
}

.modal-content{
    overflow: hidden;
}

.search-modal-body .inputs{
    margin: 0 0.5rem 1rem 1rem;
}

.search-modal-body .acordion:last-of-type{ 
    margin-bottom: 4rem;
}

.search-modal-body .search-accordion-cat{
    position: relative;
    padding: 1.4rem 1.6rem;
    font-weight: 500;
    background-color: var(--primary-light);
    border: none;
}

.search-modal-body .search-accordion-cat:after{
    content: "";
    position: absolute;
    top: 50%;
    right: 2rem;
    transform: translateY(-50%) rotate(90deg);
    display: inline-block;
    width: 0.642rem;
    height: 1.1rem;
    background: url('/general/img/icon_arrow.svg') no-repeat;
    background-size: contain;
}

.search-modal-body .search-accordion-cat.opened{
    border-radius: 0.5rem 0.5rem 0 0;
}

.search-modal-body .search-accordion-cat.opened:after{
    transform: translateY(-50%) rotate(-90deg);
}

.search-modal-body .form-check{
    padding: 0 2rem;
    font-size: 1.4rem;
}

.search-modal-body .search-accordion-subcat{
    font-size: 1.4rem;
    font-weight: 400;
    background-color: var(--white);
    border-left: 0.2rem solid var(--primary-light);
    border-right: 0.2rem solid var(--primary-light);
    border-bottom: 0.2rem solid var(--primary-light);
}

.modal-footer{
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 1.2rem 2rem;
    background-color: var(--light-gray);
    box-shadow: -1rem 0 1rem rgba(0, 0, 0, 0.3);
}

.search-modal .modal-footer{
    height: 7rem;
}

.search-modal .modal-footer .search-num{
    margin: 0;
}

.modal-footer .btn{
    height: 4.5rem;
    max-width: 20rem;
    margin: 0;
    padding: 1rem 2rem 1.1rem;
    border: 0.1rem solid var(--primary);
    white-space: nowrap;
}

.modal-footer .btn::after{
    display: none;
}

.modal-footer .specified-btn{
    width: 12rem;
    min-width: auto;
    margin: 0;
    padding: 1rem 2rem 1.1rem;
    color: var(--dark)!important;
    font-size: 1.4rem;
    font-weight: 500;
    border: 0.1rem solid var(--primary);
}

@media (min-width: 992px) {
    .search-modal .modal-footer .search-num{
        width: 12rem;
    }
}

@media (max-width: 991.98px) {
    .modal-header{
        padding: 2rem 1rem;
        border-radius: 0;
    }

    .modal-footer{
        padding: 1rem 1.5rem;
        border-radius: 0;
    }

    .search-modal-body{
        height: calc(100vh - 7rem);
    }

    .search-modal .modal-dialog{
        max-width: 100vw;
        width: 100%;
    }

    .search-modal .modal-footer > div{
        gap: 1.2rem;
        flex-shrink: 0;
    }

    .search-modal .modal-footer .search-num{
        flex: 0 0 auto;
    }

    .search-modal .modal-footer .btn{
        width: auto;
        flex: 1;
    }

    .search-modal .modal-footer .specified-btn{
        flex: 0 0 8rem;
        margin: 0;
    }

    .search-modal .close{
        top: 2.2rem;
        right: 1.5rem;
    }
}

@media (max-width: 767.98px) {
    .modal-footer{
        position: fixed;
    }
}

@media (min-width: 576px) {
    .option-modal .specified-btn{
        position: absolute;
        right: 2rem;
    }
}

/* 女性医局の3つのメリット */
.top-merit{
    padding: 0;
    background-color: transparent;
}

.detail-merit.card{
    display: flex; 
    flex-direction: column;
    align-items: center;
    padding: 0 2rem 2rem;
}

.merit-num-wrapper{
    display: flex;
    justify-content: center;
    align-items: end;
    width: 17.8rem;
    height: 5.4rem;
    margin-bottom: 2.4rem;
    background-color: var(--primary-light);
    border-radius: 0 0 2rem 2rem;
}

.merit-num{
    display: flex;
    align-items: baseline;
    color: var(--primary-dark);
    font-size: 2.4rem;
    font-weight: 400;
}

.merit-num span{
    display: inline-block;
    padding-left: 0.3rem;
    font-size: 4rem;
    font-weight: 500;
}

.detail-merit-sentence{
    margin: 2.4rem 0 3rem; 
}

.detail-merit-link{
    position: absolute;
    bottom: 2rem;
    right: 2rem;
}

.detail-merit-link .btn{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    align-self: flex-end;
    width: 10rem;
    height: 4rem;
    min-width: initial;
    margin: auto 0 auto auto;
    padding: 0 0.2rem 0 0;
    font-size: 1.2rem;
    background-color: var(--primary);
}

.point-banner{
    display: flex;
    justify-content: center;
    margin: 3rem auto;
}

.point-banner img{
    width: 100%;
    height: auto;
    max-width: 56.8rem;
}

@media (min-width: 992px) {
    .detail-merit{
        width: calc((100% - 4rem) / 3);
    }

    .detail-merit-title span{
        font-size: 1.4rem;
    }

    .detail-merit-link{
        right: auto;
        left: 50%;
        transform: translateX(-50%);
        width: calc(100% - 4rem);
        margin: 0;
    }

    .detail-merit-link .btn{
        width: 100%;
    }
}

/* 女性医局とは */
.about-contents li{
    padding-left: 1em;
    text-indent: -1em;
}

.about-img  img{
    width: 18rem;
    height: auto;
}

.top-about .about-img img{
    width: 23.6rem;
}

@media (min-width: 992px) {
    .top-about .about-contents{
        width: calc(100% - 2rem - 23.6rem);
    }

   .about-contents:not(.top-about){
        width: calc(100% - 2rem - 18rem);
        line-height: 1.7;
    }
}

@media (max-width: 991.98px) {
    .about .d-flex{
        align-items: center;
    }
}

/* 求人・特集 */
.special-feature-contents{
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.top-special-feature .card{
    border-radius: 0.5rem 0.5rem 0 0;
}

.special-contents-img{
    aspect-ratio: 68 / 19;
}

@media (min-width: 992px) {
    .special-feature-contents a{
        width: calc((100% - 4rem)/3);
    }
}

@media (max-width: 991.98px) {
    .special-feature-content{
        flex-direction: column;
    }
}

/* リンク群 */
.top .top-spot-card{
    padding-top: 0;
    border-radius: 0 0 0.5rem 0.5rem;
}

.top-job-link a{
    position: relative;
    display: inline-block;
    padding-right: 2rem;
    color: var(--dark);
}

.top-job-link a:hover{
    color: var(--primary);
    opacity: 1;
}

.top-job-link a:not(:last-of-type):after{
    content: "";
    position: absolute;
    top: 53%;
    right: 1rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 0.3rem;
    height: 1em;
    background-color: var(--primary);
    border-radius: 0.5rem;
}

/* 登録から勤務開始までの流れ */
.top-step-list li{
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 1.4rem;
    font-weight: 700;
    overflow: visible;
    background-color: var(--white);
    border-radius: 0.5rem;
}

.top-step-list li:not(:last-of-type)::after{
    position: absolute;
    display: block;
    content: "";
    top: 50%;
    right: -1.5rem;
    transform: translateY(-50%);
    width: 1.1rem;
    height: 1.7rem;
    background: url(/general/img/icon_arrow_2.svg) no-repeat;
    background-size: contain;
}

.step-decoration{
    position: absolute;
    top: 1.3rem;
    right: 5.9rem;
    display: inline-block;
    width: 6.3rem;
    height: 6.3rem;
    background-color: var(--primary-light);
    border-radius: 50%;

}

.step-num{
    text-align: center;
    align-items: baseline;
    color: var(--primary-dark);
    font-size: 2.4rem;
    font-weight: 400;
    z-index: 1;
}


.step-num span{
    display: inline-block;
    padding-left: 1rem;
    font-size: 4rem;
    font-weight: 500;
}

.top-step p{
    margin: 2.2rem 0;
    font-weight: 400;
}

.top-step-img{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 13.2rem;
}

.top-step-list li:nth-of-type(1) img{
    width: 10.6rem;
}

.top-step-list li:nth-of-type(2) img{
    width: 18.2rem;
}

.top-step-list li:nth-of-type(3) img{
    width: 14.6rem;
    margin-top: -3rem;
}

.top-step-list li:nth-of-type(4) img{
    width: 15.1rem;
}

@media (min-width: 992px) {
    .top-step-list li{
        width: calc((100% - 6rem)/4);
    }

    .top-step-list li p{
        text-align: center;
    }

    .top-step-messeage{
        text-align: center;
        line-height: 1.6;
        font-size: 1.6rem;
    }
}

@media (max-width: 991.98px) {
    .top-step-list{
        gap: 3rem;
    }

    .top-step-list li{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        padding: 2rem 2rem 2rem 1.4rem;
    }
    
    .top-step-list li:not(:last-of-type)::after {
        top: auto;
        left: 50%;
        right: auto;
        bottom: -3.2rem;
        transform: translate(-50%,-50%) rotate(90deg);
    }

    .top-step-img{
        width: 14rem;
    }

    .step-decoration{
        top: 2rem;
        left: calc(50% + 2.6rem);
        transform: translateX(-50%);
    }
}

/* お知らせ */
.card-news > a{
    padding: 1.5rem 0;
    border-top: 0.2rem dashed var(--light-gray-3);
}

.card-news > a:last-of-type{
    border-bottom: 0.2rem dashed var(--light-gray-3);
}

.top-news{
    padding: 1rem 0;
}

.news-item{
    display: flex;
    border: none;
}

.news-date{
    width: auto;
    padding: 0;
    color: var(--primary);
    font-weight: 700;
}

.news-sentence{
    width: auto;
    display: inline-block;
}

.news-item .news-sentence{
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

@media (min-width: 992px) {
    .card-news{
        padding: 3rem 5rem;
    }

    .card-news-list{
        padding: 3rem 5rem;
    }

    .news-item{
        gap: 2rem;
    }

    .news-date{
        display: inline-block;
    }
}

@media (max-width: 991.98px) {
    .news-item{
        flex-direction: column;
    }
}

/* ----------------------------
求人一覧、求人詳細、お気に入り求人一覧
---------------------------- */
.card-job .card-body{
    padding: 2rem;
}

.card-job-name{
    color: var(--dark);
    margin-bottom: 2rem;
    font-size: 1.8rem;
    text-decoration: underline;
}

.card-job-info{
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 2rem;
}

.card-job-info dt{
    display: inline-block;
    width: 10rem;
    color: var(--primary);
    font-weight: 500;
}

.card-job-info dd{
    display: inline-block;
    width: calc(100% - 11rem);
}

/* 検索エリア */
.search{
    margin-bottom: 2rem;
}

.nav-tabs{
    gap: 0.5rem;
    border: none;
}

.nav-tabs .nav-link.active, .nav-tabs .nav-item.show .nav-link{
    background-color: var(--primary);
    color: var(--white);
    border-top: 0.15rem solid var(--primary);
    border-left: 0.15rem solid var(--primary);
    border-right: 0.15rem solid var(--primary);
}

.nav-tabs .nav-item{
    height: auto;
}

.nav-tabs .nav-link{
    margin-bottom: -0.15rem;
    background-color: var(--white);
    border-top: 0.15rem solid var(--primary);
    border-left: 0.15rem solid var(--primary);
    border-right: 0.15rem solid var(--primary);
}

.nav-tabs .nav-link:hover:not(.active.nav-link),
.nav-tabs .nav-link:focus{
    border-top: 0.15rem solid var(--primary);
    border-left: 0.15rem solid var(--primary);
    border-right: 0.15rem solid var(--primary);
}

.nav-tabs .nav-link:hover:not(.active.nav-link){
    background-color: var(--primary-light);
}

.tab-content .card{
    border: 0.15rem solid var(--primary);
}

.tab-content .card{
    border-radius: 0 0.5rem 0.5rem 0.5rem;
}

.tab-content .btn{
    max-width: 30rem;
}

.tab-content .btn::after{
    display: none;
}

.search{
    margin-top: 0;
}

.search-item{
    border-bottom: 0.1rem dashed var(--light-blue);
}

.search-title{
    color: var(--primary);
    font-size: 1.8rem;
}

.search-click .btn{
    width: auto;
    margin: 0;
    font-size: 1.2rem;
}
@media (min-width: 992px) {
    .search-click {
        margin-left: 2rem;
    }
}

@media (max-width: 991.98px) {
    .search-selected{
        display: inline-block;
        width: auto;
    }

    .search-click {
        display: inline-block;
        margin: 1rem 0 0 auto;
    }

    .search-item{
        padding: 1.6rem 0;
    }
}

/* 求人一覧 */
.job-item-title{
    margin-bottom: 1.6rem;
    font-size: 1.8rem;
}

.job-item-info{
    gap: 2rem;
}

.job-item-detail{
    width: calc(100% - 25rem);
}

.job-item-detail dt{
    width: 20rem;
    color: var(--primary);
}

.job-item-detail dd{
    width: calc(100% - 22rem);
}

.recommend-job-block .job-item-detail{
    width: 100%;
}

.job-item-btn{
    gap: 1.5rem;
}

.job-item-btn .btn{
    min-width: 0;
    margin: 0!important;
}

@media (min-width: 992px) {
    .job-item-info{
        align-items: end;
    }

    .job-item-btn{
        flex-direction: column;
        align-items: center;
        gap: 1.5rem;
    }

    .job-item-btn .btn{
        margin: 0;
    }

    .job-item-btn .btn{
        min-width: 23rem;
    }
}

@media (max-width: 991.98px) {
    .job-item-info{
        flex-direction: column;
    }
    
    .job-item-detail{
        width: 100%;
    }

    .job-item-detail dt{
        width: 15rem;
        color: var(--primary);
    }

    .job-item-detail dd{
        width: calc(100% - 17rem);
    }

    .job-item-btn {
        width: 100%;
        flex-direction: column;
        margin-top: 5rem;
    }

    .job-item-btn .btn{
        width: 100%;
        margin: 0;
        font-size: 1.4rem;
    }
}

/* 求人詳細 */
.job-detail#wrapper{
    padding-bottom: 15rem;
}

.job-title{
    margin-bottom: 2rem;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.3;
}

.detail-point{
    width: 100%;
    margin-top: 1rem;
    padding: 2rem 2rem 2.4rem;
    background-color: var(--white);
    border: 0.1rem solid var(--primary);
}

.detail-point::before{
    content: "求人PR";
    top: -1.5rem;
    left: 50%;
    transform: translateX(-50%);
    width: auto;
    padding: 0 2rem;
    color: var(--primary);
    font-size: 1.8rem;
    font-weight: 500;
    background-color: var(--white);
    opacity: 1;
}

@media (max-width: 991.98px) {
    .job-detail#wrapper{
        padding-bottom: 13rem;
    }
}

/* お気に入り一覧、お気に入りボタン */
.bookmark-all{
    padding: 2rem 3rem;
    background-color: var(--white);
}

.bookmark-all .form-check-inline{
    margin: 0;
}

.bookmark-all .btn{
    min-width: 22rem;
}

.bookmark-item-btn {
    gap: 1.5rem;
}

.tooltip-bookmark .tooltip-inner {
    padding: 1rem;
    font-size: 1.2rem;
    background-color: var(--pink);
}

.tooltip-bookmark .arrow::before, .tooltip-bookmark .bs-tooltip-auto[x-placement^="top"] .arrow::before {
  border-top-color: var(--pink);
}

.tooltip.favorite-removed .tooltip-inner {
    background-color: var(--secondary);
}

.tooltip.favorite-removed .arrow::before, .tooltip.favorite-removed .bs-tooltip-auto[x-placement^="top"] .arrow::before {
    border-top-color: var(--secondary);
}

.bookmark-item-detail dt{
    width: 20rem;
}

.bookmark-item-detail dd{
    width: calc(100% - 20rem);
}

@media (min-width: 992px) {
    .bookmark-item-info{
        align-items: end;
    }

    .bookmark-item-btn {
        flex-direction: column;
        align-items: center;
        gap: 1.5rem;
    }

    .bookmark-item-btn .btn {
        min-width: 22rem;
        margin: 0;
    }
}

@media (max-width: 991.98px) {
    .bookmark-all{
        gap: 1rem;
        flex-direction: column;
        padding: 2rem;
    }

    .bookmark-item-btn {
        width: 100%;
        flex-direction: column;
        margin-top: 5rem;
    }

    .bookmark-item-btn .btn {
        margin: 0;
        width: 100%;
    }
    
    .bookmark-item-detail dt{
        width: 15rem;
        color: var(--primary);
    }

    .bookmark-item-detail dd{
        width: calc(100% - 15rem);
    }

    .bookmark-item-btn .btn{
        font-size: 1.8rem;
    }
}

/* ----------------------------
求人応募
---------------------------- */
.job-application-btn-area{
    display: flex;
    justify-content: center;
    column-gap: 1.5rem;
    row-gap: 2rem;
    margin-top: 3rem;
}

.job-application-btn-area .btn{
    width: 22rem;
    margin: 0;
}

@media (max-width: 767.98px) {
    .job-application-btn-area{
        flex-direction: column;
    }

    .job-application-btn-area .btn{
        width: 100%;
    }
}

/* ----------------------------
会員登録
---------------------------- */
.was-validated .form-control:invalid,
.form-control.is-invalid{
    background-position: right 2rem center;
}


/* ----------------------------
テンプレート
---------------------------- */
.contents .heading-h1{
    padding-top: 1rem;
}

.template-heading-bar{
    margin-top: 3rem;
}

.template-faq{
    background-color: var(--primary-light);
    border-radius: 1rem;
}

.template-faq:not(:last-of-type){
    margin-bottom: 1.5rem;
}

.template-faq p{
    margin: 0;
}

.template-faq .faq-q{
    background-color: var(--primary-light)!important;
    border-radius: 1rem;
}

.template-point-title{
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 2.5rem;
}

.template-point-number{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 4.5rem;
    height: 4.5rem;
    padding-top: 0.3rem;
    line-height: 1;
    color: var(--white);
    font-size: 0.8rem;
    font-weight: 700;
    background-color: var(--primary);
}

.template-point-number span{
    font-size: 2.5rem;
}

.template-point-text{
    margin: 0;
    font-size: 1.8rem;
}

.template-3column{
    display: flex;
    gap: 1.5rem;
}

.template-3column-item{
    flex: 1;
}

.template-text-image img{
    flex-basis: 30%;
}


.template-btn-2column{
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 3rem;
}

.template-table {
    width: 100%;
    border-collapse: collapse;
}
.template-table th, .template-table td {
    border: 0.1rem solid var(--gray-2);
    padding: 1rem;
    text-align: left;
}
.template-table th {
    font-weight: 700;
    background-color: var(--primary-light);
}

.template-component-set{
    display: flex;
    gap: 1.5rem;
}

.template-components{
    flex: 1;
}

.template-component-set img{
    width: 20rem;
    height: auto;
    flex-shrink: 0;
}

.step{
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-bottom: 4rem;
}

.step-number{
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 5rem;
    height: 5rem;
    font-size: 1.2rem;
    color: var(--white);
    background-color: var(--primary);
}

.step-number span{
    font-size: 2rem;
}

.step p{
    font-weight: 700;
    font-size: 1.6rem;
}

.btn-area{
    display: flex;
    gap: 2rem;
    margin: 3rem auto;
}

.btn-area a{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 5rem;
    max-width: 30rem;
    margin: 0 auto;
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 1.8rem;
}

.btn-area a::before{
    content: "";
    position: absolute;
    top: 51%;
    right: 2rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 0.642rem;
    height: 1.1rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_arrow_3.svg) no-repeat;
    background-size: contain;
}

.column-flex{
    display: flex;
    gap: 2rem;
    justify-content: space-between;
}

.flow{
    display: flex;
    align-items: stretch;
    margin: 1rem 0;
}

.flow-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 1.5rem;
    background: var(--primary-light);
    border-radius: 0.5rem;
}

.flow i{
    flex-shrink: 0;
    margin: 0.5rem;
    color: var(--primary);
    align-self: center;
}

.flow-vertical {
    flex-direction: row;
    justify-content: center;
}

.flow-vertical > .flow-item {
    flex-grow: 1;
    flex-basis: 0;
}

.flow-horizontal {
    align-items: center;
    flex-direction: column;
}

.flow-horizontal .flow-item {
    flex-direction: column;
    flex-grow: 0;
    flex-basis: auto;
}

@media (min-width: 992px) {
    .template-btn-2column .btn{
        min-width: 30rem;
    }

    .template-component-set .btn{
        margin: 0 0 0 auto;
    }
    
    .tag-description dt{
        width: 21.5rem;
    }

    .column-2{
        display: flex;
        width: calc((100% - 1.5rem) / 2);
        gap: 1.5rem;
    }

    .column-3{
        display: flex;
        width: calc((100% - 3rem) / 3);
        gap: 1.5rem;
    }

    .flow .vertical-write {
        writing-mode: vertical-rl;
        text-orientation: upright;
    }

    .flow-horizontal .flow-item {
        display: flex;
        justify-content: flex-start;
        width: 70%;
        padding: 1.5rem 3rem;
    }
}

@media (max-width: 991.98px) {
    .template-3column{
        display: flex;
        gap: 2rem;
    }

    .template-btn-2column{
        flex-direction: column;
        gap: 2rem;
    }

    .template-btn-2column .btn{
        width: 100%;
        max-width: none;
    }
    
    .template-table {
        display: block;
    }

    .template-table thead {
        display: none;
    }

    .template-table tbody{
        display: block;
        width: 100%;
    }

    .template-table tr {
        display: block;
        width: 100%;
    }

    
    .template-table tr:not(:first-of-type) {
        border-top: 0.1rem solid var(--gray-2);
    }

    .template-table tr:not(:last-of-type) {
        margin-bottom: 1.5rem;
    }
    
    .template-table td {
        position: relative;
        display: block;
        padding: 1rem 1.5rem 1rem 13rem;
        border-top: none;
        border-bottom: 0.1rem solid var(--gray-2);
    }

    .template-table td::before {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        content: attr(data-label);
        display: inline-block;
        width: 12rem;
        font-weight: bold;
        padding: 1rem;
        background-color: var(--primary-light);
    }

    .template-table tr:first-of-type td:first-of-type {
        border-top: 0.1rem solid var(--gray-2);
    }

    .template-component-set{
        flex-direction: column;
    }

    .template-component-set img{
        margin: 0 auto;
    }

    .tag-description dl{
        flex-direction: column;
        align-items: start;
        gap: 0.5rem;
    }

    .btn-area {
        flex-direction: column;
    }

    .flow-vertical {
        flex-direction: column;
        align-items: stretch;
    }

    .flow-vertical .flow-item {
        flex-grow: 0;
        flex-basis: auto;
        flex-direction: column;
        width: 100%;
    }

    .flow-vertical i {
        transform: rotate(90deg);
    }
}

/* ----------------------------
女性医局ポイントについて
---------------------------- */
.point-img{
    width: 80%;
    max-width: 34rem;
}

@media (min-width: 992px) {
    .point-description{
        width: calc(100% - 2rem - 34rem);
    }
}

/* ----------------------------
よくあるご質問
---------------------------- */
.faq{
    padding: 0;
    border: none;
}

.faq-contents:not(:last-of-type){
    margin-bottom: 1.5rem;
}

.faq-contents p{
    margin: 0;
}

.faq-contents .faq-q{
    background-color: var(--primary-light);
    border-radius: 1rem;
}

.faq-contents .faq-q.open{
    border-radius: 1rem 1rem 0 0;
}

.faq-contents  .faq-a{
    background-color: var(--primary-light);
    border-radius: 0 0 1rem 1rem;
}

.faq-anchor-list{
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, 1fr);
}

.faq-anchor-item{
    flex:1;
    height: 6rem;
    padding: 0 1.5rem;
    transition: all 0.3s ease-in-out;
    border-radius: 0.5rem;
    background-color: var(--light-gray-2);
}

.faq-anchor-item:hover{
    background-color: var(--primary-light);
    opacity: 1;
}

.faq-anchor-item a{
    display: flex;
    align-items: center;
    width: 100%;
    height: 100%;
    color: var(--dark);
}

.faq-anchor-item a:hover{
    opacity: 1;
}

.faq-page-anchor{
    display: flex;
    gap: 2rem;
}

.faq-list {
    display: flex;
    flex-flow: column;
    gap: 1.5rem;
    margin-bottom: 4rem;
}

.faq-list p{
    margin: 0;
    line-height: 1.7;
    text-emphasis: left;
}

.faq-list a{
    color: var(--primary);
    text-decoration: underline;
}

.faq-list li{
    font-size: 1.4rem;
    background-color: var(--white);
    border-radius: 1rem;
    cursor: pointer;
}

.faq-q {
    position: relative;
    display: flex;
    width: 100%;
    text-align: left;
    font-size: 1.6rem;
    font-weight: 500;
    background-color: var(--white);
    border: none;
    opacity: 1;
    line-height: 1.5;
}

.faq-q span:first-of-type{
    display: inline-block;
    width: 2.5rem;
    flex-shrink: 0;
    color: var(--primary);
    font-weight: 700;
}

.faq-a {
    position: relative;
    width: 100%;
    line-height: 1.7;
    color: var(--dark);
    font-size: 1.6rem;
    font-weight: 400;
    opacity: 1;
}

.accordion-header.open .faq-a {
    display: flex;
    align-items: center;
}

.faq-a span:first-of-type{
    display: inline-block;
    width: 2.5rem;
    flex-shrink: 0;
    padding-left: 0.25rem;
    color: var(--pink);
    font-weight: 700;
}

.faq-a p{
    display: inline-block;
}

@media screen and (max-width: 991.98px) {
    .faq-anchor-list{
        grid-template-columns: 1fr;
    }

    .faq-anchor-item{
        min-height: 6rem;
        padding: 1rem 1.5rem;
        height: auto;
    }

    .faq-list{
        gap: 1rem;
        margin-bottom: 3rem;
    }

    .faq-list li{
        border-radius: 0.5rem;
    }
    
}

/* ----------------------------
医療機関のご担当者様へ（医師募集のご依頼）
---------------------------- */
@media screen and (min-width: 992px) {
    .medical-institution-closing-remarks{
        text-align: center;
    }
}


/* ----------------------------
サイトマップ
---------------------------- */
.sitemap a{
    color: var(--dark);
    font-size: 1.4rem;
}

.sitemap a:hover{
    color: var(--primary);
    opacity: 1;
}

.sitemap-title{
    margin: 0 0 1rem;
    padding: 0.5rem 1.5rem;
    font-weight: 500;
    background-color: var(--primary-light);
}

.sitemap-list,
.sitemap-list-2{
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding-left: 1em;
}

.sitemap-list-2{
    padding: 1rem 0 0;
}

.sitemap-list li{
    padding-left: 1rem;
    text-indent: -1rem;
    line-height: 1.7;
}
    
.sitemap-list-2 li{
    position: relative;
    padding-left: 3rem;
}

.sitemap-list-2 li::before {
    content: "";
    position: absolute;
    top: 1.05rem;
    left: 0.5rem;
    width: 1rem;
    height: 0.2rem;
    display: inline-block;
    background-color: var(--light-gray);
    border-radius: 0.5rem;
}

.sitemap-list-2 li::after {
    content: "";
    position: absolute;
    top: -2.4rem;
    left: 0.5rem;
    width: 0.2rem;
    height: 3.5rem;
    display: inline-block;
    background-color: var(--light-gray);
    border-radius: 0.5rem;
}

.sitemap-list-2 li:first-of-type::after {
    top: -0.6rem;
    height: 1.6rem;
}

@media (min-width: 992px) {
    .sitemap .card{
        display: flex;
        gap: 4rem;
        justify-content: space-between;
        flex-direction: row;
        margin: 0 2rem;
    }

    .sitemap .card > div{
        flex: 1;
    }
}

/* ----------------------------
投稿ページ
---------------------------- */
.post-list{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    column-gap: 2rem;
    row-gap: 4rem;
    margin: 0;
}

.post-list-item{
    width: calc((100% - 6rem) / 4);
    margin: 0;
    background-color: var(--white);
    border-radius: 0.5rem;
}

.post-list-img{
    border-radius: 0.5rem 0.5rem 0 0;
}


.post-list-title{
    font-size: 1.4rem;
}

.post-list-contents{
    padding: 1rem 1.8rem 2rem;
}

ul.post-ul{
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

@media screen and (max-width: 991.98px) {
    .post-list-item{
        width: calc((100% - 4rem) / 2);
    }
}

@media screen and (max-width: 767.98px) {
    .post-list{
        flex-direction: column;
    }

    .post-list-item{
        width: 100%;
    }
}

/* ----------------------------
マイページ
---------------------------- */
.mypage-side-column .sidenav-item {
    font-size: 1.4rem;
}

.sidenav-item.btn-primay{
    background-image: none;
}

a.mypage-top-btn{
    position: relative;
    width: 100%;
    max-width: 79rem;
    background-color: var(--primary);
}

a.mypage-top-btn::before{
    content: "";
    position: absolute;
    top: 51%;
    right: 2rem;
    transform: translateY(-50%);
    display: inline-block;
    width: 0.642rem;
    height: 1.1rem;
    padding-top: 0.5rem;
    background: url(/general/img/icon_arrow_2.svg) no-repeat;
    background-size: contain;
}

.table-option-child{
    position: relative;
}

.table-option-child::before {
    content: "";
    position: absolute;
    top: 0.9rem;
    left: -1.5rem;
    width: 1rem;
    height: 0.2rem;
    display: inline-block;
    background-color: var(--light-gray);
    border-radius: 0.5rem;
}

.table-option-child::after {
    content: "";
    position: absolute;
    top: -1rem;
    left: -1.5rem;
    width: 0.2rem;
    height: 2rem;
    display: inline-block;
    background-color: var(--light-gray);
    border-radius: 0.5rem;
}

.table-option-child:first-of-type::after {
    top: 0;
    height: 0.9rem;
}


.my-page-card .form-control-confirm{
    font-size: 1.6rem;
}

@media (min-width: 768px) {
    .card-news {
        width: 100%;
    }
}

@media (min-width: 992px) {
    .mypage-side-column{
        margin: 8.6rem 0 0;
    }

    .mypage-side-column .sidenav{
        box-shadow: none;
    }

    .mypage-side-column .sidenav-item::after {
        content: "";
        position: absolute;
        top: 50%;
        right: 1rem;
        transform: translateY(-50%)!important;
        width: 0.642rem;
        height: 1.1rem;
        background: url(/general/img/icon_arrow_3.svg) no-repeat;
        background-size: contain;
        border: none;
        transform: none;
    }

    .mypage-side-column .sidenav-item{
        height: auto;
        font-weight: 700;
    }
    
    .mypage-side-column .sidenav-item:not(:last-of-type){
        border-bottom: 0.1rem dashed var(--primary);
    }

    .my-page-card .table-default tbody th{
        width: 33%!important;
    }
}

/* お知らせ */
@media (min-width: 992px) {
    .mypage-news-list{
        padding: 2rem 3rem;
    }
}

/* 応募履歴 */
.application-history-date,
.application-history-client{
    font-size: 1.4rem;
    font-weight: 400;
}

.application-history-title{
    font-size: 1.8rem;
    font-weight: 500;
}

.application-history-payment-date{
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    width: 100%;
    color: var(--dark);
}

.application-history-payment-date:last-of-type{
    margin-bottom: 0.5rem;
}

#action.confidential-action{
    height: auto;
    gap: 0.5rem;
}
