/* Google Fonts*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Krub:wght@200;300;400;500;600;700&display=swap');

html {
    font-size: 16px;
}

body {
    font-family: 'Krub', sans-serif;
    color: #8A735F;
    /* brown ++ */

    font-size: 1rem;
    font-weight: 400;
}

/*
color: #665546;  brown +++
color: #8A735F;  brown ++
color: #7083be;  purple +++
color: #A0B2DB;  purple +
color: #f06595;  pink +++
color: #F288B7;  pink ++
*/


/* ------------------------------------------------------- 

BASIC ELEMENTS

------------------------------------------------------- */
h1,
h2,
h3,
h4,
h5 {
    line-height: 1.2;
    font-family: 'Playfair Display', serif;
}

/* h : Default font-weight:500 */
p {}

a {
    color: #7083be;
    /* purple +++ */
    text-decoration-line: none;
    cursor: pointer;
}

a:hover {
    font-weight: 600;
}

a,
button {
    -webkit-transition: all 0.3s ease-in-out 0s;
    transition: all 0.3s ease-in-out 0s;
}

hr {
    border-color: #ddd;
    /*light gray */
}

/* ------------------------------------------------------- 

IMAGES - ALL

------------------------------------------------------- */
.img-small {
    max-width: 300px;
}

.img-medium {
    max-width: 400px;
}

.img-headline {
    max-width: 400px;
}

@media (max-width: 1199px) {}

@media (max-width: 991px) {}

@media (max-width: 767px) {}

@media (max-width: 575px) {}

.img-mobile {
    max-width: 300px;
}

.img-about1 {
    max-width: 240px;
}

.img-about2 {
    max-width: 200px;
}

/* ------------------------------------------------------- 

PAGES - HOME

------------------------------------------------------- */
#home .main-title {
    text-align: center;
    background-color: rgb(247, 183, 212);
    /*pale pink*/
    padding: 2rem 0 1rem 0;
    margin-top: 0;
}

#home h2 {
    font-size: 2rem;
    /* Playfair */
    color: #665546;
    /* brown +++ */
}
@media (max-width: 767px) {
   #home h2 {
        font-size: 1.75rem;
    }
}
#home .welcome {
    font-size: 1.5rem;
    margin-bottom: .5rem;
}
@media (max-width: 767px) {
   #home .welcome {
        font-size: 1.15rem;
    }
}
#home .intro {
    font-size: 1rem;
    display: block;
    margin-top: 1.75rem;
    margin-bottom: 1rem;
    line-height: 1.2;
    color: #fff;
    letter-spacing: 0.03em;
}

#home .main-image {
    background: url('./images/header/img_home.jpg') no-repeat center center;
    background-size: 70% auto;
    height: 550px;
}

@media (max-width: 1199px) {
    #home .main-image {
        background-size: cover;
        background-image: url('./images/header/img_home.jpg');
        height: 500px;
    }
}

@media (max-width: 991px) {}

@media (max-width: 767px) {}

@media (max-width: 575px) {}


#home .subpages-wrap {
    padding-top: 2.5rem;
    padding-bottom: 1.5rem;
}

#home .subpage-box {
    margin-bottom: 2.5rem;
    text-align: center;
}

#home .subpage-box h3 {
    font-size: 1.5rem;
    font-weight: 500;
    color: #8A735F;
    /* brown ++ */
    color: #665546;
    /* brown +++ */

}

#home .subpage-box img {
    margin-top: 0.75rem;
    margin-bottom: 1.5rem;
}

#home .subpage-box p {
    font-size: 0.9rem;
    font-size: 0.93rem;
    line-height: 1.1;
    font-weight: 500;
}

#home .leaf-green {
    color: darkseagreen;
}

#home a.readmore {
    color: #f06595;
    /*pink +++ */
    text-decoration-line: underline;
    font-size: 0.9rem;
    font-weight: 500;
}

#home a.readmore:hover {
    color: #f06595;
    /*pink +++ */
    font-weight: 700;
}

/* ------------------------------------------------------- 

HEADER - ALL PAGES

------------------------------------------------------- */




/* ------------------------------------------------------- 

ALL SUB PAGES

------------------------------------------------------- */
.filter-blk {
    background-color: rgba(0, 0, 0, 0.1);
}

