@charset "UTF-8";
@import url("grid.css");

body {
    font-family: 'Kosugi', sans-serif;
}

img {
	max-width:100%;
	height: auto;/*高さ自動*/
}
a {
    display:block;
    color: #666;
    text-decoration-line: none;
}
a:hover { 
    color: #999;
    text-decoration: underline;
}
a img:hover {
	opacity: 0.8;
}

h1,h2,h3,h4,h5,h6,.head a {
    font-family: 'Kaisei Opti', serif;
}
h1 {
    border: none;
    position: relative;
    padding: .5em 1em;
}
h1:after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 5px;
    width: 100%;
    background-image: repeating-linear-gradient(-45deg, #6eaf6e, #6eaf6e 5px, #effffb 0, #effffb 10px);
}
.mainimg h1{
    border: initial;
    position: initial;
    padding: initial;
}
.mainimg h1:after {
    content: initial;
    position: initial;
    left: initial;
    bottom: initial;
    height: initial;
    width: initial;
    background-image: initial;
}
h2 {
    border: none;
    position: relative;
    padding: .5em 1em;
    margin: 2rem 0;
    background-color: #f6fff7;/*付箋の色*/
    border-left: 20px solid #6eaf6e;/*左端のポイント色*/
    border-radius: 8px;
}
h3 {
    margin: 2rem 0;
	border-bottom: 3px solid #6eaf6e;
	padding-bottom: 0.5rem;
}
.head a {
    font-size: 3rem;
    margin-bottom: 2rem;
}
mark {
    background: linear-gradient(transparent 80%, #FFF100 0%);
    color: #76421f;
    padding: 4px;
    font-size: 20px;
    font-weight: 700;
}

/*ヘッダー
-------------------------------------*/
.head {
	display: flex;
    flex-direction: row;
    padding: 1rem 0 0 0;
}

.head h1 { 
    padding: 1rem 0;
}
.telbox {
	margin-left: auto;
	font-size: 3.0rem;
	padding: 1rem 0 0 0;
}
nav ul {
	display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    list-style: none;
	margin-bottom: 1rem;
}
nav li {
    display: block;
    flex: 0 0 33%;
}
nav li a {
    text-decoration: none;
    text-align: center;
    margin: 1rem 1rem 0 1rem;
}
nav a:hover {
    text-decoration: underline;    
}
nav a img {
    border: solid 10px #f0f0f0;
}

@media screen and (min-width: 768px){
/* PC時はMENUボタンを非表示 */
#open,#close {
    display: none !important;
}

#navi {
    display: block !important;
}
}

.topicon img {
    cursor: pointer;
    border-radius: 50%;
    transition-duration: 0.3s;
}
.topicon img:hover {
    border-radius: 10%;
    transition-duration: 0.3s;
}

@media screen and (max-width: 768px){
.head {
	flex-direction: column;
    text-align: left;
    margin-bottom: 20px;
}
.head #open,#close  {
    position: absolute;
    top: 28px;
    right: 12px;
    }
nav ul {
	flex-flow: row wrap;
}

nav li {
	padding-top: 0;
	margin-bottom: 0;
    flex: 0 0 49%;
}
/* スマホ時はMENUボタンを表示 */
#open {
    display: block;
    background: url(../img/button.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    border: none;
    position: absolute;
    top: 20px;
    right: 12px;
}
#close  {
    display: block;
    background: url(../img/button2.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    border: none;
    position: absolute;
    top: 20px;
    right: 12px;
}
/* スマホ時はメニューを非表示 */
#navi {
    display: none;
}
}

/*メイン画像
-------------------------------------*/
.mainimg img {
	width: 100vw;
}
.kadomaru img {
    border-radius: 30px;
}

/*メインコンテンツ
-------------------------------------*/
main {
    margin:0 0 5rem 0;
}
.kakomiwaku {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 3rem;
    padding: 1em;
  background: #fff;
  border-radius: 10px 50px/50px 20px;
  border: dashed 3px rgb(124, 198, 151);
   }
   .kakomiwaku2 {
    width: 90%;
    margin: 0 auto;
    margin-bottom: 3rem;
    padding: 1em;
  background: #fff;
  border-radius: 50px 50px/30px 20px;
  border: dashed 3px rgb(165, 172, 168);
   }
.kakomiwaku2 a {
    display: inline-block;
}
.circle1 img,
.circle2 img {
    color: #fff;
    padding: 2%;
    width: 100%;
    height: 100%;
    margin: 0 -15px;
    mix-blend-mode: multiply;
   }
.circle1 img {
    background: #eee;
    border-radius: 50% 50% 50% 70%/50% 50% 70% 60%;
}
.circle2 img {
    background: #eee;
    border-radius: 50% 30% 50% 50%/50%;
}
.circle1 img:hover, .circle2 img:hover {
    border-radius: 30%;
    transition-duration: 0.3s;
}
.kako a {
    display: inline-block;
}

/*ページャー
-------------------------------------*/
.pager {
    list-style-type: none;
}
.middle {
    vertical-align: middle; 
    padding-right: 0.3em;
}
.pager li a, .mokuji li a {
    color: #447244;
}
/*もくじ
-------------------------------------*/
.mokuji-wrap p, .mokuji-wrap table {
    margin-bottom: 0;
}
.mokuji a {
    display: inline-block;
}
.mokuji-midashi {
    margin-top: 0;
}


/*フッター
-------------------------------------*/
.footerback {
    background: url(../img/footer-back.png);
    background-position: bottom;
    background-repeat: repeat-x;
    padding: 5rem;
}
footer {
    background-position: 0%;
    background-color: #6eaf6e;
}
/*コピーライト
-------------------------------------*/
.copyright {
    text-align: center;
    padding: 1rem 0;
    color: #fff;
}
.copyright a {
    color: #fff;
    text-decoration: none;
	display: inline-block;
}

/*ページトップへ戻るボタン
-------------------------------------*/
#pagetop {
    position: fixed;
    bottom: 15px;
    right: 15px;
}
#pagetop a {
    display: block;
    width: 100px;
    padding: 10px 5px;
    text-align: center;
}
#pagetop a:hover {
    opacity: 0.8;
}
/*パンくずリスト
-----------------------------------*/
.breadcrumb {
    margin: 0 0 1em 0;
    padding: 0;	
}
.breadcrumb li {
    list-style-type: none;
}
.breadcrumb li a {
    display: inline-block;
    color: #959fa5;
}
/*2022
-----------------------------------*/
.inline {
    display: inline-block;
}

/*改行
-----------------------------------*/
.br-sp {
    display: none;
}
@media screen and (max-width: 768px){
/*ヘッダー
-------------------------------------*/
.head a { 
    font-size: 2.5rem;
}
nav a img {
    border: solid 5px #f0f0f0;
}
.mokuji-sp {
    display: none;
}
.circle1 img,
.circle2 img {
    padding: 2%;
    width: 100%;
    height: 100%;
    margin: 0;
    mix-blend-mode: multiply;
   }
/*YouTube
-----------------------------------*/
iframe {
    height: 315px;
}
/*改行
-----------------------------------*/
.br-sp {
    display: block;
}
}