/*
Theme Name:kizunanokai
Theme URI:
Description:「NPO法人 きずなの会」用テーマ
Author:OA-center
Author URI:
Version:1.0
*/

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

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

ul,
ul li {
  list-style-type: none;
}

a {
  color: inherit;
  text-decoration: none;
}

.kk_sp {
  display: none;
}

.kk_clear {
  clear: both;
}


svg {}

svg .back {
  fill: #ff0000;
  fill-opacity: 0.5;
}

svg .arrow {
  stroke-width: 10;
  stroke: currentColor;
  fill: currentColor;
}

svg .arrow2 {
  fill: currentColor;
}



body {
  font: 400 16px/1.7 "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

em {
  white-space: nowrap;
  font-style: normal;
}

.skip-link {
  position: absolute;
}

/*
.kk_sp_inline, .kk_sp_block {
  display: none;
}
@media ( max-width: 1000px ) {
.kk_pc {
  display: none;
}
.kk_sp_inline {
  display: inline;
}
.kk_sp_block {
  display: block;
}
}
*/

/****

*****/
.kk_button {
  position: relative;
  display: inline-block;
  padding: 1em 1em 0.7em 1em;
  text-align: center;
  line-height: 1;
  color: #ffffff;
  background-color: #1655a0;
  border-bottom: solid 5px #003783;
  border-radius: 5px;
  transition: 0.3s;
}

.kk_button:hover,
.kk_active {
  background-color: #003783;
  border-color: #333333;
}

.kk_pagenav {
  max-width: 1050px;
  margin: 20px auto;
  padding: 0 20px;
}

.kk_pagenav nav {
  display: flex;
  justify-content: center;
}

.kk_pagenav .kk_button {
  width: 100%;
  max-width: 240px;
  margin: 0 10px;
}

.kk_button svg {
  display: inline;
  float: right;
  height: 1em;
  transform: rotate(90deg);
}

@media (max-width: 760px) {
  .kk_pagenav {
    margin: 0;
    padding: 0;
    border-top: solid 1px #003783;
    border-bottom: solid 1px #003783;
  }

  .kk_pagenav .kk_button {
    max-width: none;
    margin: 0;
    padding: 0;
    line-height: 2.8;
    border: solid 1px #003783;
    border-radius: 0;
  }

  .kk_pagenav .kk_button svg {
    display: none;
  }
}

@media (max-width: 560px) {
  .kk_pagenav {
    border-bottom: none;
  }

  .kk_pagenav nav {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .kk_pagenav .kk_button {
    width: 50%;
  }
}

.kk_button_next {
  line-height: 1.2;
}

.kk_button_next svg {
  display: inline-block;
  height: 1.2em;
  margin-left: 0.7em;
  transform: rotate(0);
  background-color: #ffffff;
  border-radius: 100%;
}

.kk_button_next .arrow2 {
  fill: #1655a0;
}

/****

*****/
header {
  position: relative;
  z-index: 10;
  background-color: #ffffff;
  border-top: solid 2px #3f78bc;
}

header .kk_description {
  width: 100%;
  background-color: #f9f9f9;
}

header .kk_description p {
  max-width: 1070px;
  margin: 0 auto;
  padding: 0 10px;
  line-height: 1.4;
  font-size: 0.81em;
}

header .kk_header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1070px;
  margin: 0 auto;
  padding: 15px 10px;
}

header .kk_header .kk_header_logo {}

header .kk_header .kk_header_fb {
  flex-shrink: 0;
  width: 50px;
  margin-left: 5px;
}

header .kk_header .kk_header_fontsize {
  display: flex;
  align-items: center;
  font-weight: 700;
}

header .kk_header .kk_header_fontsize span {
  margin-left: 5px;
  padding: 0.6em 0.6em 0.4em 0.6em;
  cursor: pointer;
}

header .kk_header .kk_header_right {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  padding-left: 20px;
}

header .kk_header .kk_menu_header {
  margin-left: 10px;
}

header .kk_header .kk_menu_header #headermenu_pc {
  display: flex;
}

header .kk_header .kk_menu_header #headermenu_pc li {
  max-width: 180px;
  margin: 0 5px;
  text-align: center;
}

header .kk_header .kk_menu_header #headermenu_pc li a {
  display: block;
  padding: 10px 15px 5px 15px;
  color: #ffffff;
  background-color: #32b16c;
  border-bottom: solid 5px #097c25;
  border-radius: 5px;
  transition: 0.3s;
}

header .kk_header .kk_menu_header #headermenu_pc li:nth-of-type(2) a {
  background-color: #fcaf3c;
  border-bottom: solid 5px #ec6941;
}

header .kk_header .kk_menu_header #headermenu_pc li:nth-of-type(3) a {
  background-color: #f85c5d;
  border-bottom: solid 5px #ec4646;
}

header .kk_header .kk_menu_header #headermenu_pc li a:hover {
  background-color: #097c25;
  border-color: #333333;
}

header .kk_header .kk_menu_header #headermenu_pc li:nth-of-type(2) a:hover {
  background-color: #ec6941;
  border-color: #333333;
}

