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

* {
  font-size: 100.01%; }

html {
  font-size: 62.5%;
  height: 100%; }

body {
  margin: 0;
  height: 100%;
  font: 1.3rem/1.61538 "Montserrat", sans-serif; }

p {
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 62.5%;
  line-height:1.6;
  margin-bottom:10px; }
  
.btn, a {
  -webkit-transition: color linear .4s, background-color linear .4s, border-color linear .4s;
  transition: color linear .4s, background-color linear .4s, border-color linear .4s; }
  .btn:hover, a:hover {
    text-decoration: none;
    outline: none; }
		

#wrapper {
  width: 100%;
  height: 100%;
  display: table;
  overflow: hidden;
  table-layout: fixed; }
  
#header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  padding: 0;
  background: #3179bf;
  box-shadow: 0 1px 1px rgba(196, 194, 202, 0.23);
  -webkit-backface-visibility: hidden;
  /* Prevent Chrome bug because of on-scroll effect in other section */ }
  
#header .logo {
  float: left;
  margin: 20px 0 0 15px;
  width: 360px;
  height: 50px; }
  
#nav {
  overflow: hidden;
  text-align: center;
  font-size: 0;
  letter-spacing: -4px;
  white-space: nowrap; }
  #nav .nav-drop {
    overflow: hidden; }
  #nav ul {
    padding: 15px 0 30px;
    margin: 0; }
  #nav li {
    display: inline-block;
    vertical-align: top;
    font-size: 1.4rem;
    line-height: 24px;
    font-weight: bold;
    letter-spacing: 0;
    white-space: normal;
    margin: 10px 0 0 54px;
	border-right: #FFF 1px dotted;
	padding:0 15px; }
    #nav li a {
      display: block;
      color: #FFFFFF; }
      #nav li a:hover {
        text-decoration: none;
        color: #abc8e5; }

.nav-opener {
  display: none;
  float: right;
  width: 31px;
  height: 31px;
  position: relative;
  text-indent: -9999px;
  overflow: hidden; }

.nav-opener:before, .nav-opener:after, .nav-opener span {
  background: #333;
  border-radius: 4px;
  position: absolute;
  top: 17px;
  left: 3px;
  right: 3px;
  height: 3px;
  margin-top: -2px;
  /* height/2 */
  -webkit-transition: all 0.2s linear;
  transition: all 0.2s linear; }

.nav-opener:before {
  content: '';
  top: 8px;
  left: 30%; }

.nav-opener:after {
  content: '';
  top: 26px; }

.nav-active .nav-opener span {
  opacity: 0; }

.nav-opener:hover {
  opacity: .9; }

.nav-active .nav-opener:after, .nav-active .nav-opener:before {
  -moz-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 16px;
  left: 5%;
  right: 5%; }

.nav-active .nav-opener:after {
  -moz-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg); }
  


.visual {
  min-height: 1000px;
  position: relative;
  overflow: hidden;
  text-align: center;
  color: #000;
  font-size: 0;
  letter-spacing: -4px;
  padding: 104px 0 0;
  background: #FFF; }
  .visual .bg-stretch {
    position: absolute;
	width:100%;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
  .visual > .container {
    display: inline-block;
    vertical-align: top;
    position: relative;
    z-index: 1;
    font-size: 2.4rem;
    line-height: 1.5;
    letter-spacing: 0; }

  .visual p {
    margin: 0 0 8px; }
    .visual p.tagline {
      line-height: 1.6;
      font-size: 2.5rem;
	  color: #FFF;
  text-shadow: 0px 4px 3px rgba(0,0,0,0.4),
               0px 8px 13px rgba(0,0,0,0.1),
               0px 18px 23px rgba(0,0,0,0.1) }

  .visual .text-block {
    padding: 90px 0; }

.visual .info {
    display: block;
	background-color: rgba( 255, 255, 255, 0.55 );
	width: 100%;
	margin-top:200px;
	padding:30px;
	overflow:hidden;
    text-transform: uppercase; }
	.info_l {
		width:55%;
		float:left;
		overflow:hidden;
		text-align:left; }
		.mds01 {
			font-size:100%;
			margin-bottom:20px; }
	
	.info_r {
		width:40%;
		float:right;
		overflow:hidden; }
		.info_r img {
		width:100%; }
		
.about, .guide {
  position: relative;
  width:100%;
  overflow:hidden;
  margin-bottom: 50px;
  padding-top:0px;
  text-align: center;
  font-size: 1.3rem;
  line-height: 1.28571428; }

    .moc {
		width:100%;
		text-align:left;
		overflow:hidden;
		padding:20px 0 10px;/*2025-07 30px 0*/ }
	.moc2 {
		width:70%;
		margin:0 auto;
		text-align:left;
		overflow:hidden;
		padding:30px 0; }
	.moc2of {
		max-height:450px;
		overflow-y: scroll; }
		
	.moc2of::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 7px;
}
	.moc2of::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background-color: rgba(0,0,0,.5);
    box-shadow: 0 0 1px rgba(255,255,255,.5);
}
	.moc p,.moc2 p {
      line-height: 1.8;
      font-size: 110%; }

