@charset "UTF-8";

/*
Theme Name: habichal
Author: BORDER Inc.
*/

@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Noto+Sans+JP:wght@100..900&family=Zen+Kaku+Gothic+New&display=swap');

:root {
    --color-brand: #002655;
    --color-brand-green: #00b1b2;
    --color-brand-blue: #00a5ea;
    --color-brand-orange: #f99a00;
    --color-brand-sky: #5a96be;
    --color-black: #000;
    --color-dark-gray: #67747b;
    --color-gray: #888888;
    --color-light-gray: #f4f5f5;
    --color-bg-gray: #FAFCFD;
    --color-footer: #f9fafa;
}

html,
body {
    height: 100%;
}

body {
    font-family: YuGothic, "Zen Kaku Gothic New", YuGothic-M, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    color: #261f1e;
    background-color: #FFFFFF;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: .1em;
    font-size: 1em;
    -webkit-text-size-adjust: 100%;
    font-feature-settings: "palt";
}

.font-noto {
    font-family: "Noto Sans JP", sans-serif;
}

.font-num {
    font-family: "Be Vietnam Pro", sans-serif;
}

.fs-10 {
    font-size: 10px;
}

.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl {
    --bs-gutter-x: 32px;
}

button {
    padding: 0;
    background-color: transparent;
    border: none;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

[class^="d-"]>img,
[class*=" d-"]>img,
.d-flex img,
.card img,
.row img {
    flex: none;
}

a,
*::after,
*::before,
a span,
a img,
a svg,
button {
    color: inherit;
    -webkit-transition-duration: .16s;
    -webkit-transition-property: color, border-color, background-color, opacity;
    -webkit-transition-delay: 0s;
    transition-duration: .16s;
    transition-property: color, border-color, background-color, opacity;
    transition-delay: 0s;
    outline: none !important;
}

a:visited,
a:link,
a:active,
a:hover {
    text-decoration: none;
}

.nav-link,
.nav-link:hover,
a:hover {
    color: inherit;
}

a:hover img,
a:hover svg,
.pointer:hover {
    opacity: 0.7;
}

.form-min {
    width: 100px;
}

.form-minmin {
    width: 60px;
}

.post-content img {
    max-width: 100%;
    height: auto;
}

.navbar-custom {
    position: fixed !important;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
    color: inherit;
    -webkit-transition-duration: .40s;
    -webkit-transition-property: color, border-color, background-color, opacity;
    -webkit-transition-delay: 0s;
    transition-duration: .40s;
    transition-property: color, border-color, background-color, opacity;
    transition-delay: 0s;
    min-height: 58px;
}


.navbar-custom.affix {
    background-color: #fcfdfd;
    box-shadow: 0 0 10px 0 rgb(0 0 0 / 15%);
    padding-top: 0 !important;
}

#drawer {
    background: none;
    border: none;
    padding: 0;
    position: absolute;
    background-image: none;
    top: 0;
    right: 16px;
    left: auto;
    top: 50%;
    transform: translateY(-50%);
}

.icon-bar {
    display: block;
    width: 24px;
    height: 1px;
    border-radius: 1px;
    border-color: transparent;
    cursor: pointer;
    margin: auto;
    background-color: #2f2725;
}

.icon-bar+.icon-bar {
    margin-top: 6px;
}

.btn-close {
    width: 21px;
    height: 21px;
    --bs-btn-close-bg: none;
    position: relative;
    z-index: 10;
}

.btn-close:before {
    content: '';
    position: absolute;
    top: 50%;
    left: 40%;
    width: 21px;
    height: 1px;
    background-color: currentColor;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.btn-close:after {
    content: '';
    position: absolute;
    top: 50%;
    left: 40%;
    width: 21px;
    height: 1px;
    background-color: currentColor;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.offcanvas,
.offcanvas-lg,
.offcanvas-md,
.offcanvas-sm,
.offcanvas-xl,
.offcanvas-xxl {
    --bs-offcanvas-width: 256px;
}

.ls-0 {
    letter-spacing: 0;
}

.ls-normal {
    letter-spacing: .064em;
}

.ls-wide {
    letter-spacing: 0.3rem;
}

.hover-bottom-line span {
    position: relative;
}

.hover-bottom-line span::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    border-radius: 50%;
    background: var(--color-brand);
    transition: all .3s;
    transform: scale(0, 1);
    transform-origin: center bottom;
}

.hover-bottom-line.active span::after,
.hover-bottom-line:hover span::after {
    height: 1px;
    border-radius: 0;
    transform: scale(1, 1);
}

.nav-underline .nav-link {
    transition: all .3s;
}

.nav-underline .nav-link.active,
.nav-underline .show>.nav-link,
.nav-underline .nav-link:hover {
    font-weight: 400;
    color: var(--color-brand);
    border-bottom-color: var(--color-brand);
    transform: scale(1, 1);
}

a.link-underline-hover {
    text-decoration: underline !important;
    text-underline-offset: 0.32rem !important;
    --bs-link-underline-opacity: 0;
    text-decoration-color: var(--color-brand) !important;
}

a.link-underline-hover:hover {
    --bs-link-underline-opacity: 0.75;
    text-decoration: underline !important;
}

.fadein {
    opacity: 0;
    transform: translate(0, 50px);
    transition: all 0.8s;
}

.fadein.scrollin {
    opacity: 1;
    transform: translate(0, 0);
}

.table-like-title,
.table-like-text {
    padding: 0.75em;
}

#pageTop {
    position: fixed;
    right: 8px;
    bottom: 0;
    width: 80px;
    transition: .3s;
    z-index: 999;
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
    opacity: 0;
    visibility: hidden;

}