header .kk_header .kk_menu_header #headermenu_pc li:nth-of-type(3) a:hover {
  background-color: #ec4646;
  border-color: #333333;
}

@media (max-width: 760px) {
  header .kk_description {
    display: none;
  }

  header .kk_header .kk_header_logo {}

  header .kk_header .kk_header_fb {
    width: 40px;
  }
}

header .kk_top_image {
  width: 100%;
  background: url(assets/images/kabekami02.jpg) center bottom no-repeat;
  background-size: 100% auto;
  border-top: solid 1px #d2d2d2;
}

header .kk_top_image div {
  max-width: 1050px;
  height: 300px;
  margin: 0 auto;
  padding: 20px 40px;
  background: url(assets/images/head2022.png) 100% 52% no-repeat;
  background-size: 1050px auto;
  text-align: center;
}

header .head_office {
  height: auto;
}

header .kk_top_image div.kk_top_image_office {
  height: auto !important;
  padding: 0;
  background: none;
  background-size: auto;
}

header .kk_top_image p {
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
  font-size: 40px;
  text-shadow: 2px 2px 4px #2c65a9, -2px 2px 4px #2c65a9, 2px -2px 4px #2c65a9, -2px -2px 4px #2c65a9;
  color: #ffffff;
  margin-top: 0.5em;
  line-height: 1.5em;
}

header .kk_top_image p:nth-child(2) {
  margin-top: 0.2em;
  font-size: 22px;
  font-weight: bold;
  text-shadow: 1px 1px #fff, -1px 1px #fff, 1px -1px #fff, -1px -1px #fff;
  color: #2c65a9;
}

header .kk_top_image p:last-of-type {
  text-align: center;
  margin-top: 5px;
  text-shadow: none;
}

header .kk_top_image a {
  width: 160px;
  position: unset;
  font-size: 14px;
  /* background-color: #f85c5d;
  border-bottom: solid 5px #ec4646; */
  background-color: #1655a0;
  border-bottom: solid 5px #003783;
  position: relative;
  display: inline-block;
  padding: 1em 1em 0.7em 1em;
  text-align: center;
  line-height: 1;
  color: #ffffff;
  border-radius: 5px;
  transition: 0.3s;
  font-family: none;
}

header .kk_top_image a:hover {
  background-color: #003783;
  border-color: #333333;
}

/* 2024.03.29 Add */
header .kk_top_image a.link_cm {
  background: url("./images/kizuna-button-01.png") no-repeat;
  background-size: cover;
  width: calc(417px / 2);
  height: calc(106px / 2);
  color: #000000;
  font-weight: bold;
  background-color: none;
  border-bottom: none;

  display: inline-flex;
  justify-content: center;
  align-items: center;

  padding-bottom: 15px;

}

header .kk_top_image a.link_cm:hover {
  background-color: rgba(255, 255, 255, 0.4);
  background-blend-mode: lighten;
}

header .kk_top_image p.link_cm {
  display: flex;
  justify-content: center;
  padding-top: 0.7rem;
}

@media (max-width: 760px) {
  header .kk_top_image a.link_cm {
    width: calc(320px / 2) !important;
    height: calc(80px / 2) !important;
    padding-bottom: 10px;
  }

  header .kk_top_image p.link_cm {
    margin-top: 0 !important;
  }

  header .kk_top_image .top_text {
    margin-top: 0.5em !important;
  }
}

/* TOP 料金の変更追加 */
.top_text2{
					margin-top: 3em!important;
					background-color: #ffebeb!important;
                }
	@media(max-width:760px){
		div.top_text.top_text2{
					height: 50px!important;
                }
	}


/* TOP TV放映紹介追加 */
header .kk_top_image .top_text {
  max-width: 1050px;
  height: 70px !important;
  text-align: center;
  color: #c43535;
  font-weight: bold;
  padding: 5px;
  background-color: #fff!important;
  border: 6px double;
  margin-top: 3em;
  background: none;
}

header .kk_top_image .top_text p {
  font-size: 28px;
  color: #003783;
}

header .kk_top_image .top_text span:before {
  color: #fcaf3c;
  content: "\02605";
}

header .kk_top_image .top_text .sp_hide {
  display: initial;
}

header .kk_top_image .top_text .pc_hide {
  display: none;
}

@media (min-width:768px) {
  header .kk_top_image {
    height: 400px !important;
  }
}

@media (max-width:767px) {
  header .kk_top_image div {
    height: 250px !important;
	display: flex;
    flex-flow: column;
    justify-content: center;
  }

  header .kk_top_image .top_text .sp_hide {
    display: none;
  }

  header .kk_top_image .top_text .pc_hide {
    display: initial;
  }

  header .kk_top_image .top_text {
    background-color: rgba(255, 255, 255, 0.6);
    border: 4px double;
    margin: 0;
    padding-bottom: 0;
  }

  header .kk_top_image .top_text p {
    font-size: 14px;
  }
}

