@charset "utf-8";
body{
    margin: 0;
    padding: 0;
    background: #ffffff;
    font-family: 'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
    text-align: center;
}
a{
	color: black;
	text-decoration: none;
	padding: 0px 20px;
}
.in_content p{
	padding: 0px 70px;
	line-height: 2.5;
	font-size: 17px;
	font-family:'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
}

.red{
	color: red;
}
.marking-red{
	background:linear-gradient(transparent 30%,rgba(255,175,177,1.00) 50%);
}
@media(max-width:300px){
	
}
.center{
	display: flex;
}
.center1{
	width: auto;
}
.center2{
	display: flex;
	margin-top: -48px;
	border-radius: 0px 0px 10px 10px;
}
.p_big{
		font-size: 40px;	
		}
.color a:hover{
	color:red;
}
.img_center{
	display: flex;
	justify-content: center;
}
@media screen and (max-width:1300px){
	.img_box{
		width: 500px;
		height: auto;
	}
}
.chart img{
	width: 100%;
}
.introduction{
	margin-bottom: -100px;
}
.yohaku0{
	margin-bottom: -100px;
}
.yohaku01{
	margin-bottom: -100px;
	margin-top:-20px; 
}
.yohaku1{
	margin-bottom: -100px;
	padding-top: 100px;
}
.yohaku2{
	padding-top: 100px;
}
.chapter{
	background-color: #E3E3E3;
	padding: 10px;
	border-left: solid 5px rgba(0,33,161,1.00);
	text-align: left;
}
/* ===================================================================
header 18~85
=================================================================== */
header{
	height:auto;
	width: 100vw;
	top: 0;
	z-index: 1;
	position: fixed
}
.menu{
	display: inline-block;
	font-size: 22px;
	margin-left: -240px;
}
.header{
	background-color: #FFFFFF;
	display: flex;
	border-bottom: solid 4px #000000;
	position: fixed;
	right: 0;
	left: 0;
	height: 82px;
}
.menubabox{
	display: inline-flex;
	align-items: center;
	margin: 0 auto ;
	height: auto;
}
.menuba{
    padding: 0;
    margin: 0;
    list-style: none;
}
.menuba li{
	display: inline;
	width: 100%;
    padding: 10px;
    margin: 0;
}
.menuba li a{
	text-decoration: none;
    justify-content: center;
    align-items: center;
    text-align: center;
    width: 100%;
    /*liから移動*/padding:5px;
	font-size: 15px;
}
.menu-item:hover a{
	color: rgba(0,33,161,1.00);
}
@media(max-width:800px){
    .menuba{
		flex-wrap: wrap;
    }
    .menuba li{
		width: 50%;
    }
	.link-circle-box{
		width: 100vw;
		display: flex;
	}
	.flex2{
		width: 100%;
		display: flex;
		justify-content: center;
		
	}
}
@media screen and (max-width: 1300px) {
/* 1300pxまでの幅の場合に適用される */

	.menu{
		display: none;
	}
	.header{
		display: block;
		margin: 0 0 auto 0;
		align-items: center;
		text-align: center;
		align-content: center;
	}
}
/* =============menu-btn(hamburger-menu)86~================ */
.menu-btn {
    position: fixed;
    top: 10px;
    right: 10px;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 90;
	
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #000000;
    position: absolute;
}
.menu-btn span:before {
    bottom: 8px;
}
.menu-btn span:after {
    top: 8px;
}
#menu-btn-check{
	display: none;
}
#menu-btn-check:checked ~ .menu-btn span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
}
.menu-content {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 80;
    background-color: #fff;
}
.menu-content ul {
    padding: 70px 10px 0;
}
.menu-content ul li {
    border-bottom: solid 1px #000;
    list-style: none;
}
.menu-content ul li a {
    display: block;
    width: 100%;
    font-size: 18px;
	text-align: left;
    box-sizing: border-box;
    color:#000;
    text-decoration: none;
    padding: 9px 15px 10px 10px;
    position: relative;
	font-family:"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
}
.menu-content li a:hover{
	background-color: #E0E0E0;	
}
.menu-content ul li a::before {
    width: 7px;
    height: 7px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(45deg);
    position: absolute;
    right: 11px;
    top: 16px;
}
.menu-content {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    background-color: #fff;
    transition: all 0.5s;/*アニメーション設定*/
}
#menu-btn-check:checked ~ .menu-content {
    left: 0;/*メニューを画面内へ*/
}
@media screen and (min-width:1300px) {
    /*　画面サイズが1024pxからはここを読み込む　*/
	.hamburger-menu{
		display: none;
	}
}
@media screen and (max-width: 768px) {
/* 768pxまでの幅の場合に適用される */
	.hamburger-menu{
		display: block;
	}
	
}
/*=title=*/
.title{
	
	border-bottom: solid 4px #000000;
	padding: auto;
	margin: auto;
	margin-top: 90px;
}
.title-p{
	margin: 5px 0px;
	text-align: center;
	font-size: 25px
}
@media screen and (max-width: 450px) {
/* 1024pxまでの幅の場合に適用される */
	.title-p{
	margin: 5px 0px;
	text-align: center;
	font-size: 15px;
    }
}
@media screen and (min-width:451px) and ( max-width:1024px) {
/* 1024pxまでの幅の場合に適用される */
	.title-p{
	margin: 5px 0px;
	text-align: center;
	font-size: 20px;
    }
}
.red-line{
		border-bottom: solid 2px red;
	}