.kt-subpage1 .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_home.jpg') no-repeat;
    background-size: 100%;
    background-position: center right;
}

.kt-subpage1 h2 {
    font-family: 'Krub', sans-serif;
    font-size: 2.5rem;
    font-weight: 200;
    color: #fff;
    /* white */
    letter-spacing: 0.1em;
    margin: 6rem 0;
}

@media (max-width: 991px) {
    .kt-subpage1 h2 {
        padding: 0;
        margin: 6rem 0;
    }
}

@media (max-width: 767px) {
    .kt-subpage1 h2 {
        padding: 0;
        margin: 4rem 0;
    }
}

@media (max-width: 575px) {
    #service h2 {
        padding: 0;
        margin: 3rem 0;
    }
}


.kt-subpage1 h3 {
    font-size: 2rem;
    font-weight: 600;
    color: #665546;
    /* brown +++ */
    margin: 2rem 0;
}

#telepractice h3,
#about h3,
#rebates h3 {}

#community h3 {}

@media (max-width: 767px) {
    .kt-subpage1 h3 {
        font-size: 1.75rem;
    }

}

.kt-subpage1 h4 {
    font-size: 1.5rem;
    font-weight: 500;
    color: #7083be;
    /*purple +++ */
    margin: 2rem 0 1.5rem 0;
}



#telepractice h4,
#about h4,
#rebates h4 {}

#community h4 {
    color: #F288B7;
    /*pink ++ */
    margin-top: 0;
}

#links h4 {
    color: #665546;
    /* brown +++ */
    margin: 3.5rem 0 2.5rem 0;
}

@media (max-width: 767px) {
    .kt-subpage1 h4 {
        font-size: 1.4rem;
    }

}


.kt-subpage1 h5 {
    color: #665546;
    /* brown +++ */
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    font-weight: 400;
    margin: 2rem 0 1.5rem 0;
}

#service h5 {
    color: #F288B7;
    /*pink ++ */
}

#links h5 {
    color: #F288B7;
    /*pink ++ */
    font-size: 1.15rem;
    font-weight: 600;
    margin: 2rem 0 2rem 0;

}

.kt-subpage1 p {
    font-size: 0.95rem;
    font-weight: 500;
    margin-bottom: 1.5rem;
    line-height: 1.5;
}

#about p {
    line-height: 1.7;
}

#services p {
    line-height: 1.6;
}

.kt-subpage1 .description {
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.3;
    margin: 1.5rem 0;
    display: block;
}

#telepractice .description,
#rebates .description {}

@media (max-width: 767px) {
    .kt-subpage1 .description {
        font-size: 1.15rem;
    }
}


.kt-subpage1 .group-label-1 {
    font-size: 1.75rem;
    font-weight: 500;
    color: #fff;
    padding: 0.8rem;
    background-color: #889BCD;
    /*purple ++ */
}

@media (max-width: 767px) {
    .kt-subpage1 .group-label-1 {
        font-size: 1.5rem;
    }
}


.kt-subpage1 .content-wrap1 {
    margin-top: 3rem;
    margin-bottom: 3rem;
    padding: 1.5rem;
}

.kt-subpage1 .left-col-wrap {
    margin-bottom: 3rem;
}

.kt-subpage1 .right-col-wrap {
    padding-left: 2rem;
    border-left: 1px dashed #d1d1d1;
}

/* For Small Device */
@media (max-width: 991px) {
    .kt-subpage1 .right-col-wrap {
        padding-left: 15px;
        border-left: none;
    }
}

/* ------------------------------------------------------- 

PAGES - SERVICES

------------------------------------------------------- */
#services .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_services.jpg') no-repeat;
    background-size: 100%;
    background-position: center right;
}

#services .step-number {
    color: #F288B7;
    /*pink ++ */

}

#services ul li {
    font-size: .95rem;
    font-weight: 500;
    line-height: 1.3;
    margin-bottom: 0.85rem;

}

#services ul.large {
    margin-top: 2.75rem;
    margin-bottom: 3.75rem;
}

#services ul.large li {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.1;
    margin-bottom: 0.85rem;
}