/* TOP 高齢者等終身サポート事業者ガイドライン追加 */
header .kk_top_image .top_text .link-guidelines a{
  width: 100%!important;
  background-color: transparent!important;
  border-bottom: none !important;
  font-size: 22px!important;
  color: #c43535!important;
  padding-top: 0!important;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif"!important;
  text-decoration: underline;
  line-height: 1.3!important;
}
header .kk_top_image .top_text .link-guidelines a:hover{
  opacity: 0.5;
}
@media (max-width:767px) {
  header .kk_top_image .top_text .link-guidelines a {
    font-size: 11px!important;
  }
}


@media screen and (min-width: 768px) and (max-width: 1070px) {
  header .kk_top_image .top_text p {
    font-size: 19px;
  }
}






@media (max-width: 760px) {
  header .kk_top_image div {
    max-width: 1050px;
    height: 150px;
    margin: 0 auto;
    padding: 10px 20px;
    background: url(assets/images/head2022.png) 30% 40% no-repeat;
    background-size: 130% 100%;
  }

  header .kk_top_image p {
    line-height: 1.2;
    font-size: 20px;
    margin-top: 0.2em;
  }

  header .kk_top_image p:nth-child(2) {
    font-size: 14px;
    margin-top: 1em;
  }

  header .kk_top_image p:last-of-type {
    text-align: center;
    margin-top: 0.5em;
  }

  header .kk_top_image a {
    width: 120px !important;
    font-size: 11px !important;
  }

  header .kk_top_image br {
    display: inline;
  }
}



header .kk_menu_global {
  width: 100%;
  background: linear-gradient(to bottom, #4b7bb9, #003783);
  border-top: solid 2px #003783;
  border-bottom: solid 2px #003783;
}

header #globalmenu {
  position: relative;
  display: flex;
  justify-content: space-around;
  max-width: 1050px;
  margin: 0 auto;
  border-right: solid 2px #ffffff;
}

header #globalmenu>li {
  position: relative;
  flex-grow: 1;
  width: 100%;
  min-height: 3.75em;
  text-align: center;
  line-height: 1.2;
  color: #ffffff;
}

header #globalmenu>li>a {
  overflow: hidden;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #ffffff;
  border-left: solid 2px #ffffff;
  background-image: linear-gradient(to bottom, #4b7bb9, #003783, #218BBD, #59BFE5);
  background-size: 100% 200%;
  transition: 0.3s;
}

header #globalmenu>li>a:after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 100%;
  height: 8px;
  background-color: #00b7ee;
}

header #globalmenu>li>a:hover,
header #globalmenu>li.current-menu-item a {
  background-position: bottom;
}

header #globalmenu>li>a:hover:after,
header #globalmenu>li.current-menu-item a:after {
  /*display: none;*/
  background-color: #ffffff;
}

header #globalmenu .sub-menu {
  position: absolute;
  display: none;
  left: 0;
  top: 100%;
  width: 100%;
}

header #globalmenu>li:hover .sub-menu {
  display: block;
}

header #globalmenu>li:hover .sub-menu li {}

header #globalmenu>li:hover .sub-menu li a {
  display: block;
  margin-left: 2px;
  padding: 10px;
  text-align: left;
  color: #003783;
  border: solid 2px #003783;
}

header #globalmenu>li:hover .sub-menu li a:before {
  content: '> ';
}

header #globalmenu>li:hover .sub-menu li a:hover {
  color: #ffffff;
  background-color: #003783;
}



@media (min-width: 761px) {
  header #headermenu_sp {
    display: none;
  }
}

header #headermenu_sp {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  width: 100%;
  margin: 0 auto;
}

header #headermenu_sp li {
  margin: 0;
  text-align: center;
}

header #headermenu_sp li a {
  display: block;
  padding: 10px 15px 5px 15px;
  color: #ffffff;
  background-color: #32b16c;
}

header #headermenu_sp li:nth-of-type(1) {
  width: 100%;
}

header #headermenu_sp li:nth-of-type(2) {
  width: 50%;
}

header #headermenu_sp li:nth-of-type(3) {
  width: 50%;
}

header #headermenu_sp li:nth-of-type(1) a {
  background: linear-gradient(to bottom, #31b06b, #0c8029);
}

header #headermenu_sp li:nth-of-type(2) a {
  background: linear-gradient(to bottom, #fbab3c, #ed6d41);
}

header #headermenu_sp li:nth-of-type(3) a {
  background: linear-gradient(to bottom, #f85b5d, #ed4847);
}

header #headermenu_sp li:nth-of-type(1) a:hover {
  background: #097c25;
}

header #headermenu_sp li:nth-of-type(2) a:hover {
  background: #ec6941;
}

header #headermenu_sp li:nth-of-type(3) a:hover {
  background: #ec4646;
}

header .kk_sp_block {
  display: none;
}

@media (max-width: 1000px) {
  header #globalmenu {
    flex-wrap: wrap;
  }

  header #globalmenu>li {
    width: 25%;
  }
}