.info_l2 {
		width:45%;
		float:left;
		text-align:right;
		overflow:hidden; }
		.info_l2 img {
			width:200px;
			height:150px; }
	.info_r2 {
		width:50%;
		float:right;
		overflow:hidden; }
		.mds02 {
			font-weight:bold;
			margin-bottom:5px;/*2025-07 20px*/ }
	
	.info_l3 {
		width:47%;
		float:left;
		overflow:hidden; }
	.info_r3 {
		width:47%;
		float:right;
		overflow:hidden; }
.info_l3of {
		width:47%;
		max-height:450px;
		float:left;
		overflow-y: scroll; }
.info_r3of {
		width:47%;
		float:right;
		max-height:450px;
		overflow-y: scroll; }
		
		.info_l3 img, .info_r3 img {
			width:100%;
			height:auto; }
			
	.info_l4 {
		width:47%;
		float:left;
		color:#FFF;
		overflow:hidden; }
	.info_r4 {
		width:47%;
		float:right;
		text-align:right;
		color:#FFF;
		font-size:85%;
		overflow:hidden; }
		.info_l4 img {
			width:95px;
			height:71px;
			float:left;
			margin:0 20px 30px 0; }
		
.member, .membermap {
	position: relative;
	width:100%;
	overflow:hidden;
	margin-bottom: 50px;
	background:#e1eaf4;
	text-align: center;
	font-size: 1.3rem;
	line-height: 1.28571428;
	padding-top: 0px;
	padding-right: 0;
	padding-bottom: 30px;
	padding-left: 0;
}
  .corp-tables {
  padding: 0;
  font-size: 0;
  letter-spacing: -4px;
  white-space: nowrap;
  overflow:hidden; }
  .company {
  float: left;
  vertical-align: top;
  width: 21%;
  background: #FFF;
  min-height: 100px;
  margin: 30px 0 0 35px;
  padding: 5px 5px 0;
  font-size: 1.6rem;
  letter-spacing: 0;
  white-space: normal; }
  .company img {
	  width:100%;
	  height: auto;
	  margin-bottom:10px; }
	  .ltd {
		  font-size:100%; }
	  .ctg {
		  color:#8f929f; }
		
/*--- table ---*/
.tbl_01{
width: 100%;
border-collapse: separate;
border-spacing: 0px;
border-top: 1px solid #ccc;
}
.tbl_01 th{
width:25%;
padding:10px;
font-weight:normal;
vertical-align: top;
border-bottom: 1px dotted #ccc;
}
.tbl_01 td{
width:75%;
padding:10px;
vertical-align: top;
border-bottom: 1px dotted #ccc;
}

.tbl_03{
width: 100%;
border-collapse: separate;
border-spacing: 0px;
border-top: 1px dotted #ccc;
margin-bottom:10px;
}
.tbl_03 th, .tbl_03 td {
padding:10px;
text-align: center;
vertical-align: middle;
border-bottom: 1px dotted #ccc;
}

.scl {
	display: block;
	white-space: nowrap;
	overflow-x: scroll;
	-webkit-overflow-scrolling: touch; }
		
.scl, .scl:before, .scl:after,
.tbl_03, .tbl_03:before, .tbl_03:after {-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box;}	

		.mds03 {
			font-size:120%;
			font-weight:bold;
			margin-bottom:20px; }	
		.red01 {
			color:#e4007e;
			font-weight:bold;
			margin-bottom:20px; }
			
.mmap img {
	width:100%;
	margin-bottom:10px; }

.ftr {
	width:100%;
	margin:0 auto;
	text-align:center;
	max-width:1170px;
	padding-top:30px; }	
	.ftr img {
	width:100%;
	max-width:1170px; }		
			
/*--- Google map ---*/
.moc_map {
	width:100%;
	overflow:hidden;
	padding:30px 0; }
.gmap{
position: relative;
padding-bottom: 30%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
.gmap iframe, .gmap object, .gmap embed{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}	

#footer {
	position: relative;
	width: 100%;
	overflow: hidden;
	font-size: 2rem;
	background-color: #21ab38;
	background-image: url(../images/ftr.jpg);
	background-repeat: no-repeat;
	background-position: center 0px;
	padding-top: 120px;
	padding-right: 0;
	padding-bottom: 0px;
	padding-left: 0;
}
  
h2 {
	margin-top: 60px;
}

/* 2023-12 add 2025-07 change */
.button-036 {
    width: 250px;/*300*/
    margin: 0 5px 10px;/*0 auto*/
    padding: .6em 1em;
    border: 1px solid #3179bf;
    border-radius: 5px;
    font-size: 1em;
}
.button-036 a {
	color: #3179bf;
}

.button-036:hover {
    border: none;
    background-color: #3179bf;
	    color: #fff;
    font-weight: 600;
}
.button-036 a:hover {
    color: #fff;	
}
			
  
@media print, screen and (max-width: 992px) {
	
	#header {
    padding: 0; }
    #header > .container {
      padding: 10px 0 0; }
    #header .logo {
      margin: 3px 0 32px 25px; }
	  
  .nav-opener {
    display: inline-block;
    vertical-align: top; }

  .opener-holder {
    float: right;
    display: inline-block;
    vertical-align: top;
    position: relative;
    padding: 0 0 0 25px;
    margin: 7px 25px 0; }
    .opener-holder:before {
      position: absolute;
      content: "";
      width: 1px;
      left: 0;
      top: 0;
      bottom: -6px;
      background: #f4f4f4; }
	  
  #nav {
    overflow: visible;
    font-size: 1.6rem;
    line-height: 1.3333333;
    letter-spacing: 0;
    font-weight: normal; }
    #nav .nav-drop {
      display: block;
      clear: both;
      width: 100%;
      max-width: 300px;
      position: absolute;
      right: 0;
      top: 100%;
      pointer-events: none;
      opacity: 0;
      -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
      transition: transform 0.3s, opacity 0.3s;
      -webkit-transform: translate3d(0, 30px, 0);
      transform: translate3d(0, 30px, 0); }
      #nav .nav-drop > ul {
        display: block;
        padding: 0;
        text-align: left; }
        #nav .nav-drop > ul li {
          position: relative;
          margin: 0;
          padding: 0 35px;
          display: block;
          font-size: 1.6rem;
          line-height: 1.3333333;
          font-weight: normal; }
          #nav .nav-drop > ul li.active:before {
            content: '';
            position: absolute;
            top: 20px;
            bottom: 20px;
            width: 4px;
            left: 0;
            background: #abc8e5; }
          #nav .nav-drop > ul li a {
            display: block;
            margin: 0 -9999px;
            padding: 20px 9979px;
            border-bottom: 1px solid #3E3D3F;
            color: #fff;
            background: rgba(51, 51, 51, 0.98); }
            #nav .nav-drop > ul li a:active, #nav .nav-drop > ul li a:focus, #nav .nav-drop > ul li a:hover {
              text-decoration: none;
              color: #abc8e5; }
          #nav .nav-drop > ul li.active {
            position: relative; }
            #nav .nav-drop > ul li.active a {
              color: #3179bf; }
      #nav .nav-drop .drop-holder {
        margin: 0 -9999px;
        padding: 20px 10014px;
        background: #333;
        text-align: left;
        color: #9a9a9a; }
        #nav .nav-drop .drop-holder span {
          display: block;
          margin: 0 0 20px; }
        #nav .nav-drop .drop-holder ul {
          padding: 0; }
          #nav .nav-drop .drop-holder ul li {
            padding: 0;
            margin: 0; }
          #nav .nav-drop .drop-holder ul li + li {
            margin: 0 0 0 20px; }
          #nav .nav-drop .drop-holder ul a {
            font-size: 3rem;
            color: #fff; }
            #nav .nav-drop .drop-holder ul a:hover {
              color: #abc8e5; }

  .nav-active #nav .nav-drop {
    pointer-events: auto;
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
	
  .visual {
    padding: 0;
    min-height: 760px; }
    .visual .text-block {
      padding: 150px 0 0; }
    .visual:before {
      display: none; }
    .visual .bg-stretch {
      bottom: -60px; }
	    .visual p.tagline {
      font-size: 80%; }	  
