@charset "utf-8";
/* CSS Document */


/* ↓↓↓style.css納品後修正↓↓↓ */
body {
  padding-top: 0 !important;
}

@media screen and (max-width: 768px) {
  body {
    padding-top: 0 !important;
  }
}

/* ↑↑↑style.css納品後修正↑↑↑ */

/*---------------------------------------------------------------------
	container
---------------------------------------------------------------------*/
#container {
  overflow: hidden;
  padding-top: 90px;
}

#container.fixed {
  position: fixed;
  width: 100%;
}

#container.recruit {
  padding-top: 150px;
}

@media print,
screen and (max-width: 768px) {
  .sp_none {
    display: none;
  }

  #container {
    padding-top: 50px;
  }

  #container.recruit {
    padding-top: 100px;
  }
}

@media print,
screen and (min-width: 769px) {
  .pc_none {
    display: none;
  }

}

@media print,
screen and (max-width: 425px) {
  .sp_block {
    display: block;
  }
}

.font_mincho {
  font-family: 'Noto Serif JP';
}

/*---------------------------------------------------------------------
	main
---------------------------------------------------------------------*/
main+.common__contact {
  margin-top: 80px;
}

main+.recruit__entry {
  margin-top: 80px;
}

main.recruit__top+.recruit__entry,
main.case+.common__contact,
main.top+.common__contact {
  margin-top: 0;
}

main:has(.summary_wrap)+.recruit__entry {
  margin-top: 0;
}

/*---------------------------------------------------------------------
	alert_box
---------------------------------------------------------------------*/
.alert_box {
  padding: 10px;
  background: #B20000;
}

.alert_box .inner {
  background: #fff;
  padding: 12px;
  border: 4px solid #FF8A92;
  max-width: 1200px;
  margin: 0 auto;
}

.alert_box .head {
  background: #B20000;
  padding: 10px;
  position: relative;
}

.alert_box .ttl {
  color: #fff;
  font-weight: bold;
  font-size: 1.8rem;
}

.alert_box .link {
  position: absolute;
  right: 8px;
  top: 8px;
}

.alert_box .link a {
  color: #000;
  display: block;
  font-size: 1.5rem;
  text-decoration: none;
  text-align: center;
  background: #fff;
  border: 1px solid #BFBFBF;
  padding: 2px 20px 2px 10px;
}

.alert_box .link a::before {
  content: "";
  position: absolute;
  right: 0px;
  top: 11px;
  border: 5px solid transparent;
  border-left: 7px solid #E60011;
}

.alert_box .list {}

.alert_box .list li {}

.alert_box .list a {
  display: block;
  text-decoration: none;
  border-bottom: 1px dotted #BFBFBF;
  padding: 5px;
  padding-left: 20px;
  position: relative;
}

.alert_box .list a::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 11px;
  border: 5px solid transparent;
  border-left: 7px solid #B20000;
}

.alert_box .list .date {
  color: #707070;
  font-size: 1.4rem;
}

.alert_box .list .title {
  text-decoration: underline;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .alert_box {
    padding: 30px;
  }

  .alert_box .ttl {
    font-size: 2.4rem;
  }

  .alert_box .link a {
    width: 200px;
    padding: 6px;
    transition: .3s;
  }

  .alert_box .link a::before {
    right: 8px;
    top: 14px;
  }

  .alert_box .link a:hover {
    background: #fff4bd;
  }

  .alert_box .list a {
    display: table;
    width: 100%;
    padding: 10px 10px 10px 20px;
    transition: .3s;
  }

  .alert_box .list a:hover {
    border-bottom-color: #B20000;
    background: #fff4bd;
  }

  .alert_box .list .date {
    display: table-cell;
    vertical-align: top;
    font-size: 1.6rem;
    width: 140px;
    padding-top: 4px;
  }

  .alert_box .list .title {
    display: table-cell;
    vertical-align: top;
    font-size: 2rem;
  }

  .alert_box .list a::before {
    top: 22px;
  }
}

/*---------------------------------------------------------------------
	site_header
---------------------------------------------------------------------*/
#site_header {
  position: relative;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #ddd;
  padding: 10px;
  position: relative;
  z-index: 100;
}

.site_logo {
  float: left;
  width: 60%;
  max-width: 300px;
  line-height: 1;
  vertical-align: top;
}

.header_menu {
  display: none;
}

/*--- fixed ---*/
#site_header.fixed {
  position: fixed;
  top: 0;
  left: 0;
}


/* pc */
@media print,
screen and (min-width: 1280px) {
  #site_header {
    padding: 15px 110px 15px 15px;
  }

  .site_logo {
    margin-top: 7px;
  }

  .header_menu {
    display: block;
    float: right;
    text-align: right;
  }

  .g_navi {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10px;
  }

  .g_navi>li {}

  .g_navi>li+li {
    margin-left: 10px;
  }

  .g_navi>li>a {
    color: #000;
    font-size: 1.7rem;
    font-weight: 500;
    display: block;
    text-decoration: none;
    padding: 5px 20px;
    transition: .3s;
    background: #ebebeb;
  }

  .g_navi>li>a:hover {
    color: #019FE8;
  }

}


/*----- btn_site_navi -----*/
.btn_site_navi {
  width: 70px;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
}

.btn_site_navi a {
  width: 100%;
  height: 100%;
  color: #fff;
  background: #019FE8;
  text-decoration: none;
  position: relative;
  display: block;
  font-size: 1.1rem;
  text-align: center;
  font-weight: bold;
}

.btn_site_navi .line {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -13px;
  background: #fff;
  width: 26px;
  height: 2px;
  margin-top: -15%;
}

.btn_site_navi .line::before,
.btn_site_navi .line::after {
  content: "";
  position: absolute;
  left: 0;
  background: #fff;
  width: 100%;
  height: 2px;
  transition: .3s;
}

.btn_site_navi .line::before {
  top: -6px;
}

.btn_site_navi .line::after {
  top: 6px;
}

.btn_site_navi .text {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  text-align: center;
}


/*.btn_site_navi.open .line { background: none; }
.btn_site_navi.open .line::before {transform: rotate(45deg);top: 0;}
.btn_site_navi.open .line::after { transform: rotate(-45deg); top:0;}*/

/* pc_l */
@media print,
screen and (min-width: 1460px) {
  .btn_site_navi {
    width: 94px;
  }

  .btn_site_navi a {
    font-size: 1.3rem;
  }
}


/*----- site_navi -----*/
.site_navi {
  /*display: none;*/
  background: #ccc;
  position: fixed;
  right: -100%;
  top: 0;
  width: 80%;
  height: 100%;
  z-index: 100;
  padding: 60px 20px 20px;
  transition: .8s;
  opacity: 0;
  max-width: 600px;
}

.site_navi .inner {
  height: 100%;
  overflow-y: scroll;
}

.site_navi .search_form {}

.close_site_navi {
  cursor: pointer;
  position: absolute;
  right: 10px;
  top: 10px;
  color: #fff;
  font-size: 4rem;
  line-height: 1;
  text-shadow: 0 0 3px rgb(0 0 0 / 50%);
}

.close_site_navi a {
  display: block;
  width: 70px;
  height: 70px;
}

.close_site_navi .line {
  position: absolute;
  left: 130%;
  top: 50%;
  width: 26px;
  margin-left: -13px;
  transition: all .5s ease .5s;
}

.close_site_navi .line::before,
.close_site_navi .line::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #008ECF;
  transition: all .3s ease 1s;
}

.close_site_navi .line::before {
  top: -9px;
}

.close_site_navi .line::after {
  top: 3px;
}

.site_navi.open {
  right: 0;
  opacity: 1;
}

.open .close_site_navi .line {
  left: 50%;
}

.open .close_site_navi .line::before {
  top: -3px;
  transform: rotate(-45deg);
}

.open .close_site_navi .line::after {
  transform: rotate(45deg);
  top: -3px;
}

.site_navi_links .menu_01 {
  margin-bottom: 20px;
}

.site_navi_links .menu_01 li {
  margin-bottom: 3px;
}

.site_navi_links .menu_01 li a {
  display: block;
  color: #fff;
  text-decoration: none;
  background: #00468C;
  padding: 10px;
  position: relative;
}

.site_navi_links .menu_01 li a::before {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-right: 2px solid #92DDFF;
  border-bottom: 2px solid #92DDFF;
  transform: rotate(-45deg);
  margin-top: -4px;
}

.site_navi_links .menu_02 {}

.site_navi_links .menu_02 .item {}

.site_navi_links .menu_02 .item>ul>li {
  margin-bottom: 5px;
}

.site_navi_links .menu_02 .item>ul>li>a {
  display: block;
  color: #000;
  text-decoration: none;
  border: 1px solid #92DDFF;
  padding: 10px;
  position: relative;
}

.site_navi_links .menu_02 .item>ul>li>a::before {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-right: 2px solid #92DDFF;
  border-bottom: 2px solid #92DDFF;
  transform: rotate(-45deg);
  margin-top: -4px;
}

.site_navi_links .menu_02 .item .pull_btn::before {
  transform: rotate(45deg);
  margin-top: -6px;
  transition: .5s;
}

.site_navi_links .menu_02 .item .pull_btn.open::before {
  transform: rotate(225deg);
  margin-top: -4px;
}

.site_navi_links .menu_02 .pull_link {
  display: none;
  padding: 10px;
  background: #c7eeff;
}

.site_navi_links .menu_02 .pull_link li {}

.site_navi_links .menu_02 .pull_link li+li {
  border-top: 1px dotted #009fe8;
}

.site_navi_links .menu_02 .pull_link a {
  display: block;
  text-decoration: none;
  color: #000;
  font-size: 1.4rem;
  padding: 5px;
}

/* tablet */
@media print,
screen and (min-width: 768px) {
  .site_navi {
    padding-top: 80px;
  }

  .close_site_navi a {
    height: 77px;
  }
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .site_navi {
    padding: 100px 40px 40px;
  }

  .site_navi .inner {
    max-width: 1200px;
    margin: 0 auto;
    overflow: inherit;
  }

  .site_navi_links .menu_01 {
    display: table;
    width: 100%;
    table-layout: fixed;
  }

  .site_navi_links .menu_01 li {
    display: table-cell;
    vertical-align: top;
  }

  .site_navi_links .menu_01 li+li {
    padding-left: 5px;
  }

  .site_navi_links .menu_01 li a {
    text-align: center;
    font-size: 1.5rem;
    font-weight: 500;
    padding: 11px 10px 20px;
  }

  .site_navi_links .menu_01 li a:hover {
    transition: .3s;
    background-color: #FC841A;
  }

  .site_navi_links .menu_01 li a::before {
    transform: rotate(45deg);
    right: auto;
    left: 50%;
    top: auto;
    bottom: 10px;
    margin-left: -2px;
  }

  .site_navi_links .menu_01 li a:hover::before {
    border-right-color: #fff;
    border-bottom-color: #fff;
  }

  .site_navi_links .menu_02 {
    display: table;
    width: 100%;
    table-layout: fixed;
  }

  .site_navi_links .menu_02 .item {
    display: table-cell;
    vertical-align: top;
    padding: 0 15px;
    text-align: left;
    border-right: 1px dashed #BFBFBF;
  }

  .site_navi_links .menu_02 .item:first-child {
    padding-left: 10px;
  }

  .site_navi_links .menu_02 .item ul+ul {
    margin-top: 30px;
  }

  .site_navi_links .menu_02 .item>ul>li>a {
    border: none;
    padding: 5px;
    font-weight: 500;
  }

  .site_navi_links .menu_02 .item>ul>li>a:hover {
    transition: .3s;
    background: #f7f7da;
  }

  .site_navi_links .menu_02 .item>ul>li>a::before {
    display: none;
  }

  .site_navi_links .menu_02 .pull_link {
    display: block;
    background: none;
    padding: 0 0 0 20px;
  }

  .site_navi_links .menu_02 .pull_link li+li {
    border-top: none;
  }

  .site_navi_links .menu_02 .pull_link a {
    font-size: 1.5rem;
    padding: 2px;
  }

  .site_navi_links .menu_02 .pull_link a:hover {
    transition: .3s;
    background: #f7f7da;
  }

}

/* pc_l */
@media print,
screen and (min-width: 1460px) {}

/*---------------------------------------------------------------------
	topic_path_top
---------------------------------------------------------------------*/
.topic_path_top {
  margin: 10px auto 30px;
}

.topic_path_top>ol {
  font-size: 13px;
  font-size: 1.3rem;
}

.topic_path_top>ol>li {
  display: inline;
}

.topic_path_top>ol>li+li::before {
  content: ">";
  margin: 0 5px;
}

.topic_path_top>ol>li a {
  text-decoration: underline;
}

.topic_path_top>ol>li:last-child a {
  text-decoration: none;
  color: #333;
}

/*---------------------------------------------------------------------
	pagebody
---------------------------------------------------------------------*/
.pagebody_inner {
  max-width: 1200px;
  padding: 0 15px;
  box-sizing: content-box;
  margin: 0 auto;
}

.pagebody_inner_02 {
  max-width: 1760px;
  padding: 0 15px;
  box-sizing: content-box;
  margin: 0 auto;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .pagebody_inner_02 {
    padding: 0 40px;
  }

  .pagebody_inner_02 .pagebody_inner {
    padding: 0;
  }
}

/*--------------------------------------------------
	alpha
--------------------------------------------------*/
#alpha {}

/* pc */
@media print,
screen and (min-width: 1280px) {
  #alpha {
    float: left;
    width: 76.66%;
  }
}


/*--------- text -----------*/
/*h1.page_ttl {
  color: #007FB9;
  font-size: 2.2rem;
  font-weight: 500;
  background: #eee;
  padding: 25px 10px;
  line-height: 1.4;
}
.page_ttl span {
  max-width: 1200px;
  margin: 0 auto;
  display: block;
}*/

/* tablet */
/*@media print, screen and (min-width: 768px) {
  h1.page_ttl {
    font-size: 3rem;
  }
}*/