@media (max-width: 760px) {
  header .kk_pc {
    display: none;
  }

  header #globalmenu>li {
    width: 50%;
    min-height: 2.5em;
    line-height: 1.2;
  }

  header #globalmenu>li br {
    display: none;
  }

  header #globalmenu>li>a:after {
    height: 4px;
  }

  header .kk_sp_block {
    display: block;
  }
}

@media (max-width: 360px) {

  header #globalmenu>li,
  header #headermenu_sp li,
  .kk_pagenav nav a {
    font-size: 0.8em;
  }
}

/****

*****/
footer {
  position: relative;
  z-index: 10;
  background-color: #ffffff;
  border-top: solid 2px #3f78bc;
}


footer .kk_footer_nav {
  border-bottom: solid 1px #bfbfbf;
}

footer .kk_footer_nav nav {
  max-width: 1050px;
  margin: 0 auto;
  padding: 10px;
}

footer .kk_footer_nav nav ul {
  display: flex;
}

footer .kk_footer_nav nav ul li {
  padding-right: 30px;
}

footer .kk_footer_nav nav ul li a {
  font-size: 0.8em;
  color: #333333;
}

footer .kk_footer_menu {
  display: flex;
  max-width: 1050px;
  margin: 0 auto;
  padding: 10px;
}

footer .kk_footer_menu {
  display: flex;
  max-width: 1050px;
  margin: 0 auto;
  padding: 20px;
}

footer .kk_footer_logo {
  max-width: 200px;
}

footer .kk_footer_menu nav {
  width: 100%;
}

footer .kk_footer_menu nav ul {
  display: flex;
  flex-wrap: wrap;
  padding-left: 10%;
}

footer .kk_footer_menu nav ul li {
  width: 25%;
}

footer .kk_footer_menu nav ul li a {
  font-size: 0.8em;
  color: #333333;
}

footer .kk_copyright {
  padding: 20px;
  background-color: #eeeeee;
}

footer .kk_copyright p {
  text-align: center;
  font-size: 0.8em;
}

@media (max-width: 760px) {
  footer .kk_pc {
    display: none;
  }

  footer .kk_sp {
    display: block;
  }

  /*
  footer .kk_sp a.kk_button {
    padding: 10px 15px 5px 15px;
  }*/
  footer .kk_footer_menu nav ul li {
    width: 50%;
  }
}

@media (max-width: 500px) {
  footer .kk_footer_logo {
    max-width: 200px;
    margin: 0 auto;
  }

  footer .kk_footer_menu {
    display: block;
    padding: 0 20px;
  }

  footer .kk_footer_menu nav ul {
    margin-top: 20px;
    padding-left: 0;
    border-top: solid 1px #bfbfbf;
    border-right: solid 1px #bfbfbf;
    border-left: solid 1px #bfbfbf;
  }

  footer .kk_footer_menu nav ul li {
    width: 100%;
  }

  footer .kk_footer_menu nav ul li a {
    display: block;
    width: 100%;
    padding: 0.7em 1em;
    border-bottom: solid 1px #bfbfbf;
  }
}


/****

*****/
#kk_breadcrumb {
  max-width: 1050px;
  margin: 10px auto;
  padding: 0 20px;
}

#kk_breadcrumb ul {
  display: flex;
}

#kk_breadcrumb ul li {
  font-size: 0.75em;
}

#kk_breadcrumb ul li:before {
  content: '>';
  margin: 0 0.5em;
}

#kk_breadcrumb ul li:first-of-type:before {
  content: '';
  margin: 0;
}


/****

*****/
.kk_pagenation {
  padding: 20px;
  ;
}

.kk_pagenation ul.page-numbers {
  display: flex;
  justify-content: center;
}

.kk_pagenation ul.page-numbers li {
  margin: 5px;
  line-height: 1;
}

.kk_pagenation ul.page-numbers li a,
.kk_pagenation ul.page-numbers li span {
  display: inline-block;
  padding: 0.7em 1em;
}

.kk_pagenation ul.page-numbers li a {
  border: solid 1px #cfcfcf;
}


/****

*****/
main {
  display: block;
  overflow: hidden;
  background: url("assets/images/blue-sky_3.jpg") center top no-repeat;
  background-attachment: fixed;
  background-size: cover;
}


.kk_totop {
  position: relative;
}

.kk_totop .kk_sp {
  display: none;
}

.kk_totop div {
  position: relative;
  max-width: 1050px;
  height: 60px;
  margin: 0 auto;
}

.kk_totop a {
  position: absolute;
  right: 50px;
  ;
  bottom: 0;
  display: block;
  max-width: 1050px;
  margin: 0 auto;
  padding: 0.5em 1.5em;
  text-align: center;
  font-size: 0.8em;
  font-weight: 700;
  color: #ffffff;
  background-color: #4981C0;
  transition: 0.3s;
}

.kk_totop a span {
  display: inline-block;
  transform: rotate(-90deg);
}

.kk_totop a:hover {
  padding-bottom: 1.5em;
}

