body{
margin-bottom: 0;
}

/* レイアウト
------------------------------------------------------------*/
#wrapper, .inner{
margin:0 auto;		
width:960px;
}

#header{
overflow:hidden;
}

#content{
width:100%;
padding:30px 0;
}

/* トップページ　メイン画像  ■
----------------------------------*/
#mainImg{
clear:both;
margin-top:35px;
line-height:0;
text-align:center;
z-index:0;
}

#mainImg a:hover img{opacity:.9;}

.postWrap{
margin:0 0 20px 0;
padding:3px;
}

article.archive span{padding-left:10px;}


/*Google　Map　レスポンシブデザイン
-----------------------------------*/
 .map{
position:relative;
width:100%;
height:0;
padding-top:75%;
}
.map iframe{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
}


/*YouTube　レスポンシブデザイン
-----------------------------------*/

.you_responsiv {
position: relative;
width: 100%; 
max-width: 560px; 
height: 315px;
margin: 0 auto;  /* センタリングのため */ 
margin-top: 80px;
margin-bottom: 50px;
}

.you_responsiv iframe {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}


/* タイポグラフィ
*****************************************************/
h2.title{
clear:both;
margin:30px 0 60px;
font-size:140%;
text-align:center;
}

h2.title span{
padding:5px 0 8px 0;
border-bottom:5px solid #000000;
}

.dateLabel{
margin:0 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.post p{padding-bottom:15px;}

.post ul{margin: 0 0 10px 10px;}

.post ul li{
margin:5px 0 0 15px;
list-style:disc;
}

.post ol{margin: 0 0 10px 30px;}

.post ol li{list-style:decimal;}

.post h1, .post h2, .post h3, .post h4, .post h6{clear:both;}

.post h1{
margin:20px 0 30px 0;
padding:10px 15px;
font-size:130%;
background:#eeeeee;
}

.post h2{
margin:20px 0 30px 0;
padding:3px 20px;
font-size:120%;
font-weight:normal;
border-left:5px solid #000000;
}

.post h3{
margin:25px 0 35px 0;
padding-bottom:10px;
font-size:110%;
font-weight:normal;
border-bottom:1px solid #dddddd;
}

.post h4{
margin:20px 0 20px 0;
padding-bottom:10px;
font-size:100%;
font-weight:bold;
}

.post h5{
margin:20px 0 30px 0;
padding:10px 15px;
font-size:130%;
text-align: center;
background:#eeeeee;
}

 /*　■　h6追加　中原芳江さま  */
.post h6{
margin:20px 0 30px 0;
padding:10px 15px;
font-size:130%;
background:#8AD1A4;
}

.heading12 {
	position: relative;
	font-size: 26px;
	color: #333; /* 追加 */
	background: #FFFF00;
}

.heading12::before {
	content: attr(data-number);
	display: inline-block;
	margin-right: 20px;
	color: #333; /* 番号の数字　ブルー：498ee0  ピンク：E04986 */
	font-size: 28px; /* 30px */
	border-bottom: 0px solid #498ee0; /* 1px*/
}

 /*　ここまで　■　h6追加　中原芳江さま  */

.post blockquote {
clear:both;
padding:10px 0 10px 20px;
margin:10px 0 25px 10px;
border-left:5px solid #ccc;
}

.post table{
	width:100%;
border: 1px #ddd solid;
border-collapse: collapse;
border-spacing: 0;
margin:20px 0 20px;
}

.post table th{
padding:15px 15px;
border: #fff solid; /*dddddd  */
border-width: 0 0 1px 1px;
background:#f6f6f6;
}

.post table td{
padding:15px 15px;
border: 1px #ddd solid;
border-width: 0 0 1px 1px;
}

.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}

.post ul{margin-bottom:20px;}

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

img.aligncenter {
display: block;
margin:5px auto 40px 0;
}

img.alignright{
margin:0 0 25px 25px;
float:right;
}

img.alignleft{
margin: 0 25px 25px 0;
float: left;
}
/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
#wrapper, #header, .inner{width:100%;}

#header h1, #header p{padding:5px 10px;}
#header h2{padding:20px 10px 0;}
#header ul{padding:20px 10px 40px;}


nav#mainNav ul, .thumbWrap{margin:0 auto;}
nav#mainNav ul ul{padding:0;}

nav div.panel{float:none;}

#mainImg img{
width:100%;height:auto;
margin-top:-0px;/* -----35px*/
}
#content, #sidebar{
clear:both;
width:95%;
float:none;
margin:0 auto;
padding:20px 0 10px;
}

#banners{width:100%;margin:0 auto;text-align:center;}
#banners p{display:inline;margin:0 1% 0 0;}
#banners p img{width:31%;height:auto;}