.black-line{
		border-bottom: solid 2px #000000;
	}
.black-line2{
		border-bottom: solid 1px #000000;
	}
.left3 img{
	width: 100%;
}
.right3 img{
	width: 100%;
}

/* ===================================================================
CSS information

 file name  : css.css
 style info : index(トップページ)
=================================================================== */
.index_box{
	width: 60vw;
	height: auto;
	margin: 20px auto 0px;
	line-height: 2.25;
	font-size: 20px;
	justify-content: center;
}
.index_box1{
	width: 100vw;
	height: auto;
	margin: 0px auto;
	line-height: 2.25;
	font-size: 20px;
	padding-top: 100px;
	text-align: center;
	
}
.index_box1 img{
	margin-top: 50px;
	text-align: center;
	margin: 0 auto;
}
@media screen and (max-width:450px){
	.index_box1 img{
		width: 100%;
	}
}
.flex4 a+a{
	margin-left: 30px;
	margin-right: 30px;
}
@media screen and (max-width:1300px){
	.flex4 .right2{
		margin-top: 20px;
	}
}
@media screen and ( max-width:1100px ){
	.index_box1 img {
		width: 80vw;
		height: auto;
	}
}
.flex2{
	display: flex;
	margin: 0 auto 50px auto;
	width: 21vw;
	padding: 10px;
	border: solid 2px #000;
	justify-content: center;
	align-items: center;
}
.flex3{
	display: flex;
	justify-content: center;
	text-align: center;
}
.flex4{
	display: flex;
	justify-content: center;
	text-align: center;
	margin: 10px 0px;
	flex-wrap: wrap;
	width: auto;
}