/* pc */
/*@media print, screen and (min-width: 1280px) {
  .page_ttl {
    font-size: 3.4rem;
    padding: 35px;
  }
}*/




h1.page_ttl {
  background: -webkit-gradient(linear, left top, right top, from(#2373B9), to(#238ECB));
  background: linear-gradient(to right, #2373B9 0%, #238ECB 100%);
  text-align: center;
  color: #fff;
  font-size: 50px;
  font-weight: 500;
  line-height: 1;
  padding: 84px 20px;
  margin-bottom: 10px;
}

@media screen and (max-width: 768px) {
  h1.page_ttl {
    font-size: 20px;
    padding: 40px 20px;
  }
}


.content1 {
  line-height: 1.8;
}

.content1 p {
  margin: 1em 0;
}

.content1 h2+p,
.content1 h3+p,
.content1 h4+p,
.content1 h5+p,
.content1 h6+p {
  margin-top: 0;
}

.content1 div>p {
  margin-top: 0;
}

/* headline */
.content1 *+h2 {
  margin-top: 80px;
}

.content1 *+h3 {
  margin-top: 60px;
}

.content1 *+h4 {
  margin-top: 40px;
}

.content1 *+h5 {
  margin-top: 20px;
}

.content1 h2+h3,
.content1 h3+h4 {
  margin-top: 0;
}

/* utility */
.content1 *+dl,
.content1 *+ol,
.content1 *+ul,
.content1 *+table {
  margin-top: 20px;
}

ol[style*="decimal"],
ol[style*="roman"],
ol[style*="alpha"] {
  padding-left: 22px;
}

.lead_01,
.content1 h2,
.c__headline2 {
  font-size: 40px;
  font-weight: 500;
  letter-spacing: 0.1em;
  position: relative;
  margin-bottom: 40px;
  line-height: 1.25;
  padding-bottom: 20px;
}

.lead_01::before,
.content1 h2::before,
.c__headline2::before {
  content: "";
  width: 220px;
  height: 10px;
  background: #2838A9;
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 2;
}

.lead_01::after,
.content1 h2::after,
.c__headline2::after {
  content: "";
  height: 10px;
  width: 100%;
  background: #E0E0E0;
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
}

@media screen and (max-width: 768px) {

  .lead_01,
  .content1 h2,
  .c__headline2 {
    font-size: 24px;
    padding-bottom: 10px;
  }

  .lead_01::before,
  .content1 h2::before,
  .c__headline2::before {
    width: 100px;
    height: 5px;
  }

  .lead_01::after,
  .content1 h2::after,
  .c__headline2::after {
    height: 5px;
  }
}

.lead_02,
.content1 h3,
.c__headline3 {
  font-size: 30px;
  font-weight: 400;
  letter-spacing: 0.1em;
  position: relative;
  background-size: 8px 1px;
  background-image: -webkit-linear-gradient(left, #606060 4px, transparent 4px);
  background-image: linear-gradient(to right, #606060 4px, transparent 4px);
  background-repeat: repeat-x;
  background-position: 0 100%;
  padding-bottom: 10px;
  margin-bottom: 30px;
}

.lead_02::before,
.content1 h3::before,
.c__headline3::before {
  content: "";
  width: 100px;
  height: 6px;
  background: #2838A9;
  display: block;
  position: absolute;
  left: 0;
  bottom: -2px;
}

@media screen and (max-width: 768px) {

  .lead_02,
  .content1 h3,
  .c__headline3 {
    font-size: 20px;
    margin-bottom: 22px;
  }

  .lead_02::before,
  .content1 h3::before,
  .c__headline3::before {
    width: 60px;
    height: 3px;
  }
}

.lead_03,
.content1 h4,
.c__headline4 {
  font-size: 26px;
  letter-spacing: 0.1em;
  font-weight: 400;
  margin-bottom: 30px;
}

.lead_03::before,
.content1 h4::before,
.c__headline4::before {
  content: "";
  display: inline-block;
  width: 26px;
  height: 26px;
  background: url("/image/common/icon_headline04.svg") no-repeat;
  vertical-align: middle;
  margin-right: 10px;
  position: relative;
  top: -2px;
}

@media screen and (max-width: 768px) {

  .lead_03,
  .content1 h4,
  .c__headline4 {
    font-size: 18px;
    margin-bottom: 20px;
  }

  .lead_03::before,
  .content1 h4::before,
  .c__headline4::before {
    width: 18px;
    height: 18px;
    background-size: contain;
  }
}

.content1 h4.c__headline4-orange {
  display: inline-block;
  background: #FF762B;
  color: #fff;
  font-weight: 500;
  padding: 10px;
  margin-bottom: 20px;
}

.lead_04,
.content1 h5,
.c__headline5 {
  font-size: 24px;
  letter-spacing: 0.1em;
  font-weight: 400;
  margin-bottom: 20px;
}

.lead_04::before,
.content1 h5::before,
.c__headline5::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 26px;
  background: url("../image/common/icon_headline05.svg") no-repeat;
  vertical-align: middle;
  margin-right: 10px;
  position: relative;
  top: -2px;
}

@media screen and (max-width: 768px) {

  .lead_04,
  .content1 h5,
  .c__headline5 {
    font-size: 18px;
    margin-bottom: 20px;
  }

  .lead_04::before,
  .content1 h5::before,
  .c__headline5::before {
    width: 11px;
    height: 18px;
    background-size: contain;
  }
}

.content1 h5.c__headline5-bld {
  font-weight: 500;
  font-size: 16px;
}

.content1 h6,
.c__headline6 {
  font-size: 22px;
  letter-spacing: 0.1em;
  font-weight: 400;
  margin-bottom: 20px;
}

.content1 h6::before,
.c__headline6::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 26px;
  background: #2838A9;
  vertical-align: middle;
  margin-right: 10px;
  position: relative;
  top: -2px;
}

@media screen and (max-width: 768px) {

  .content1 h6,
  .c__headline6 {
    font-size: 18px;
    margin-bottom: 20px;
  }

  .content1 h6::before,
  .c__headline6::before {
    width: 4px;
    height: 18px;
    background-size: contain;
  }
}

.lead_05 {
  color: #224262;
  font-weight: 500;
  font-size: 1.8rem;
}

.lead_06 {
  color: #B55C5C;
  font-weight: 500;
  font-size: 1.8rem;
}

.lead_07 {
  color: #333333;
  font-weight: 500;
  font-size: 1.8rem;
}

.lead_08 {
  margin-top: 20px;
  color: #2838A9;
  font-weight: 900;
  font-size: 16px;
}

.content1 .lead_08+dl,
.content1 .lead_08+ol,
.content1 .lead_08+ul,
.content1 .lead_08+table {
  margin-top: 5px;
}

/* pc */
/*@media print, screen and (min-width: 1280px) {
  .lead_01,
  .content1 h2 {
    font-size: 3.2rem;
    min-height: 140px;
    padding: 20px 25px;
    margin-bottom: 35px;
  }
  
  .lead_02,
  .content1 h3 {
    font-size: 3rem;
    padding-bottom: 15px;
  }
  
  .lead_03,
  .content1 h4 { font-size: 2.8rem; padding-bottom: 12px; }
  
  .lead_04,
  .content1 h5 { font-size: 2.6rem; }
  
  .lead_05,
  .lead_06,
  .lead_07 { font-size: 2.4rem; }
}*/


.fc_01 {
  color: #D80000;
}

.fc_02 {
  color: #2838A9;
}

.modified_date {
  color: #333;
  font-size: 86.66%;
  margin-bottom: 20px;
  text-align: right;
}

/*--------- btn -----------*/
a.btn_01 {
  display: inline-block;
  vertical-align: top;
  color: #333;
  text-decoration: none;
  border: 1px solid #CCCCCC;
  background: #fff url("/image/icon/arrow_01.png") no-repeat right 10px center;
  min-width: 31.66%;
  padding: 10px 30px;
  font-size: 1.4rem;
  border-radius: 3px;
}

/* pc */
@media screen and (min-width: 1280px) {
  a.btn_01 {
    padding: 18px 30px;
  }

  a.btn_01 {
    transition: .3s;
  }

  a.btn_01:hover {
    color: #fff;
    background-color: #008ECF;
    background-image: url("/image/icon/arrow_01_w.png");
  }
}


/*--------- bg -----------*/
.bg_box_01 {
  background: #F0F7F6;
  padding: 10px 15px;
}

.bg_box_02 {
  background: #F6F5EE;
  padding: 10px 15px;
}

.bg_box_03 {
  border: 1px solid #ccc;
  padding: 10px 15px;
}

/*--------- template -----------*/
.fll_img {
  margin-bottom: 15px;
}

.flr_img {
  margin-bottom: 15px;
}

.sp_flr_img {
  float: right;
  margin: 0 0 0 20px;
}

.sp_fll_img {
  float: left;
  margin: 0 20px 0 0;
}

.fll_img img,
.fll_img img {
  max-width: 100%;
  height: auto;

}

.fl_over {
  overflow: hidden;
}

@media print,
screen and (min-width: 767px) {
  .fll_img {
    float: left;
    max-width: 45%;
    margin: 0 40px 0 0;
  }

  .flr_img {
    float: right;
    max-width: 45%;
    margin: 0 0 0 40px;
  }
}

.caption,
.list_1column .caption,
.list_2column .caption,
.list_3column .caption,
.list_4column .caption,
.list_5column .caption {
  font-size: 86.66%;
  line-height: 1.4;
  padding-top: 7px;
  text-align: center;
  margin: 0;
}

.list_1column img,
.list_2column img,
.list_3column img,
.list_4column img,
.list_5column img {
  width: 100%;
  height: auto;
}

.list_2column .width_auto,
.list_3column .width_auto {
  width: auto;
}

/* list_2column */
.list_2column {}

.list_2column .item+.item {
  margin-top: 15px;
}

@media print,
screen and (min-width: 768px) {
  .list_2column {
    display: flex;
    flex-wrap: wrap;
  }

  .list_2column .item {
    width: 48.75%;
    margin: 0 2.5% 2.5% 0;
  }

  .list_2column .item+.item {
    margin-top: 0;
  }

  .list_2column .item:nth-child(2n) {
    margin-right: 0;
  }
}

/* list_3column */
.list_3column {}

.list_3column .item+.item {
  margin-top: 15px;
}

@media print,
screen and (min-width: 768px) {
  .list_3column {
    display: flex;
    flex-wrap: wrap;
  }

  .list_3column .item {
    width: 31.08%;
    margin: 0 3.33% 3.33% 0;
  }

  .list_3column .item+.item {
    margin-top: 0;
  }

  .list_3column .item:nth-child(3n) {
    margin-right: 0;
  }
}

/* list_4column */
.list_4column {
  display: flex;
  flex-wrap: wrap;
}

.list_4column .item {
  width: 48.75%;
  margin: 0 2.5% 2.5% 0;
}

.list_4column .item:nth-child(2n) {
  margin-right: 0;
}

@media print,
screen and (min-width: 768px) {

  .list_4column .item,
  .list_4column .item:nth-child(2n) {
    width: 23.33%;
    margin: 0 2.08% 2.08% 0;
  }

  .list_4column .item:nth-child(4n) {
    margin-right: 0;
  }
}

/* list_5column */
.list_5column {
  display: flex;
  flex-wrap: wrap;
}

.list_5column .item,
.list_5column.sp_2column li {
  width: 48.75%;
  margin: 0 0.3% 0.3% 0;
}

.list_5column .item:nth-child(2n),
.list_5column.sp_2column li:nth-child(2n) {
  margin-right: 0;
}

@media print,
screen and (min-width: 768px) {

  .list_5column .item,
  .list_5column .item:nth-child(2n),
  .list_5column.sp_2column li {
    width: 19.6%;
  }

  .list_5column .item:nth-child(2n),
  .list_5column.sp_2column li:nth-child(2n) {
    margin-right: 0.3%;
    ;
  }

  .list_5column .item:nth-child(5n),
  .list_5column.sp_2column li:nth-child(5n) {
    margin-right: 0;
  }
}

.contact_box {
  background: #fafafa;
  padding: 15px 20px;
  border: 3px solid #133775;
}

*+.contact_box {
  margin-top: 60px;
}

/*--------- list_index -----------*/
*+.list_index {
  margin-top: 60px;
}

.list_index {}

.list_index .item {}

.list_index .item+.item {
  margin-top: 15px;
}

.list_index .item>a {
  color: #000;
  text-decoration: none;
  position: relative;
  border: 1px solid #bfbfbf;
  display: table;
  width: 100%;
}

.list_index .item .thumb {
  display: table-cell;
  vertical-align: middle;
  width: 35%;
}

.list_index .item .thumb span {
  position: relative;
  padding-bottom: 66.66%;
  overflow: hidden;
  display: block;
}

.list_index .item .thumb img {
  position: absolute;
  top: -100%;
  left: -100%;
  right: -100%;
  bottom: -100%;
  margin: auto;
  max-width: none;
  max-height: 100%;
  transition: .5s;
  width: 100%;
}

.list_index .item>a:hover .thumb img {
  opacity: 1;
  transform: scale(1.08);
}

.list_index .item .thumb+.detail {
  border-left: 1px solid #ccc;
}

.list_index .item .detail {
  display: table-cell;
  vertical-align: middle;
  background: #018FCF no-repeat right 10px center/40px;
  padding: 15px 0;
}

.list_index .item .ttl {
  font-size: 1.8rem;
  color: #fff;
  font-weight: normal;
  position: relative;
  padding-left: 30px;
  padding-right: 10px;
}

.list_index .item .ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 9px;
  margin-top: -4px;
  width: 6px;
  height: 6px;
  border-right: 2px solid #009FE8;
  border-bottom: 2px solid #009FE8;
  transform: rotate(-45deg);
}

.list_index .item .lead {
  font-size: 1.5rem;
  margin-top: 5px;
  padding: 7px 10px;
  background: #FCE6D6;
}

.list_index .item>ul {
  margin: 5px 0 30px 10px;
}

.list_index .item>ul li+li {}

.list_index .item>ul a {
  display: block;
  color: #000;
  text-decoration: none;
  border-bottom: 1px solid #bfbfbf;
  font-size: 1.5rem;
  padding: 5px 10px 5px 20px;
  position: relative;
}

.list_index .item>ul a::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 12px;
  border: 4px solid transparent;
  border-left: 6px solid #009FE8;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .list_index {
    display: flex;
    flex-wrap: wrap;
  }

  .list_index .item {
    width: 31.08%;
    margin: 0 3.33% 3.33% 0;
  }

  .list_index .item+.item {
    margin-top: 0;
  }

  .list_index .item:nth-child(3n) {
    margin-right: 0;
  }

  .list_index .item a {
    display: block;
  }

  .list_index .item a:hover {
    border-color: #008ECF;
  }

  .list_index .item a:hover .ttl {
    color: #008ECF;
  }

  .list_index .item .thumb {
    display: block;
    width: auto;
  }

  .list_index .item .detail {
    display: block;
    padding: 15px 10px;
    background-size: auto;
  }

  .list_index .item a:hover .detail {
    background-color: #ffffe9;
    transition: .3s;
  }

  .list_index .item .thumb+.detail {
    border-left: none;
  }

  .list_index .item .ttl {
    padding: 7px 0 7px 30px;
  }

  .list_index .item .ttl::before {
    left: 7px;
  }
}