/* ------------------------------------------------------- 

PAGES - Community-based

------------------------------------------------------- */
#community .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_comm.jpg') no-repeat;
    background-size: 100%;
    background-position: center right;
}


.qa-box {
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    margin-bottom: 1rem;
    background-color: #fff;
    display: flex;
}

.qa-img {
    width: 275px;
    background-size: 100%;
    background-position: center center;
    background-repeat: no-repeat;
    opacity: 0.7;
}

.qa-text {
    width: calc(100% - 275px);
    padding: 2rem;

}

.qa-text p {}

@media (max-width: 767px) {
    .qa-box {
        display: block;
    }

    .qa-img {
        width: 100%;
        background-size: cover;
        height: 200px;
    }

    .qa-text {
        width: 100%;
    }
}


/* ------------------------------------------------------- 

PAGES - Telepractice

------------------------------------------------------- */
#telepractice .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_tele.jpg') no-repeat;

    background-size: 100%;
    background-position: center right;
}

#telepractice ul li {}

#telepractice ul.desc {}

#telepractice ul.desc li {
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.1;
    margin-bottom: 0.75rem;
}

/* ------------------------------------------------------- 

PAGES - ABOUT

------------------------------------------------------- */
#about .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_about.jpg') no-repeat;

    background-size: 100%;
    background-position: center right;
}

.thumbnail {
    display: inline-block;
    height: 220px;
    margin-right: 15px;
    margin-bottom: 15px;

}

.thumbnail img {
    height: 100%;
}

/* ------------------------------------------------------- 

PAGES - bilingual

------------------------------------------------------- */
#bilingual .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_bilingual.jpg') no-repeat;
    background-size: 100%;
    background-position: center right;
}

/* ------------------------------------------------------- 

PAGES - REBATES

------------------------------------------------------- */
#rebates .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_fund.jpg') no-repeat;

    background-size: 100%;
    background-position: center right;
}

/* ------------------------------------------------------- 

PAGES - LINKS - MILESTONES

------------------------------------------------------- */

#links ul li {
    font-size: 0.9rem;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 0.6rem;
}

#links .ref {
    font-size: small;
    font-weight: 400;
    display: block;
}

/* ------------------------------------------------------- 

PAGES - LINKS - USEFUL LINKS

------------------------------------------------------- */
#links .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_useful.jpg') no-repeat;
    background-size: 100%;
    background-position: center right;
}

#links ul.linklist {
    text-align: center;
    list-style: none;
    padding-left: 0;
}

#links ul.linklist li {
    font-size: 1.2rem;
    word-break: break-all;
}

@media (max-width: 575px) {
    #links ul.linklist li {
        font-size: 1rem;
    }
}

#links ul.linklist li a {
    font-size: 1rem;
    display: block;
    margin-bottom: 2rem;
    text-decoration-line: underline;
}



/* ------------------------------------------------------- 

PAGES - CONTACT

------------------------------------------------------- */
#contact .pagetitle-wrap {
    text-align: center;
    background: url('./images/header/img_contact.jpg') no-repeat;

    background-size: 100%;
    background-position: center right;
}

.lead {
    font-size: 1.5rem;
    font-weight: 400;
}

.help-block {
    color: #f06595;
}

.result-msg {
    margin-bottom: 200px !important;
    font-size: 1.2rem;
}

/* 送信ボタン */
a.theme_button,
button.theme_button {
    display: inline-block;
    padding: .9em 5.5em;
    text-transform: uppercase;
    font-size: .8em;
    font-weight: 600;
    border: 2px solid #f288b7;
    border-radius: 2em;
    background-color: #f288b7;
    color: #fff;
    text-decoration: none !important;
}

@media (max-width: 991px) {

    a.theme_button,
    button.theme_button {
        padding: .9em 1.5em;
    }
}

a.theme_button:hover,
button.theme_button:hover {
    background-color: #fff;
    color: #f288b7;
}

a.theme_button.s,
button.theme_button.s {
    padding: .9em 1.5em;
}

/* ------------------------------------------------------- 

FOOTER - ALL PAGES

------------------------------------------------------- */
.footer {
    border-top: 1px solid #ddd;
    border-top: none;
}

