@charset "shift_jis";

/* body.css */
/*
	2017 new design ver.5.0
	県サイト作成・レスポンシブ
*/
/* --------------------------------------------------
header　オリジナル修正
-------------------------------------------------- */


/* --------------------------------------------------
-----------------------------------------------------
FLOW　Add　20250207
-----------------------------------------------------
-------------------------------------------------- */

.toparea_FLOW_body > p{
  color: #fff;
  margin: 20px auto 0;
  width: 94%;

}
.flow_1024px{
  width: 100%;
  max-width: 1024px;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
}


.flow_1024px_add{
  width: 100%;
  max-width: 1024px;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
  margin: 0px 0 0px 0;
}

.flow_1024px_add_02{
  width: 100%;
  max-width: 1024px;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
  margin: 0px 0 0 0;
}

.flow_1024px_innnerBox{
width: 100%;
    max-width: 1024px;
    margin: 0 auto;
display: flex; /* ★【重要】これを追加してFlexboxを有効化 */
    flex-direction: column; /* ★【修正】デフォルトを縦並び(スマホ)に設定 */
}


.flow_1024px_tate{
  width: 100%;
  max-width: 1024px;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
}

.flow01a {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 0% 0% 20px 0%;
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow01 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
       margin: 2% 0% 6% 0%;
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow02 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
      margin: 2% 0% 6% 0%;
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}


.flow03 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
       margin: 2% 0% 6% 0%; /*ここで下部の空白調整 */
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}

.flow04 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
      margin: 2% 0% 6% 0%;
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow_7days {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
         margin: 2% 0% 4% 0%;/*ここで下部の空白調整 */
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}


.flow_img_area{
  width: 100%;
  height: auto;
  clear: both;
  background-color: #E6F4FD;
  padding: 10px 0;
}
.flow_img_area img{
  max-width: 100%;
}

	/* 画像一部だけ表示 */
.flow_img_area img.flow001 {
	width: 90%;
	height: auto;
  object-fit: cover; 
  object-position: center top; 
}

.flow_img_area img.flow002 {
	 width: 50%;
	height: auto;
    object-fit: cover; /* 画像を枠内に収めつつ、はみ出た部分をカット */
    object-position: center top; /* 画像の表示位置を調整 */
}


.flow_img_area img.flow003,
.flow_img_area img.flow004,
.flow_img_area img.flow005 {
	 width: 60%;
	height: auto;
    object-fit: cover; /* 画像を枠内に収めつつ、はみ出た部分をカット */
    object-position: center top; /* 画像の表示位置を調整 */
}

.rounded-obalbox {
width: 35px;
    height: 35px;
    padding: 0;
    margin: 0;
    margin-right: 10px; /* h4との間に隙間を作る */

    background-color: #E50012;
    border-radius: 50%;

    color: white;
    font-size: 1.5em;
    font-weight: bold;
    cursor: pointer;

    display: flex;
    justify-content: center;
    align-items: center;

    /* ★★★ 修正箇所: 潰れないようにする設定 ★★★ */
    flex-shrink: 0; /* 親要素が縮んでも、この要素は縮まない */
}




h4.thema_top_7days {
  color: #0B79C4;
  width: 70%;
  font-size:clamp(1.813rem, 1.75rem + 0.33vw, 1.938rem); /* size 33px-35px 300px-900px */
  font-weight: 300;           /* 文字を太字に */
  text-align: left;            /* 左寄せにする */
  padding: 0;
  align-items: center;
  font-family: "RoundedMgenplus-medium", sans-serif;                   /* 余白をなくす */
   display: flex;
   float: left;             /* 横並びにする */
  align-items: center; /* 要素縦の中央揃え */
        margin: 7px 0; /* 縦の中央揃え 調整 */
    line-height: 1; /* 行の高さを調整（必要に応じて） */

}

/*メールがとどかない場合*/
#flow_maillost{
  margin-top: 15px;
  margin-bottom: 0px;
}

.foot_txt_inner > li{
  width: 96%;
  margin: auto;
}

#flow_maillost .box_white_thema{
  font-size: 18px;
  font-weight: bold;
  background-color: #0B79C4;
  padding: 5px 10px;
  margin: 0 auto 20px auto;
  box-sizing: border-box;
  text-align: left;
}
#flow_maillost .box_white_thema a,
#flow_maillost .box_white_thema a:link,
#flow_maillost .box_white_thema a:hover{
  color: #fff;
  text-decoration: none;
}
#flow_maillost ul.chui{
  border-bottom: 1px solid #ccc;
  margin-bottom: 20px;
}
#flow_maillost ul.chui li{
  list-style:disc;
  width: 90%;
  margin: 0 auto 10px auto;
  text-align: left;
}
#flow_maillost ul.kobetsu li{
  width: 90%;
  margin: 0 auto 20px;
  line-height: 1.5em;
  text-align: left;
}