/* hierarchy_link */
.hierarchy_link {
  background: #eee;
  text-align: center;
  padding: 20px;
  margin: 70px 0;
}

.hierarchy_link .inner {
  max-width: 1200px;
  margin: 0 auto;
}

.hierarchy_link .ttl {
  font-size: 2rem;
  font-weight: normal;
  margin-bottom: 20px;
}

.hierarchy_link .ttl a {
  color: #000;
  text-decoration: none;
  display: inline-block;
}

.hierarchy_link li {}

.hierarchy_link li+li {
  margin-top: 10px;
}

.hierarchy_link li a {
  display: block;
  color: #000;
  text-decoration: none;
  position: relative;
  border: 1px solid #BFBFBF;
  text-align: left;
  background: #fff;
  padding: 10px 10px 10px 30px;
}

.hierarchy_link li a::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 18px;
  width: 6px;
  height: 6px;
  border-right: 2px solid #EB6100;
  border-bottom: 2px solid #EB6100;
  transform: rotate(-45deg);
}

/* tablet */
@media print,
screen and (min-width: 768px) {
  .hierarchy_link {
    margin: 100px 0;
  }

  .hierarchy_link .ttl {
    font-size: 2.4rem;
  }

  .hierarchy_link .inner {
    display: flex;
    flex-wrap: wrap;
  }

  .hierarchy_link li {
    width: 31.08%;
    margin: 0 3.33% 3.33% 0;

  }

  .hierarchy_link li+li {
    margin-top: 0;
  }

  .hierarchy_link li:nth-child(3n) {
    margin-right: 0;
  }

  .hierarchy_link li a {
    font-size: 1.8rem;
    transition: .3s;
    padding: 16px 16px 16px 35px;
  }

  .hierarchy_link li a::before {
    left: 13px;
    top: 26px;
  }

  .hierarchy_link li a:hover {
    color: #000;
    border-color: #EB6100;
    background-color: #FFF6D1;
  }
}


/*--------------------------------------------------
	list_magazine
--------------------------------------------------*/
.list_magazine {
  display: flex;
  flex-wrap: wrap;
}

.list_magazine .item {
  width: 48%;
  margin: 0 4% 4% 0;
}

.list_magazine .item:nth-child(2n) {
  margin-right: 0;
}

.list_magazine .item a {
  display: block;
  color: #000;
  text-decoration: none;
}

.list_magazine .item img {
  border: 1px solid #ccc;
  width: 100%;
}

.list_magazine .ttl {
  font-weight: 500;
  color: #007FB9;
  margin: 5px 0;
}

.list_magazine .icon_cat {
  font-size: 1.1rem;
  display: inline-block;
  vertical-align: top;
  background: #ebebeb;
  border-radius: 3px;
  padding: 2px 10px;
}

/* tablet */
@media print,
screen and (min-width: 768px) {

  .list_magazine .item,
  .list_magazine .item:nth-child(2n) {
    width: 31%;
    margin: 0 3.5% 3.5% 0;
  }

  .list_magazine .item:nth-child(3n) {
    margin-right: 0;
  }

  .list_magazine .ttl {
    font-size: 2rem;
  }

  .list_magazine .icon_cat {
    font-size: 1.4rem;
  }
}

/*--------------------------------------------------
	list_topics
--------------------------------------------------*/
/* list_topics */
.list_topics {
  background: #fff;
  border-top: 1px dotted #bbb;
}

.list_topics li {
  border-bottom: 1px dotted #bbb;
}

.list_topics li a {
  color: #000;
  display: block;
  text-decoration: none;
  padding: 10px;
}

.list_topics li span {
  display: inline-block;
  vertical-align: top;
}

.list_topics li .date {
  margin-right: 10px;
  font-size: 1.3rem;
}

.list_topics li .icon_cat {
  font-size: 1.1rem;
  text-align: center;
  font-weight: normal;
  background: #EBEBEB;
  padding: 1px 8px;
  border-radius: 3px;
}

.list_topics li .cat_01 {
  background: #DFFFBF;
}

.list_topics li .cat_02 {
  background: #BFDFFF;
}

.list_topics li .cat_03 {
  background: #E4F4FC;
}

.list_topics li .cat_04 {
  background: #FFF9E5;
}

.list_topics li .cat_05 {
  background: #ECE5FF;
}

.list_topics li .title {
  display: block;
  margin-top: 5px;
}

/* tablet */
@media print,
screen and (min-width: 768px) {
  .list_topics li a {
    padding: 15px 20px;
  }

  .list_topics li .date {
    font-size: 1.5rem;
  }

  .list_topics li .icon_cat {
    font-size: 1.3rem;
    padding: 3px 20px;
  }
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .list_topics li a {
    transition: .3s;
  }

  .list_topics li a:hover {
    background-color: #fffced;
  }

  .list_topics li a:hover .title {
    text-decoration: underline;
  }
}



/* .pager */
.pager {
  margin: 60px 0;
  padding: 50px 0;
  text-align: center;
  background: #FCF8ED;
}

.pager ul {}

.pager ul li {
  font-size: 81.25%;
  margin: 3px;
  display: inline-block;
}

.pager a,
.pager span {
  color: #000;
  display: block;
  text-decoration: none;
  border: 1px solid #CCC;
  padding: 9px 16px;
  background-color: #fff;
}

.pager li.total span {
  border-color: #FFF;
}

.pager li.prev span,
.pager li.next span,
.pager li.first span,
.pager li.last span {
  border: 1px solid #ccc;
  color: #EDEDED;
}

.pager li.current span {
  color: #fff;
  background: #915E33;
}

.pager a:hover {
  color: #915E33;
  border: 1px solid #999;
  background: #EEEAD9;
}

/* link_prev_next */
.link_prev_next {
  text-align: center;
  max-width: 600px;
  margin: 60px auto 0;
  border-top: 1px solid #ccc;
  padding-top: 40px;
}

.link_prev_next>li {
  display: inline-block;
  width: 80%;
  max-width: 300px;
}

.link_prev_next>li a {
  color: #000;
  border: 1px solid #ccc;
  display: block;
  padding: 16px 40px;
  text-decoration: none;
  transition: .3s;
  border-radius: 3px;
  position: relative;
}

.link_prev_next>li a::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 50%;
  border: 5px solid transparent;
  border-right: 8px solid #aaa;
  margin-top: -5px;
}

.link_prev_next>li a:hover {
  background-color: #e6f6fd;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .link_prev_next {
    margin-top: 80px;
  }
}


/*サムネイル付きトピックス*/
.list_thumb_topics {
  font-size: 0;
  margin-bottom: 30px;
}

.list_thumb_topics li {
  font-size: 16px;
  width: 31.66%;
  display: inline-block;
  margin: 0 2.5% 0 0;
  vertical-align: top;
}

.list_thumb_topics li:nth-child(3n) {
  margin-right: 0;
}

.list_thumb_topics .thumb {
  position: relative;
  padding-bottom: 66.66%;
  overflow: hidden;
  background-color: #F8F6F0;
  border: 1px solid #ccc;
}

.list_thumb_topics .thumb img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: auto;
}

.list_thumb_topics a {
  text-decoration: none;
}

.list_thumb_topics .detail {
  font-size: 15px;
  color: #333;
  padding: 5px 0;
  border-bottom: 1px dotted #bbb;
}

.list_thumb_topics a:hover .detail {
  background-color: #f8f6f0;
}

/*広報紙*/
.list_kouhou {
  font-size: 0;
  margin-bottom: 30px;
}

.list_kouhou .item {
  font-size: 16px;
  width: 31.66%;
  display: inline-block;
  margin: 0 2.5% 0 0;
  vertical-align: top;
  text-align: center;
  border: 1px solid #bbb;
}

.list_kouhou .item a {
  display: block;
  padding: 5px;
}

.list_kouhou .item a:hover {
  background-color: #f5f4ef;
}

.list_kouhou .item:nth-child(3n) {
  margin-right: 0;
}

.list_kouhou .ttl a {
  font-size: 16px;
  font-weight: normal;
  text-decoration: none;
  color: #333;
}

/*障害情報*/
.topics_head.caution .cate {
  background-color: #2838A9;
}

.toggle_content_block {
  margin-bottom: 20px;
}

.toggle_content_block .toggle_content_name {
  line-height: 1.55;
  margin: 0 0 15px;
  padding: 12px 40px 12px 15px;
  border: 1px solid #CCD1DB;
  background-color: #F5F5F5;
  font-size: 18px;
  font-weight: 400;
  color: #333333;
  cursor: pointer;
}

.toggle_content_block .toggle_content_name::before {
  content: none;
}

.toggle_content_block .toggle_content_name::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  bottom: auto;
  left: auto;
  width: 10px;
  height: 10px;
  border-top: 2px solid #FF4E00;
  border-right: 2px solid #FF4E00;
  background: none;
  transform: rotate(135deg) translate(-55%, 55%);
  transition: all .3s;
}

.toggle_content_block.open .toggle_content_name::after {
  transform: rotate(-45deg) translate(15%, -15%);
}

.toggle_content_block.open+.toggle_content_block {
  margin-top: 50px;
}

@media print,
screen and (min-width: 769px) {
  .toggle_content_block {
    margin-bottom: 40px;
  }

  .toggle_content_block .toggle_content_name {
    line-height: 1.55;
    margin: 0 0 50px;
    padding: 9px 65px 9px 20px;
    font-size: 26px;
  }

  .toggle_content_block .toggle_content_name::after {
    right: 24px;
  }

  .toggle_content_block.open+.toggle_content_block {
    margin-top: 80px;
  }
}

/*---------------------------------------------------------------------
	top_ttl
---------------------------------------------------------------------*/
.top_ttl {
  text-align: center;
  font-weight: normal;
  font-size: 2.4rem;
  line-height: 1;
  position: relative;
  margin-bottom: 15px;
}

.top_ttl .ja {
  display: block;
}

.top_ttl .en {
  color: #00468C;
  display: inline-block;
  margin: 0 auto;
  background: #fff;
  padding: 0 15px;
  font-size: 1.3rem;
  font-family: 'Noto Serif JP';
  position: relative;
}

.top_ttl::before {
  content: "";
  width: 80%;
  height: 1px;
  position: absolute;
  left: 50%;
  bottom: 6px;
  background: #009FE8;
  margin-left: -40%;
}

/* tablet */
@media screen and (min-width: 768px) {
  .top_ttl::before {
    width: 390px;
    margin-left: -195px;
  }

  #top a.btn_01 {
    width: 300px;
    min-width: auto;
  }
}

/* pc */
@media screen and (min-width: 1280px) {
  .top_ttl {
    font-size: 3.4rem;
    margin-bottom: 25px;
  }

  .top_ttl .en {
    font-size: 1.6rem;
  }
}




/*---------------------------------------------------
	beta
---------------------------------------------------*/
#beta {
  margin-top: 40px;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  #beta {
    float: right;
    width: 20%;
    margin-top: 0;
  }
}

/*---------------------------------------------------
	sidemenu
---------------------------------------------------*/
.side_menu {}

.side_menu a {
  color: #000;
  display: block;
  text-decoration: none;
}

.side_menu a:hover {
  text-decoration: underline;
}

.side_menu .level_1 {
  border-top: 1px solid #ccc;
}

.side_menu .level_1>li>a {
  font-size: 1.5rem;
  font-weight: 500;
  padding: 10px 0 10px 20px;
  border-bottom: 1px solid #ccc;
  position: relative;
}

.side_menu .level_1>li>a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 17px;
  border: 5px solid transparent;
  border-left: 7px solid #aaa;
}

.side_menu .level_1>li>a.selected,
.side_menu .level_1>li>a:hover {
  color: #133557;
}

.side_menu .level_2>li+li {}

.side_menu .level_2>li>a {
  font-size: 1.4rem;
  border-bottom: 1px dotted #bbb;
  padding: 15px;
  position: relative;
}

.side_menu .level_2>li>a::before {
  content: "";
  width: 2px;
  height: 20px;
  background: #BBBBBB;
  position: absolute;
  left: 0;
  top: 16px;
}

.side_menu .level_2>li>a.selected,
.side_menu .level_2>li>a:hover {
  color: #008ECF;
}

.side_menu .level_2>li>a.selected::before,
.side_menu .level_2>li>a:hover::before {
  background: #009FE8;
}

.side_menu .level_3 {
  margin: 10px 0 10px 10px;
  background: #fafafa;
}

.side_menu .level_3>li>a {
  padding: 10px;
  padding-left: 23px;
  font-size: 1.4rem;
  border-bottom: 1px dotted #ccc;
  position: relative
}

