* {
  box-sizing: border-box;
}

html {
	font-size: 62.5%; /* -> 10px */
	scroll-behavior: smooth;
}


/* コンテナ全体 */
.container {
    	width: 1000px;
		margin: 20px auto;
		background: #ffffff;
		padding: 15px;
		border-radius: 10px;
		font-size: 1.3rem;
		padding-bottom: 3em;
    }
@media screen and (max-width: 480px) {
	.container{
		width: auto;
		border-radius: 0px;
		margin: ;
		padding: 5rem 0 5em 0;
		}
}
/* マージン調整 */


/* コンテナ内リンク */
.container a{
	color: #0fd052;/* #444444 */
}
.container a:hover{
	color: #16c152;
	text-decoration: underline;
}

/* セクション、記事全体 */
.section {
	scroll-margin-top: 80px;
}
.content{
	padding-bottom: 30px;
}
.content p{
	font-size: 1.45rem;
	margin: 0 5rem 2rem 5.5rem;
	line-height: 2.0;
}
@media screen and (max-width: 480px) { 
	.content p{
		font-size: 1.5rem;
		padding: 0em 1.5rem;
		line-height: 1.8;
		margin: 0rem 0.2rem 2rem 0.2rem;
		}
}


/*　コンテンツ下のスペース空間 */
.space-bottom-0.5rem{
	height: 0.5rem;
}
.space-bottom-1rem{
	height: 1rem;
}
.space-bottom-2rem{
	height: 2rem;
}
.space-bottom-3rem{
	height: 3rem;
}
.space-bottom-4rem{
	height: 4rem;
}
.space-bottom-5rem{
	height: 5rem;
}
.space-bottom-6rem{
	height: 6rem;
}
.space-bottom-7rem{
	height: 7rem;
}
.space-bottom-8rem{
	height: 8rem;
}
.space-bottom-9rem{
	height: 9rem;
}
.space-bottom-10rem{
	height: 10rem;
}
.space-bottom-11rem{
	height: 11rem;
}
.space-bottom-12rem{
	height: 12rem;
}
.space-bottom-13rem{
	height: 13rem;
}
.space-bottom-14rem{
	height: 14rem;
}
.space-bottom-15rem{
	height: 15rem;
}