@media (max-width: 600px) {
  .kk_totop {}

  .kk_totop .kk_pc {
    display: none;
  }

  .kk_totop .kk_sp {
    display: block;
  }

  .kk_totop .kk_sp a {
    display: block;
    position: fixed;
    z-index: 50;
    right: 30px;
    bottom: 30px;
    width: 40px;
    height: 40px;
    margin: 0;
    padding: 0.4em 0 0 0;
    opacity: 0.7;
    background-color: #333333;
    border-radius: 100%;
  }
}



/****

*****/
h1 {
  overflow: hidden;
  padding: 0 10px;
  margin-bottom: 20px;
  color: #ffffff;
  background-color: #0f468d;
}

h1 span {
  display: block;
  max-width: 1050px;
  margin: 0.4em auto;
  padding: 0 0.4em;
  line-height: 1.2;
  border-left: solid 3px #ffffff;
}

.kk_contents {
  max-width: 1070px;
  margin: 0 auto;
  padding: 0 10px;
}

.kk_content {
  overflow: hidden;
  width: 100%;
  margin: 20px auto;
  padding-bottom: 10px;
  background-color: #ffffff;
}

.kk_content_center {
  max-width: 1050px;
  margin: 20px auto;
  text-align: center;
}

.kk_content_events {
  overflow: hidden;
  width: 100%;
  margin: 20px auto;
  padding: 20px 20px 10px 20px;
  background-color: #ffffff;
}

.kk_content h2 {
  clear: both;
  margin-bottom: 10px;
  padding: 12px 30px 10px 30px;
  line-height: 1.2;
  font-size: 1.38em;
  color: #0f468d;
  border-bottom: solid 3px #0f468d;
}

.kk_content h3 {
  margin: 50px 10px 0 10px;
  padding: 10px 0.5em;
  line-height: 1.2;
  font-size: 1.12em;
  color: #ffffff;
  background-color: #4981c0;
}

.kk_content h3:first-of-type {
  margin-top: 20px;
}

.kk_content h4 {
  margin: 30px 10px 0.5em 10px;
  padding: 0 10px 0.2em 10px;
  line-height: 1.2;
  border-bottom: solid 1px #4981c0;
}

.kk_content p {
  margin: 0.7em 0;
  padding: 0 20px;
}

.kk_content ul.kk_list_normal {
  margin: 20px 0;
  padding: 0 20px;
}

.kk_content ul.kk_list_normal li {
  list-style: disc outside;
  margin-left: 20px;
}

.kk_content figure {
  padding: 0 10px;
}

.kk_content .kk_portrait figure {
  float: left;
  width: 300px;
  padding: 20px;
  text-align: center;
}

@media (max-width: 600px) {
  .kk_content .kk_portrait figure {
    float: none;
    width: 100%;
  }
}


/****

*****/
.kk_content .kk_cover {
  width: 100%;
  padding: 10px;
}

.kk_content table.format-money {
  border-collapse: collapse;
  width: 100%;
}

@media (max-width: 640px) {
  .kk_content table.format-money {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  .kk_content table.format-money th,
  .kk_content table.format-money td {
    font-size: 0.75em;
  }
}

.kk_content table.format-money th,
.kk_content table.format-money td {
  padding: 0.3em 0.7em;
  border: solid 1px #bfbfbf;
}

.kk_content table.format-money .row-odd {
  background-color: #f3f3f9;
}

.kk_content table.format-money tr td:nth-of-type(2) {
  text-align: center;
}

.kk_content table.format-money tr td:nth-of-type(3),
.kk_content table.format-money tr td:nth-of-type(4) {
  text-align: right;
}

.kk_content table.format-money tr td.gray-color {
  text-align: center;
  vertical-align: middle;
  background-color: #e9e9e9;
}



.kk_content .kk_content_link {
  margin: 0 20px;
  padding: 20px 20px 0 20px;
  text-align: right;
}


/****

*****/
.kk_content .kk_inputform {
  margin: 20px 0;
  padding: 0 20px;
}

.kk_content .kk_inputform dl {
  overflow: hidden;
  padding: 10px 20px;
  border-top: dashed 1px #bfbfbf;
}

.kk_content .kk_inputform dl dt {
  float: left;
  width: 30%;
  padding: 5px 10px;
}

.kk_content .kk_inputform dl dt span {
  color: #ff0000;
}

.kk_content .kk_inputform dl dd {
  float: left;
  width: 70%;
  padding: 5px 10px;
}

/* 240129 チェックボックスの追加*/
.kk_content .kk_inputform dl dd input[type="text"],
.kk_content .kk_inputform dl dd input[type="email"],
.kk_content .kk_inputform dl dd textarea {
  width: 100%;
  font-size: 1.12em;
  padding: 4px;
  border: solid 1px #bfbfbf;
}

.kk_content .kk_inputform dl dd input[type="checkbox"] {
  width: 5%;
}

.kk_content .kk_inputform dl dd .how-to-media .wpcf7-list-item {
  display: block;
}

.kk_content .kk_inputform input[type="submit"] {
  display: block;
  margin: 20px auto 0 auto;
  padding: 0.5em 1em;
  text-align: center;
  font-size: 1.25em;
  color: #ffffff;
}

.kk_content .kk_inputform input[type="submit"]:disabled {
  color: #666666;
  background-color: #bfbfbf;
}

@media (max-width: 760px) {

  .kk_content .kk_inputform dl dt,
  .kk_content .kk_inputform dl dd {
    float: none;
    width: 100%;
  }
}


/****

*****/
.kk_faq {
  overflow: hidden;
  width: 100%;
  margin: 20px auto;
  padding: 20px;
  background-color: #ffffff;
}

.kk_faq h2 {
  position: relative;
  margin-bottom: 15px;
  padding: 5px 20px 0 55px;
  line-height: 1.4;
  color: #4981c0;
}

.kk_faq p {
  position: relative;
  padding: 5px 20px 0 55px;
}

.kk_faq h2:before,
.kk_faq p:first-of-type:before {
  content: 'Q';
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 40px;
  padding: 0.5em 0 0.4em 0;
  text-align: center;
  line-height: 1;
  font-size: 1.38em;
  font-weight: 700;
  color: #ffffff;
  background-color: #4981c0;
  border-radius: 8px;
}

.kk_faq p:first-of-type:before {
  content: 'A';
}

/****

*****/
.kk_infolist {
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  padding: 0 20px;
}

ul.kk_infolist li {
  position: relative;
  width: 50%;
  margin: 15px 0;
  padding: 0 20px 0 0;
  font-size: 1.12em;
}

ul.kk_infolist li:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -15px;
  width: 100%;
  height: 1px;
  border-bottom: dashed 1px #bfbfbf;
}