.foot_txt_area {
    text-align: left;
    margin: 15px 0 15px 0;
    width: 100%;
}




/* 番号とテーマの回り込み解除 */
.float_reset
 {
	text-align: left;
   clear: both;           /* テキスト色（調整可能） */
}

.font_color_red
 {
  color: #B81C22;
  font-weight: 600;
}

.font_color_blue
 {
   color: #0B79C4;
  font-weight: 600;
}

.font_color_bold
 {
  color: #000000;
  font-weight: 600;
}

.font_margin_bt
 {
margin-bottom: 10px;
}


.box_yellow_topic li{
  /* text-indent: -1em; */
}

li.box_yellow_topic{
background-color: #FFFFE7;
padding: 2% 2% 2% 4%;
margin: 0 0 2% 0 !important;
}

/* 行間に関わる */
.flow01a li,
.flow01 li.topix_title,
.flow01 li,
.flow02 li,
.flow03 li,
.flow04 li,
.flow05 li,
.flow06 li,
.flow06a li,
.flow07 li,
.flow_7days li{
margin: 2% 0 2% 0; /* 各リスト項目の間にスペースを追加 */
    display: block;
}

.flow01a li.topix_title,
.flow01 li.topix_title,
.flow02 li.topix_title,
.flow03 li.topix_title,
.flow04 li.topix_title,
.flow05 li.topix_title,
.flow06 li.topix_title,
.flow06a li.topix_title,
.flow07 li.topix_title,
.flow_7days li.topix_title{
margin: 2% 0 2% 0; /* 各リスト項目の間にスペースを追加 */
display: flex;
align-items: center; /* 縦方向の中央揃え */
 height: auto;
}


.topix_title {
    display: flex;
    align-items: center;  /* ← 縦方向の中央揃え */
    justify-content: start; /* ← 横方向の中央揃え */
    gap: 10px; /* 余白の調整 */
}


ul.box_yellow_thema {
text-align: left;
font-size: 15px;
}

.box_yellow_top{
  display: block;
font-size: 16px;
font-weight: 900;
margin-bottom: 0.5em;
}



.box_yellow_topicRED{
  display: block;
font-size: 1.8em;
    color: #af1717;

margin-bottom: 0.5em;
}

.box_yellow_topic li{
  /* text-indent: -1em; */
  margin-top:-0.3em;
    font-size: 15px;
}

li.box_white_thema {
text-align: left;
margin: 0 0 1% 0;
}
/* 上部 */
ul.box_links_innner {
list-style-type: disc !important; /* ● を表示 */
    padding-left: 0px; /* 左の余白を確保 */
    color: #0B79C4;
    font-weight: 500;
    font-size: clamp(1.25rem, 1.146rem + 0.55vw, 1.5rem);
}

ul.box_links_innner li::before {
    content: "●"; /* 黒丸を追加 */
    color: #0B79C4; /* 色を変更 */
    font-size: clamp(1.25rem, 1.146rem + 0.55vw, 1.5rem);/* サイズを変更 */
    margin-right: 8px; /* テキストとの間隔 */
}
/* 下部 */
ul.box_links_innnerU {
list-style-type: none !important; /* ● を表示 */
        color: #0B79C4;
        font-weight: 500;
       font-size: clamp(1.25rem, 1.146rem + 0.55vw, 1.5rem);
           margin: 0 0 10px 0;
}
ul.box_links_innnerU li{
  color: #000;
}


li.box_white_thema a {
    color: #0B79C4; /* 好きな色を指定 */
    text-decoration: none; /* 下線を消す（必要なら） */
}

li.box_white_thema a:hover {
        color: #af1717; /* ホバー時の色（赤） */
}

li.box_links{
  padding: 0 0 0 0;

}

.innner_topix {
    font-size: 0.7em;
  text-align: left;            /* テキストのサイズ */
  color: #333;                 /* テキスト色（調整可能） */
}

ul.innner_topix{
padding-left: 0px;
  /* 左側にスペースを追加（オプション） */
}

.innner_topix li{
     list-style-type: disc;             /* テキスト色（調整可能） */
}


li.box_topic {
text-align: left;
font-size: 15px;
padding: 3% 0 3% 0;    /* 各リスト間行間調整 */
}




ul.foot_txt_inner {
    width: 100%;
    max-width: 960px;
    height: auto;
    background-color: #ffffff;
    padding: 4% 2% 4% 2%;
    /* padding: 0 0 0 10px; */
    margin: 0px auto 0px auto;
    border-radius: 10px;
}