.visual .info {
	margin-top:100px; }	  
	.info_l, .info_r, .info_l3, .info_r3, .info_l3of, .info_r3of, .info_l4, .info_r4  {
		width:90%;
		float:none;
		margin:0 auto 20px; }
		.info_l3 {
			margin-bottom:20px;
		}
		
	.info_l2, .info_r2 {
		width:90%;
		float:none;
		text-align:center;
		margin:0 auto 20px; }

		.info_l3 img, .info_r3 img {
			width:80%;
			text-align:center; }
			
			.tbl_01 {
				text-align:left; }
			.info_r4 {
				text-align:center; }
		
		 .moc {
		/*text-align:center;2025-07*/ }
		.moc2 {
		width:100%;
		/*text-align:center;2025-07*/ }			

  .company {
    width: 42%;
    margin: 20px 0 0 35px;
    max-width: 310px; }
	
.moc_map {
	width:90%;
	margin:0 auto; }	
.gmap{
padding-bottom: 56%;
}

#footer {
	-moz-background-size:100% auto;
	background-size:100% auto;
	padding-top: 80px;
}
.info_l4 img {
	height: auto !important;
	width: 60px !important;
	margin: 0px;
	padding: 0px;
}
h2 {
	margin-top: 60px;
}
}

@media print, screen and (max-width: 767px) {

  .visual .bg-stretch {
    top: 100px; }
		
  .company {
    width: 90%;
	float:none;
	padding-bottom:5px;
    margin: 20px auto 0; }
	.company img {
		display:none; }

#footer {
	-moz-background-size:100% auto;
	background-size:100% auto;
	padding-top: 60px;
}
.info_l4 img {
	height: auto !important;
	width: 50px !important;
	margin: 0px;
	padding: 0px;
}
h2 {
	margin-top: 50px;
}
}

