@charset "utf-8";

/* fonts */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500&family=Shippori+Mincho:wght@400;500;600;700&display=swap');

/* use 
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Shippori Mincho', serif;
*/

html {
    font-size: 10px;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    line-height: 1.6;
    background-color: #FFF;
    color: #675b5d;
}

@media (max-width:767px) {
    body {
        font-size: 1.4rem;
        line-height: 1.5;
        letter-spacing: 0.02em;
    }
}

#container {
    with: 100%;
    padding-top: 75px;
    /*background-color: rgba(0,0,0,0.008);*/
}

@media (max-width:767px) {
    body.isHome #container {
        padding-top: 64px;
    }
}

main {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    background-color: #FFF;
    position: relative;
    z-index: 0;
    padding-bottom: 75px;
}

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

a {
    color: #F87C8B;
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
}

a.aBlank {

}

a.aBlank::after {
    content: "";
    display: inline-block;
    margin-left: 5px;
    width: 16px;
    height: 16px;
    background-image: url("/wp-content/uploads/images/icn_blank.png");
    background-size: cover;
    opacity: 0.5;
}

a img {
    transition: 0.3s;
}

a img:hover {
    opacity: 0.3;
}

.spbr {
    display: none;
}
.spbr {
    display: inline;
}

span.smallText {
    font-size: 90%;
}


/* text */

main p {
    padding: 0 1em;
    margin: 0 0 0.75em 0;
    letter-spacing: 0.05em;
    text-align: justify;
}

main p.caption,
main span.caption {
    padding: 0 1em 0 2em;
    text-indent: -1em;
    font-size: 1.3rem;
}

h2,h3,h4,h5 {
    margin: 0;
}


/* bred */
#bread {
    width: 100%;
    font-size: 1.2rem;
    border-bottom: 2px solid #F4DFE2;
    opacity: 0.4;
}

#bread > div {
    padding: 5px 15px;
}

#bread ul {
    display: flex;
}

#bread ul li {
    margin-right: 10px;
}

#bread ul li,
#bread ul li a {
    display: block;
    background-repeat: no-repeat;
    text-decoration: none;
    color: #333;
}
#bread ul li a:hover {
    text-decoration: underline;
}

#bread ul li:first-child a {
    background-image: url("/wp-content/uploads/images/bred_home.png");
    background-size: 20px auto;
    padding-left: 25px;
}

#bread ul li:nth-child(n + 2) {
    background-image: url("/wp-content/uploads/images/bred_arr.png");
    background-size: 15px auto;
    padding-left: 15px;
}

/* section */
section {
    box-sizing: border-box;
    width: 100%;
    padding: 30px 20px;
}

.isHome section {
    margin-bottom: 50px;
}


section[id^="anc"] {
    padding-top: 100px;
    margin-top: -70px;
}

@media (max-width:767px) {
    section {
        padding: 30px 15px;
    }
}

div.smallSection {
    margin-bottom: 55px;
}

/* colmn */

.flexWrap {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.flexWrap .item:nth-child(odd) {
    padding-right: 10px;
}
.flexWrap .item:nth-child(even) {
    padding-left: 10px;
}

.flexWrap .item.w30 {
    width: 30%;
}

.flexWrap .item.w40 {
    width: 40%;
}

.flexWrap .item.w50 {
    width: 50%;
}

.flexWrap .item.w60 {
    width: 60%;
}

.flexWrap .item.w70 {
    width: 70%;
}

.flexWrap .item.w100 {
    width: 100%;
}

@media (max-width:767px) {
    .flexWrap .item {
        padding: 0 !important;
        margin-bottom: 15px;
        width: 100% !important;
    }
}


/* page title */

#pagetitle {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 35px 0 55px 0;
}

#pagetitle::before {
    display: block;
    content: "";
    width: 72px;
    height: 72px;
    background-size: cover;
    background-image: url("/wp-content/uploads/images/title_l.png");
    opacity: 0.5;
}
#pagetitle::after {
    display: block;
    content: "";
    width: 72px;
    height: 72px;
    background-size: cover;
    background-image: url("/wp-content/uploads/images/title_r.png");
    opacity: 0.5;
}

#pagetitle h2 {
    display: inline-block;
    font-size: 3.2rem;
    font-weight: 600;
    font-family: 'Shippori Mincho', serif;
    margin: 0 15px;
    border-bottom: 2px solid #F4DFE2;
}

@media (max-width:767px) {
    #pagetitle h2 {
        font-size: 2.2rem;
    }
    #pagetitle::before,
    #pagetitle::after {
        width: 40px;
        height: 40px;
    }
}



.sectionTitle {
    background-image: url("/wp-content/uploads/images/leaf.png");
    background-repeat: no-repeat;
    background-size: 30px auto;
    min-height: 48px;
    padding-left: 40px;
    margin-bottom: 35px;
    font-family: 'Shippori Mincho', serif;
}

.sectionTitle.red,
.sectionTitle.blue,
.sectionTitle.green,
.sectionTitle.yellow {
    background-size: 36px auto;
    background-image: url("/wp-content/uploads/images/bird_red.png");
    padding-left: 50px;
}
.sectionTitle.blue {
    background-image: url("/wp-content/uploads/images/bird_blue.png");
    background-position: left 10px;
}
.sectionTitle.green {
    background-image: url("/wp-content/uploads/images/bird_gren.png");
    background-position: left 10px;
}
.sectionTitle.yellow {
    background-image: url("/wp-content/uploads/images/bird_yel.png");
}