/*文字装飾系*/
.marker-red{  /*赤*/
	background: linear-gradient(transparent 50%, #ffc3c3 50%);
	color: #dc0000;
	font-weight: bold;
    font-size: 1.0em;
}
.marker-yellow{  /*黄色*/
	background: linear-gradient(transparent 50%, #fff2a6 50%);
    font-size: 1.0em;
}

/*パンくずリスト*/
.topicPath {
    clear: both;
    line-height: 1;
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
}
.topicPath ol {
    display: inline-block;
    text-align: left;
}
.topicPath ol li {
    display: inline-block;
    font-size: 11px;
    color: #5c5c5c
}
.topicPath ol li::before {
    content: "\f105";
    display: inline-block;
    padding: 0rem 0.5rem 0rem 0.5rem;
    font-family: FontAwesome;
    color: #d3d3d3;
    font-size: 0.9rem;
}
.topicPath ol li:first-child:before { display: none; }
.topicPath ol li a {
    color: #0fd052;
    text-decoration: none;
}
.topicPath .home::before{
	content: "\f015";
    display: inline-block;
    padding: 0 0.5em;
    font-family: FontAwesome;
    color: ;
	
}
@media print, screen and (min-width: 768px) {
	.topicPath{
		width: auto;
	}
    .topicPath ol li a:hover { text-decoration: none; }
}
@media screen and (max-width: 767px) {
	.topicPath {
	 	padding-top: 85px;
	 	padding-left: 5px;
	}
}




/* せつめい */
.setumei{
	background-color: #fad0e2;
	width: 70%;
	margin: auto 0;
	display: flex; /* flexboxを使用 */
    justify-content: center; /* 水平方向の中央揃え */
    align-items: center; /* 垂直方向の中央揃え */
    flex-direction: column; /* 縦方向の配置を意識 */
    margin-left: auto;
    margin-right: auto;
    margin-top: 2rem;
    
    color: #bc1152;
    padding: 1rem 0rem 2rem 4rem;
    border-radius: 2rem;
}
@media screen and (max-width: 420px) {
	.setumei{
		padding-left: 1rem;
	}
}

/*h1  タイトル
h1{
	font-weight: 900;
	color:var(--fontcolor-main) ;
	font-size: 3rem;
	padding: 0 0;
	margin: 1rem 0 1rem 0;
	text-align: center;
	
}
@media screen and (max-width: 420px) {
	h1{
		margin: 4.5rem 0rem 2rem 0rem;
		text-align: center;
		font-size: 3rem;
	}
}*/
/*h4(h1)  タイトル
h4 {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    
    font-weight: 900;
    color: var(--dimgray);
    font-size: 2.5rem;
    padding: 0;
    
    text-align: center;
    margin: 0;
    margin-top: 4rem;
    margin-bottom: 3rem;
}
@media screen and (max-width: 420px) {
    h4 {
	    margin-top: 3rem;
        font-size: 2.2rem;
    }
}*/
/*h2(h1>h4>h2)  タイトル*/
h2 {
    display: flex; /* flexboxを使用 */
    justify-content: center; /* 水平方向の中央揃え */
    align-items: center; /* 垂直方向の中央揃え */
    flex-direction: column; /* 縦方向の配置を意識 */
    
    font-weight: 900;
    color: var(--dimgray);
    font-size: 2.5rem;
    padding: 0;
    
    text-align: center;
    margin: 0; /* 余計な余白を削除 */
    margin-top: 4rem;
    margin-bottom: 3rem;
}
@media screen and (max-width: 420px) {
    h2 {
	    margin-top: 3rem;
        font-size: 2.2rem;
    }
}


/*h2 黄色見出し    
.container h2 {
   position: relative;
   color: white;
   font-size: 2.0rem;
   background: #f3cf2f;
   line-height: 1.4;
   padding: 0.6em 0.6em 0.6em 2.8em;
   border-radius: 0.5em;
   margin: 7rem 0em 2.0em 0em;
   text-align: left;
	}

.container h2:before {
	font-family: "Font Awesome 5 Free";
	content: "\f14a";
	font-weight: 900;
	position: absolute;
	left : 1em;
	}
@media screen and (max-width: 420px) {
	.container h2{
		border-radius: 0;
		font-size: 2.0rem;
		padding-left: 4.0rem;
		margin-top: 2rem;
	}
	.container h2::before {
		font-family: "Font Awesome 5 Free";
		content: "\f14a";
		font-weight: 900;
		position: absolute;
		left : 0.8em;
	}
}*/
/*h5(h2) 黄色見出し*/    
.container h5 {
   position: relative;
   color: white;
   font-size: 2.0rem;
   background: #f3cf2f;
   line-height: 1.4;
   padding: 0.6em 0.6em 0.6em 2.8em;
   border-radius: 0.5em;
   margin: 7rem 0em 2.0em 0em;
   text-align: left;
	}

.container h5:before {
	font-family: "Font Awesome 5 Free";
	content: "\f14a";
	font-weight: 900;
	position: absolute;
	left : 1em;
	}
@media screen and (max-width: 420px) {
	.container h5{
		border-radius: 0;
		font-size: 2.0rem;
		padding-left: 4.0rem;
		margin-top: 2rem;
		margin-bottom: 3rem;
	}
	.container h5::before {
		font-family: "Font Awesome 5 Free";
		content: "\f14a";
		font-weight: 900;
		position: absolute;
		left : 0.8em;
	}
}



/*h3 黄色見出し*/    
.container h3 {
   position: relative;
   color: white;
   font-size: 2.2rem;
   background: var(--maincolor);
   line-height: 1.4;
   padding: 0.6em 2.2em;
   border-radius: 5em;
   margin: 4rem 0em 1.5em 0em;
   text-align: left;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
	}
.container h3:before {
	font-family: "Font Awesome 5 Free";
	content: "\f0da";
	font-weight: 900;
	position: absolute;
	left : 1.3em;
	}
@media screen and (max-width: 420px) {
	.container h3{
		border-radius: 0;
		font-size: 2.1rem;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		margin: 2rem 0rem 3rem 0rem;
	}
	.container h3::before {
  content: none;
	}
}

/* h7test */
h7.aaa{
	background-color: aqua;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
}


/*h6(h3)小見出し*/
.container h6 {
  position: relative;
  font-size: 1.7rem;
  padding-left: 1.2em;/*アイコン分のスペース*/
  line-height: 1.4;
  margin: 0em 0em 1.4em 2em;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
}

.container h6::before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c";/*アイコンのユニコード*/
  font-weight: 900;
  position: absolute;/*絶対位置*/
  font-size: 1em;/*サイズ*/
  left: 0;/*アイコンの位置*/
  top: 0;/*アイコンの位置*/
  color: #f3cf2f; /*アイコン色*/
  font-weight: 900;
}
@media screen and (max-width: 420px) {
	.container h6{
		margin: 0em 1rem 1rem 1rem;
	}
}

/*h4小見出し（前バージョン）*/
.heading-h4_v2 {
  position: relative;
  font-size: 1.7rem;
  font-weight: 900;
  padding-left: 1.2em;
  line-height: 1.4;
  margin: 0em 0em 1.4em 2em;
  color: var(--fontcolor-main);
  text-align: left;
}

.heading-h4_v2::before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c";
  font-weight: 900;
  position: absolute;
  font-size: 1em;
  left: 0;
  top: 0;
  color: #f3cf2f;
  font-weight: 900;
}

