@charset "utf-8";

@import "style.css";
@import "color.css";
@import "font.css";
@import "line-height.css";
@import "margin.css";
@import "padding.css";
@import "policy.css";

:root {
    --bs-font-sans-serif: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    --bs-font-serif: 'Noto Serif JP', serif;
    --bs-emphasis-color: #000;
    --color_dark: #222222;
    --color_black2: #293325;
    --bs-body-bg: #fff;
    --bs-body-width: 1366px;
    --bs-color-pink: #E46179;
    --bs-color-gray: #F0F0F0;
}

/*---------------------------------------------------
font-familyここから
----------------------------------------------------*/
body {
    font-family: var(--bs-font-sans-serif);
}

/*---------------------------------------------------
リセットCSSここから
----------------------------------------------------*/
header a,
main a,
footer a {
    color: #222 !important;
}

ul {
    padding: 0;
}

li {
    list-style-type: none;
}

a {
    text-decoration: none;
}

input[type="text"]:focus {
    outline: 0;
}

button:focus {
    outline: 0;
}

*:focus {
    outline: none;
}

.width-fit-content {
    width: fit-content;
}

.grecaptcha-badge {
    visibility: hidden;
}

input[type="text"],
input[type="email"],
input[type="select"],
input[type="tel"],
input[type="date"],
select,
textarea {
    background-color: #fff;
    border: 1px solid #A3A3A3 !important;
    border-radius: 5px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    text-decoration: none;
    color: var(--color_dark);
}

input[type="text"]:focus {
    outline: 0;
}

input[type="submit"] {
    -webkit-appearance: none;
    appearance: none;
}

/*---------------------------------------------------
 header
----------------------------------------------------*/
.header {
    z-index: 9999;
}

.header-height {
    height: 100px;
}

.header-wrapper {
    background-color: #fff;
    border-radius: 8px;
    margin-top: 30px;
    height: 66px;
}

.header-nav_item {
    margin-right: 1.875rem;
}

.header-logo {
    max-height: 80px;
    height: 100%;
}

.header-sub-list {
    position: relative;
}

.header-sub-list::before {
    position: absolute;
    content: "";
    top: 50%;
    left: -18px;
    background-color: #E46179;
    width: 10px;
    height: 2px;
    transform: translateY(-50%);
}

.header-link-button {
    background-color: #fff;
    max-width: 361px;
    width: 100%;
    height: 100%;
    padding: 38px 0;
}

.icon-phone {
    width: 22px;
    height: 22px;
}

.tel-number {
    aspect-ratio: 230 / 23;
    width: 100%;
}

.header-logo-sns {
    width: 32px;
    height: 32px;
}

.ham-box {
    width: 30px;
    height: 20px;
    cursor: pointer;
    margin-left: 26px;
    z-index: 3000;
}

.ham-bar,
.ham-bar::before,
.ham-bar::after {
    background: var(--color_dark);
    position: absolute;
    width: 100%;
    height: 2px;
    opacity: 1;
}

.ham-bar {
    top: 50%;
    transform: translateY(-50%);
}

.ham-bar::before {
    content: "";
    top: -10px;
}

.ham-bar::after {
    content: "";
    top: 10px;
}

.is-active .ham-bar {
    background-color: transparent !important;
    transform: rotate(180deg);
}

.is-active .ham-bar::before {
    background: var(--color_dark);
    transform: translateY(10px) rotate(-135deg);
    transition: 0.2s;
}

.is-active .ham-bar::after {
    background: var(--color_dark);
    transform: translateY(-10px) rotate(135deg);
    transition: 0.2s;
}

.ham-drawer {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    top: 0;
    left: 0;
    width: 100%;
    max-height: 100lvh;
    transition: .4s;
    opacity: 0;
    pointer-events: none;
    overflow-y: scroll;
    z-index: 2000;
}

.ham-drawer.is-active {
    opacity: 1;
    pointer-events: auto;
}

.ham-drawer_contents {
    padding-top: 5.625rem
}

#header .bnr-text {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

html.is-fixed {
    height: 100%;
    overflow: hidden;
}

@media screen and (min-width: 992px) {
    .header-wrapper {
        height: 54px;
    }

    .ham-drawer_contents {
        padding: 0;
    }
}

/*---------------------------------------------------
 sidebar
----------------------------------------------------*/
.sidebar {
    bottom: 0;
    right: 0;
    z-index: 9990;
}

.sidebar-item:nth-child(n+2) {
    margin-top: 0.75rem;
}

.sidebar-item {
    width: 100%;
    height: 55px;
}

.sidebar-item a {
    width: 100%;
    height: 100%;
}

@media screen and (min-width: 992px) {
    .sidebar {
        top: 12.5rem;
        right: 0;
    }

    .sidebar-item:nth-child(n+2) {
        margin-top: 0.75rem;
    }

    .sidebar-item {
        width: 55px;
        height: 180px;
    }

    .sidebar-item a {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        width: 100%;
        height: 100%;
    }
}

/*---------------------------------------------------
 breadcrumb
----------------------------------------------------*/
.breadcrumb-area {
    padding-top: 125px;
}

@media screen and (min-width: 992px) {
    .breadcrumb-area {
        padding-top: 105px;
    }
}

/*---------------------------------------------------
 pagination
----------------------------------------------------*/
.pagination .pagination-item {
    margin: 0;
}

.pagination .pagination-item .disable {
    pointer-events: none;
}

.pagination-arrow {
    width: 40px;
    height: 40px;
    margin: 0 10px;
}

.page-numbers {
    margin: 0 5px;
    padding: 0 10px;
    border-radius: 0 !important;
    color: var(--color_dark) !important;
    font-size: 18px;
    letter-spacing: 0.1em;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 2.5rem;
    transition: 0.3s;
}

.page-numbers.current {
    color: #E56161 !important;
}

.page-numbers.current:hover,
.page-numbers.dots:hover {
    opacity: 1;
}

.page-numbers:hover {
    opacity: 0.7;
}

.page-numbers.dots {
    pointer-events: none;
}

/*---------------------------------------------------
 footer
----------------------------------------------------*/
.footer-logo {
    max-width: 220px;
    width: 100%;
}

.footer-link-button {
    max-width: 260px;
    width: 100%;
    border-radius: 10px;
}

.arrow-right::after {
    position: absolute;
    content: "";
    border-right: 1px solid #6CB4B9;
    border-bottom: 1px solid #6CB4B9;
    width: 10px;
    height: 10px;
    top: 30%;
    left: 16px;
    transform: rotate(-45deg) translateY(-30%);
}