@media screen and ( max-width:1100px){
	.flex2{
		width: 90vw;
		margin: 0 auto;
	}
	.flex7{
		flex-wrap: wrap;
	}
}
.left2{
	border-radius: 10px;
	width: 300px;
	height: 300px;
	border: solid 2px #000;
}
.left10{
	width: auto;
}
.right10{
	width: auto;
}
.flex7{	
    display: flex;
	width: 60vw;
	margin: 0 auto;
	justify-content: center;
}
.flex7 div+div{
	margin: 1rem;
}
.right2{
	border-radius: 10px;
	width: 300px;
	height: 300px;
	border: solid 2px #000;
}
.right4{
	margin: 0 auto;
	height: auto;
	text-align: left;
	width:auto;
	padding-top: 10px;
}
.right4 img{
	padding: 10px 0;
}
.domein{
	
}
.left3 img{
	width: 100%;
	height:auto;
	border: solid 3px #000;
	margin-right: 10px;
}
.right3 img{
	width:100%;
	height:auto;
	border: solid 3px #000;
	margin-left: 10px;
}
.flex2 h2{
	text-align: center;
}
.left5+.right5{
	padding: 0px 30px;
}
.logubox{
	width: auto;
}
.logu_p{
    font-size: 14px;
    text-align: left;
}
.lg_center{
	margin:0 auto;
	text-align: center;
}
.flex6{
	display: flex;
	flex-wrap: wrap;
	line-height: 0.1px;
	width: auto;
	font-size: 12.5px;
	padding: 0;
	margin: 0;
}
.flex6 .year{
	padding: 0 50px 0 0;
}
.center2{
	width: auto;
	margin-left: -13px;
}
/* ===================================================================
CSS information

 file name  : css.css
 style info : what
=================================================================== */
.Wh_images1{
	border-radius: 15px;
}
.Wh_images1-p{
	margin-top: -20px;
}
.Wh_images2{
	margin-left: 10px;
	height: 200px;
}
.Wh_images1 img{
	border-radius: 15px;
}
.Wh_images2 img{
}
.Wh_images2-p{
	margin-top: 0px;
	margin-bottom: 10px;
}
.Wh_images2{
	margin: 0px 0px 0px 30px;
}

/* ===================================================================
CSS information

 file name  : css.css
 style info : patent
=================================================================== */
.b_image1{
	width: 300px;
	height: 217px;
}

/* ===================================================================
CSS information

 file name  : css.css
 style info : utilitymodel
=================================================================== */

/* ===================================================================
CSS information

 file name  : css.css
 style info : design
=================================================================== */
.de_images1{
	margin: 0 auto;
}
.de_images2{
	margin: 10px auto 0px auto;
 }

.de_images3{
	margin: 0 auto -30px;
}
.image{
	margin: 0 auto;
}
.down{
	margin: 0 auto;
}
/* ===================================================================
CSS information

 file name  : css.css
 style info : trademark
=================================================================== */

/* ===================================================================
CSS information

 file name  : css.css
 style info : copy
=================================================================== */

/* ===================================================================
CSS information

 file name  : css.css
 style info : sonota
=================================================================== */
.lg_h{
	margin: 0 auto -10px;
	padding: 0;
	height: auto;
	width: 100%;
}
/* ===================================================================
CSS information

 file name  : css.css
 style info : interview
=================================================================== */
h2{
	font-size: 20px;
	height: auto;
	width:auto;
}
.in_content{
	text-align: center;
	margin: 30px auto 100px;
	width: 40%;
}
.in_content p{
	text-align: left;
}
ul{
	list-style: none;
	margin: 0;
	padding: 0;
}
.in_con{
	background-color: rgba(0,33,161,1.00);
	color: white;
	width: 45%;
	height: auto;
	text-align: center;
	margin: 0;
	padding-top: 5px;
}
.in_content p{
	padding: 0px 0px;
	line-height: 2.25;
}
.number{
	counter-increment: number;
}
.number::before{
	 content: counter(number);
     margin-right: 1px; /* 番号の右に5pxのスペース */
     font-weight: bold; /* 太文字指定 */
}
.big{
	font-size: 14.5px;
}
.nav2{
	height: auto;
	width: 320px;
	margin-top: 25px;
	left: 50px;
	font-size: 10.5px;
	position: fixed;	
}
.in_nav2{
	border: solid 3px rgba(0,33,161,1.00);
	padding:40px 10px;
	background-color:#fff;
	text-align: left;
}
.in_nav2 li{
	padding: 10px 0px;
	line-height: 0.5rem;
}
.in_nav2_p{
	padding: 0;
}
.in_sub{
	text-align: left;
	padding-left: 100px;
}
.in_sub_p{
	margin: auto;
	border-bottom: solid 2px #000; 
	padding-bottom: 10px;
}
.in2 img{
	width: auto;
	height: auto;
}
@media screen and (min-width:0px) and ( max-width:450px) {
	/* 450pxまでの幅の場合に適用される */
	.nav2{
		width:auto;
	}
	.in_con{
	    width: 45%;
	    text-align: center;
	    margin: 0;
        }
}
@media screen and (min-width:0px) and ( max-width:1300px) {
	/* 450pxまでの幅の場合に適用される */
	.in_content{
		width: 80vw;
		margin: 0 30px;
	}
	.nav2{
		margin: 50px auto 0px;
		position: static;
	}
	.flex{
		display: flex;
		flex-wrap: wrap;
		margin-top: -30px;
		height: auto;
		float: none;
	}
	.wrap{
		display: flex;
		justify-content: center;
	}
	.Wh_images1{
		margin:0 auto 30px auto;
	}
	.Wh_images2{
		margin: 0px auto 30px;
	}
}
@media screen and (max-height:750px){
	.wrap{
		display: flex;
		flex-wrap: wrap;
	}
	.in_content{
		margin: 0 auto;
	}
	.nav2{
		margin: 50px auto 0px;
		position: static;
	}
	.flex{
		display: flex;
		flex-wrap: wrap;
		margin-top: -30px;
		height: auto;
	}
	.wrap{
		display: flex;
		justify-content: center;
	}
	.Wh_images1{
		margin:0 auto 30px auto;
	}
	.Wh_images2{
		margin: 0px auto 30px;
	}
}
   