@media screen and (max-width: 420px) {
  .heading-h4_v2 {
    margin: 0em 1rem 1rem 1rem;
  }
}

/*h4小見出し v2*/
.heading-h4 {
  position: relative;
  font-size: 2.0rem;
  font-weight: 900;
  line-height: 1.4;
  margin: 0em 2.5em 1.4em 2.5em;
  color: var(--fontcolor-main);
  text-align: left;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
  
  background: linear-gradient(transparent 70%, #f6ebb3 70%);
}
/*
.heading-h4::before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c";
  font-weight: 900;
  position: absolute;
  font-size: 1em;
  left: 0;
  top: 0;
  color: #f3cf2f;
  font-weight: 900;
}
*/
@media screen and (max-width: 420px) {
  .heading-h4 {
    margin: 0em 1.5rem 2.0rem 1.5rem;
  }
}






/* 先頭　メニュー */
.list_inner {
  	width: 80%;
  	margin: 0 auto;
  	padding: 3rem 0 0 0;
}
.list_anchor{
  	display: -webkit-box;
  	display: flex;
  	-webkit-justify-content: space-between;
  	justify-content: space-between;
  	-webkit-flex-wrap: wrap;
  	flex-wrap:         wrap;
}
.list_anchor::after{
  	content: "";
  	width: 30%;
}
.list_anchor a:hover{
	text-decoration: none;
}
.list_anchor li {
  	width: 31%;
  	margin-bottom: 1em;
	list-style: none;
	border-bottom: 1px solid #c2c2c2;
	font-size: 0.9em;
	display: flex; /* これを追加 */
    align-items: center; /* 縦方向中央 */
    position: relative; /* これを追加 */
}

.list_anchor li a {
  	display: block;
  	line-height: 1.2;
  	position: relative;
  	color: #444444;
  	background: #ffffff;
  	text-decoration: none;
  	padding: 10px 0px;
  	font-weight: 500;
  	padding-right: 18px;
}

.list_anchor li::after {
  	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0; /* 右に固定 */
	width: 1em;
	height: 1em;
	line-height: 1em;
	margin: auto;
	text-align: center;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free"; 
	font-weight: 900;
	color: #ffdf73;
	content: '\f13a';
	transform: translateY(-50%); /* 完全な縦中央揃え */
}

@media screen and (max-width: 420px) {
	.list_anchor li{
		width: 48%;
        margin-right: auto;
	}
	.list_inner{
		width: 85%;
		margin: 0 auto;
		padding: 1rem 0 0rem 0;
	}
}



/* 黄色の囲み枠 */
.box-yellow {
	padding:1.5em 2.5em;
	background-color: #fff6cb;
	border-radius:1.3em;
	font-size: 1rem;
	margin: 0rem 5rem 3rem 5rem;
}
.box-yellow .box-title {
	color: #444444 ; /* タイトル文字色 */
	font-size: 1.5rem;/*タイトル文字の大きさ*/
	font-weight: bold;
	padding-bottom: 0em;
	background: linear-gradient(transparent 70%, # 70%);
	margin-bottom: 1.0em;
	margin-top: 0.2em;
}
.box-yellow .box-title:before {
	font-family: "Font Awesome 5 Free";
	content: "\f06a";
	font-size: 1.5rem;/*アイコンの大きさ*/
	margin: 0 0.5em 0 0;
	font-weight: bold;
	color: #d8b206;
}
.box-yellow p{
	line-height: 1.8em;
	font-size: 1.4rem;
	margin: 0rem 2.5rem 0.5rem 2.5rem;
	color: #444444;
}
@media screen and (max-width: 420px) {
	.box-yellow{
		margin: 0 1.2em 2.0rem 1.2em;
		padding: 0.5rem 0.7rem 1.5rem 0.7rem;
	}
	.box-yellow p{
		margin: 0;
		font-size: 1.3rem;
	}
	.box-yellow .box-title{
		margin: 1rem 0.5rem 1rem 1rem; 
	}
}



/* 2列テーブル */

table{
  border-collapse: collapse;
  width: 89%;
  margin: 0.5em 3.5em 0em 3.5em;
}
.tb1 th,
.tb1 td{
  padding: 10px;
  border: solid 1px var(--border-lightgray);
  text-align:left;
  box-sizing:border-box;
  font-size: 0.9em;
  line-height: 1.8;
}
.tb1 th {
  background: var(--cell-lightgray);
  color: var(--fontcolor-main);
  font-size: 0.9em;
  width: 250px;
  text-align: center;
  
}
@media screen and (max-width: 420px) {
  .tb1 {
    width: 91%;
    margin: 0 auto;
  }
  table.tb1 th,
  table.tb1 td {
    display: block;
    width: 100%;
    border-bottom:none;
  }
  .tb1 tr:last-child{
    border-bottom: solid 1px #ccc;
  }
}


.tb1 .faws{
	color: #0eb252;
	margin-right: 5px;
}



/* アコーディオン開閉 */
.accordion-container{
	background-color: #ededed;
	border-radius: 1.3em;
	margin: 0rem 5rem 3rem 5rem;
}
.accordion {
  max-width: 100%;
  color: #444;
}

/* チェックボックスは非表示 */
.accordion-hidden{
  display: none;
}

/* Question部分 */
.accordion-open {
  display: block;
  padding: 10px 10px 10px 70px;
  background: ;
  cursor: pointer;
  margin: 5px 0;
  font-weight: 700;
  position: relative;/* 変更部分 */
}

/* 開閉状態を示すアイコン+の作成 */
.accordion-open::before,
.accordion-open::after {
  content: '';
  width: 20px;
  height: 3px;
  background: #444;
  position: absolute;
  border-radius: 1em;
  top: 50%;
  right: 5%;
  transform: translateY(-50%);
}

/* 一本は縦にして+を作る */
.accordion-open::after {
  transform: translateY(-50%) rotate(90deg);
  transition: .5s;
}

/* QとAのデザイン */
.accordion-open span,
.accordion-close span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 100%;
  background: ;
  position: absolute;
  text-align: center;
  left: 0;
  top: 0;
}

/* アコーディオンが開いたら縦棒を横棒にして-にする */
.accordion-hidden:checked + .accordion-open:after {
  transform: translateY(-50%) rotate(0);
}

/* Answer部分 */
.accordion-close {
  display: block;
  height: 0;/* 要素の高さは0 */
  overflow: hidden;/* 非表示 */
  padding: 0 0 0 60px;
  opacity: 0;
  transition: 0.5s;/* 表示速度の設定 */
  position: relative;
  font-size: 1em;
  margin-left: 0em;
  margin-bottom: 0.9em;
  margin-right: 5em;
  line-height: 1.5;
}
.accordion-close ul{
	background-color: white;
	border-radius: 1em;
	padding: 1rem 3rem 1rem 3rem ;
	margin: 0em 0em 2rem 1em;
	list-style: none;
}
.accordion-close li{
	font-size: 1.2rem;
	margin-left: 0em;
  line-height: 1.5;
}
.accordion-close li:last-child {
	margin-bottom: 0.2rem;
}
.accordion-close ul li::before {
  left: 0;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: '\f00c';
  color: #bfbfbf;
  padding-right: 0.5em;
}
.accordion-close-title{
	font-weight: 900;
	font-size: 1em;
	margin: 0 0 0.3rem 0;
	padding: 0;
}
.accordion-close-title::before{
	font-size: 1.0em;/*アイコンの大きさ*/
	margin: 0 0.5em 0 0;
	font-weight: bold;
	color: #55bacb;
}
.accordion-close-title-check::before{
	font-family: "Font Awesome 5 Free";
	content: "\f058";
}
.accordion .text{
	font-size: 1.2rem;
	margin-bottom: 1.0rem;
}

/* チェックボックスにチェックが入ったらAnswer部分を表示する */
.accordion-hidden:checked + .accordion-open + .accordion-close {
  height: auto;
  opacity: 1;
  padding: 10px 10px 10px 70px;
  background: ;
}

.accordion .accordion-title {
	color: #444444 ; /* タイトル文字色 */
	font-size: 1.2em;/*タイトル文字の大きさ*/
	font-weight: bold;
	padding-bottom: 0em;
	background: linear-gradient(transparent 70%, # 70%);
	margin-left: 2em;
}
.accordion .accordion-title:before {
	font-family: "Font Awesome 5 Free";
	content: "\3f";
	font-size: 1.0em;/*アイコンの大きさ*/
	margin: 0 0.5em 0 0;
	font-weight: bold;
	color: #444444
}

@media screen and (max-width: 420px) {
	.accordion{
		width: auto;
	}
	.accordion-container{
		margin: 0 1.2rem 2.0rem 1.2rem;
		}
	.accordion .accordion-title:before{
		margin: 0 0em 0 3em;
	}
	.accordion .accordion-title {
		margin-left: 0;
	}
	.accordion-open{
		margin-left: -2em;
		padding-right: 3em;
	}
	.accordion-close{
		margin: 0rem 0rem 0rem -4.5rem;
	}
	.accordion-close-title{
		font-size: 1.5rem;
		}
	.accordion .text{
		font-size: 1.5rem;
		margin-right: 1rem;
	}
	.accordion-close ul{
		width: ;
		padding: 0.5em 1rem;
		margin-left: 0;
		margin-right: 1rem;
	}
	.accordion-close ul li{
		font-size: 1.5rem;	
	}
}


/* メインヘッダー画像 */
.main-picture {
  margin-top: 0px;
  display: flex; /* ←中央揃えのためにflexに変更 */
  justify-content: center; /* 横方向に中央揃え */
}
.main-picture img {
  width: 90%;
  height: auto;
  display: block;
  
  border-radius: 1rem;
}
@media (max-width: 768px) {
  .main-picture img {
    margin-top: 0px;
    border-radius: 0;
    width: 100%;
  }
}


/* 画像　通常2列　レスポンシブ1列 */
.grid-2col-to-1col {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-left: 50px;
  margin-right: 50px;
}
.grid-2col-to-1col .item {
  flex: 1 1 45%;
  box-sizing: border-box;
  overflow: visible; /* 念のため追加 */
}
.grid-2col-to-1col .item img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 1rem;
  margin-bottom: -5px;
}
.grid-2col-to-1col .item p {
  margin-top: 15px;
  font-size: 1.3rem;
  text-align: center;
  color: #555;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .grid-2col-to-1col {
    flex-direction: column;
    margin-left: 15px;
    margin-right: 15px;
  }
  .grid-2col-to-1col .item {
    flex: none;
    width: 100%;
  }
  .grid-2col-to-1col .item p {
    font-size: 1.3rem;
    margin-top: 10px;
    margin-bottom: -3px;
  }
}