@media print, screen and (max-width: 479px) {
	
  body {
    min-width: 320px; }

  #header > .container {
    min-width: 320px;
	padding: 10px 0 0; }
	
  #header .logo {
	width: 200px;
	margin-top: 0px;
	margin-right: 0;
	margin-bottom: 10px;
	margin-left: 10px;
}
	  #header .logo img {
    width: 200px;
	height:auto; }

  #nav .nav-drop > ul li.active:before {
    top: 15px;
    bottom: 15px; }
	
 .opener-holder {
    margin: 4px 10px;
    padding: 0 0 0 10px; }
	

  .visual .text-block {
    padding: 90px 0 0; }
		    .visual p.tagline {
      font-size: 70%; }	  

.mmap img {
	width:90%; }
		.info_l4 {
			font-size:80%; }

#footer {
	-moz-background-size:200% auto;
	background-size:200% auto;
	padding-top: 40px;
}
.info_l4 img {
	height: auto !important;
	width: 35px !important;
	margin: 0px;
	padding: 0px;
}
.visual .info {
    display: block;
	background-color: rgba( 255, 255, 255, 0.55 );
	width: 100%;
	margin-top:60px;
	padding:30px;
	overflow:hidden;
    text-transform: uppercase; }
	h2 {
	margin-top: 20px;
}
.info_l2 img {
	height: auto;
	width: 150px;
}
}

@media print, screen and (min-width: 1025px) {
  [href^='tel:'] {
    cursor: default;
    pointer-events: none; }	
}
@media print {

body {
width: 1100px;
}
/*2025-07*/
.print_none{
        display: none;
    }
a[href]:after {
    content: "" !important;
  }
}

/*2025-07 kaigi-flexbox*/
.fb01 {
 display: flex;
gap: 20px;
	flex-wrap: wrap;
}
.fb01 .fb01-item {
  width: calc((100% - 40px) / 3);
}
.fb01-item img{
	width: 100%;
}	
.fb01-item p {
	font-size: 1em;
	padding-top: 5px;
	text-align: right
}
@media print, screen and (max-width: 992px) {
	.fb01 .fb01-item {
    width: calc((100% - 20px) / 2);
  }	
}
@media print, screen and (max-width: 479px) {
	.fb01 {
		display: block;
	}
	.fb01 .fb01-item {
		width: 80%;
		margin: 0 auto;
	}
}
/*kaigi-flexbox end*/
/*2025-07 kaigi-table*/
.fb-tbl {
	display: flex;
	justify-content: space-between;
	margin-bottom: 10px;
}
.fb-tbl-left {
	width: 65%;
}
.fb-tbl-right {
	width: 25%;
}
.fb-tbl-right img {
	width: 100%;
}
@media print, screen and (max-width: 767px) {
	.fb-tbl {
		display: block;
	}
	.fb-tbl-left {
		width: 100%;
		padding-bottom: 10px;
	}
	.fb-tbl-right {
		width: 60%;
		margin: 0 auto 20px;
	}
}
/*kaigi-table end*/