ul.kk_infolist li:nth-of-type(2n) {
  padding: 0 0 0 20px;
  border-left: dashed 1px #bfbfbf;
}

ul.kk_infolist li .kk_info_thumb {
  float: left;
  width: 100px;
  height: 100px;
  margin: 0 20px 0 0;
  padding: 0;
  background-color: #fff;
}

.kk_content ul.kk_infolist li h3 {
  margin: 0;
  padding: 0 0 0 120px;
  line-height: 1.4;
  font-size: 1.12em;
  color: inherit;
  background-color: transparent;
}

ul.kk_infolist li .kk_info_date {
  margin: 0 0 0.3em 0;
  padding: 0;
  line-height: 1.2;
  color: #0f468d;
}

ul.kk_infolist li .kk_info_tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin: 0;
  padding: 0 0 0.3em 0;
  line-height: 1.2;
}

ul.kk_infolist li .kk_info_tags a {
  margin: 0 0.4em 0.5em 0;
}

ul.kk_infolist li .kk_info_tags a[rel*="category"] {
  display: inline-block;
  margin-top: -0.15em;
  padding: 0.2em 0.4em;
  font-size: 0.8em;
  color: #ffffff;
  background-color: #0f468d;
}

ul.kk_infolist li .kk_info_link {
  margin: 0.5em 0 0 0;
  padding: 0;
  text-align: right;
}

ul.kk_infolist li .kk_info_link a {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  color: #000000;
}

ul.kk_infolist li .kk_info_link a:after {
  content: url('data:image/svg+xml;utf-8,<svg fill="%23fff" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><polygon points="150 100 86.46 40 70 40 133.54 100 70 160 86.46 160 150 100"/></svg>');
  box-sizing: border-box;
  width: 1em;
  height: 1em;
  margin-left: 0.7em;
  padding: 1px;
  line-height: 0;
  background-color: #0f468d;
  border-radius: 100%;
}

.kk_content p.kk_infolist_no {
  padding: 2em 2em 0 2em;
  text-align: center;
}

@media (max-width: 760px) {
  ul.kk_infolist li {
    width: 100%;
    padding: 0 10px !important;
  }

  ul.kk_infolist li:nth-of-type(2n) {
    border-left: none;
  }
}

@media (max-width: 560px) {
  ul.kk_infolist li .kk_info_thumb {
    width: 80px;
    height: 80px;
  }

  ul.kk_infolist li .kk_info_thumb img {
    height: auto;
  }

  .kk_content ul.kk_infolist li h3 {
    padding: 0;
  }
}

/****

*****/
.kk_event0 .kk_button_all,
.kk_event6 .kk_button[href*="nagoya"],
.kk_event29 .kk_button[href*="toyota"],
.kk_event30 .kk_button[href*="toyohashi"],
.kk_event31 .kk_button[href*="kasugai"],
.kk_event32 .kk_button[href*="handa"],
.kk_event33 .kk_button[href*="ichinomiya"],
.kk_event34 .kk_button[href*="gifu"],
.kk_event35 .kk_button[href*="shizuoka"],
.kk_event36 .kk_button[href*="hamamatsu"],
.kk_event37 .kk_button[href*="hikone"],
.kk_event38 .kk_button[href*="osaka"],
.kk_event39 .kk_button[href*="tokyo"],
.kk_event40 .kk_button[href*="hachioji"],
.kk_event41 .kk_button[href*="yokohama"],
.kk_event42 .kk_button[href*="tokorozawa"] {
  background-color: #fe9d4d;
  border-color: #fc6400;
}