/* 画像1列 */
.single-image-block {
  text-align: center;
  margin-bottom: 30px;
  margin-left: 50px;
  margin-right: 50px;
}
.single-image-block img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: 8px;
}
.single-caption {
  margin-top: 8px;
  font-size: 14px;
  color: #555;
}
@media (max-width: 768px) {
  .single-image-block {
		margin-left: 15px;
		margin-right: 15px;
    	margin-bottom: 10px;
  }
}


/* 末尾用の空白 */
.page-end{
	height: 20px;
}
.page-end-sp{
	height: 0px;
}
@media (max-width: 768px) {
	.page-end-sp{
		height: 20px;
	}
}

/* リンク */
.center-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  margin: 10px 0;
  padding: 0 10px;
}
.center-links a {
  background-color:#2bb1e2 ;
  color: white;
  text-decoration: none;
  padding: 1rem 10rem;
  border-radius: 5rem;
  font-size: 2.2rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
  transition: background-color 0.4s ease;
  text-align: center;
}
.center-links a {
  flex: 0 1 auto;
}
.center-links a:hover {
  background-color: var(--maincolor);
  color: #333;
  text-decoration: none;
}
@media (max-width: 768px) {
  .center-links {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    margin-bottom: 20px;
  }
  .center-links a {
    width: 100%;
    padding: 1.2rem;
    font-size: 1.8rem;
  }
}