.side_menu .level_3>li>a::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 18px;
  width: 6px;
  height: 6px;
  background: #ccc;
  border-radius: 50%;
}

.side_menu .level_3>li>a.selected,
.side_menu .level_3>li>a:hover {
  color: #133557;
}

.side_menu .level_3>li>a.selected::before,
.side_menu .level_3>li>a:hover::before {
  background: #009FE8;
}

.side_menu .level_4 {
  margin-left: 22px;
}

.side_menu .level_4>li+li {
  border-top: 1px dotted #ccc;
}

.side_menu .level_4>li>a {
  padding: 8px;
  font-size: 1.4rem;
  position: relative;
}

.side_menu .level_4>li>a::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 15px;
  width: 7px;
  height: 7px;
  border-left: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.side_menu .level_4>li>a.selected,
.side_menu .level_4>li>a:hover {
  color: #133557;
}

.side_menu .level_4>li>a.selected::before,
.side_menu .level_4>li>a:hover::before {
  border-left-color: #009FE8;
  border-bottom-color: #009FE8;
}

/*--------- beta -----------*/
.list_side_menu {
  border: 4px double #bdbdbd;
}

.list_side_menu+.list_side_menu {
  margin-top: 30px;
}

.list_side_menu .ttl {
  font-size: 100%;
  color: #007fb9;
  font-weight: bold;
  padding: 15px 10px;
  position: relative;
  background: #ececec;
}

.list_side_menu ul {
  padding: 10px;
}

.list_side_menu li {}

.list_side_menu li+li {
  border-top: 1px dotted #e0d7bc;
}

.list_side_menu li a {
  display: block;
  color: #000;
  text-decoration: none;
  font-size: 94%;
  padding: 7px 5px 7px 23px;
  position: relative;
}

.list_side_menu li a::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 13px;
  border: 5px solid transparent;
  border-left: 7px solid #aaa;
}

.list_side_menu li .date {
  display: block;
  font-size: 90%;
  font-weight: bold;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .list_side_menu li a {
    transition: .3s;
  }

  .list_side_menu li a:hover {
    background: #ecf7fd;
  }
}

/*------サイドバナー-------*/
.bnr_side li {
  font-size: 14px;
  text-align: center;
  margin: 0 0 10px;
}

/*---------------------------------------------------------------------
	faq
---------------------------------------------------------------------*/
.list_faq+.lead_01 {
  margin-top: 60px;
}

.list_faq .item {
  margin-bottom: 20px;
}

.list_faq .btn_q {
  font-size: 16px;
  font-weight: 500;
  position: relative;
  background-color: #ecf7fd;
}

.list_faq .btn_q::before,
.list_faq .btn_q::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  margin-top: -11px;
  width: 2px;
  height: 22px;
  background: #009fe8;
  transition: .3s;
}

.list_faq .btn_q::before {}

.list_faq .btn_q::after {
  transform: rotate(90deg);
}

.list_faq .btn_q.on {
  background: #ffffe7;
}

.list_faq .btn_q.on::before {
  transform: rotate(-90deg);
  background: #FD6D06;
}

.list_faq .btn_q.on::after {
  transform: rotate(270deg);
  background: #FD6D06;
}

.list_faq .btn_q>* {
  color: #000;
  cursor: pointer;
  display: block;
  font-size: 112.5%;
  line-height: 1.6;
  padding: 15px 40px 15px 43px;
  border: 1px solid #ccc;
  position: relative;
}

.list_faq .btn_q>*::before {
  content: "Q";
  display: inline-block;
  color: #009fe8;
  position: absolute;
  top: 14px;
  left: 16px;
}

.list_faq .box_a {
  display: none;
  position: relative;
  border: 1px solid #BFBFBF;
  padding: 15px 15px 15px 50px;
  border-top: none;
}

.list_faq .box_a::before {
  content: "A";
  display: inline-block;
  color: #FD6D06;
  font-size: 112.5%;
  font-weight: bold;
  position: absolute;
  top: 14px;
  left: 22px;
}

.faq_contents {}

.faq_contents .icon_q {}

.faq_contents .icon_a {}



@media screen and (min-width: 768px) {
  .list_faq .item {
    margin-bottom: 20px;
  }

  .list_faq .btn_q>* {}

  .list_faq+.lead_01 {
    margin-top: 100px;
  }
}

/*---------------------------------------------------------------------
	gallery　フォトアルバム
---------------------------------------------------------------------*/
.list_gallery {
  width: 100% !important;
}

.list_gallery .item {
  float: left;
  /*width: 260px;*/
  width: 100%;
  margin-bottom: 20px;
}

.list_gallery .item a {
  color: #fff;
  display: block;
  position: relative;
}

.list_gallery .item img {
  width: 100%;
}

.list_gallery .detail {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .3);
}

.list_gallery .detail dl {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.list_gallery .detail .date {
  font-size: 15px;
  text-align: center;
}

.list_gallery .detail .ttl {
  font-size: 17px;
  text-align: center;
}

/* tablet */
@media print,
screen and (min-width: 768px) {
  .list_gallery .item {
    width: 32%;
    margin: 0 1% 1% 0;
  }
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .list_gallery .item {
    width: 24%;
    margin: 0 1% 1% 0;
  }

  .list_gallery .detail {
    background: rgba(0, 0, 0, .6);
    -webkit-transform: rotateY(-90deg) rotateX(-90deg);
    transform: rotateY(-90deg) rotateX(-90deg);
    -webkit-transition: .5s;
    transition: .5s;
    opacity: 0;
  }

  .list_gallery a:hover .detail {
    -webkit-transform: rotateY(0) rotateX(0);
    transform: rotateY(0) rotateX(0);
    opacity: 1;
  }
}

/* gallery_detail */
.gallery_detail_head {
  margin-bottom: 30px;
}

.gallery_detail_head .date {
  font-size: 17px;
  text-align: center;
}

.gallery_detail_head .ttl {
  font-size: 20px;
  font-weight: normal;
  text-align: center;
}

.gallery_detail_head .content {
  text-align: center;
  margin-top: 20px;
}

/*---------------------------------------------------------------------
	contact
---------------------------------------------------------------------*/
.mail_form {
  /*
  border: 8px solid #d6f0fb;
  margin: 0 auto;
  padding: 22px;
  */
}

.mail_form form {
  margin: 0 auto;
}

.mail_form form dl {
  display: table;
  width: 100%;
}


.mail_form form * {
  box-sizing: border-box;
}

.mail_form form>dl {
  border: 1px solid #CCD1DB;
}

.mail_form form>dl+dl {
  border-top: none;
}

.mail_form form>dl>dt {
  background: #E5EBF7;
  font-weight: 500;
}

.mail_form form>dl>dt,
.mail_form form>dl>dd {
  margin: 0;
  padding: 20px 20px;
}

.mail_form form dt {
  width: 30%;
  display: table-cell;
  vertical-align: top;
  /* font-size: 93.75%; */
  padding-right: 10px;
  padding-top: 12px;
}

.mail_form form dd {
  display: table-cell;
  vertical-align: top;
}

.mail_form form dd>dl:not(:last-child) {
  margin-bottom: 20px;
}

.mail_form form .bg_on {
  background-color: #ececec;
  padding: 12px;
}

.mail_form form .bg_on label {
  /*width: 20%;*/
  display: inline-block;
  vertical-align: middle;
  margin-right: 10px;
}

.mail_form form .border_on {
  border: 1px solid #CCCCCC;
  padding: 12px;
}

.mail_form.confirm_list dd {
  word-break: break-all;
}

.mail_form .btn_list {
  text-align: center;
  margin: 20px auto;
}

.mail_form .icon_required::after {
  content: "必須";
  vertical-align: middle;
  color: #fff;
  background: #D40F0F;
  font-size: 14px;
  padding: 2px 9px;
  margin-left: 10px;
}

.mail_form .icon_any::after {
  content: "任意";
  vertical-align: middle;
  color: #202020;
  border: 1px solid #224DBE;
  background-color: #fff;
  font-size: 14px;
  padding: 0 9px;
  margin-left: 10px;
}

.icon_required_p {
  color: #fff;
  background: #D40F0F;
  font-size: 80%;
  border-radius: 3px;
  padding: 2px 9px;
  margin-right: 10px;
}

.mail_form span.error {
  display: block;
  color: #D40F0F;
  font-size: 13px;
}

.form_errors {
  color: #d80000;
  border: 5px solid #e69898;
  text-align: left;
  padding: 20px;
  background: #fafafa;
  margin-bottom: 20px;
}

.mail_form.type_02 form {
  max-width: none;
}

.mail_form.type_02 form dl {
  max-width: 870px;
}

.mail_form.type_02 form dl dt {
  width: 35%;
}

.mail_form input,
.mail_form button,
.mail_form textarea,
.mail_form select {
  margin: 0;
  font-size: 16px;
  padding: 12px;
}

.mail_form input:-ms-input-placeholder {
  color: #808080;
}

.mail_form select,
.mail_form textarea,
.mail_form input[type="tel"],
.mail_form input[type="text"],
.mail_form input[type="email"],
.mail_form input[type="password"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  border-radius: 0;
  /* outline: none; */
  width: 100%;
  background-color: #FFFFFF;
}

.mail_form input.small {
  width: 27%;
}

.mail_form .input_size_ss {
  max-width: 200px;
}

.mail_form .input_size_s {
  max-width: 300px;
}

.mail_form input[type="file"] {
  font-size: 16px;
}

.mail_form input[type="radio"] {
  margin-right: 5px;
  padding: 5px;
}

.mail_form input[type="checkbox"] {
  margin-right: 5px;
  padding: 5px;
}

.mail_form select {
  -webkit-appearance: menulist;
  -moz-appearance: menulist;
  appearance: menulist;
  background-color: #FFFFFF;
  position: relative;
}

.mail_form select,
.mail_form textarea,
.mail_form input[type="tel"],
.mail_form input[type="text"],
.mail_form input[type="email"],
.mail_form input[type="password"],
.mail_form input[type="date"] {
  border: 1px solid #707070;
  border-radius: 5px;
}

.mail_form .twin {
  font-size: 0;
}

.mail_form .twin input+input {
  margin-left: 3.44%;
}

.mail_form .twin input {
  width: 48.26%;
  display: inline-block;
}

.mail_form textarea {
  width: 100%;
  height: 150px;
  background-color: #FFFFFF;
}

.mail_form input[type="text"]:focus,
.mail_form input[type="email"]:focus,
.mail_form textarea:focus {
  box-shadow: 0 0 7px #008CD6;
}

.btm_text {
  /*width: 69%;
  margin-left: auto;*/
  text-align: center;
}

*+.btm_text {
  margin-top: 40px;
}

/*
.mail_form input[type="submit"] {
  color: #fff;
  padding: 1em 5em;
  background-color: #358FDD;
  border: none;
  border-radius: 0;
}
.mail_form input[type="submit"]:hover {
  background-color: #055FAD;
}
*/

.mail_form input[type="submit"],
.mail_form .submit_button {
  display: block;
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  background: #2838A9 url("../image/common/arrow_yellow.svg") no-repeat right 12px top 50%;
  border-radius: 5px;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  padding: 15px;
  -webkit-transition-duration: 200ms;
  transition-duration: 200ms;
  -webkit-transition-property: background-color;
  transition-property: background-color;
}

.mail_form input[type="submit"]:hover,
.mail_form .submit_button:hover {
  background-color: #224DBE;
}

.mail_form input[type="reset"],
.mail_form input.back {
  color: #fff;
  padding: 0.6em 1em;
  background-color: #b5b5b5;
  border: none;

  margin-top: 30px;
  color: #2838A9;
  padding: 0;
  background: none;
  text-decoration: underline;
}

.mail_form input[type="reset"]:hover,
.mail_form input.back:hover {
  background-color: transparent;
}

.mail_form .btn_backhome {
  color: #fff;
  padding: 0.6em 1em;
  background-color: #358FDD;
  text-decoration: none;
  border: none;
  border-radius: 0;
  display: inline-block;
}

.mail_form .btn_backhome:hover {
  color: #fff;
  padding: 0.6em 1em;
  background-color: #b5b5b5;
}

.form_message {
  background-color: #ffffbb;
  border: 2px solid #df0000;
  color: #df0000;
  font-size: 120%;
  font-weight: bold;
  margin: 10px auto 30px;
  padding: 10px 15px;
}

.mail_form input[type="radio"]:focus+label::before,
.mail_form input[type="checkbox"]:focus+label::before {
  outline: 2px solid #000;
}

.mail_form input.error,
.mail_form textarea.error,
.mail_form select.error {
  border-color: #df0000;
  border-width: 2px;
  color: #000;
  font-size: 16px;
}

.mail_form input[type="checkbox"].error+label::before {
  border-color: #df0000;
  border-width: 2px;
}

.mail_form fieldset.error_group .btn_radio+label::before {
  border-color: #df0000;
  border-width: 2px;
}

@media print,
screen and (max-width: 768px) {
  .mail_form {}

  .mail_form form dl {}

  .mail_form form dt {
    display: block;
    width: auto;
    text-align: left;
    margin: 0 0 5px;
    padding: 0;
  }

  .mail_form form dd {
    display: block;
    width: auto;
  }

  .mail_form form>dl>dt+dd {
    border-top: 1px solid #CCD1DB;
  }

  .mail_form input,
  .mail_form button,
  .mail_form textarea,
  .mail_form select {
    padding: 10px;
  }

  .mail_form input.small {
    width: 50%;
  }

  .mail_form input[type="submit"] {
    padding: 1em;
  }

  .btm_text {
    width: auto;
    text-align: center;
  }
}

/* btn_radio  btn_checkbox */
.btn_radio,
.btn_checkbox {
  display: inline-block;
  margin-right: 6px;
}

.btn_radio+label,
.btn_checkbox+label {
  /*background-color: #ececec;
  border: 1px solid #358fdd;
  border-radius: 4px;*/
  cursor: pointer;
  display: inline-block;
  position: relative;
  /* padding: 10px 20px 10px 10px; */
}

*+.btn_radio+label,
*+.btn_checkbox+label {
  margin-top: 15px;
}

.mail_form dd .btn_line:last-child label {
  margin-bottom: 0;
}

#confirm.btn_checkbox+label {
  /*
  background: #ffffe5;
  border: 1px solid #aaa;
  */
  width: 100%;
}