.foot-subtitle {
    text-transform: uppercase;
    margin-bottom: .5rem;
    display: block;
    color: #f06595;
}

.foot-title {
    font-family: 'Playfair Display', serif;
    color: #665546;
    /* brown ++ */
    line-height: 1.1;
    font-size: 1.5rem;
    display: block;
    margin-bottom: 0.4rem;
}

.foot-desc {
    font-size: 0.85rem;
    font-weight: 500;
    display: block;
    line-height: 1.4;
}

.foot-contact {
    font-size: 1.5rem;
}

a.foot-link {
    color: #fff;
}

.cpsp-logo {
    width: 90%;
    max-width: 400px;
    margin-bottom: 1rem;
}

.kt-copy {
    font-size: small;
}

ul.footer-nav li {
    margin-bottom: 0.5rem;
}

/* ------------------------------------------------------- 

COMMON PARTS

------------------------------------------------------- */
/* 上へ戻るアイコン */
.btt {
    position: fixed;
    right: 30px;
    bottom: 30px;
    font-size: 2rem;
    cursor: pointer;
    color: rgb(247, 183, 212);
    z-index: 9999;
}

/* 背景のバブル（左）： 未使用 */
.bg-bubbles-l {
    background: url('./images/common/bg-bubbles2-op.png') repeat-y bottom left / 30%
}

/* 背景のバブル（右）： Home */
.bg-bubbles-r {
    background: url('./images/common/bg-bubbles2-op.png') repeat-y bottom right / 30%;
}

/* 背景のバブル（左右）： Other all pages */
.bg-bubbles-lr {
    background: url('./images/common/bg-bubbles2-op.png') repeat-y top left / 25%, url('./images/common/bg-bubbles2.png') repeat-y bottom right / 25%;
}

@media (max-width: 575px) {

    .bg-bubbles-lr,
    .bg-bubbles-l,
    .bg-bubbles-r {
        background-size: 40%;
    }
}

/* コンテンツのフェードイン */

.fadeIn {
    opacity: 0;
    transition: 3s;
}

.fadeIn.is-show {
    opacity: 1;
}

.flex {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}

/* ------------------------------------------------------- 

COLOR

------------------------------------------------------- */
.white {
    color: white;
}

.pink {
    color: #f06595;
    /* pink +++ */
}

.dustypink {
    color: #F288B7;
    /* pink ++ */
}

.dustyblue {
    color: #A0B2DB;
    /* purple + */
}

.bg-white {
    background-color: #fff;
}

.bg-lightgrey {
    background-color: #f8f8f8;
}

.bg-pink2 {
    background-color: #f288b7;
}

.bg-clear {
    background-color: transparent;
}


/* ------------------------------------------------------- 

NAVIBAR

------------------------------------------------------- */
.navbar-brand img {
    width: 175px;
}

@media (max-width: 767px) {
    .navbar-brand img {
        width: 150px;
    }
}

@media (max-width: 575px) {
    .navbar-brand img {
        width: 125px;
    }
}

.navbar-narrow {}

.navbar-light .navbar-nav .nav-link {
    font-size: 0.95rem;
    font-weight: 600;
    font-weight: 500;
    text-decoration-line: none;
    padding: 0 0.5rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: #8A735F;
    /* brown ++ */
    line-height: 1.1;

}

@media (max-width: 767px) {
    .navbar-light .navbar-nav .nav-link {
        font-size: 1.2rem;
        font-weight: 600;
    }
}

.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.active,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .show > .nav-link {

    border-bottom: 4px solid #f7b7d4;
    /* pink + */
    color: #f7b7d4;
    /* pink + */
}

.navbar-light .navbar-nav .nav-link:hover {
    border-bottom: 4px solid #f7b7d4;
    /* pink + */
    color: #f7b7d4;
    /* pink + */
}

.navbar-light .navbar-toggler {
    border: none;
    background-color: transparent;
}

.navbar-toggler .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(240, 101, 149,1)' stroke-width='3' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

.is-hide {
    display: none;
}

/* ------------------------------------------------------- 

OTHER（レスポンシブ対応）

------------------------------------------------------- */
@media (max-width: 991px) {}

@media (max-width: 767px) {}

@media (max-width: 575px) {}