/* レスポンシブ　トップ画像用
　　レスポンシブでのみメイン画像表示、通常は非表示 */
.responsive-only {
  display: none;
}
@media (max-width: 768px) {
  .responsive-only {
    display: block;
    max-width: 100%;
    height: auto;
    margin-top: 70px;
  }
}




/*フェードイン エフェクト用*/
.fade-up-on-scroll {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.fade-up-on-scroll.show {
  opacity: 1;
  transform: translateY(0);
}


/* ふきだし */
.fukidashi-01-01 {
  position: relative;
  width: 100％; /* 横幅を画面いっぱいに */
  padding: 12px 16px;
  text-align: left; /* テキストを左揃えに */
  box-sizing: border-box; /* パディング含めて100vw内に収める */
  margin: 0px 50px;
}

.fukidashi-01-01::before {
  content: "";
  position: absolute;
  top: -6px;
  left: 50%;
  width: 100%;
  height: 50%;
  box-sizing: border-box;
  border: 2px solid var(--maincolor);
  border-bottom: none;
  border-top-right-radius: 50px;
  border-top-left-radius: 50px;
  translate: -50%;
}

.fukidashi-01-01::after {
  content: "";
  position: absolute;
  bottom: calc(100% + 8px); /* 上に表示（吹き出しの上側） */
  left: 10%; /* ← ここをleft: 50% → left: 16px に変更して左寄せ */
  width: 30px;
  height: 2px;
  box-sizing: border-box;
  background-color: var(--maincolor);
  box-shadow: 0 2px 0 #ffffff, 0 -2px 0 #ffffff;
  rotate: -50deg; /* 傾きはそのままでもOK。逆方向なら +50deg に */
  translate: 0; /* -50% → 0 に変更（中心寄せを解除） */
}