.thumbWrap{width:100%;margin:10px auto 0;text-align:center;}
.thumbWrap ul.thumb li{width:30%; float:left;margin:0 1% 0 2%;}
.thumbWrap img{width:100%;height:auto;}
    
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
#header{text-align:center;}
#header h2,#header h1,#header p,#header ul{float:none;}
#headerInfo{width:250px;margin:0 auto;}
}
/* 幅330px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 330px){
#calendar_wrap table{width:100%;}
#banners p img{width:31%;height:auto;}
}
  
  
/* li　■■　20250424　 文頭に記号を配置する　追加
****************************************************/  
ul.mark > li { /* .markクラスの直下の子要素であるliに適用 */
  list-style: none;}

ul.mark li::before {
  content: "✨"; /* キラキラした記号 */
  color: #ffcc00; /* 黄色 */
  font-size: 1.2em;
  margin-right: 0.1em;
  margin-left: -2.5em;
  vertical-align: middle; /* テキストと垂直方向中央揃え */
}

/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
ul.mark > li { /* .markクラスの直下の子要素であるliに適用 */
  list-style: none;}

ul.mark li::before {
  content: "✨";
  color: #ffcc00; /* 黄色 */
  font-size: 1.2em;
  margin-right: 0.1em;
  margin-left: -1.5em;/* ■　左のマージンを少なくする　 */
  vertical-align: middle; /* テキストと垂直方向中央揃え */
}
}

  
/* footer　■■　20220526　 追加
****************************************************/

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
 
#footer01 {
  position: relative;
  background: #fff;
}
 
#footer01 .logo {
  text-align: center;
  padding: 20px 0; /*  20から変更**/
  border-bottom: 1px solid #111;
}
 
#footer01 .logo a {
  display: inline-block;
}

/*
p img {
  width: 120px;
}
**/ 

 
#footer01 .nav a {
  display: block;
  padding: 0 10px; /* 0　10　から変更**/
margin-top: 100px; /* SNS ボタンの上の幅　追加**/
  color: #fff;
}

.nav01{
    display: flex ;
    justify-content: center ;
}

.nav01 img{
    margin: 20px 
}
    .copyright {
text-align: center;
color: #fff;
background-color: #333;
font-size: 15px;
margin: 20px 0 0 0;
 }

@media only screen and (max-width: 1200px){
.nav01 img{
    margin: 30px 
}
}

@media only screen and (max-width: 730px){
    .nav01{
    display: inline;
     text-align: center;
}
    .nav01 img{
    margin: 5px 
}
}

@media only screen and (max-width: 500px){
        .copyright {
font-size: 10px;
 }
}


/* サブメニュー　■■　20220529　 追加
****************************************************/
.sub-sp{
font-size: 12px;
text-align: left;
margin:5px 0px 5px 100px; 
}

.post{
    margin-top:10px; 
}

@media only screen and (max-width: 1200px){
.post{
    margin-top:170px; 
}
}

@media only screen and (max-width: 730px){
.post{
    margin-top:70px; 
}
}


/* facebook レスポンシブデザイン対応　■■　20220611　 追加
****************************************************/
.fb_responsiv{
position:relative;
width:100%;
height:0;
padding-top:75%;
}
.fb_responsiv iframe{
position:absolute;
top:0;
left:0;
width:100%;
height:600px;
}


.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}

/* 文字背景に色　■■　20250606　中原様　 追加
****************************************************/

.highlight-text {
    background-color: #FFFF00; /* 例の薄いベージュ */
    display: inline;
    padding: 10px 0px 0px 5px; /* ← ここが上下・左右の余白 */
    line-height: 1.0; /* 行の高さ */
    display: inline-block;     /* ← inline だとベースラインが下にずれる */
    vertical-align: middle;    /* または baseline/top などで微調整 */
	margin: 0; /*  */
}

.highlight-text2 {
    background-color: #FFFF00; /* 例の薄いベージュ */
    display: inline;
    padding: 10px 0px 0px 5px; /* ← ここが上下・左右の余白 */
    line-height: 1.3; /* 行の高さ */
    display: inline-block;     /* ← inline だとベースラインが下にずれる */
    vertical-align: middle;    /* または baseline/top などで微調整 */
	margin: 10px 10px -10px 0px; /*  */
}

.highlight-text3 {
    background-color: #0FAF80; /* 例の薄いベージュ */
    display: inline;
    padding: 10px 0px 0px 5px; /* ← ここが上下・左右の余白 */
    line-height: 1.3; /* 行の高さ */
    display: inline-block;     /* ← inline だとベースラインが下にずれる */
    vertical-align: middle;    /* または baseline/top などで微調整 */
	margin: 10px 10px -10px 0px; /*  */
}

.toppage {
  text-align: center;       /* テキストを中央揃え */
  margin: 10px 0;           /* 上下10px、左右0のマージン */
  padding: 5px 0;           /* 上下5pxのパディング（必要に応じて調整） */
  font-size: 1.2em;         /* フォントサイズ調整（任意） */
  font-weight: bold;        /* 強調表示（任意） */
	color: #444;
}