.btn_radio.size_s+label,
.btn_checkbox.size_s+label {
  padding-top: 5px;
  padding-bottom: 5px;
  padding-right: 10px;
}


@media (min-width: 1px) {

  .btn_radio,
  .btn_checkbox {
    /* display: none; */
    /* margin: 0; */
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .btn_radio+label,
  .btn_checkbox+label {
    padding-left: 37px;
    color: #000;
    transition: all .2s;
    -webkit-transition: all .2s;
  }

  .btn_radio:checked+label,
  .btn_checkbox:checked+label {
    /*
		background-color: #cbe2f6;
        border-color: #358fdd;
    */
  }

  .btn_radio+label::before,
  .btn_checkbox+label::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 10px;

    -moz-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
    width: 18px;
    height: 18px;
    margin-top: -9px;

    background: #FFF;
  }

  .btn_radio+label::before {
    border: 1px solid #aaa;
    border-radius: 30px;
  }

  .btn_checkbox+label::before {
    border: 1px solid #aaa;
  }

  .btn_radio:checked+label::after,
  .btn_checkbox:checked+label::after {
    content: "";
    position: absolute;
    top: 50%;

    -moz-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
  }

  .btn_radio:checked+label::after {
    left: 15px;

    width: 8px;
    height: 8px;
    margin-top: -4px;

    background: #358fdd;
    border-radius: 8px;
  }

  .btn_checkbox:checked+label::after {
    left: 12px;

    width: 16px;
    height: 8px;
    margin-top: -8px;

    border-left: 3px solid #358fdd;
    border-bottom: 3px solid #358fdd;

    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
}

.input_btn_list {
  letter-spacing: -.5em;
}

.input_btn_list li {
  letter-spacing: normal;
  display: inline-block;
  vertical-align: top;
  margin: 0 10px 10px 0;
}

.input_btn_list label {
  margin: 0 !important;
}

.mail_form input.input_other {
  display: none;
  width: auto;
  margin-left: 10px;
  padding: 10px;
}

.form_fieldset {
  border: none;
}

.visually_hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

.form_note {
  font-size: 14px;
  margin-top: 5px;
}

@media print,
screen and (min-width: 769px) {

  .mail_form .icon_required::after,
  .mail_form .icon_any::after {
    display: table;
    line-height: 1.2;
    margin: 5px 10px 0 0;
  }

  .mail_form .icon_any::after {
    padding: 1px 9px;
  }

  .mail_form form dd>dl,
  .mail_form form dd>dl dt,
  .mail_form form dd>dl dd {
    display: block;
  }

  .mail_form form dd>dl dt,
  .mail_form form dd>dl dd {
    width: 100%;
    padding: 0;
  }

  .mail_form dd>dl .icon_any::after {
    display: inline-block;
    margin: 0 0 0 15px;
  }

  .mail_form dd>dl dd {
    margin-top: 10px;
  }
}

@media print,
screen and (min-width: 992px) {}

/*---------------------------------------------------------------------
	404
---------------------------------------------------------------------*/
.thumb_404 {
  margin-right: 40px;
  float: left;
  width: 20%;
}

.border_box {
  padding: 20px;
  border: 10px solid #fbf4e8;
}

.border_box>ul {
  color: #FF7F00;
  padding-left: 20px !important;
}

.bl_img_404 {
  width: 331px;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .bl_img_404 {
    width: 200px;
  }
}

/*---------------------------------------------------------------------
	search
---------------------------------------------------------------------*/
/* google カスタム検索の調整 */
.site_search {}

.site_search #___gcse_0 {
  background: #edf8fd;
  padding: 15px;
}

.site_search #___gcse_0 .gsc-control-searchbox-only {
  max-width: 500px;
  margin: 0 auto;
}

.site_search table,
.site_search table.gsc-search-box td,
.site_search table.gsc-search-box td.gsc-input {
  padding: 0;
  border: none;
}

.site_search .gsc-adBlock {
  display: none;
}

/* pc */
@media screen and (min-width: 1280px) {

  .site_search #___gcse_0 {
    padding: 30px;
  }

  .site_search input#gsc-i-id1 {
    padding: 10px !important;
  }

  .site_search button.gsc-search-button {
    padding: 15px 27px;
    margin-left: 10px;
  }

  .site_search .gsc-above-wrapper-area-container {
    border: none;
  }

  .site_search .gsc-above-wrapper-area-container td {
    border: none;
    padding: 0;
  }

  .site_search .gsc-selected-option-container {
    box-sizing: content-box;
  }

  .site_search .gsc-webResult.gsc-result {
    border: 1px solid #e9e9e9;
    margin: 20px 0;
    padding: 15px 20px;
  }

  .site_search .gsc-results {
    width: 100%;
  }

  .site_search .gsc-cursor-box.gs-bidi-start-align {
    text-align: center;
  }

  .site_search .gsc-cursor-page {
    font-size: 1.6rem;
    border: 1px solid #ccc;
    padding: 7px 15px;
    border-radius: 3px;
    display: inline-block !important;
  }

  .site_search {}

}



.list_search {}

.list_search .item {
  border: 1px solid #ccc;
  border-radius: 6px;
  padding: 15px;
}

.list_search .item+.item {
  margin-top: 20px;
}

.list_search .ttl {
  font-size: 1.8rem;
  font-weight: bold;
}

.list_search .url {
  color: #808080;
  font-size: 1.2rem;
  margin: 5px 0;
}



/*---------------------------------------------------------------------
	sitemap
---------------------------------------------------------------------*/
.list_sitemap {}

.list_sitemap a:hover {
  opacity: .8;
}

.list_sitemap .level01 {
  font-size: 100%;
  font-weight: normal;
  margin-bottom: 15px;
}

.list_sitemap *+.level01 {
  margin-top: 40px;
}

.list_sitemap .level01>a {
  display: block;
  background: #E5EBF7;
  text-decoration: none;
  color: #202020;
  font-size: 30px;
  font-weight: 500;
  padding: 18px 29px;
  border-radius: 5px;
  border: 1px solid #E5EBF7;
  transition: .3s;
}

.list_sitemap .level01>a:hover {
  color: #2838A9;
  border: 1px solid #2838A9;
  opacity: 1;
}

.list_sitemap .level02 {
  font-size: 0;
}

.list_sitemap .level02>li {
  font-size: 16px;
  display: inline-block;
  vertical-align: top;
  width: 49.16%;
  margin: 0 1.66% 1.66% 0;
}

.list_sitemap .level02>li:nth-child(2n) {
  margin-right: 0;
}

.list_sitemap .level02>li>a {
  border: 1px solid #A3A3A3;
  display: block;
  text-decoration: none;
  padding: 8px 29px;
  border-radius: 5px;
  color: #202020;
  font-size: 24px;
  font-weight: 500;
  background: #F5F5F5;
  transition: .3s;
  position: relative;
}

.list_sitemap .level02>li>a:hover {
  color: #2838A9;
  border: 1px solid #2838A9;
  opacity: 1;
}

/*.list_sitemap .level02 >li > a::before {
    content: "";
    position: absolute;
    right: 9px;
    top: 50%;
    margin-top: -6px;
    border: 4px solid transparent;
    border-left: 6px solid #133775;
}*/

.list_sitemap .level03,
.list_sitemap .level04,
.list_sitemap .level05 {
  color: #2838A9;
  margin-top: 10px;
  list-style-type: disc;
  list-style-position: outside;
  margin-left: 36px;
}

.list_sitemap .level03>li a {
  color: #2838A9;
}

.list_sitemap .level04,
.list_sitemap .level05 {
  margin-left: 24px;
}

.list_sitemap .level03 li+li {
  margin-top: 5px;
}

@media screen and (max-width: 768px) {
  .list_sitemap .level01>a {
    font-size: 24px;
    padding: 10px;
  }

  .list_sitemap .level02>li>a {
    font-size: 18px;
    padding: 10px;
  }

  .list_sitemap *+.level01 {
    margin-top: 20px;
  }
}

/*---------------------------------------------------------------------
  js-inview
---------------------------------------------------------------------*/
/* 管理画面で見えなくなるので…#container */
#container .js_slide_up {
  opacity: 0;
  position: relative;
  top: 50px;
}

#container .js_slide_down {
  opacity: 0;
  position: relative;
  top: -50px;
}

#container .js_slide_left {
  opacity: 0;
  position: relative;
  left: -50px;
}

#container .js_slide_right {
  opacity: 0;
  position: relative;
  right: -50px;
}

#container .js_fade {
  opacity: 0;
}

/*---------------------------------------------------------------------
	page_scroll
---------------------------------------------------------------------*/
#page_scroll_navi {
  position: absolute;
  z-index: 1;
  left: 50%;
  top: -30px;
  margin-left: -30px;
}

#page_scroll_navi a {
  display: block;
  background: #133557;
  width: 60px;
}

#page_scroll_navi.fixed {
  position: fixed;
  top: auto;
  bottom: 70px;
}

/* pc */
@media screen and (min-width: 1280px) {
  #page_scroll_navi {
    left: auto;
    right: 30px;
    margin: 0;
  }

  #page_scroll_navi a {
    width: 70px;
  }
}

/*---------------------------------------------------------------------
	site_footer
---------------------------------------------------------------------*/
#site_footer {
  background: #fafafa;
  text-align: center;
  border-top: 1px solid #ccc;
  margin-top: 80px;
  position: relative;
}

#site_footer .inner {
  padding: 10px;
}

.footer_navi {
  padding: 40px 20px 20px;
  background: #ECF7FD;
}

.copyright {
  color: #fff;
  font-size: 1.3rem;
  text-align: center;
  background-color: #009FE8;
  padding: 7px 0;
}

/* pc */
@media print,
screen and (min-width: 1280px) {
  .footer_navi {
    padding: 30px;
  }

  .copyright {
    font-size: 1.5rem;
  }
}


/*---------------------------------------------------------------------
	edit_btn 公開まで非表示
---------------------------------------------------------------------*/
#edit_btn {
  background: #444;
}

#edit_btn #edit_btn_inner {
  padding: 5px 10px;
  margin: 0 auto;
}

#edit_btn a {
  color: #333;
  font-size: 13px;
  border-radius: 4px;
  display: block;
  float: right;
  font-weight: bold;
  margin: 5px 0 5px 5px;
  padding: 3px 15px 4px;
  text-decoration: none;
  background-image: -moz-linear-gradient(50% 0% -90deg, rgb(255, 255, 255) 0%, rgb(238, 238, 238) 100%);
  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0, rgb(255, 255, 255)), color-stop(1, rgb(238, 238, 238)));
  background-image: -webkit-linear-gradient(-90deg, rgb(255, 255, 255) 0%, rgb(238, 238, 238) 100%);
  background-image: -o-linear-gradient(-90deg, rgb(255, 255, 255) 0%, rgb(238, 238, 238) 100%);
  background-image: -ms-linear-gradient(-90deg, rgb(255, 255, 255) 0%, rgb(238, 238, 238) 100%);
  background-image: linear-gradient(180deg, rgb(255, 255, 255) 0%, rgb(238, 238, 238) 100%);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#ffffffff,endColorstr=#ffeeeeee,GradientType=0)";
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#ffffffff, endColorstr=#ffeeeeee, GradientType=0);
}

#edit_btn a:hover {
  background-image: -moz-linear-gradient(50% 0% -90deg, rgb(238, 238, 238) 0%, rgb(255, 255, 255) 100%);
  background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0, rgb(238, 238, 238)), color-stop(1, rgb(255, 255, 255)));
  background-image: -webkit-linear-gradient(-90deg, rgb(238, 238, 238) 0%, rgb(255, 255, 255) 100%);
  background-image: -o-linear-gradient(-90deg, rgb(238, 238, 238) 0%, rgb(255, 255, 255) 100%);
  background-image: -ms-linear-gradient(-90deg, rgb(238, 238, 238) 0%, rgb(255, 255, 255) 100%);
  background-image: linear-gradient(180deg, rgb(238, 238, 238) 0%, rgb(255, 255, 255) 100%);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#ffeeeeee,endColorstr=#ffffffff,GradientType=0)";
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#ffeeeeee, endColorstr=#ffffffff, GradientType=0);
}



/*---------------------------------------------------------------------
	追加CSS
---------------------------------------------------------------------*/
/*--- font ---*/
h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.4;
}

.fwb {
  font-weight: bold !important;
}

.tal {
  text-align: left !important;
}

.tac {
  text-align: center !important;
}

.tar {
  text-align: right !important;
}

/*--- width ---*/
.u__w15 {
  width: 15%;
}

.u__w25 {
  width: 25%;
}

.u__w33 {
  width: 33%;
}

.u__w50 {
  width: 50%;
}

.u__w75 {
  width: 75%;
}