.kk_info_tags a[href*="nagoya"],
.kk_info_tags a[href*="toyota"],
.kk_info_tags a[href*="toyohashi"],
.kk_info_tags a[href*="kasugai"],
.kk_info_tags a[href*="handa"],
.kk_info_tags a[href*="ichinomiya"] {
  color: #3293ff;
}

.kk_info_tags a[href*="gifu"] {
  color: #7e6b5a;
}

.kk_info_tags a[href*="shizuoka"],
.kk_info_tags a[href*="hamamatsu"] {
  color: #32b16c;
}

.kk_info_tags a[href*="hikone"] {
  color: #1655a0;
}

.kk_info_tags a[href*="osaka"] {
  color: #fcaf3c;
}

.kk_info_tags a[href*="tokyo"],
.kk_info_tags a[href*="hachioji"] {
  color: #ea68a2;
}

.kk_info_tags a[href*="yokohama"] {
  color: #ff5c52;
}

.kk_info_tags a[href*="tokorozawa"],
.kk_info_tags a[href*="saitama"] {
  color: #b3d465;
}


/****

*****/
#ai1ec-calendar {
  padding-top: 20px;
}

.ai1ec-subscribe-container,
.ai1ec-calendar-toolbar,
.ai1ec-actions,
.timely .ai1ec-next-year {
  display: none;
}

.ai1ec-next-month {
  border-bottom-right-radius: 3px !important;
  border-top-right-radius: 3px !important;
}

.ai1ec-month-view .ai1ec-event {
  height: auto;
  padding: 5px;
  line-height: 1.4;
  font-size: 0.88em;
  white-space: normal;
}

/****

*****/
.kk_content_banner {
  overflow: hidden;
  max-width: 1070px;
  margin: 20px auto;
  padding: 0;
}

.kk_content_banner>div {
  float: left;
  width: 42%;
  padding: 17px 20px 10px 20px;
  background-color: #ffffff;
}

.kk_youtbe {
  position: relative;
  padding-bottom: 62.5%;
  height: 0;
  overflow: hidden;
}

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

.kk_content_banner ul {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  width: 100%;
  padding: 15px;
  background-color: #ffffff;
}

.kk_content_banner ul li {
  width: 50%;
  padding: 5px;
}

@media (max-width: 760px) {

  .kk_content_banner>div,
  .kk_content_banner ul {
    float: none;
    width: 100%;
  }

  .kk_content_banner ul {
    margin-top: 20px;
    flex-wrap: wrap;
  }
}


/****

*****/
.kk_top_area {
  float: left;
  margin-top: 20px;
}

.kk_top_area_wrapper {
  overflow: hidden;
}

.kk_top_area dt {
  padding: 2px 0.5em;
  margin-bottom: 8px;
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1;
  border-left: solid 10px #000000;
}

.kk_top_area .kk_button {
  width: 200px;
  margin: 0 20px 10px 0;
}

@media (max-width: 590px) {
  .kk_top_area {
    float: none;
    width: 100%;
  }

  .kk_top_area .kk_button {
    width: 45%;
    margin: 0 2% 10px 2%;
  }
}

/****

*****/
.kk_support {
  overflow: hidden;
  max-width: 100%;
  margin: 0 20px;
  padding: 20px 0;
  border-bottom: solid 1px #bfbfbf;
}

.kk_support:last-of-type {
  border: none;
}

.kk_support img {
  float: left;
  width: 200px;
  margin: 0 20px 0 10px;
}

.kk_support div {
  float: left;
  width: calc(100% - 230px);
}

.kk_support h3 {
  margin: 0;
  padding: 0 0 0 0.7em;
  line-height: 1.3;
  font-size: 1.25em;
  font-weight: 700;
  color: inherit;
  border-left: solid 5px #1655a0;
  background-color: transparent;
}

.kk_support h3 span {
  color: #1655a0;
}

.kk_support p {
  max-width: 100%;
  margin: 0.7em 0;
  padding: 0;
}

.kk_support .kk_content_link {
  margin: 0;
  padding: 0;
}

@media (max-width: 590px) {
  .kk_support img {
    float: none;
    width: 100%;
    margin: 0 0 0 0;
  }

  .kk_support div {
    float: none;
    width: 100%;
  }
}

.kk_gallery .wp-block-group__inner-container {
  display: flex;
  flex-wrap: wrap;
  margin: 20px 0;
}

.kk_gallery .wp-block-group__inner-container div {
  width: 50%;
  text-align: center;
}

/****

*****/
.kk_office_content {
  overflow: hidden;
  padding: 20px;
}

.kk_office_content p {
  margin-bottom: 0.8em;
}

.kk_office_content figure {
  width: 200px;
  text-align: center;
}

.kk_office_contact {
  padding: 20px;
  text-align: right;
}

.kk_office_contact strong {
  font-size: 1.38em;
  font-weight: 700;
  color: #4a81c0;
}

.kk_office_contact strong a {
  color: inherit;
  text-decoration: underline;
}

.kk_office_contact span {
  white-space: nowrap;
}