@media screen and (min-width:1216px) and ( max-width:1500px) {
	/* 450pxまでの幅の場合に適用される */
}
@media screen and (min-width:450px) and ( max-width:1216px) {
	/* 450pxまでの幅の場合に適用される */
}
.wrap{
	display: flex;
	flex-wrap: wrap;
	
}
.in3{
	border-bottom: solid 4px #000;
}
.in4{
	border-bottom: solid 4px #000;
}
.in5{
	border-bottom: solid 4px #000;
}
.in6{
	border-bottom: solid 4px #000;
}
.in7{
	border-bottom: solid 4px #000;
}
.flex{
		margin-top: -20px;
	}
/* ===================================================================
sa_content 
=================================================================== */
.sa_box{
	width: 32%;
	margin: 20px;
	height: auto;
	display:block;
	border-radius: 10px;
	line-height: 1px;
}
.sa_box .sa_box_h a{
	font-family:'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
	width: auto;
	padding: 5px 0px;
}
.sa_box .sa_box_h{
	border-bottom: solid 3px #000;
}
.sa_box_h{
	font-size: 25px;
	text-align: left;
	line-height: normal;
}
.sa_box_a{
	font-size: 99%;
}
.sa_box_a_li{
	text-align: left;
	width: 100%;
	margin: 30px 0px 30px;
	line-height: 1px;
	padding: 0;
}
.sa_content{
	width: 65vw;
	margin: 60px auto 0px;
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	justify-content: center;
}
@media screen and (min-width:0px) and (max-width:1300px) {
	.sa_box{
		width: 85vw;
		margin: 20px 0px;
	}
	.sa_box_a_li{
		height: auto;
		font-size: 14px;
	}
}
/* ===================================================================
CSS information

 file name  : css.css
 style info : patecon
=================================================================== */
.patecon_sub{
	text-align: left;
}
.patecon_sub_sub{
	text-align: left;
}
.patecon_sub_sub_sub{
	text-align: left;
}
.patecon_sub_sub_sub_sub{
	text-align: left;
	background-color: #E3E3E3;
	padding: 10px;
}
@media screen and (min-width:0px) and ( max-width:1300px) {
/* 1024pxまでの幅の場合に適用される */
	.in_content{
		padding:0;	
	}
}
.pa1{
	border-bottom: solid 4px #000;
}
.up{
	margin-top: -20px;
}
/* ===================================================================
CSS information

 file name  : css.css
 style info : profile
=================================================================== */
.mini_chaputer{
	background-color: #E3E3E3;
	border-left: solid 3px rgba(0,33,161,1.00); 
	width: auto;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.mini_chaputer_p{
	width: 90%;
	height: auto;
	margin: 0 auto;
}

/* ===================================================================
CSS information

 file name  : css.css
 style info : works cited
=================================================================== */
.wc_box{
	margin: 0 auto;
	line-height: 2;
	width: 60vw;
}
.wc_p{
	list-style: square;
	text-align: left;
}
.syoseki ul li::marker{
    color: rgba(0,33,161,1.00);
	font-size: 100%;
}
.site ul li::marker{
    color: rgba(0,33,161,1.00);
	font-size: 100%;
}
.site a:hover{
	color: rgba(0,33,161,1.00);
}
.site_q ul li::marker{
    color: rgba(0,33,161,1.00);
	font-size: 100%;
}
.site_q a:hover{
	color: rgba(0,33,161,1.00);
}
.site_q{
	width: 60%;
}
/* ===================================================================
footer ~
=================================================================== */
.footer{
	border-top: solid 4px #000000;
	padding-top: 15px;
	height: auto;
	list-style: none;
	display:flex;
	width: 100%;
	margin: 10px 0px 20px 0px;
	justify-content: center;
}
.footer_images{
	list-style: none;
	    font-size: clamp(8px, 1.3vw, 13px);
}
footer{
	margin: 20px 0px 20px 0px;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
}
footer .left{
	text-align: left;
	display:flex;
	flex-wrap: wrap;
}
footer .left a{
	text-align: left;
	padding: 0 10px;
}
.footer .left+.right{
	padding: 0px 2%;		
}
.right{
	margin-right: -15px
}
.footerp:hover a{
	color: rgba(0,33,161,1.00);
}
.introduction1{
	margin-bottom: 20px;
}
.link-circle{
	margin-bottom: 20px;
	width: 210px;
	height: 210px;
	text-align: center;
}
.link-circle+.link-circle{
	padding: 0px 10px;
}
.link-circle img{
	border:solid 4px #000;
	margin: 0 auto;
	padding: 0;
	border-radius: 90%;
}
.link-circle-box{
	width: 90%;
	display: flex;
	margin: 20px auto;
	
}
.wrap .link-circle-box{
	display: flex;
	justify-content:center;
	flex-wrap: wrap;
	text-align: center;
}
.nav-button {
            background: rgba(0, 0, 0, 0);
            color: black;
            border: none;
            cursor: pointer;
            font-size: 20px;
            margin: 0 10vw; /* ボタンの左右にマージンを追加して間隔を広くする */
	        width: auto;
}
.nav-buttons {
    display: flex;
    justify-content: space-around;
    margin-top: 20px;
}
.nav-buttons_r {
    display: flex;
    justify-content: flex-end;
    margin-top: 20px;
	text-align: right;
	
}
.nav-buttons_l {
    display: flex;
    justify-content: flex-start;
    margin-top: 20px;
	text-align: left;
	
}
.slider-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
	margin: 0px 20px;
}
        .slider-wrapper {
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        .slider {
			overflow: hidden;
			width: 100vw; /* スライダーの幅を調整 */
			height: 60vh; /* スライダーの高さを調整 */
			position: relative;
			display: flex;
			align-items: center;
			justify-content: center;
}
        .slides {
            display: flex;
            transition: transform 0.5s ease;
            will-change: transform;
        }

        .slide {
			width: 25vw; /* スライドの幅 */
			height: 50vh; /* スライドの高さ */
			box-sizing: border-box;
			padding: 10px;
			background: #FFFFFF;
			justify-content: center;
			text-align: center;
			font-size: 16px;
			position: relative;
			border-radius: 10px;
			flex-shrink: 0; /* スライドの幅no固定 */
			margin: 0 108px; /* スライド間のマージンをゼロに設定 */
			display: flex;
			align-items: center;
			transition: transform 0.5s ease, z-index 0s;
			border: 5px solid #000000;
}
        .slide.active {
            transform: scale(1.15);
            z-index: 1;
        }
        .slide:not(:last-child)::after {
            content: "";
            position: absolute;
            top: 0;
            right: -1px;
            width: 2px;
            height: 100%;
            background-color: #ccc;
            z-index: 1;
        }

        .slide a {
            color: black;
            text-decoration: none;
        }

.box_content{
	margin: 40px auto 0px;
}
td{
	padding: 5px;
}