/*--- float clear class ---*/
.clearfix:after {
  content: "";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clearfix {
  display: inline-block;
  min-height: 1%;
  /* for IE 7*/
}

/* Hides from IE-mac \*/
* html .clearfix {
  height: 1%;
}

.clearfix {
  display: block;
}


/* FontSize = fs */
/* Relative FontSize = fsr */
.fsr10 {
  font-size: 62.5%;
}

.fsr11 {
  font-size: 68.75%;
}

.fsr12 {
  font-size: 75%;
}

.fsr13 {
  font-size: 81.25%;
}

.fsr14 {
  font-size: 87.5%;
}

.fsr15 {
  font-size: 93.75%;
}

.fsr16 {
  font-size: 100%;
}

.fsr17 {
  font-size: 106.25%;
}

.fsr18 {
  font-size: 112.5%;
}

.fsr19 {
  font-size: 118.75%;
}

.fsr20 {
  font-size: 125%;
}

.fsr21 {
  font-size: 131.25%;
}

.fsr22 {
  font-size: 137.5%;
}

.fsr23 {
  font-size: 143.75%;
}

.fsr24 {
  font-size: 150%;
}

.fsr25 {
  font-size: 156.25%;
}

.fsr26 {
  font-size: 162.5%;
}

.fsr27 {
  font-size: 168.75%;
}

.fsr28 {
  font-size: 175%;
}

.fsr29 {
  font-size: 181.25%;
}

.fsr30 {
  font-size: 187.5%;
}

/*--- Padding = pd ---*/
/* Padding (top + right + bottom + left) = pd */
.pd2 {
  padding: 2px !important;
}

.pd5 {
  padding: 5px !important;
}

.pd8 {
  padding: 8px !important;
}

.pd10 {
  padding: 10px !important;
}

.pd15 {
  padding: 15px !important;
}

.pd20 {
  padding: 20px !important;
}

.pd25 {
  padding: 25px !important;
}

.pd30 {
  padding: 30px !important;
}

.pd35 {
  padding: 35px !important;
}

.pd40 {
  padding: 40px !important;
}

.pd45 {
  padding: 45px !important;
}

.pd50 {
  padding: 50px !important;
}

.pd55 {
  padding: 55px !important;
}

.pd60 {
  padding: 60px !important;
}

/* Padding (top + bottom) = pdtb */
.pdtb5 {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.pdtb10 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.pdtb15 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

.pdtb20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.pdtb25 {
  padding-top: 25px !important;
  padding-bottom: 25px !important;
}

.pdtb30 {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

.pdtb35 {
  padding-top: 35px !important;
  padding-bottom: 35px !important;
}

.pdtb40 {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}

.pdtb45 {
  padding-top: 45px !important;
  padding-bottom: 45px !important;
}

.pdtb50 {
  padding-top: 50px !important;
  padding-bottom: 50px !important;
}

.pdtb55 {
  padding-top: 55px !important;
  padding-bottom: 55px !important;
}

.pdtb60 {
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}

/* Padding (right + left) = pdrl */
.pdrl5 {
  padding-right: 5px !important;
  padding-left: 5px !important;
}

.pdrl10 {
  padding-right: 10px !important;
  padding-left: 10px !important;
}

.pdrl15 {
  padding-right: 15px !important;
  padding-left: 15px !important;
}

.pdrl20 {
  padding-right: 20px !important;
  padding-left: 20px !important;
}

.pdrl25 {
  padding-right: 25px !important;
  padding-left: 25px !important;
}

.pdrl30 {
  padding-right: 30px !important;
  padding-left: 30px !important;
}

.pdrl35 {
  padding-right: 35px !important;
  padding-left: 35px !important;
}

.pdrl40 {
  padding-right: 40px !important;
  padding-left: 40px !important;
}

.pdrl45 {
  padding-right: 45px !important;
  padding-left: 45px !important;
}

.pdrl50 {
  padding-right: 50px !important;
  padding-left: 50px !important;
}

.pdrl55 {
  padding-right: 55px !important;
  padding-left: 55px !important;
}

.pdrl60 {
  padding-right: 60px !important;
  padding-left: 60px !important;
}

/* Padding (top) = pdt */
.pdt0 {
  padding-top: 0px !important;
}

.pdt5 {
  padding-top: 5px !important;
}

.pdt10 {
  padding-top: 10px !important;
}

.pdt15 {
  padding-top: 15px !important;
}

.pdt20 {
  padding-top: 20px !important;
}

.pdt25 {
  padding-top: 25px !important;
}

.pdt30 {
  padding-top: 30px !important;
}

.pdt35 {
  padding-top: 35px !important;
}

.pdt40 {
  padding-top: 40px !important;
}

.pdt45 {
  padding-top: 45px !important;
}

.pdt50 {
  padding-top: 50px !important;
}

.pdt55 {
  padding-top: 55px !important;
}

.pdt60 {
  padding-top: 60px !important;
}

/* Padding (right) = pdr */
.pdr0 {
  padding-right: 0px !important;
}

.pdr5 {
  padding-right: 5px !important;
}

.pdr10 {
  padding-right: 10px !important;
}

.pdr15 {
  padding-right: 15px !important;
}

.pdr20 {
  padding-right: 20px !important;
}

.pdr25 {
  padding-right: 25px !important;
}

.pdr30 {
  padding-right: 30px !important;
}

.pdr35 {
  padding-right: 35px !important;
}

.pdr40 {
  padding-right: 40px !important;
}

.pdr45 {
  padding-right: 45px !important;
}

.pdr50 {
  padding-right: 50px !important;
}

.pdr55 {
  padding-right: 55px !important;
}

.pdr60 {
  padding-right: 60px !important;
}

/* Padding (bottom) = pdb */
.pdb0 {
  padding-bottom: 0px !important;
}

.pdb5 {
  padding-bottom: 5px !important;
}

.pdb10 {
  padding-bottom: 10px !important;
}

.pdb15 {
  padding-bottom: 15px !important;
}

.pdb20 {
  padding-bottom: 20px !important;
}

.pdb25 {
  padding-bottom: 25px !important;
}

.pdb30 {
  padding-bottom: 30px !important;
}

.pdb35 {
  padding-bottom: 35px !important;
}

.pdb40 {
  padding-bottom: 40px !important;
}

.pdb45 {
  padding-bottom: 45px !important;
}

.pdb50 {
  padding-bottom: 50px !important;
}

.pdb55 {
  padding-bottom: 55px !important;
}

.pdb60 {
  padding-bottom: 60px !important;
}

/* Padding (left) = pdl */
.pdl5 {
  padding-left: 5px !important;
}

.pdl10 {
  padding-left: 10px !important;
}

.pdl15 {
  padding-left: 15px !important;
}

.pdl20 {
  padding-left: 20px !important;
}

.pdl25 {
  padding-left: 25px !important;
}

.pdl30 {
  padding-left: 30px !important;
}

.pdl35 {
  padding-left: 35px !important;
}

.pdl40 {
  padding-left: 40px !important;
}

.pdl45 {
  padding-left: 45px !important;
}

.pdl50 {
  padding-left: 50px !important;
}

.pdl55 {
  padding-left: 55px !important;
}

.pdl60 {
  padding-left: 60px !important;
}


/*--- Margin = mg ---*/
/* Margin (top + right + bottom + left) = mg */
.mg2 {
  margin: 2px !important;
}

.mg5 {
  margin: 5px !important;
}

.mg8 {
  margin: 8px !important;
}

.mg10 {
  margin: 10px !important;
}

.mg15 {
  margin: 15px !important;
}

.mg20 {
  margin: 20px !important;
}

.mg25 {
  margin: 25px !important;
}

.mg30 {
  margin: 30px !important;
}

.mg35 {
  margin: 35px !important;
}

.mg40 {
  margin: 40px !important;
}

.mg45 {
  margin: 45px !important;
}

.mg50 {
  margin: 50px !important;
}

.mg55 {
  margin: 55px !important;
}

.mg60 {
  margin: 60px !important;
}

/* Margin (top + bottom) = mgtb */
.mgtb5 {
  margin-top: 5px !important;
  margin-bottom: 5px !important;
}

.mgtb10 {
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}

.mgtb15 {
  margin-top: 15px !important;
  margin-bottom: 15px !important;
}

.mgtb20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.mgtb25 {
  margin-top: 25px !important;
  margin-bottom: 25px !important;
}

.mgtb30 {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}

.mgtb35 {
  margin-top: 35px !important;
  margin-bottom: 35px !important;
}

.mgtb40 {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.mgtb45 {
  margin-top: 45px !important;
  margin-bottom: 45px !important;
}

.mgtb50 {
  margin-top: 50px !important;
  margin-bottom: 50px !important;
}

.mgtb55 {
  margin-top: 55px !important;
  margin-bottom: 55px !important;
}

.mgtb60 {
  margin-top: 60px !important;
  margin-bottom: 60px !important;
}

.mgtb70 {
  margin-top: 60px !important;
  margin-bottom: 70px !important;
}

.mgtb80 {
  margin-top: 80px !important;
  margin-bottom: 80px !important;
}

/* Margin (right + left) = mgrl */
.mgrl5 {
  margin-right: 5px !important;
  margin-left: 5px !important;
}

.mgrl10 {
  margin-right: 10px !important;
  margin-left: 10px !important;
}

.mgrl15 {
  margin-right: 15px !important;
  margin-left: 15px !important;
}

.mgrl20 {
  margin-right: 20px !important;
  margin-left: 20px !important;
}

.mgrl25 {
  margin-right: 25px !important;
  margin-left: 25px !important;
}

.mgrl30 {
  margin-right: 30px !important;
  margin-left: 30px !important;
}

.mgrl35 {
  margin-right: 35px !important;
  margin-left: 35px !important;
}

.mgrl40 {
  margin-right: 40px !important;
  margin-left: 40px !important;
}

.mgrl45 {
  margin-right: 45px !important;
  margin-left: 45px !important;
}

.mgrl50 {
  margin-right: 50px !important;
  margin-left: 50px !important;
}

.mgrl55 {
  margin-right: 55px !important;
  margin-left: 55px !important;
}

.mgrl60 {
  margin-right: 60px !important;
  margin-left: 60px !important;
}

/* Margin (top) = mgt */
.mgt0 {
  margin-top: 0px !important;
}

.mgt5 {
  margin-top: 5px !important;
}

.mgt10 {
  margin-top: 10px !important;
}

.mgt15 {
  margin-top: 15px !important;
}

.mgt20 {
  margin-top: 20px !important;
}

.mgt25 {
  margin-top: 25px !important;
}

.mgt30 {
  margin-top: 30px !important;
}

.mgt35 {
  margin-top: 35px !important;
}

.mgt40 {
  margin-top: 40px !important;
}

.mgt45 {
  margin-top: 45px !important;
}

.mgt50 {
  margin-top: 50px !important;
}

.mgt55 {
  margin-top: 55px !important;
}

.mgt60 {
  margin-top: 60px !important;
}

.mgt70 {
  margin-top: 70px !important;
}

/* Margin (right) = mgr */
.mgr5 {
  margin-right: 5px !important;
}

.mgr10 {
  margin-right: 10px !important;
}

.mgr15 {
  margin-right: 15px !important;
}

.mgr20 {
  margin-right: 20px !important;
}

.mgr25 {
  margin-right: 25px !important;
}

.mgr30 {
  margin-right: 30px !important;
}

.mgr35 {
  margin-right: 35px !important;
}

.mgr40 {
  margin-right: 40px !important;
}

.mgr45 {
  margin-right: 45px !important;
}

.mgr50 {
  margin-right: 50px !important;
}

.mgr55 {
  margin-right: 55px !important;
}

.mgr60 {
  margin-right: 60px !important;
}

/* Margin (bottom) = mgb */
.mgb0 {
  margin-bottom: 0px !important;
}

.mgb5 {
  margin-bottom: 5px !important;
}

.mgb10 {
  margin-bottom: 10px !important;
}

.mgb15 {
  margin-bottom: 15px !important;
}

.mgb20 {
  margin-bottom: 20px !important;
}

.mgb25 {
  margin-bottom: 25px !important;
}

.mgb30 {
  margin-bottom: 30px !important;
}

.mgb35 {
  margin-bottom: 35px !important;
}

.mgb40 {
  margin-bottom: 40px !important;
}

.mgb45 {
  margin-bottom: 45px !important;
}

.mgb50 {
  margin-bottom: 50px !important;
}

.mgb55 {
  margin-bottom: 55px !important;
}

.mgb60 {
  margin-bottom: 60px !important;
}

.mgb80 {
  margin-bottom: 80px !important;
}

.mgb100 {
  margin-bottom: 100px !important;
}

/* Margin (left) = mgl */
.mgl0 {
  margin-left: 0px !important;
}

.mgl5 {
  margin-left: 5px !important;
}

.mgl10 {
  margin-left: 10px !important;
}

.mgl15 {
  margin-left: 15px !important;
}

.mgl20 {
  margin-left: 20px !important;
}

.mgl25 {
  margin-left: 25px !important;
}

.mgl30 {
  margin-left: 30px !important;
}

.mgl35 {
  margin-left: 35px !important;
}

.mgl40 {
  margin-left: 40px !important;
}

.mgl45 {
  margin-left: 45px !important;
}

.mgl50 {
  margin-left: 50px !important;
}

.mgl55 {
  margin-left: 55px !important;
}

.mgl60 {
  margin-left: 60px !important;
}

/*--- list ---*/
ul.list_disc {
  margin-left: 1em;
}

ul.list_disc li {
  text-indent: -1em;
}

ul.list_disc li::before {
  content: "・";
}

/*--- a ---*/
a.icon_tel {
  text-decoration: none;
  pointer-events: none;
  color: #2373B9;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  display: flex;
  align-items: center;
}

a.icon_tel::before {
  content: "";
  display: inline-block;
  background: url("/image/common/icon_tel.svg") no-repeat center;
  background-size: contain;
  width: 36px;
  height: 36px;
  margin-right: 13px;
}

@media screen and (max-width: 768px) {
  a.icon_tel {
    pointer-events: inherit;
    font-size: 24px;
  }

  a.icon_tel::before {
    width: 24px;
    height: 24px;
  }

  .sp_fwb {
    font-weight: bold !important;
  }

  .sp_tal {
    text-align: left !important;
  }

  .sp_tac {
    text-align: center !important;
  }

  .sp_tar {
    text-align: right !important;
  }
}

/*------------------------------
  会社情報
------------------------------*/
p.company_lead {
  font-size: 40px;
  font-weight: 600;
  text-align: center;
  line-height: 1.2;
  margin-bottom: 60px;
}

.message_inner {
  max-width: 900px;
  margin: 60px auto 120px;
}

p.message_neme {
  font-size: 30px;
  font-weight: bold;
  text-align: right;
  margin-top: 80px;
  line-height: 1.3;
}

.content1 p.message_neme {
  margin-top: 80px;
}

p.message_neme span {
  font-size: 16px;
}

p.company_lead02 {
  font-size: 50px;
  font-weight: 600;
  color: #2838A9;
  line-height: 1;
  margin-bottom: 60px;
}

p.company_lead02 span {
  font-size: 30px;
  color: #202020;
}

p.company_lead03 {
  font-size: 30px;
  font-weight: 500;
}

.philosophy_box {
  background: #f5f5f5;
  padding: 50px 200px;
}

.philosophy_list li {
  background: #fff;
  border: 1px solid #2373b9;
  font-size: 30px;
  font-weight: 400;
  color: #2373b9;
  margin-bottom: 20px;
  padding: 9px 20px;
}

.philosophy_list li:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 1200px) {
  .philosophy_box {
    padding: 50px 100px;
  }
}

@media screen and (max-width: 768px) {
  p.company_lead {
    font-size: 24px;
    margin-bottom: 24px;
  }

  .message_inner {
    margin: 30px auto 60px;
  }

  .content1 p.message_neme {
    margin-top: 40px;
  }

  p.company_lead02 {
    font-size: 36px;
    margin-bottom: 40px;
  }

  p.company_lead02 span {
    font-size: 20px;
  }

  p.company_lead03 {
    font-size: 22px;
  }

  .philosophy_box {
    padding: 30px 15px;
  }

  .philosophy_list li {
    font-size: 16px;
    margin-bottom: 20px;
  }
}

.yakuin_list {
  display: flex;
  column-gap: 20px;
  flex-wrap: wrap;
}

.yakuin_list li {
  width: calc(33% - 13px);
  margin-bottom: 60px;
}

.yakuin_list_custom li {
  padding-bottom: 10px;
  border: 1px solid #D9D9D9;
  border-radius: 10px;
  overflow: hidden;
}

.yakuin_list li span {
  display: block;
}

.yakuin_list li span.yakuin_img {
  background: #F1F3F2;
  text-align: center;
}

.yakuin_list li span.sub {
  text-align: center;
  margin-top: 10px;
}

.yakuin_list li span.name {
  text-align: center;
  font-size: 20px;
  font-weight: 600;
}

.aboutUsList dt {
  width: 20em;
}

.aboutUsList dd {
  margin: -1.6em 0 2px 0;
  padding: 0 0 2px 23em;
}

.img_box {
  background: #f5f5f5;
  border: 1px solid #aeaeae;
  padding: 30px;
}

.acc_section {
  margin-top: 40px;
}

.acc_section .acc_ttl {
  font-size: 26px;
  color: #333;
  font-weight: 500;
  background: #f5f5f5;
  border: 1px solid #ccd1db;
  cursor: pointer;
  position: relative;
  padding: 5px 50px 5px 20px;
  width: 100%;
  text-align: left;
}

.acc_section .acc_ttl::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  border-bottom: 3px solid #FF4E00;
  border-right: 3px solid #FF4E00;
  transform: rotate(45deg);
  position: absolute;
  right: 23px;
  top: 50%;
  margin-top: -6px;
  transition: all .3s;
}

.acc_section .acc_ttl.open::after {
  transform: rotate(-135deg);
  margin-top: -2px;
}

.acc_section .accordion-content {
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  .yakuin_list {
    display: block;
  }

  .yakuin_list li {
    width: 100%;
    margin-bottom: 40px;
  }

  .acc_section .acc_ttl {
    font-size: 20px;
  }

  .aboutUsList dt {
    width: auto;
  }

  .aboutUsList dd {
    margin: 0 0 10px 0;
    padding: 0 0 2px 0;
  }
}

/*------------------------------
  採用情報 絵で見るOTNet
------------------------------*/
@keyframes anime {
  0% {
    margin-top: -10px;
  }

  50% {
    margin-top: 10px;
  }

  100% {
    margin-top: -10px;
  }
}

@-webkit-keyframes anime {
  0% {
    margin-top: -10px;
  }

  50% {
    margin-top: 10px;
  }

  100% {
    margin-top: -10px;
  }
}

@keyframes anime2 {
  0% {
    margin-top: 10px;
  }

  50% {
    margin-top: -10px;
  }

  100% {
    margin-top: 10px;
  }
}

@-webkit-keyframes anime2 {
  0% {
    margin-top: 10px;
  }

  50% {
    margin-top: -10px;
  }

  100% {
    margin-top: 10px;
  }
}

.summary_wrap {
  background: #f2e65e;
}

.sec-about02 {
  position: relative;
  margin-bottom: 90px;
}

.sec-about02 .bg_img {
  position: relative;
  z-index: 1;
}

.sec-about02 .bg_img .imgA {
  position: relative;
  z-index: 1;
  width: 100%;
}

.sec-about02 .bg_img .balloon {
  position: absolute;
  z-index: 10;
  transform: translate3d(-50%, -50%, 0);
  width: 100px;
  height: 134px;
}

.sec-about02 .bg_img .i01 {
  top: calc(10px + 9vw);
  left: calc(10px + 16vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i02 {
  top: calc(10px + 10vw);
  left: calc(10px + 58vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about02 .bg_img .i03 {
  top: calc(0px + 7vw);
  left: calc(0px + 93vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i04 {
  top: calc(10px + 19vw);
  left: calc(10px + 41vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about02 .bg_img .i05 {
  top: calc(10px + 18vw);
  left: calc(10px + 65vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i06 {
  top: calc(10px + 24vw);
  left: calc(10px + 76vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about02 .bg_img .i07 {
  top: calc(10px + 32vw);
  left: calc(10px + 21vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i08 {
  top: calc(10px + 30vw);
  left: calc(10px + 90vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about02 .bg_img .i09 {
  top: calc(10px + 41vw);
  left: calc(10px + 4vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i10 {
  top: calc(10px + 48vw);
  left: calc(10px + 17vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about02 .bg_img .i11 {
  top: calc(10px + 51vw);
  left: calc(10px + 39vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about02 .bg_img .i12 {
  top: calc(10px + 41vw);
  left: calc(10px + 85vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about03 {
  position: relative;
}

.sec-about03 .bg_img {
  position: relative;
  z-index: 1;
}

.sec-about03 .bg_img .imgA {
  position: relative;
  z-index: 1;
  width: 100%;
}

.sec-about03 .bg_img .balloon {
  position: absolute;
  z-index: 10;
  transform: translate3d(-50%, -50%, 0);
  width: 100px;
  height: 141px;
}

.sec-about03 .bg_img .i13 {
  top: calc(10px + 11vw);
  left: calc(10px + 52vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about03 .bg_img .i14 {
  top: calc(10px + 24vw);
  left: calc(10px + 52vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about03 .bg_img .i15 {
  top: calc(10px + 22vw);
  left: calc(5px + 72vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about03 .bg_img .i16 {
  top: calc(10px + 17vw);
  left: calc(10px + 82vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about03 .bg_img .i17 {
  top: calc(10px + 41vw);
  left: calc(2px + 56vw);
  animation-delay: 500ms;
  -webkit-animation: anime 4s linear infinite;
  animation: anime 4s linear infinite;
}

.sec-about03 .bg_img .i18 {
  top: calc(10px + 49vw);
  left: calc(10px + 9vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about03 .bg_img .i19 {
  top: calc(10px + 11vw);
  left: calc(10px + 38vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.sec-about03 .bg_img .i20 {
  top: calc(10px + 24vw);
  left: calc(10px + 64vw);
  animation-delay: 500ms;
  -webkit-animation: anime2 4s linear infinite;
  animation: anime2 4s linear infinite;
}

.white-popup {
  width: 100%;
  max-width: 750px;
  padding: 65px 85px;
  margin: 0 auto;
  background: #fff;
}

.white-popup h2 {
  font-size: 18px;
  font-weight: 700;
  margin: 10px 0;
}

@media screen and (max-width: 768px) {

  .sec-about02 .bg_img .balloon,
  .sec-about03 .bg_img .balloon {
    width: 50px;
    height: 67px;
  }

  .sec-about02 {
    margin-bottom: 45px;
  }

  .sec-about02 .bg_img .i03 {
    top: calc(0px + 8vw);
    left: calc(0px + 88vw);
  }
}

@media screen and (max-width: 600px) {

  .mfp-container,
  .mfp-iframe-holder {
    padding: 0 !important;
  }

  .mfp-iframe-holder .mfp-content {
    max-width: 100% !important;
  }

  .mfp-close {
    /*top: 10px !important;*/
    top: 12px !important;
    right: 20px !important;
  }
}

/*------------------------------
  採用情報 数字で見るOTNet
------------------------------*/
.data_list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

p.data_num {
  font-size: 30px;
  font-weight: 700;
  margin: 0;
  line-height: 1;
}

p.data_num span {
  font-size: 100px;
  font-weight: 800;
  color: #224DBE;
}

p.sub_ttl_data {
  margin: 0;
  font-size: 24px;
  font-weight: 500;
}

p.sub_ttl_data span {
  border-bottom: 3px solid #2838A9;
}

p.notice {
  margin: 0;
  font-size: 15px;
}

dl.data_box {
  background: #f5f5f5;
  border: 4px solid #00bad7;
  padding: 30px 0;
  width: calc(33.3% - 13px);
  margin-top: 0;
}

dl.data_box.middle {
  width: calc(66.6% - 7px)
}

dl.data_box>dt {
  text-align: center;
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 30px;
}

dl.data_box>dt>span {
  display: inline-block;
  border-bottom: 3px dashed #2838a9;
}

dl.data_box .lyt_fl {
  display: flex;
  justify-content: center;
}

dl.data_box .lyt_fl .col {
  padding: 0 30px;
}

dl.data_box .lyt_fl .col:first-child {
  position: relative;
}

dl.data_box .lyt_fl .col:first-child::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 132px;
  background: #D1D1D1;
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -66px;
}

.older_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 70px;
}

.older_list .col {
  padding: 0 15px;
}

.older_list p.gene {
  text-align: center;
  font-size: 30px;
  font-weight: 700;
  margin: 0;
}

.older_list p.data_num_sub {
  text-align: center;
  font-size: 25px;
  font-weight: 700;
  line-height: 1;
}

.older_list p.data_num_sub span {
  font-size: 70px;
  font-weight: 800;
  color: #224DBE;
}

@media screen and (max-width: 1280px) {
  dl.data_box {
    width: calc(50% - 10px)
  }

  dl.data_box.middle {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  p.data_num span {
    font-size: 50px;
  }

  p.data_num {
    font-size: 20px;
  }

  p.sub_ttl_data {
    font-size: 18px;
    margin-bottom: 20px;
  }

  dl.data_box {
    padding: 15px;
  }

  dl.data_box>dt {
    font-size: 24px;
  }

  dl.data_box .lyt_fl.sp_nonfl {
    display: block;
  }

  dl.data_box .lyt_fl .col {
    padding: 0;
  }

  dl.data_box .lyt_fl .col:first-child {
    padding-bottom: 20px;
    margin-bottom: 20px;
  }

  dl.data_box .lyt_fl .col:first-child::after {
    width: 130px;
    height: 2px;
    bottom: 0;
    left: 50%;
    right: auto;
    margin-left: -65px;
    top: auto;
    margin-top: 0;
  }

  .older_list {
    margin-top: 30px;
  }

  .older_list p.gene {
    font-size: 20px;
  }

  .older_list p.data_num_sub {
    font-size: 20px;
  }

  .older_list p.data_num_sub span {
    font-size: 50px;
  }
}

@media screen and (max-width: 500px) {
  .data_list {
    gap: 10px;
  }

  dl.data_box {
    width: calc(50% - 5px);
  }

  p.data_num span {
    font-size: 32px;
  }

  p.data_num {
    font-size: 16px;
  }

  dl.data_box>dt {
    font-size: 18px;
  }

  .older_list p.gene {
    font-size: 16px;
  }

  .older_list p.data_num_sub {
    font-size: 16px;
  }

  .older_list p.data_num_sub span {
    font-size: 32px;
  }

}

/*------------------------------
  contact お問い合わせフォーム
------------------------------*/
.step {
  list-style-type: none;
  display: grid;
  grid: auto / repeat(3, 1fr);
  gap: 10px 34px;
  width: 100%;
  max-width: 900px;
  padding: 0;
  margin: auto auto 30px;
  overflow: hidden;
  border-radius: 5px;
}

.step li {
  position: relative;
  min-height: 50px;
  line-height: 1.2;
  box-sizing: border-box;
  background: #BDCAD5;
  padding: 19px 20px;
  padding: 8px 3px 8px 10px;
  font-size: 14px;
}

.step li:before,
.step li:after {
  content: "";
  position: absolute;
  top: 0;
  width: 34px;
  height: 100%;
}

.step li:before {
  left: -34px;
}

.step li:after {
  right: -34px;
  background: url(/image/icon/icon_02.svg) no-repeat 0 0 /cover;
}

.step .step_num {
  font-size: 12px;
}

.step li.is-current {
  background: #237CBF;
  color: #fff;
}

.step li.is-current::after {
  background-image: url(/image/icon/icon_02_current.svg);
}

.step li+li.is-current::before {
  background-image: url(/image/icon/icon_02_current_02.svg);
}

.contact_no_error_txt {
  margin-bottom: 30px;
}

@media print,
screen and (min-width: 768px) {
  .step {
    gap: 10px 40px;
    margin: auto auto 40px;
  }

  .step li {
    min-height: 56px;
    padding: 8px 3px 8px 10px;
    font-size: 15px;
  }

  .step .step_num {
    font-size: 13px;
  }

  .step li:before,
  .step li:after {
    width: 40px;
  }

  .step li::before {
    left: -40px;
  }

  .step li:after {
    right: -40px;
    background: url(/image/icon/icon_02_pc.svg) no-repeat 0 0 /cover;
  }

  .step li.is-current::after {
    background-image: url(/image/icon/icon_02_current_pc.svg);
  }

  .step li+li.is-current::before {
    background-image: url(/image/icon/icon_02_current_02_pc.svg);
  }

  .contact_no_error_txt {
    margin-bottom: 35px;
  }

}

/*お問い合わせ完了 thanks*/
.mail_form_thanks {
  margin: 30px 0 0;
}

.mail_form_thanks_ttl {
  margin: 0 0 30px;
  font-size: 24px;
  font-weight: 500;
}

.mail_form_thanks_txt {
  margin: 0 0 40px;
}

.mail_form_thanks_txt p+p {
  margin-top: 30px;
}

.bg_chara_decoration {
  padding-bottom: 260px;
  background: url(/image/top/character03.png) no-repeat center bottom/280px;
}

@media print,
screen and (min-width: 768px) {
  .mail_form_thanks {
    margin-top: 80px;
  }

  .mail_form_thanks_ttl {
    margin-bottom: 75px;
    font-size: 40px;
  }

  .bg_chara_decoration {
    padding-bottom: 380px;
    background-size: 408px;
  }

  .mail_form_thanks_txt {
    margin-bottom: 90px;
  }
}

/*------------------------------
  /contact/hikari-yui/ ひかりゆいまーるに関するお問い合わせ
------------------------------*/
.hikari_yui_lead {
  margin-bottom: 20px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  color: #224DBE;
}

*+.hikari_yui_lead {
  margin-top: 30px;
}

.contact_hikari_yui_caution_box {
  padding: 10px 20px 30px;
  border-radius: 5px;
  background-color: #F5F5F5;
}

.fwb_01 {
  font-weight: bold;
}

.fc_caution {
  color: #D40F0F;
}

.list_indent {
  margin-left: 1em;
  text-indent: -1em;
}

.fc_notice {
  color: #224DBE;
}

.yui_center_block {
  display: grid;
  gap: 20px 30px;
  margin: 20px 0 0;
  padding: 20px 20px;
  border-radius: 8px;
  background-color: #224DBE;
  color: #fff;
}

.contact_hikari_yui_caution_box>* {
  margin-top: 20px;
}

.hikari_hikari_fiber_box td {
  background-color: #fff;
}

.yui_center_block .block_01 {}

.yui_center_line_01 {
  font-size: 20px;
}

.yui_center_line_02 {
  font-size: 16px;
  font-weight: bold;
}

.yui_center_line_03 {
  font-size: 14px;
}

.yui_center_block .block_02 {}

.yui_center_block a {
  transition: all .3s;
}

.yui_center_block a:hover {
  opacity: .7;
  transition: all .3s;
}

.footer_hikari_yui {
  margin-top: 60px;
  text-align: center;
}

.contact_hikari_yui h1.page_ttl {
  margin-bottom: 40px;
  background: #0C4396;
}

.footer_hikari_yui_link_block {
  background: #f6f6f6;
}

.hikari_yui_link_list {
  display: grid;
  gap: 15px 0;
  justify-content: center;
  max-width: 80%;
  margin: 0 auto;
  padding: 30px 0;
}

.hikari_yui_link_list li {
  flex-basis: 100%;
  max-width: 100%;
  /* margin: 4% auto; */
  padding: 0 1%;
}

.footer_hikari_yui_logo {
  padding: 20px 0;
}

.form_name_txt {
  margin: 0 0 15px;
  font-size: 18px;
}

*+.form_name_txt {
  margin-top: 25px;
}

.contact_tel_num {
  font-size: 34px;
  font-weight: bold;
  color: #70ad47;
}

@media print,
screen and (min-width: 769px) {
  .hikari_yui_lead {
    font-size: 24px;
  }

  *+.hikari_yui_lead {
    margin-top: 80px;
  }

  .contact_hikari_yui_caution_box {
    padding: 15px 40px 30px;
  }

  .fwb_01 {
    font-size: 18px;
  }

  .fc_caution {}

  .fc_notice {}

  .yui_center_block {
    margin: 25px 0 0;
    padding: 25px 40px;
  }

  .contact_hikari_yui_caution_box>* {
    margin-top: 30px;
  }

  .yui_center_block .block_01 {}

  .yui_center_line_01 {
    font-size: 30px;
  }

  .yui_center_line_02 {
    margin-top: 5px;
    font-size: 18px;
  }

  .yui_center_line_03 {
    margin-top: 5px;
    font-size: 16px;
  }

  .yui_center_block .block_02 {}

  .footer_hikari_yui {
    margin-top: 100px;
  }

  .contact_hikari_yui h1.page_ttl {
    margin-bottom: 90px;
  }

  .hikari_yui_link_list {
    grid: auto / 1fr 1fr;
    gap: 37px 37px;
    max-width: 674px;
    padding: 60px 0;
  }

  .form_name_txt {
    font-size: 22px;
  }

  .contact_tel_num {
    font-size: 60px;
  }
}

@media print,
screen and (min-width: 992px) {
  .yui_center_block {
    grid: auto / 1fr 1fr;
    align-items: center;
  }
}

/*------------------------------
  /contact/hikari-fiber-cover/ 光ファイバーケーブル 防護カバー取付のお問い合わせ
------------------------------*/
.img_scroll:has(> img) {
  text-align: center;
}

.img_scroll>img {
  max-width: none;
}

.ly_contact_pickup {
  padding: 20px 20px 20px;
  background-color: #F5F5F5;
}

.ttl_contact_pickup {
  margin: 0 0 20px;
  font-size: 22px;
  font-weight: bold;
}

.txt_contact_pickup {}

.bg_contact_pickup {
  padding: 20px;
  background-color: #fff;
}

.bg_contact_pickup>*+* {
  margin-top: 10px;
}

*+.bg_contact_pickup {
  margin-top: 20px;
}

.ttl_contact_pickup02 {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: bold;
}

.txt_icon_tel {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 5px 20px;
}

.ly_contact_pickup .icon_tel {
  text-decoration: underline;
}

.common__btn_multi_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 10px;
}

.common__btn_multi_wrap .common__btn {
  width: 100%;
  max-width: 300px;
  margin: 0;
  line-height: 1.4;
}

.common__btn_multi_wrap .common__btn>a {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 10px 15px;
}

.contact_hikari_yui_caution_box.hikari_hikari_fiber_box,
.hikari_hikari_fiber_box {
  padding: 30px 20px;
}

.hikari_hikari_fiber_box>* {
  margin-top: 0;
}

.hikari_hikari_fiber_box> :is(h1, h2, h3, h4, h5, h6) {
  margin-bottom: 10px;
  font-weight: normal;
}

.hikari_hikari_fiber_box> :is(h2, h3, h4, h5) {
  font-size: 20px;
}

@media print,
screen and (min-width: 768px) {
  .img_scroll:has(> img) {}

  .img_scroll>img {
    max-width: 100%;
  }

  .ly_contact_pickup {
    padding: 50px 20px;
    text-align: center;
  }

  .ttl_contact_pickup {
    margin: 0 0 20px;
    font-size: 28px;
  }

  .txt_contact_pickup {}

  .bg_contact_pickup {
    width: 600px;
    margin: 0 auto;
    padding: 30px;
  }

  .bg_contact_pickup>*+* {
    margin-top: 10px;
  }

  *+.bg_contact_pickup {
    margin-top: 20px;
  }

  .ttl_contact_pickup02 {
    margin: 0 0 10px;
    font-size: 18px;
    font-weight: bold;
  }

  .txt_icon_tel {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px 20px;
  }

  .icon_tel {}

  .contact_hikari_yui_caution_box.hikari_hikari_fiber_box,
  .hikari_hikari_fiber_box {
    padding: 30px 50px;
  }

  .hikari_hikari_fiber_box> :is(h2, h3, h4, h5) {
    font-size: 24px;
  }

  /*
  .hikari_hikari_fiber_box > * {
    margin-top: 0;
  }
    
  .hikari_hikari_fiber_box > :is(h1,h2,h3,h4,h5,h6){
    margin-bottom: 10px;
  }
  */
}

@media screen and (max-width: 768px) {
  .hikari_hikari_fiber_box .c__table.scroll {
    width: 100%;
    max-width: 280px;
  }
}

/*------------------------------
  /service/spamcheck/ 迷惑メール判定サービス
------------------------------*/
.icon_important_blue {
  color: #2838a9;
  font-weight: bold;
}

.icon_important_blue::before {
  background: url("../image/common/icon_important_info_blue.svg") no-repeat;
  width: 25px;
  height: 22px;
}

.c__attention .icon_important_red {
  font-size: 20px;
  padding-left: 26px;
  font-weight: bold;
  position: relative;
}

.c__attention .icon_important_red::before {
  content: '';
  display: inline-block;
  background: url("../image/common/icon_important_info_red.svg") no-repeat;
  background-size: contain;
  width: 26px;
  height: 22px;
  position: absolute;
  left: 0%;
  top: calc((1em / 2) - 4px);
}


.spamcheck_color_blue {
  color: #2838a9;
}

.icon_important.spamcheck_color_red {
  color: #D40F0F;
}

.spamcheck_anchor_link::after {
  content: "";
  width: 13px;
  height: 10px;
  background: url("../image/common/icon_anchor.svg") no-repeat;
  display: inline-block;
  margin-left: 9px;
}

.setting_table_wrap {
  overflow-x: auto;
}

.setting_table_wrap table {
  min-width: 600px;
}

a.target_blank::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url("../image/common/icon_ext_blue.svg") no-repeat;
  background-size: contain;
  margin-left: 10px;
  position: relative;
  top: 1px;
}

/*------------------------------
  /company/dx/ DXへの取り組み
------------------------------*/
.dx_strategy_block {
  display: grid;
  gap: 10px 10px;
}

.dx_strategy_found {
  padding: 6px 10px;
  background-color: #2373B9;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  color: #FFFFFF;
}

.dx_strategy_pillars {
  display: grid;
}

.dx_strategy_block .dx_strategy_pillars {
  margin-top: 0;
}

.strategy_ttl,
.strategy_concept_name {
  padding: 8px 15px;
  background-color: #F0F6F8;
  font-size: 15px;
  text-align: center;
  font-weight: 700;
  color: #2373B9;
}

.strategy_concept {
  line-height: 1.466;
  padding: 11px 15px;
  background-color: #fff;
  font-size: 15px;
}

.strategy_ttl {
  background-color: #5FB6EF;
  color: #fff;
}

.check_icon_bef {
  padding-left: 22px;
  position: relative;
}

.check_icon_bef::before,
.check_icon_bef::after {
  content: "";
  display: block;
  height: 3px;
  width: 7px;
  background: #2838A9;
  border-radius: 10px;
  transform: rotate(45deg);
  position: absolute;
  left: 3px;
  top: 10px;
  bottom: 1px;
  margin: auto;
}

.check_icon_bef::before {
  /* width: 5px; */
}

.check_icon_bef::after {
  transform: rotate(-45deg);
  width: 14px;
  left: 6px;
  bottom: 4px;
}

@media print,
screen and (max-width : 767px) {

  .strategy_ttl,
  .strategy_concept_name,
  .strategy_concept {
    border: 1px solid #B3B3B3;
  }

  .strategy_concept,
  .strategy_ttl+.strategy_concept,
  .strategy_concept+.strategy_ttl,
  .strategy_concept_name+.strategy_concept,
  .strategy_concept+.strategy_concept_name {
    border-top: none;
  }

  .strategy_concept_name+.strategy_ttl {
    margin-top: 15px;
  }
}

@media print,
screen and (min-width: 768px) {
  .dx_strategy_block {
    grid: auto/180px 1fr;
  }

  .dx_strategy_found {
    display: flex;
    align-items: center;
    padding: 5px 25px;
    font-size: 30px;
    text-align: left;
  }

  .dx_strategy_pillars {
    /*
    grid: auto/1fr 2.5fr;
    grid: auto/1fr 2.4fr 1fr;
    */
    grid: auto/1fr 2.4fr 0.6fr;
    gap: 10px 10px;
  }

  .strategy_ttl,
  .strategy_concept_name,
  .strategy_concept {
    border: 1px solid #B3B3B3;
  }

  .strategy_ttl,
  .strategy_concept_name {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .strategy_concept {
    display: flex;
    align-items: center;
    padding: 13px 15px;
  }

  .philosophy_list .font_size_m_pc,
  .font_size_m_pc li {
    font-size: 24px;
  }

  .philosophy_list .font_size_s_pc,
  .font_size_s_pc li {
    font-size: 19px;
  }
}

@media print,
screen and (min-width: 992px) {

  .strategy_ttl,
  .strategy_concept_name {
    font-size: 18px;
  }

  .strategy_concept {
    font-size: 16px;
  }

}

/*======================
20251023
======================*/
/*PDF*/

@media (max-width: 680px) {
  .TextContainer {
    width: 100%;
  }
}

.MessageItem_flex {
  display: flex;
  justify-content: center;
  gap: 30px;
  max-width: 100%;
}

p.mb-20 {
  margin-bottom: -10px !important;
}

h2.President-Message_ttl {
  margin-left: 29%;
  text-align: center;
  font-size: 2.3rem;
  font-weight: bolder;
}

p.mt-0 {
  margin-top: 0;
}

h2.President-Message_ttl.d-none::before {
    display: none;
}
h2.President-Message_ttl.d-none::after {
    display: none;
}

.ImageContainer img {
    width: 425px;
    height: 518px;
}

.TextContainer ul {
    margin-top: 5px;
}
ul.mb-40 {
    margin-bottom: 40px;
}

p.mb-0 {
    margin-bottom: 0;
    margin-top: 0;
}
p.mb-5 {
    margin-bottom: 0;
}
@media(max-width:1340px){
  .MessageItem_flex {
    display: block;
}
h2.President-Message_ttl {
    margin: 0 auto;
}
}

@media(max-width:780px){
.MessageItem_flex {
    display: block;
}
.TextContainer {
    width: 100%;
}
.ImageContainer {
    width: 100%;
    margin: 0 auto;
    text-align: center;
}
}