.kk_office_access {
  padding: 20px;
}

.kk_googlemap {
  width: 100%;
  margin: 10px 0;
}

.kk_content p.kk_post_info {
  margin: 0 0 0.7em 0;
  text-align: right;
  font-size: 0.8em;
  color: 333333;
}

.kk_content p.kk_post_info a[rel*="category"] {
  display: inline-block;
  margin: 0 0.7em;
  padding: 1px 0.3em;
  color: #ffffff;
  background-color: #0f468d;
}


/****

*****/
.kk_officelist {
  border-collapse: collapse;
  width: 100%;
  font-size: 0.88em;
  border-bottom: dashed 1px #333333;
}

.kk_officelist .kk_officelist_border {
  border-top: dashed 1px #333333;
}

.kk_officelist tr td {
  padding: 0.5em 0.3em;
  vertical-align: middle;
}

.kk_officelist .kk_officelist_border td:first-of-type {
  vertical-align: top;
}

.kk_officelist tr td a {
  display: inline-block;
  padding: 0 0.5em;
  font-size: 0.75em;
  color: #ffffff;
  letter-spacing: -0.1px;
  background-color: #4981C0;
  border-radius: 10px;
}

.kk_officelist tr td a.map {
  background-color: darkblue;
  border-radius: 4px;
}

@media (max-width: 760px) {
  table.kk_officelist {
    border-top: dashed 1px #333333;
    border-bottom: none;
  }

  table.kk_officelist,
  table.kk_officelist tr,
  table.kk_officelist td {
    display: block;
    width: 100%;
  }

  table.kk_officelist tbody {
    display: block;
    width: 100%;
  }

  table.kk_officelist td {
    padding: 0.1em 0.3em;
  }

  table.kk_officelist .kk_officelist_border {
    border-top: none;
  }

  table.kk_officelist .kk_officelist_border td:first-of-type {
    margin-bottom: 0.3em;
    text-align: center;
    border-bottom: dashed 1px #333333;
  }

  table.kk_officelist tr td:last-of-type {
    margin-bottom: 0.3em;
    border-bottom: dashed 1px #333333;
  }
}

/****
TOP 20210318４columnコンテンツ追加
*****/
.kk_content_4columns {
  overflow: hidden;
  width: 24%;
  margin: 0 5px;
  background-color: #ffffff;
  float: left;
  padding: 15px;
}

.kk_content_4columns h3 {
  margin: 0;
  padding: 0 0 0 0.7em;
  line-height: 1.3;
  font-size: 1.2em;
  font-weight: 700;
  color: inherit;
  border-left: solid 5px #1655a0;
  background-color: transparent;
}

.kk_content_4columns h3 span {
  color: #1655a0;
  font-size: 80%;
}

.kk_content_4columns p {
  max-width: 100%;
  letter-spacing: -0.1em;
}

.kk_content_4columns img {
  padding: 20px 0px;
}

.clear {
  clear: both;
}

@media (max-width: 767px) {
  .kk_content_4columns {
    width: 100%;
    margin: 10px 0;
  }
}

.banner_2columns {
  width: 50% !important;
}

.banner_2columns img {
  margin-bottom: 0.5em;
}

@media (max-width: 767px) {
  .banner_2columns {
    width: 100% !important;
  }
}

@media screen and (min-width:768px) and (max-width:1044px) {
  .kk_content_4columns {
    width: 23%;
  }

  .kk_content_4columns h3 {
    font-size: 1em;
  }

  .kk_content_4columns h3 span {
    font-size: 65%;
  }
}

.kk_content_4columns.active {
  background-color: #e3f0ff;
}

.kk_content_4columns.active h3 {
  color: #4981c0;
}

.kk_content_4columns.active span {
  color: #4981c0;
}

.kk_content_4columns.active p {
  color: #4981c0;
}

.kk_content_4columns.active img {
  filter: brightness(70%);
}

/****
各事業所ページ　電話番号リンク20220215
*****/
.tel_pc {
  text-decoration: none !important;
}

.tel_sp {
  text-decoration: underline;
}

@media (max-width: 600px) {
  .tel_pc {
    display: none;
  }
}

@media (min-width: 601px) {
  .tel_sp {
    display: none;
  }
}

.d-flex {
  display: flex;
}

.d-flex-wrap {
  flex-wrap: wrap;
}

.d-flex-justify-content-center {
  justify-content: center;
}

.w-100 {
  width: 100% !important;
}

.na-map {
  row-gap: 20px;
  margin-bottom: 20px;
}

.img-map {
  width: 80%
}

.map-an {
  margin-top: 10px;
  gap: 20px;
}

.map-an.d-flex {
  width: 100% !important;
}

.map-an.d-flex .box {
  width: fit-content;
}

.map-an.d-flex .box a {
  width: 100%;
  height: auto;
  display: block;
  padding: 5px 10px;
  background-color: darkblue;
  color: #fff;
}

@media screen and (max-width: 600px) {
  .img-map {
    width: 100%
  }

  .map-an.d-flex .box {
    width: calc(100% - 20px);
  }
}