#pageTop.active {
    opacity: 1;
    visibility: visible;
}

#pageTop.absolute {
    position: absolute;
    top: -48px;
    bottom: auto;
}

.navbar-nav .nav-link.active,
.navbar-nav .nav-link.show,
.nav-link:focus,
.nav-link:hover {
    color: inherit;
}

.page-link {
    color: #000 !important;
    border-color: transparent;
    background-color: transparent;
    align-items: center;
    border-radius: 70px !important;
    display: flex;
    height: 40px;
    justify-content: center;
    line-height: 27.36px;
    width: 40px;
}


a.page-link {
    color: #2f2725 !important;
    border-color: var(--color-brand) !important;
    background-color: #fff;
    font-size: 0.875rem;
}

.active>.page-link,
.page-link.active {
    background: var(--color-brand);
    color: #fff !important;
    border-color: transparent;
}

#singlePoost img {
    max-width: 100%;
    height: auto;
}

#singlePoost a {
    color: var(--color-brand-blue);
    -bs-link-underline-opacity: 0;
    text-underline-offset: 0.25em !important;
}

#singlePoost a:hover {
    --bs-link-underline-opacity: 1;
    -webkit-text-decoration-color: rgba(var(--bs-link-color-rgb),var(--bs-link-underline-opacity,1))!important;
    text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
    text-decoration: underline !important;
}

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

.text-brand-green {
    color: var(--color-brand-green);
}

.text-brand-blue {
    color: var(--color-brand-blue);
}

.text-brand-orange {
    color: var(--color-brand-orange);
}

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

.hover-btn {
    background-color: #fff;
}
.hover-btn:hover,
.bg-brand {
    background-color: var(--color-brand);
    color: #fff;
}

.bg-brand-discussion,
.bg-brand-green {
    background-color: var(--color-brand-green);
    color: #fff;
}

.bg-brand-blue {
    background-color: var(--color-brand-blue);
    color: #fff;
}

.bg-brand-lecture,
.bg-brand-orange {
    background-color: var(--color-brand-orange);
    color: #fff;
}
.news-cat,
.bg-brand-sky {
    background-color: var(--color-brand-sky);
    color: #fff;
}

.bg-brand-green-op {
    background-color: #00b2b31a;
}

.bg-brand-blue-op {
    background-color: #00a4eb1a;
}

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

.report-cat,
.bg-navy {
    background-color: #003c8c;
    color: #fff;
}

.text-date {
    color: #7d7d7d;
}

.hover-btn {
    color: var(--color-brand);
    border-color: var(--color-brand);
}

#headerHome {
    background-image: url(img/headerbg.jpg);
    background-size: cover;
    background-position: top center;
}
#headerBn img {
    height: 100%;
    max-height: 56px;
    min-height: 36px;
    width: 100%;
}

#courseTable .col-md-3,
#courseTable .col {
    border: 1px solid #251e1d80;
    margin-top: -1px;
    margin-left: -1px;
}


.imageTrimming {
    position: relative;
}

.imageTrimming img {
    object-fit: cover;
    aspect-ratio: 30 / 19;
}

.swiper-pagination-bullet-active {
    background: var(--color-brand);
}

.eventday {
    width: 248px;
}

#schedule .list-group-item,
#schedule .border-bottom-dotted {
    border: none !important;
    border-bottom: none !important;
    background-image: linear-gradient(to right, #d8dfee 2px, transparent 2px);
    background-size: 10px 2px;
    background-repeat: repeat-x;
    background-position: bottom;
}


#schedule .list-group-item a:hover {
    background-color: var(--color-light-gray);
}


#programHope th.table-title {
    min-width: 178px;
}

#programCommunity th.table-title {
    min-width: 98px;
}

#programHope td {
    font-size: .84rem;
}

#programHope th,
#programHope td,
#programCommunity td {
    vertical-align: middle;
}

@media (min-width: 992px) {
    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
    }

}


@media (max-width: 575.98px) {
    .lead {
        font-size: 1rem;
    }

    .ratio-21x9 {
        --bs-aspect-ratio: 100%;
    }

    .swiper-next,
    .swiper-prev {
        width: 2rem;
        height: 4rem;
    }

    .swiper-prev::before {
        content: "";
        position: absolute;
        width: 2rem;
        height: 4rem;
        background: #fff;
        border-radius: 0 2rem 2rem 0;
    }

    .swiper-next::before {
        content: "";
        position: absolute;
        width: 2rem;
        height: 4rem;
        background: #fff;
        border-radius: 2rem 0 0 2rem;
    }

}