ul.foot_txt_inner li .font_color_bold{
  margin-right: 20px;
}

/*　--- 追加エリア　---- */

  .flow_1024px_innnerBox{
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  display: flex; /* ★【重要】これを追加してFlexboxを有効化 */
  flex-direction: column; /* ★【修正】デフォルトを縦並び(スマホ)に設定 */
  }

  .TopBox{
  margin: 25px 0 5px 0;
}

 .TopBox_B,.TopBox_C{
  margin: 50px 0 5px 0;
  padding-top: 20px;
  border-top: 1px dotted #fff;
}


.flow05 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */

    /* margin-bottom: 2%;ここで下部の空白調整 */
      margin: 2% 0% 6% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}

.flow06 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 6% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow06_red {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 4% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
     background-color: #E50012;
  justify-content: space-between;
}

div.flow_1024px_add ul{
  width: 100%;
}
div.flow_1024px_add h4.box_white_thema {
font-size: 18px;
font-weight: bold;
color: #ffffff;
background-color: #0B79C4;
padding: 10px 10px;
margin: 20px auto 0px auto;
box-sizing: border-box;
text-align: center;
}
div.flow_1024px_add{

}


/* --------------------------------------------------
-----------------------------------------------------
window size 600-
-----------------------------------------------------
-------------------------------------------------- */
@media screen and (min-width:600px){



.flow_1024px{
  width: 100%;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
}

.flow01a {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 0px 0%;
    padding: 3% 3% 3% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}


.flow01 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 3% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow02 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 3% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}


.flow03 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */

    /* margin-bottom: 2%;ここで下部の空白調整 */
      margin: 2% 0% 3% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}

.flow04 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
      margin: 2% 0% 3% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow05 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */

    /* margin-bottom: 2%;ここで下部の空白調整 */
      margin: 2% 0% 2% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}

.flow06 {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 3% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    background-color: rgb(255, 255, 255);
  justify-content: space-between;
}

.flow06_red {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */
    margin: 2% 0% 0% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
     background-color: #E50012;
  justify-content: space-between;
}


.flow_7days {
    width: 100%;
/* max-width: 960px; */
    /* text-align: center; */
    /* justify-content: center; */

    /* margin-bottom: 2%;ここで下部の空白調整 */
      margin: 2% 0% 4% 0%;
    padding: 2% 3% 2% 3%;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    background-color: rgb(255, 255, 255);
  align-items: center;
  justify-content: space-between; /* 左右にスペースを均等に配置 */
}

/* ---------------@ 追加エリア ------------- */
.flow_1024px_innnerBox{
 display: flex;
  flex-direction: column;
        justify-content: space-between;
        gap: 5px;
        padding: 0 0px;
}

div.flow_1024px_add h4.box_white_thema {
font-size: 18px;
font-weight: bold;
color: #ffffff;
background-color: #0B79C4;
padding: 10px 10px;
margin: 20px auto 0px auto;
box-sizing: border-box;
text-align: center;
}

.flow01a,
.flow01,
.flow02,
.flow03,
.flow04,
.flow05,
.flow06_red,
.flow06 {
        /* 均等幅の最も簡潔でロバストな記述 */
        flex: 1 1 0%;
        /* flex-grow: 1 で利用可能なスペースを均等に分け、flex-basis: 0 で初期幅を無視させる */
}

  .TopBox{
  margin: 25px 0 5px 0;
}

 .TopBox_B{
  margin: 50px 0 5px 0;
}

 .TopBox_C{
  margin: 0px 0 0px 0;
}

/* ---------------@ MEdia END ------------- */
}/* ---------------　DOnt　erase --- */
/* --------------　@ MEdia END ------------- */

