@charset "UTF-8";
/* CSS Document */
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP&display=swap&subset=japanese");
/*------------------------------------*\
    RESET
\*------------------------------------*/
/* global box-sizing */
*, *:after, *:before {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* clear */
.clear {
  *zoom: 1;
}
.clear:before {
  content: " ";
  display: block;
}
.clear:after {
  content: " ";
  display: block;
  clear: both;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}
img[src$=".svg"] {
  width: 100%;
}

a {
  color: #444;
  text-decoration: none;
}
a:hover {
  color: #444;
  outline: 0;
}
a:focus {
  outline: 0;
}
a:active {
  outline: 0;
}

input:focus {
  outline: 0;
  border: 1px solid #04A4CC;
}

h1, h2, h3, h4, h5, p, table, ul, ol {
  margin: 0;
  padding: 0;
}

/*共通*/
body {
  -webkit-text-size-adjust: 100%;
}
body img {
  max-width: 100%;
  height: auto;
}

.lead_txt {
  line-height: 2;
  text-align: left;
  max-width: 760px;
  margin: auto;
}

.text-wrap {
  display: inline-block;
}

.red {
  color: #ff0000;
}

.bold, strong {
  font-weight: bold;
}

.sp_img {
  display: none;
}

.center {
  text-align: center;
}

.sup {
  font-size: 75.5%;
  vertical-align: top;
  position: relative;
  top: -0.1em;
}

.sub {
  font-size: 75.5%;
  vertical-align: bottom;
  position: relative;
  top: 0.1em;
}

/* ==========================
mainvisual
============================= */
.mainvisual {
  padding: 100px 0;
  text-align: center;
}
.mainvisual h1 {
  font-size: 220%;
  color: #fff;
  font-weight: bold;
}

/* ==========================
table
============================= */
table {
  width: 100%;
  border-top: 3px solid #373f9a;
}
table tr {
  border-bottom: 1px solid #d9d9d9;
}
table th, table td {
  line-height: 2;
}
table th {
  background-color: #ececf0;
  padding: 20px 60px;
  font-weight: bold;
  width: 125px;
}
table td {
  padding: 20px 90px;
}

.right_space {
  margin-right: 80px;
}

/* ==========================
=========== ぱんくず =========
============================= */
.pankuzu {
  text-align: center;
  padding: 11px 0;
  margin: 0 auto;
  width: 100%;
  background-color: #ecebf0;
}
.pankuzu ul {
  overflow: hidden;
  max-width: 1000px;
  margin: auto;
  display: inline-block;
  text-align: left;
}
.pankuzu ul li {
  float: left;
  color: #000;
  padding-right: 5px;
}
.pankuzu ul li.under_content:before {
  content: ">";
  color: #918c8a;
  padding: 0px 6px 0 0;
}
.pankuzu ul li a:link {
  text-decoration: underline;
}

/* ==========================
list-mv07
============================= */
.list-mv07 {
  opacity: 0;
  transform: translate(0, 60px);
  -webkit-transform: translate(0, 60px);
  transition: 0.8s;
}

.mv07 {
  opacity: 1;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}

/* ==========================
header
============================= */
header {
  z-index: 99999;
  background-color: #fff;
  position: sticky;
  width: 100%;
  top: 0;
  height: 142px;
  /*overflow: hidden;*/
}

.hd_inner {
  /*max-width: 1000px;
  margin: auto;*/
  padding: 25px 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.hd_icon_list {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.co_name {
  margin-bottom: 25px;
  max-width: 300px;
}
@media screen and (max-width: 768px) {
  .co_name {
    display: none;
  }
}

.hd_icon_list li.hd_menu {
  width: 25px;
}

/* ==========================
========= メニュー ==========
============================= */
/*.zdo_drawer_menu .zdo_drawer_button{
	position: absolute;
	width: 25px;
	height: 25px;
}
.zdo_drawer_menu .zdo_drawer_button {
    color: #fff;
    background: rgba(84, 83, 160, 1);
    padding: 0 0 0 0;
    border-radius: 50%;
}
.zdo_drawer_menu .zdo_drawer_bar {
    margin: 3px auto;
	hanging-punctuation: 1px;
	}

	.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar {
    width: 15px;
	}
.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar {
	 margin: 2px auto;
}

.hd_icon_list li{
	position: relative;
}
.zdo_drawer_menu .zdo_drawer_button .zdo_drawer_bar {
	background-color: #fff;
	width: 13px;
}
.zdo_drawer_nav {
	display: flex;
	justify-content: flex-end;
	width: 100%;
	max-width: 450px;
	height: 100%;
	margin-top:142px;
}
.zdo_drawer_nav li {
	width:65%;
}
.left_list {
		background: rgba(199, 203, 225, 0.7);
		padding: 0px 0 0;
}
.zdo_drawer_nav li.right_list {
    background: #43519b;
    padding: 15px 0 0;
}

.zdo_drawer_nav div.left_list p.first_l.second_chapter {
    background: #fff;
    font-size: 14px;
    width: 95%;
    margin: 0px auto 10px;
    text-align: center;
}
.zdo_drawer_nav div.left_list p.first_l.second_chapter a {
    text-align: center;
}

.zdo_drawer_nav div.left_list p.first_l {
    background: #c7cbe1;
    margin-bottom: 3px;
}
.zdo_drawer_nav div.left_list p.first_l a {
	color: #213088;
	padding: 10px 14px;
	display: block;
}
.zdo_drawer_nav li.right_list p.first_r {
    background: #43519b;
    margin-bottom: 3px;
		padding: 5px 30px;
		color: #e6e6e6;
		cursor: pointer;
}
.zdo_drawer_nav li.right_list p.first_r a {
		color: #e6e6e6;
		display: block;
}
.zdo_drawer_nav li.right_list p.first_r.se {padding: 0px;}
.zdo_drawer_nav li.right_list p.first_r.se a {padding: 22px 30px;}

.zdo_drawer_nav li.right_list p.third_r {
    padding: 5px 30px;
    background: #43519b;
}
.zdo_drawer_nav li.right_list p.third_r a {
    color: #e6e6e6;
}

.zdo_drawer_nav li.right_list .quartet_link {
    display: flex;
  	justify-content: space-between;
    flex-wrap: wrap;
    width: 96%;
    padding: 0 2% 20px;
    background: #646fac;
}
.zdo_drawer_nav li.right_list .quartet_link p {
    background: #ececec;
    width: 49%;
    font-size: 16px;
    text-align: center;
    margin-bottom: 4px;
}
.zdo_drawer_nav li.right_list .quartet_link p a {
    color: #213088;
		padding: 10px 15px;
		display: block;
}
.zdo_drawer_nav li.right_list p.first_r {
			position: relative;
	}

/* ==========================
======== スマホメニュー =======
============================= */
button.drawer-toggle.drawer-hamburger {
  display: block !important;
}

/* ==========================
.more_btn
============================= */
.more_btn {
  margin: auto;
  text-align: center;
  background: #373f9a;
  background: #373f9a;
  margin-top: 30px;
  font-weight: bold;
  border: 1px solid #373f9a;
}
.more_btn:hover {
  background: #fff;
  border: 1px solid #373f9a;
}
.more_btn a {
  display: block;
  padding: 10px;
  color: #fff;
  text-decoration: none;
}
.more_btn:hover a {
  color: #373f9a;
  font-weight: bold;
}
.more_btn .txt {
  background: url(../img/arrow_icon03.png) no-repeat right center;
  padding-right: 25px;
}
.more_btn:hover .txt {
  background: url(../img/arrow_icon04.png) no-repeat right center;
  padding-right: 25px;
}

/* ==========================
arrow_midashi
============================= */
.arrow_midashi {
  position: relative;
  width: 100%;
  text-align: center;
  display: inline-block;
  margin: 40px 0 50px 0;
  padding: 15px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  background: #e0edff;
  background: rgba(48, 168, 225, 0.7);
  box-sizing: border-box;
}
.arrow_midashi:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid rgba(48, 168, 225, 0.7);
}

/* ==========================
company_wrap
============================= */
.company_wrap {
  background-color: #767cba;
  padding: 30px 0;
}

.company_list {
  max-width: 1000px;
  margin: auto;
  display: flex;
  justify-content: space-between;
}
.company_list li {
  text-align: center;
}
.company_list li img {
  margin-bottom: 30px;
}
.company_list li a {
  color: #fff;
  text-decoration: none;
}

/* ==========================
box
============================= */
.box {
  background-color: #fff;
  padding: 50px 0;
  overflow: hidden;
}
.box.blue {
  background-color: #ecebf0;
}
.box h2 {
  text-align: center;
  color: #373f9a;
  font-weight: bold;
  font-size: 140%;
  margin-bottom: 35px;
}
.box h3 {
  text-align: center;
  font-weight: bold;
  font-size: 134%;
  margin-bottom: 35px;
}

.container {
  max-width: 1000px;
  margin: auto;
}

/* ==========================
slick
============================= */
.slick-prev:hover, .slick-next:hover {
  cursor: pointer;
}

.slick-prev {
  width: 60px;
  height: 64px;
  background: url(../img/bx-prev.png) no-repeat center;
}

.slick-next {
  width: 60px;
  height: 64px;
  background: url(../img/bx-next.png) no-repeat center;
}

.slick-prev:before, .slick-next:before {
  content: "";
  opacity: 0.5;
}

.slick-prev, .slick-next {
  position: absolute;
  z-index: 2;
  cursor: pointer;
}

.slick-prev {
  top: 30px;
  left: -75px;
}

.slick-next {
  top: 30px;
  right: -75px;
}

.box.contact {
  background: url(../img/contaact_bg.png) no-repeat center;
  background-size: cover;
  text-align: center;
  color: #fff;
  padding: 50px 5%;
}
.box.contact .title {
  font-size: 200%;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.3;
}
.box.contact .title .small {
  font-size: 55%;
  font-weight: normal;
}

.contact_tel {
  margin-bottom: 20px;
}

/* ==========================
footer
============================= */
#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  bottom: -50px;
  background: #000;
  opacity: 0.6;
  border-radius: 50%;
  right: 3%;
}
#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f106";
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -11px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

footer {
  background-color: #333333;
  position: relative;
  z-index: 999;
}

.ft_inner {
  max-width: 1000px;
  margin: auto;
  padding: 35px 0;
  color: #fff;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  overflow: hidden;
}
.ft_inner a {
  color: #fff;
}

.ft_left_list .home {
  background: url(../img/home_icon.png) no-repeat left center;
  padding-left: 30px;
  margin-bottom: 15px;
}
.ft_left_list .home a {
  text-decoration: none;
}
.ft_left_list ul {
  float: left;
  margin-right: 20px;
}
.ft_left_list li.list2 {
  background: url(../img/arrow_icon01.png) no-repeat left center;
  padding-left: 30px;
  margin: 15px 0;
}
.ft_left_list li.list3 {
  background: url(../img/arrow_icon02.png) no-repeat left center;
  padding-left: 20px;
  margin: 0 0 10px 20px;
  font-size: 90%;
}
.ft_left_list li a {
  text-decoration: none;
}

/*.ft_right_box {
  max-width: 500px;
  width: 100%;
  >.bnr {
    max-width: 250px;
    width: 100%;
    img{ 
      max-width: 100%;
    }
  }
}*/
.ft_right_box h1 {
  border-bottom: 1px solid #4b4b4b;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.ft_right_box ul.address_list, .ft_right_box ul.ft_logo_list {
  display: flex;
  justify-content: space-between;
  margin-bottom: 50px;
  font-size: 90%;
}

.ft_link_icon {
  background: url(../img/arrow_icon02.png) no-repeat left center;
  padding-left: 10px;
  display: inline-block;
}

.ft_logo_list {
  max-width: 535px;
  float: right;
}
.ft_logo_list .bold {
  font-size: 108%;
}
.ft_logo_list li {
  margin-left: 10px;
}

#copyright {
  background-color: #383f9a;
  color: #fff;
  padding: 15px 0;
  text-align: center;
}

@media print {
  body {
    width: 1100px;
    margin: auto;
  }
  .list-mv07 {
    opacity: 1 !important;
    transform: translate(0, 25px);
    -webkit-transform: translate(0, 25px);
  }
}