.sectionTitle.redSmall,
.sectionTitle.blueSmall,
.sectionTitle.greenSmall,
.sectionTitle.yellowSmall {
    background-image: url("/wp-content/uploads/images/icn_link_red.png");
    margin: 0 0 15px auto;
    width: calc(100% - 1em);
}
.sectionTitle.blueSmall {
    background-image: url("/wp-content/uploads/images/icn_link_blue.png");
}
.sectionTitle.greenSmall {
    background-image: url("/wp-content/uploads/images/icn_link_gren.png");
}
.sectionTitle.yellowSmall {
    background-image: url("/wp-content/uploads/images/icn_link_yel.png");
}

.sectionTitle.redXsmall,
.sectionTitle.blueXsmall,
.sectionTitle.greenXsmall,
.sectionTitle.yellowXsmall {
    margin: 50px 0 15px auto;
    width: calc(100% - 1em);
    height: auto;
    min-height: initial;
    background-image: none;
    position: relative;
}

.sectionTitle.redXsmall::before,
.sectionTitle.blueXsmall::before,
.sectionTitle.greenXsmall::before,
.sectionTitle.yellowXsmall::before {
    content: "";
    width: 20px;
    height: 3px;
    left: 0;
    top: 50%;
    background-color: #F0BBB7;
    position: absolute;
}
.sectionTitle.blueXsmall::before {
    background-color: #DCE9FA;
}
.sectionTitle.greenXsmall::before {
    background-color: #AAD9B7;
}
.sectionTitle.yellowXsmall::before {
    background-color: #FFEEC6;
}

.sectionTitle h3 {
    font-size: 2.6rem;
    font-weight: 500;
    border-bottom: 1px solid #F4DFE2;
}


.sectionTitle.blueSmall h4,
.sectionTitle.redSmall h4,
.sectionTitle.greenSmall h4,
.sectionTitle.yellowSmall h4 {
    font-size: 2rem;
    font-weight: 500;
    border-bottom: 1px solid #F4DFE2;
}
.sectionTitle.blueSmall h4 {
    border-bottom: 1px solid #DCE9FA;
}
.sectionTitle.greenSmall h4 {
    border-bottom: 1px solid #E5F1CD;
}
.sectionTitle.yellowSmall h4 {
    border-bottom: 1px solid #FFEEC6;
}

.sectionTitle.redXsmall h5,
.sectionTitle.blueXsmall h5,
.sectionTitle.greenXsmall h5,
.sectionTitle.yellowXsmall h5 {
    font-size: 1.8rem;
    font-weight: 500;
}

h6.smallTitle {
    font-size: 1.6rem;
    font-weight: 700;
    font-family: 'Shippori Mincho', serif;
    margin: 2em 0 1em 0;
    padding-left: 1em;
}

@media (max-width:767px) {
    .sectionTitle {
        background-size: 24px auto;
        min-height: 32px;
        padding-left: 30px;
    }
    .sectionTitle h3 {
        font-size: 2rem;
    }
    
    .sectionTitle.redSmall h4,
    .sectionTitle.blueSmall h4,
    .sectionTitle.greenSmall h4,
    .sectionTitle.yellowSmall h4 {
        font-size: 1.8rem;
    }

    .sectionTitle.redXsmall h5,
    .sectionTitle.blueXsmall h5,
    .sectionTitle.greenXsmall h5,
    .sectionTitle.yellowXsmall h5 {
        font-size: 1.6rem;
    }
    h6.smallTitle {
        font-size: 1.4rem;
    }
}


/* margin */

.mb_small {
    margin-bottom: 15px !important;
}

.mb_midium {
    margin-bottom: 25px !important;
}

.mb_large {
    margin-bottom: 40px !important;
}

.mt_small {
    margin-top: 15px !important;
}

.mt_midium {
    margin-top: 25px !important;
}

.mt_large {
    margin-top: 40px !important;
}


/* list */

ul.dotMkr {
    padding-left: 1em;
}
ul.dotMkr li {
    text-indent: -1em;
    padding-left: 1em;
    margin-bottom: 0.75em;
}
ul.dotMkr li::before {
    content: "・";
    display: inline;
}

ul.noMkr {
    padding-left: 1em;
}
ul.noMkr li {
    text-indent: -1em;
    padding-left: 1em;
    margin-bottom: 0.75em;
}




/* table */

p.tableCap {
    margin-top: 1em;
    text-indent: -1em;
    padding-left: 2em;
    font-size: 1.3rem;
}


/* image */

.photoFrame {
    border: 8px solid #FFF;
    box-shadow: 0 0 5px rgba(0,0,0,0.1);
    position: relative;
    box-sizing: border-box;
    padding: 0;
}

.photoFrame.smallPhoto {
    max-width: 320px;
}

.photoFrame.smallPhoto.inline {
    display: inline-block;
    margin-right: 1em;
}

.photoFrame img {
    border: 1px solid #EEE;
}

.photoFrame > span {
    font-size: 1.1rem;
    position: absolute;
    right: 5px;
    bottom: 5px;
}

.photoFrame.blk span {
    color: #000;
    text-shadow: 0 0 3px #FFF;
}
.photoFrame.wht span {
    color: #FFF;
    text-shadow: 0 0 3px #000;
}