/* --------------------------------------------------
-----------------------------------------------------
window size 900-
-----------------------------------------------------
-------------------------------------------------- */
@media screen and (min-width:900px){

/* 2列レイアウトにする */
.flow_1024px{
  width: 100%;
  display: flex;
  flex-direction: row; /* ★display: flex; がないため効いていない */
        justify-content: space-between;
  padding :0% 5% 0 5%;
          gap: 20px;
}



  /* flow01, flow02, flow04 の幅を50%に設定 */
  .flow01a,.flow01, .flow02, .flow04 {
    width: 100%;
    border-radius: 10px;
max-width: 960px;
    background-color: rgb(255, 255, 255);
  }


  .flow01,
.flow01a,
.flow02,
.flow03,
.flow04,
.flow05,
.flow06,
.flow06_red
 {
        /* 均等幅の最も簡潔でロバストな記述 */
        flex: 1 1 0%;
        /* flex-grow: 1 で利用可能なスペースを均等に分け、flex-basis: 0 で初期幅を無視させる */
}

  /* flow01aの表示順 */
  .flow01a {
    order: 1; /* 最初に表示 */
  }


  /* flow01 の表示順 */
  .flow01 {
    order: 1; /* 最初に表示 */
  }

  /* flow02 の表示順 */
  .flow02 {
    order: 2; /* 2番目に表示 */
  }

    /* flow03 の表示順 */
  .flow03 {
    order: 3; /* 3番目に表示 */
  }
    /* flow04 の表示順 */
    .flow04 {
    order: 4; /* 3番目に表示 */
  }

      /* flow_7days の表示順 */
    .flow_7days {
    order: 5; /* 3番目に表示 */
  }

  .flow01a {
    width: 49%;
    max-width: 960px;
    border-radius: 10px;  /* max-width: 370px; */
    background-color: rgb(255, 255, 255);
}

.flow01 {
    width: 49%;
    max-width: 960px;
    margin: 2% 0% 1% 0%;
    border-radius: 10px;  /* max-width: 370px; */
    background-color: rgb(255, 255, 255);
}
.flow02 {
    width: 49%;
    max-width: 960px;
     margin: 2% 0% 1% 0%;
    border-radius: 10px;  /* max-width: 370px; */
    background-color: rgb(255, 255, 255);
}



  .flow03 {
    width: 49%;
    max-width: 960px;
    margin: 2% 0% 1% 0%;
    border-radius: 10px;  /* max-width: 370px; */
    background-color: rgb(255, 255, 255);
}

.flow04 {
    width: 49%;
    max-width: 960px;
        margin: 2% 0% 1% 0%;
    border-radius: 10px;  /* max-width: 370px; */
    background-color: rgb(255, 255, 255);
}




.flow05 {
    width: 49%;
      margin: 2% 0% 1% 0%;
    padding: 2% 3% 2% 3%;
}

.flow06 {
    width: 49%;
      margin: 2% 0% 1% 0%;
    padding: 2% 3% 2% 3%;
}

.flow06_red {
    width: 49%;
      margin: 2% 0% 2% 0%;
    padding: 2% 3% 2% 3%;
}

  .flow_7days {
    width: 49%;
    max-width: 960px;
        margin: 2% 0% 1% 0%;

}

ul.foot_txt_inner {
    padding: 2%;
    /* padding: 0 0 0 10px; */
    margin: 0 auto 0 auto;
}

 /* 下部注意書き行間 */
ul.foot_txt_inner li{
  margin-bottom: 5px;
}

ul.foot_txt_inner li .font_color_bold{
  margin-right: 20px;
}

li.box_yellow_topic{
background-color: #FFFFE7;
padding: 2% 2% 2% 4%;
margin: 0 0 2% 0 !important;
}

/* ---------------@追加エリア ------------- */

/* 2列レイアウトにする 追加 */
/* flow_1024px_innnerBox のFlexbox設定 */
.flow_1024px_add{
  width: 100%;
  max-width: 1024px;
  display: flex;
  flex-direction: column;/* 要素間の余白を均等に配置 */
  padding :0 5% 0 5%;
}

.TopBox{
  margin: 10px 0 0 0;
}

 .TopBox_B{
  margin: 50px 0 5px 0;
}

 .TopBox_C{
  margin: 20px 0 0px 0;
}

    .flow_1024px_innnerBox{
        display: flex; /* ★【重要】Flexboxを有効にする */
        flex-direction: row; /* 横並び */
        justify-content: space-between;
        gap: 20px;
        padding: 0 0px;
    }

    /* flow05とflow06に均等な幅を割り当てる */
       .flow01a,
    .flow01,
        .flow02,
    .flow03,
        .flow04,
    .flow05,
    .flow06_red,
    .flow06 {
        flex: 1 1 0%;
    }

    ul.AppDL_inner {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        list-style: none;
        padding: 0;
        margin: 10px 0;
    }

div.flow_1024px_add h4.box_white_thema {
font-size: 18px;
font-weight: bold;
color: #ffffff;
background-color: #0B79C4;
padding: 10px 10px;
margin: 50px auto 0px auto;
box-sizing: border-box;
text-align: center;
}


    /* ★【重要】コメントを強制的に次の行へ移動させる */
    .AppDL_inner li:last-child {
        width: 100%;
        text-align: center;
    }

    /* Appアイコン間のスペース調整 */
    .AppDL_inner .App_icon_sp {
        margin: 0 10px;
    }



/* ---------------@ MEdia END ------------- */
}/* ---------------　DOnt　erase --- */
/* --------------　@ MEdia END ------------- */


/* EOF */