@charset "utf-8";
/*++++++++++++++++++++++
common
+++++++++++++++++++++++*/

:root {
	--blue-grd:linear-gradient(var(--g-angle), var(--blue-0) var(--blue-position-0), var(--blue-1) var(--blue-position-1), var(--blue-2) var(--blue-position-2));
	--blue-0: #1f9cf6;
	--blue-position-0: 0%;
	--blue-1: #22a2ff;
	--blue-position-1: 29%;
	--blue-2: #1fd0f6;
	--blue-position-2: 100%;
	--blue-3: #1fd0f6;
	--blue-position-3: 100%;

	--orange-grd:linear-gradient(var(--g-angle), var(--orange-0) var(--orange-position-0), var(--orange-1) var(--orange-position-1), var(--orange-2) var(--orange-position-2));
	--orange:rgba(rgba(246, 112, 31, 0.05));   
	--orange-0: #f6701f;
	--orange-position-0: 0%;
	--orange-1: #ff8022;
	--orange-position-1: 29%;
	--orange-2: #f6a21f;
	--orange-position-2: 100%;
	--orange-3: #f6b61f;
	--orange-position-3: 100%;
	
	--green-grd:linear-gradient(var(--g-angle), var(--green-0) var(--green-position-0), var(--green-1) var(--green-position-1), var(--green-2) var(--green-position-2));
	--green:rgba(rgba(246, 112, 31, 0.05));   
	--green-0: #51ad33;
	--green-position-0: 0%;
	--green-1: #45a44c;
	--green-position-1: 29%;
	--green-2: #83c588;
	--green-position-2: 100%;
	--green-3: #6bac5f;
	--green-position-3: 100%;
	
	--pink-grd:linear-gradient(var(--g-angle), var(--pink-0) var(--pink-position-0), var(--pink-1) var(--pink-position-1), var(--pink-2) var(--pink-position-2));
	--pink:rgba(rgba(246, 112, 31, 0.05));   
	--pink-0: #df3f64;
	--pink-position-0: 0%;
	--pink-1: #ee5e80;
	--pink-position-1: 29%;
	--pink-2: #d36b84;
	--pink-position-2: 100%;
	--pink-3: #ec92a8;
	--pink-position-3: 100%;	
	
	--red-grd:linear-gradient(var(--g-angle), var(--red-0) var(--red-position-0), var(--red-1) var(--red-position-1), var(--red-2) var(--red-position-2));
	--red:rgba(rgba(246, 112, 31, 0.05));   
	--red-0: #fa3131;
	--red-position-0: 0%;
	--red-1: #f33c3c;
	--red-position-1: 29%;
	--red-2: #e73d3d;
	--red-position-2: 100%;
	--red-3: #da5c5c;
	--red-position-3: 100%;	
   
    --g-angle: 270deg;

	--koumu:#fa3131;
	--soumu:#df3f64;
	--gyomu:#51ad33;
	--enegry:#f6701f;
	--living:#005bac;
}

/**/
/*エネルギー事業部*/
[data-color="151"] {
	--background: var(--orange-grd);
	--color: var(--enegry);
}

/*リビング事業部*/
[data-color="152"] {
	--background: var(--blue-grd);
	--color: var(--living);
}
/*総務*/
[data-color="154"] {
	--background: var(--pink-grd);
	--color: var(--soumu);
}

/*業務部*/
[data-color="155"] {
	--background: var(--green-grd);
	--color: var(--gyomu);
}
/*工務*/
[data-color="156"] {
	--background: var(--red-grd);
	--color: var(--koumu);
}



/**/


body.staff  {
	background: #fff;
}

.staff #mainttl dl {background: linear-gradient(var(--g-angle), var(--blue-0) var(--g-position-0), var(--blue-1) var(--blue-position-1), var(--blue-2) var(--blue-position-2));/* height: auto; */display: flex;}

.breadcrumb.inner  {
	padding:20px;
	/* margin: 0 30px 30px; */
	position: relative;
	margin: 0;
}
section#staff {
	margin:0;
	padding: 0;
}
section#staff.single {
	margin: 0;
	padding: 90px 0 0;
	background: #f7f7f7;
}
section#staff #sidebar {
	padding: 25px 0 0;
}


#main {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    max-width: 1400px;
    margin: 100px auto 30px;
    justify-content: space-between;
    align-items: center;
    position: relative;
}
#main .cmt{
    width: auto;
    margin: 0;
    position: absolute;
    z-index: 10;
    bottom: 10%;
    left: 3%;
}
#main .cmt:before {
	content:"";
	position: absolute;
	width: 12px;
	height: 180px;
	background: var(--blue-grd);
	left: -9%;
	bottom: 3%;
	margin: auto;
	opacity: 0.5;
}

#main .slider2 {
	border-radius: 10px;
	position: absolute;
	overflow: hidden;
	right: 0;
	max-width: 300px;
	bottom: -8%;
}

#main .slider3 {
	border-radius: 10px;
	position: absolute;
	overflow: hidden;
	left: 6%;
	max-width: 250px;
	top: -6%;
}

#main figure{
    width: 70%;
    position: relative;
    margin: auto;
    border-radius: 20px;
    overflow: hidden;
}
#main figure:before {
	content:"";
	/* background: var(--blue-0); */
	position: absolute;
	width: 100%;
	height: 480px;
	bottom: 0;
	z-index: -1;
	margin: -4%;
	left: 0%;
}

#main figure img {
	width:100%;
}
#main dl{
    margin: 0 auto 40px;
    /* text-align: center; */
}
#main dt{
    font-size: 3.5em;
    font-weight: bold;
    letter-spacing: 1px;
    margin: 0 0 15px;
    color: #005bac;
    /* background: rgba(34, 162, 255, 0.05); */
    padding: 0 0 10px;
    width: 100%;
    /* border-bottom: 1px dashed #005bac; */
    /* text-align: center; */
    max-width: max-content;
    display: block;
    text-shadow: 5px 5px 11px rgba(255,255,255,1);
}
#main p{
    line-height: 2.2;
    font-size: 1.1em;
    letter-spacing: 1px;
    /* text-align: center; */
}
.slider-thumbnail {position: absolute !important;left: 0;bottom: 0;width: 37%;}
.slider-thumbnail .swiper-slide {
	border-radius: 10px;
	height: auto;
	overflow: hidden;
	cursor: pointer;
}
.slider-thumbnail .swiper-slide-thumb-active:before {
	content:"";
	position: absolute;
	background: rgba(0,0,0,0.5);
	width: 100%;
	height: 100%;
}

/* 直線長方形のプログレスバー */
.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: x !important;
  position: relative;
}

/* 直線長方形のプログレスバー */

.swiper-pagination-bullet-active::before {
  animation: paginationActive 2s linear forwards;
}
@keyframes paginationActive {
  100% {
    width: 100%;
    opacity: 1;
  }
}

.swiper-pagination-bullet {
  position: relative;
  width: 50px !important;
  height: 5px !important;
  border-radius: 0 !important;
  opacity: 1 !important;
  transition: .3s;
  background: #ccc !important;
}
.swiper-pagination-bullet::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background-color: #0b62b0;
  transition: .3s;
}

@keyframes paginationActive {
  100% {
    width: 100%;
  }
}

/*++++++++++++++++++++++
archive
+++++++++++++++++++++++*/
.brlist {
    display: block;
}
#staff .category {
	display: flex;
	justify-content: left;
	gap: 8px;
	margin: 30px 0 50px;
}
#staff .category a{
	border: 1px solid #0b62b0;
	color: #0b62b0;
	border-radius: 100px;
	padding: 5px 20px 7px;
	cursor: pointer;
	transition: .3s;
}
#staff .category a:hover,
#staff .category a.active{
	background: linear-gradient(var(--g-angle), var(--blue-0) var(--g-position-0), var(--blue-1) var(--blue-position-1), var(--blue-2) var(--blue-position-2));
	color: #fff;
	border: 1px solid transparent;
	transition: .3s;
}

#staff .box{
	overflow: unset;
	background: none;
	margin: 50px 0 0;
}
#staff .archive li{
	width: 100%;
	background: #fff;
	margin: 0 0 20px;
}
#staff .archive li a{
	display: flex;
	overflow: hidden;
	justify-content: space-between;
}
#staff .archive li figure{
	width: 50%;
}
#staff .archive li dl {
	width: 50%;
}
/*++++++++++++++++++++++
single
+++++++++++++++++++++++*/

#staff.single .brlist {display: none;} 

#staff .inner {
	margin: auto;
	padding: 1px;
	max-width: 1200px;
}
#staff.single .inner {
	margin: auto;
}
#staff .midashi {
	color: #fff;
	max-width: 90%;
	padding: 0;
	position: absolute;
	top: 10%;
	left: 0;
	z-index: 99;
	margin: 0;
}
#staff .midashi p {
	font-weight: bold;
	font-size: 1.2em;
	letter-spacing: 3px;
	line-height: 1.8;
	padding: 3px 11px;
	margin: 0 0 10px;
	display: inline-block;
	background:var(--background);	
	color: #fff;
	opacity:0;
	position: relative;
}
#staff .midashi p:last-child {
	margin:0;
}
#staff a .midashi p:before {
	content:"";
	width:100%;
	position: absolute;
	bottom: 0;
	left: 0;
	height: 100%;
	z-index: -1;
	transform: scale(0, 1);
	transform-origin: right top;
	transition: transform .5s;
	background:var(--background);	
}
#staff a:hover .midashi p:before {
	content: "";
background:var(--background);	
	transform-origin: left top;
    transform: scale(1, 1);
transition: transform .5s;	
}
#staff a:hover .midashi p {
	color:#fff;
	position:relative;
	z-index: 9;
	opacity:1;
	background: none;
}
section#staff .schedule .box-title {
	border-radius: 5px 5px 0 0;
	margin: 0 auto 20px;
	/* max-width: 70%; */
}

section#staff .box-title {
	margin: auto;
	display: flex;
	align-items: center;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	color: #005bac;
	background: var(--background);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	max-width: 1200px;
}

#message {
	background: var(--background);
	padding: 130px 0 100px;
	margin: 50px 0 0;
	position: relative;
	z-index: 12;
}
#message .inner {
	margin: auto !important;
}
#message .messagebox {
	background: #fff;
	padding: 50px;
	border-radius: 30px;
	margin: -10px auto 0;
}
section#staff #message .box-title {
	position: relative;
	line-height: 1;
	color: #fff;
	background: #fff;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	left: 5%;
}
section#staff #message .box-title b {
	font-size: 3.3em;
	letter-spacing: 0;
}
#message .messagebox figure {
	position: absolute;
	right: 0%;
	top: 0;
	margin: -5%;
	overflow: hidden;
	border-radius: 30px;
}
#message .messagebox figure img {
	
}

#message .messagebox .honbun {
	max-width: 75%;
}
#message .messagebox .honbun .titlebox .title {
	margin: 20px 0 10px;
}
#message .messagebox .honbun .titlebox p {
	font-size: 1em;
}

#otherstaff {
	background: #fff;
	padding: 60px 0 0;
	/* margin: 50px 0 0; */
	position: relative;
	z-index: 14;
}


section#staff .box-title > b {
	font-size: 2.8em;
	font-family: 'Roboto',sans-serif;
	letter-spacing: 2px;
	font-weight: 700;
	font-family: "Poppins", sans-serif;
	margin: 0 20px 0 0;
}
section#staff .box-title span {
	font-weight: 700;
	margin: 0;
}

#staff.single .visual {
	background: #fff;
	/* height: 1100px; */
	margin: 0;
	position: relative;
}
#staff.single .visual:before {
	content:"";
	background: rgba(34, 162, 255, 0.1);
	position: absolute;
	left: 0;
	bottom: 0;
	width: 50%;
	height: 92%;
	z-index: 0;
}

#staff.single .visual figure {
	/* max-width: 60%; */
	/* float: right; */
	z-index: 10;
	position: relative;
	height: 800px;
	overflow: hidden;
}
#staff.single .visual figure img {
	/* position: absolute; */
	top: 0;
	bottom: 0;
	margin: auto;
	width: 100%;
}
#staff.single .tegaki {
    position: absolute;
    top: 0;
    z-index: 10;
    bottom: -5%;
    height: 100%;
    margin: auto;
    left: 18%;
    display: flex;
    align-items: center;
}
#staff.single .tegaki.right {
    left: inherit;
    right: 15%;
}
#staff.single .tegaki img {
}

#staff.single .schedule {
	clear: both;
	padding: 120px 40px 40px;
	box-sizing: border-box;
	background: #fff;
	margin: 0;
	position: relative;
}
.stafflist .flex {
	margin: 15px 0 12px;
	justify-content: left;
	display: block;
}
.name {
	/* color:  rgb(11,98,176); */
	font-weight: 600;
	letter-spacing: 1px;
	font-size: 1.4em;
	position: relative;
	padding: 0px 20px 0 0;
	color: var(--color);
}

.alphabet {
	/* color: rgb(11,98,176); */
	font-size: 0.9em;
	letter-spacing: 1px;
	font-weight: 600;
	padding: 2px 0 0;
	/* color: var(--color); */
}

.join {
	font-size: 0.9em;
	letter-spacing: 1px;
	font-weight: 600;
	line-height: 1.8;
}

.scbox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0;
}
.scbox .flow {
	width: 100%;
	align-items: flex-start;
}
.scbox figure {
	margin: -5% auto 0;
	width: 25%;
}

/**/

#staff.single .namebox {
	clear: both;
	position: absolute;
	z-index: 99;
	bottom: -8%;
	margin: 0;
	left: 21%;
	padding: 30px 20px 15px;
	max-width: 380px;
	box-sizing: border-box;
	width: 100%;
	background: var(--background);
}
#staff.single .namebox > div {
	/* width: 30%; */
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	color: #fff;
	margin: 0 0 5px;
}
#staff.single .namebox .midashi{
	color: #fff;
	font-size: 1.6em;
	letter-spacing: 1px;
	font-weight: 600;
	line-height: 1.6;
	margin: 0 0 10px;
}
#staff.single .namebox > div p {
	color: #eee;
	line-height: 1.9;
	letter-spacing: 1px;
}
#staff.single .namebox dl {
	text-align: center;
	box-sizing: border-box;
	padding: 0 0 33px;
	position: relative;
}
#staff.single .namebox dl:before {
	content:"";
	background: rgba(255,255,255,0.5);
	position: absolute;
	width: 100%;
	height: 1px;
	bottom: 18px;
	left: 0;
	right: 0;
	margin: auto;
}
#staff.single .namebox dt {
    text-align: center;
    background: #fff;
    border-radius: 100px;
    font-size: 0.9em;
    font-weight: bold;
    color: var(--color);
    letter-spacing: 1px;
    padding: 4px 30px 5px;
    margin: 0;
    display: inline-block;
}	
#staff.single .namebox dd {margin: 15px 0 0;display: block;justify-content: center;align-items: center;overflow: hidden;}
#staff.single .namebox dd .name {
	color: #fff;
	padding: 0 10px 0 0;
	font-size: 1.9em;
}
#staff.single .namebox dd .alphabet {
	color: #fff;
	font-size: 0.7em;
}
/**/

.flow {
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
}
.flow > div {
	display: flex;
	max-width: 1100px;
	width: 100%;
	margin: auto;
	align-items: flex-start;
}
.flow ul {
	text-align: left;
	position: relative;
	overflow: hidden;
	width: 100%;
	padding: 0 0 25px;
	/* display: flex; */
	max-width: 1100px;
	/* margin: auto; */
}


.flow ul:last-child {
	padding: 0;
}

.flow figure {
	width: 32%;
	/* float: right; */
	height: auto;
}

.flow ul:before {
	content:"";
	position: absolute;
	background: #ccc;
	width: 1px;
	height: 90%;
	left: 18px;
	top: 12px;
}
.flow ul > ul {
	display: block;
}

.flow li {
	display: flex;
	padding: 0 0 20px;
	position: relative;
}

.flow li:last-child {
	padding:0;
}

.flow li:before {
	content: "";
	background: #fff;
	width: 13px;
	height: 13px;
	border-radius: 100px;
	display: block;
	margin: 4px 10px;
	position: absolute;
	/* border: 2px solid #b6daf9; */
	border: 2px solid #ccc;
}
.flow li dl {margin: 0 0 0 38px;display: flex;}

.flow li dt {
	font-family: 'Roboto',sans-serif;
	font-weight: 700;
	letter-spacing: 1px;
	font-size: 1em;
	line-height: 1.8;
	color: var(--color);
	margin: 0 20px 0 0;
	width: 40px;
}

.flow li dd {
	margin: 0;
	width: 100%;
	font-size: 0.9em;
	color: #111;
	font-weight: 500;
	line-height: 1.6;
}
.flow li dd b {
	display: block;
	font-size: 1.2em;
	padding: 0 0 5px;
}
.flow li dd span {
	font-size:0.8em;
}

/**/
#staff.single .breadcrumb {
	margin: 50px 0 0;
	z-index: 99;
	position: absolute;
	display: inline-block;
	top: 1.2%;
	height: auto;
	padding: 10px;
	z-index: 0;
	z-index: 13;
}

#staff.single .breadcrumb ul {
	background: #fff;
	border-radius: 100px;
	max-width: max-content;
	padding: 10px 25px 12px;
}

#staff.single .box {
	padding: 0 0 100px;
	margin: -3% 0 0 0;
	position: relative;
	z-index: 12;
}

div.column__flex{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px;
	margin: 0;
	position: relative;
	z-index: 12;
}
#staff.single article {
	display: flex;
	justify-content: space-between;
	position: relative;
	padding: 50px 40px;
	box-sizing: border-box;
	background: #fff;
	width: 49%;
	margin: 0 0 20px;
}
#staff.single article:last-child {
	/* margin:0 0 100px; */
}

#staff.single .titlebox span {
    display: inline-block;
    vertical-align: middle;
    font-size: 1em;
    font-weight: 700;
    font-family: 'Roboto', sans-serif;
    letter-spacing: 2px;
    margin: 0 10px 0 0;
    color: var(--color);
}
#staff.single .titlebox .title {
	/*color: rgb(11,98,176);*/
	font-size: 1.4em;
	display: block;
	letter-spacing: 3px;
	font-weight: 600;
	line-height: 1.7;
	margin: 0 0 20px;

}

/*画像あり*/
#staff.single article.image {
	width: 100%;
	margin: 0;
	/* display: block; */
}
#staff.single article.image:last-child {
	margin:0 0 80px;
}
#staff.single article.image .honbun {
	margin: 0 50px 0 0;
	width: 66%;
	/* float: left; */
}
#staff.single article.image figure{
	width: 50%;
	margin: 0 -10% 0 0;
}

/**/


#staff.single .titlebox p {
	letter-spacing: 0;
	line-height: 2.5;
}

/**/

#staff .stafflist li {
	background: #fff;
	/* padding: 20px; */
	border-radius: 10px;
	/* overflow: hidden; */
	position: relative;
	margin: 0;
	width: 48%;
}
#staff .stafflist .flex > p {
	font-weight: 600;
	font-size: 0.9em;
	letter-spacing: 1px;
}
.stafflist ul {
	display: flex;
	/* width: 33%; */
	gap: 30px;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 20px 0 100px;
}
.stafflist a {
    border-radius: 5px;
    display: block;
    overflow: hidden;
    margin: 0;
    /* background: rgba(34, 162, 255, 0.1); */
    padding: 30px 0 30px 30px;
    box-sizing: border-box;
    background: #f7f7f7;
    transition: .3s;
    z-index: 10;
    /* position: relative; */
    /* height: 340px; */
}
.stafflist a:hover {
	transition:.3s;
	transform:scale(1.05);
}

.stafflist figure {
    max-width: 280px;
    width:100%;
    float: right;
}

.stafflist dl{
	position: absolute;
	width: auto;
	margin: auto;
	top: 0;
	box-sizing: border-box;
	text-align: center;
	display: flex;
	align-items: center;
	gap: 0;
	left: -7%;
	writing-mode: vertical-lr;
}
.stafflist dt {
	margin: 0;
	padding: 0;
	font-weight: 600;
	border-radius: 100px;
	letter-spacing: 3px;
}
.stafflist dd {
	font-weight: 600;
	margin: 0 0 5px;
}
.stafflist figure img{
	width: 100%;
}

.stafflist .profile {
    position: absolute;
    bottom: 9%;
    left: 4%;
    z-index: 11;
}

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

#main {
}
#main .cmt{
    margin: 0 3% 0 0;
    left: 5%;
}
#main figure{
}
#main figure:before {
	width: 100%;
	height: 100%;
	left: 0%;
	bottom: 0;
}
#main dl{
    
}
#main dt{
    font-size: 3em;
    font-weight: bold;
    letter-spacing: 1px;
    margin: 50px 0;
    color: var(--blue-0);
}
#main p{
    line-height: 2.2;
}	
/*++++++++++++++++++++++
common
+++++++++++++++++++++++*/
.breadcrumb.inner  {
	padding:20px;
	position: relative;
	margin: 0 30px 30px;
}
section#staff {}
/*++++++++++++++++++++++
archive
+++++++++++++++++++++++*/
#staff .box{
	overflow: unset;
}
#staff .archive li{
	width: 100%;
	background: #fff;
	margin: 0 0 20px;
}
#staff .archive li a{
	display: flex;
	overflow: hidden;
	justify-content: space-between;
}
#staff .archive li figure{
	width: 50%;
}
#staff .archive li dl {
	width: 50%;
}
/*++++++++++++++++++++++
single
+++++++++++++++++++++++*/
#staff .inner {
    margin: 0 auto 100px;
}
section#staff .box-title {display: block;margin: 0 0 30px;}
section#staff .box-title > b {display: block;line-height: 1.2;}
#staff.single .visual {
}
section#staff .schedule .box-title {max-width: 70%;}

.scbox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	margin: 30px 0 0;
}
.scbox .flow {
	width: 70%;
	align-items: flex-start;
}
.scbox figure {
	width: 25%;
}

/**/

#staff.single .namebox {
	display: block;
	padding: 20px;
	left: 18%;
}
#staff.single .namebox > div {
	width: auto;
	padding: 20px 0 0;
	box-sizing: border-box;
	justify-content: center;
}
#staff.single .namebox .midashi{
	color: #fff;
	font-size: 1.6em;
	letter-spacing: 1px;
	font-weight: 600;
	line-height: 1.6;
	margin: 0 0 10px;
}
#staff.single .namebox > div p {
	color: #eee;
	font-size: 0.75em;
	line-height: 1.9;
	letter-spacing: 1px;
}
#staff.single .namebox dl {
	width: 100%;
	padding: 0;
}
#staff.single .namebox dl:before {
	bottom: -13%;
}	
#staff.single .namebox dt {
}	
#staff.single .namebox dd {
	font-size: 1.5em;
	color: #fff;
	letter-spacing: 2px;
	font-weight: 600;
	text-align: center;
	margin: 10px 0;
}
#staff.single .namebox dd .name {
	font-size: 1.5em;
	padding: 0 0 10px;
	@: 0;
}	
/**/

.flow {
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
}

.flow ul {
	text-align: left;
	position: relative;
	overflow: hidden;
	margin: 0;
	width: 100%;
}


.flow ul:last-child {
	margin:0
}

.flow figure {
	width: 32%;
	/* float: right; */
	height: auto;
}

.flow ul:before {
}

.flow li {
	display: flex;
	padding: 0 0 20px;
	position: relative;
}

.flow li:last-child {
	padding:0;
}

.flow li:before {
}
.flow li dl {}

.flow li dt {
}

.flow li dd {
}
.flow li dd b {
	display: block;
	font-size: 1.1em;
	padding: 0 0 5px;
}
.flow li dd span {
	font-size:0.8em;
}

/**/

#staff.single .box {
	padding: 20px 0 100px;
}

div.column__flex{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px;
}
#staff.single article {padding: 40px 30px;width: 48%;}
#staff.single article.w-100 {
	width: 100%;
}
#staff.single .titlebox span {
    display: inline-block;
    vertical-align: middle;
    font-size: 1em;
    font-weight: 700;
    font-family: 'Roboto', sans-serif;
    letter-spacing: 2px;
    margin: 0 10px 0 0;
}
#staff.single .titlebox .title {
	/*color: rgb(11,98,176);*/
	font-size: 1.2em;
	display: block;
	letter-spacing: 3px;
	font-weight: 600;
	line-height: 1.7;
	margin: 0 0 12px;
}


#staff.single .titlebox p {
	font-size: 0.85em;
	letter-spacing: 1px;
	line-height: 2.5;
}

#staff .midashi p {
    margin: 0 0 5px;
    letter-spacing: 1px;
}
/**/

#staff .stafflist li {
    width: 47%;
}
.stafflist ul {
	display: flex;
	flex-wrap: wrap;
	/* width: 33%; */
	gap: 30px;
	justify-content:left;
	margin: 0;
}

.stafflist dl{
	position: absolute;
	width: 85%;
	margin: auto;
	background: #fff;
	bottom: -8%;
	left: 0;
	right: 0;
	margin: auto;
	padding: 14px 20px 12px;
	box-sizing: border-box;
	text-align: center;
}
.stafflist dt {
	font-size: 0.9em;
	margin: 0 0 5px;
	color: #005bac;
	border-radius: 100px;
	padding: 0;
	font-weight: 600;
}

#message {
	padding: 50px 0;
	margin: 50px 0 0;
}
#message .inner {
	margin: auto !important;
}
#message .messagebox {
	background: #fff;
	padding: 50px;
	border-radius: 30px;
	margin: -10px auto 0;
}
section#staff #message .box-title {
	left: 0;
}
section#staff #message .box-title b {
	font-size: 3.3em;
	letter-spacing: 0;
}
#message .messagebox figure {
	width: 25%;
	margin: 0;
}
#message .messagebox figure img {
	
}

#message .messagebox .honbun {
	max-width: 75%;
}
#message .messagebox .honbun .titlebox .title {
	margin: 5px 0 15px;
}
#message .messagebox .honbun .titlebox p {
	font-size: 0.9em;
	letter-spacing: 0;
}


#staff.single .tegaki {
    left: 2%;
}	
#staff.single .tegaki.right {
	right: 5%;
}	
}

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

#main {
    gap: 30px;
    max-width: 90%;
    margin: 100px auto 100px;
}
#main .cmt{
    margin: 0 3% 0 0;
    width: 40%;
    bottom: 15%;
}
#main .cmt:before {
	height:160px;
}	
#main figure{height: auto;width: 80%;}
#main figure:before {height: 63%;bottom: inherit;top: 6%;}
#main .slider2 {
	max-width: 250px;
}
#main .slider3 {
	left: 0;
	z-index: 100;
}
#main dt{
    margin: 30px 0 50px;
}
#main p{
    line-height: 2.2;
}	
/*++++++++++++++++++++++
common
+++++++++++++++++++++++*/
.breadcrumb.inner  {
}
section#staff {
}
/*++++++++++++++++++++++
archive
+++++++++++++++++++++++*/
#staff .box{
	overflow: unset;
}
#staff .archive li{
	width: 100%;
	background: #fff;
	margin: 0 0 20px;
}
#staff .archive li a{
	display: flex;
	overflow: hidden;
	justify-content: space-between;
}
#staff .archive li figure{
	width: 50%;
}
#staff .archive li dl {
	width: 50%;
}
/*++++++++++++++++++++++
single
+++++++++++++++++++++++*/
#staff .inner {
	/* margin: 0 0 0 300px; */
	max-width: 94%;
}
section#staff .box-title {
}
section#staff .box-title > b {
}
#staff.single .visual {
}
section#staff .schedule .box-title {max-width: 99%;}

.scbox {justify-content: space-between;}
.scbox .flow {width: 100%;}
.scbox figure {
	width: 25%;
}

/**/

#staff.single .namebox {
	padding: 20px;
	flex-direction: column;
	left: 4%;
}
#staff.single .namebox > div {
	width: 100%;
	border-right: none;
	margin: 0;
	order: 2;
	justify-content: center;
}
#staff.single .namebox .midashi{
	font-size: 1.4em;
}
#staff.single .namebox > div p {
}
#staff.single .namebox dl {
	width: auto;
	order: 1;
	margin: 0;
	display: block;
	border: none;
	padding: 0;
}
#staff.single .namebox dt {
}	
#staff.single .namebox dd {
	font-size: inherit;
	margin: 10px 0;
}
/**/

.flow {
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
}

.flow ul {padding: 0 0 20px;max-width: 100%;}


.flow ul:last-child {
	margin:0
}

.flow figure {
	width: 32%;
	/* float: right; */
	height: auto;
}

.flow ul:before {
}

.flow li {padding: 0 0 10px;}

.flow li:last-child {
	padding:0;
}

.flow li:before {
}
.flow li dl {}

.flow li dt {margin: 3px 10px 0 0;,:;font-size: 0.8em;}

.flow li dd {
}
.flow li dd b {
	display: block;
	font-size: 1.1em;
	padding: 0 0 5px;
}
.flow li dd span {
	font-size:0.8em;
}

/**/

#staff.single .box {
	padding: 20px 0 60px;
}

div.column__flex{
	gap: 15px;
}
#staff.single article {
	padding: 40px;
}
#staff.single article.w-100 {
	width: 100%;
}
#staff.single .titlebox span {
    margin: 0 0 5px;
    font-size: 0.9em;
    letter-spacing: 0px;
}
#staff.single .titlebox .title {
	font-size: 1.2em;
	line-height: 1.5;
}


#staff.single .titlebox p {
	line-height: 2;
	font-size: 0.9em;
}

/**/

#staff .midashi {
    left: 0%;
    top: 15%;
}
#staff .name {
	font-size: 1.2em;
	padding: 0 10px 0 0;
}	
#staff .alphabet {
	font-size: 0.8em;
}		
.stafflist ul {gap: 30px;}
.stafflist figure {
    max-width: 260px;
}
.stafflist dl{padding: 12px 8px 10px;}
.stafflist dt {font-size: 0.7em;}
.stafflist dd {
}
.stafflist figure img{
}
}
@media screen and (max-width: 1023px) {

#main {flex-direction: column;margin: 100px auto 50px;,:;}
#main .cmt{
    margin: 0 3% 0 0;
    order: 2;
    left: 0;
    bottom: 15%;
    max-width: 360px;
}
#main .cmt:before {
	height: 160px;
	width: 8px;
}	
#main figure{
    width: auto;
    position: relative;
    margin: 0;
}
#main figure:before {height: 100%;top: 12%;}
#main dl{
    
}
#main dt{margin: 50px 0 20px;}
#main p{
    line-height: 2.2;
}	
	
.swiper-slide.swiper-slide-prev,
.swiper-slide.swiper-slide-next,
.swiper-slide	{
	width: 100% !important;
}	
/*++++++++++++++++++++++
common
+++++++++++++++++++++++*/
.breadcrumb.inner  {margin: 0;}
#staff .category {max-width: 95%;margin: 20px auto 30px;}
/*++++++++++++++++++++++
archive
+++++++++++++++++++++++*/
.staff #mainttl dl {
	height:auto;
}	
#staff .box{
	overflow: unset;
}
#staff .archive li{
	width: 100%;
	background: #fff;
	margin: 0 0 20px;
}
#staff .archive li a{
	display: flex;
	overflow: hidden;
	justify-content: space-between;
}
#staff .archive li figure{
	width: 50%;
}
#staff .archive li dl {
	width: 50%;
}
#staff .midashi {
	left: 0;
	top: 10%;
}	
#staff .midashi p {
	font-size: 1.2em;
	margin: 0 0 10px;
	color: #fff;
	opacity: 1;
}	

#staff .name {
	font-size:1.2em;
}	
#staff .alphabet,#staff .join{
}
	
/*++++++++++++++++++++++
single
+++++++++++++++++++++++*/
#staff.single .visual figure {
	height:auto;
}	
#staff.single .namebox {
	position: relative;
	left: 0;
	width: 100%;
	max-width: 100%;
}
#staff.single .tegaki {
	max-width:400px;
}	    
    
#staff .inner {
	margin: auto;
	max-width: 100%;
	flex-direction: column;
	display: block;
	width: 100%;
}

#staff.single .namebox dd .name {
	font-size: 1.4em;
	padding: 0 0 5px;
}	
#staff.single .namebox dl:before {
	/* background:none; */
	bottom: -14%;
}
section#staff .schedule .box-title {
	max-width:100%;
}	
section#staff .box-title {
	margin: 0 0 20px 20px;
	max-width: 90%;
	display: block;
}
section#staff .box-title > b {
	display: block;
	line-height: 1.2;
}
#staff.single .visual {
	background: #fff;
	/* height: 1100px; */
	margin: 0;
}
#staff.single .schedule {padding: 30px;}

.scbox {display: block;margin: 20px 0 0;}
.scbox .flow {
	align-items: flex-start;
	width: auto;
}
.flow > div {
	max-width: 100%;
	justify-content: center;
	width: 100%;
}	
.scbox figure {
	width: 25%;
}

/**/

#staff.single .namebox .midashi{font-size: 1.3em;}
#staff.single .namebox > div p {
	color: #eee;
	font-size: 0.75em;
	line-height: 1.9;
	letter-spacing: 1px;
}

/**/

.flow {
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
}
.flow ul:last-child {
	margin:0
}

.flow figure {
	width: 32%;
	/* float: right; */
	height: auto;
}

.flow ul:before {
	content:"";
	position: absolute;
	background: #005bac;
	width: 1px;
	height: 90%;
	left: 17px;
	top: 12px;
}
.flow li:last-child {
	padding:0;
}

.flow li dd b {
	display: block;
	font-size: 1.1em;
	padding: 0 0 5px;
}
.flow li dd span {
	font-size:0.8em;
}

/**/
#staff.single .breadcrumb {
	margin: 0;
	overflow: hidden;
	z-index: 99;
	height: auto;
	max-height: max-content;
}
#staff.single .box {
	padding: 0 0 50px;
}

div.column__flex{
	margin: auto;
	max-width: 95%;
}
#staff.single article {display: block;padding: 30px;}
#staff.single article.image {margin: 0 0 20px;}
#staff.single article.image:last-child {
	margin: 0 0 80px;
	overflow: hidden;
}	
#staff.single article.w-100 {
	width: 100%;
}
#staff.single article.image .honbun {
	width: 57%;
}	
#staff.single article.image figure {
	position: absolute;
	right: 0;
	top: 0;
	margin: auto;
	width: 250px;
	bottom: 0;
	display: flex;
	align-items: center;
}	

#message {
	padding: 40px 0;
	margin: 50px 0 0;
}
#message .inner {
	margin: auto !important;
	max-width: 90%;
}
#message .messagebox {
	padding: 30px;
	border-radius: 20px;
	margin: auto;
}
section#staff #message .box-title {
	left: 0;
	margin: 0 0 20px;
	max-width: 100%;
	text-align: left;
}
section#staff #message .box-title b {
}
#message .messagebox figure {max-width: 25%;width: 100%;right: -2%;margin: 0;}
#message .messagebox .honbun {
	/* max-width: 100%; */
}
#message .messagebox .honbun .titlebox .title {
	margin: 0 0 10px;
}
#message .messagebox .honbun .titlebox p {
	font-size: 0.9em;
}
/**/
/**/

#staff .stafflist li {width: 100%;margin: 0 0 20px;}
.stafflist ul {margin: 0 auto 80px;gap: 20px;justify-content: left;max-width: 70%;}
.stafflist a {border-radius: 10px;display: block;overflow: hidden;}
.stafflist a:hover {
	transform:scale(1);
}
.stafflist dl{
	position: absolute;
	width: 85%;
	margin: auto;
	background: #fff;
	bottom: -8%;
	left: 0;
	right: 0;
	margin: auto;
	padding: 14px 20px 12px;
	box-sizing: border-box;
	text-align: center;
}

.stafflist dd {
	font-weight: 600;
	margin: 0 0 5px;
}
.stafflist figure img{
	
width: 100%;
}
}
@media screen and (max-width: 767px) {

#main {
	flex-direction: column;
	margin: 0 auto 30px;
	max-width: 100%;
	}
#main .cmt{
	width: 60%;
	bottom: 0;
	left: -13%;
	margin: -33% auto 0;
	position: relative;
}
#main .cmt:before {
	height: 120px;
	width: 8px;
	left: -5%;
}	
#main .slider2 {
	max-width: 150px;
	bottom: 7%;
	z-index: 10;
	position: relative;
}
#main .slider3 {
	max-width: 48%;
	top: -8%;
	position: relative;
}
#main figure{
    width: 95%;
    position: relative;
    margin: 20px auto 0;
    order: 1;
    padding: 0;
}
#main figure:before {
	content:"";
	height: 100%;
	top: inherit;
	bottom: 0;
}
.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
	bottom: 0 !important;
	top: 1%;
	right: 0;
	width: 40% !important;
	left: inherit !important;
	padding: 20px 0 0;
	position: absolute;
}	
.swiper-pagination-bullet {
	width: 30px !important;
	height: 3px !important;
}	
#main dl{
    
}
#main dt{margin: 20px 0 10px;font-size: 2em;}
#main p{
    line-height: 2;
    font-size: 0.9em;
}	
/*++++++++++++++++++++++
common
+++++++++++++++++++++++*/
.staff #mainttl dl {
	height:auto;
}	
.breadcrumb.inner  {margin: 0;}
section#staff {
	margin: 0;
}
	
	#staff .inner {
		max-width: 95%;
	}	
	
/*++++++++++++++++++++++
archive
+++++++++++++++++++++++*/
#staff .category a:hover{transition: none;}
#staff .category{flex-wrap: wrap;margin: 20px 0 30px 0;}
	
#staff .box{
	overflow: unset;
}
#staff .midashi {
	left: 0%;
	top: 10%;
}	
#staff .midashi p {
	font-size: 0.9em;
	margin: 0 0 5px;
	color: #fff;
	opacity: 1;
}	
#staff a:hover .midashi p {
	background:var(--background);
	z-index: 0;

}
#staff a:hover .midashi p:before {
	transform:none;
}

#staff .name {
	font-size:1.2em;
}	
#staff .alphabet,#staff .join{
	font-size:0.8em;
}
 #staff.single .stafflist .profile	.brlist {
	 display:block;
 }

	
#staff .archive li{
	width: 100%;
	background: #fff;
	margin: 0 0 20px;
}
#staff .archive li a{
	display: flex;
	overflow: hidden;
	justify-content: space-between;
}
#staff .archive li figure{
	width: 50%;
}
#staff .archive li dl {
	width: 50%;
}
/*++++++++++++++++++++++
single
+++++++++++++++++++++++*/
section#staff.single {padding: 60px 0 0;}	
#staff.single .breadcrumb {
	margin:0;
	top: 0.8%;
	width: 100%;
	border-radius: 0;
	padding: 0;
	position: relative;
}
#staff.single .breadcrumb ul {
	border-radius: 0;
	padding: 10px 10px 12px;
	background: none;
}	
section#staff .box-title {max-width: 90%;display: block;margin: 0 auto 20px;width: 100%;}
section#staff .box-title > b {font-size: 1.5em;}
#staff.single .visual figure {
	height: auto;
}
#staff.single .namebox {
	position: relative;
	left: 0;
	width: 100%;
	max-width: 100%;
}	
#staff.single .tegaki {
        max-width: 240px;
        left: 2%;
        display: flex;
        height: auto;
        bottom: 5%;
        align-items: flex-end;
        margin: 0;
        top: inherit;
    }
#staff.single .namebox dd .name {
	font-size: 1.4em;
	padding: 0;
}	
#staff.single .namebox dl:before {
	background:none;
}
.scbox .flow {
	width: auto;
	align-items: flex-start;
	margin: auto;
	display: block;
}
.flow > div {
	display: block;
}	
.scbox figure {
	max-width: 250px;
	display: block;
	margin: auto;
	width: 100%;
	text-align: center;
}
#staff.single .inner {}
/**/

#staff.single .namebox > div {
	width: 100%;
	padding:0;
	text-align: center;
	justify-content: center;
}

#staff.single .namebox > div p {
	color: #eee;
	font-size: 0.75em;
	line-height: 1.9;
	letter-spacing: 1px;
}
#staff.single .namebox dl {
	width: auto;
	border-right: none;
	padding: 0;
	border: none;
	margin: 0 0 15px;
	display: block;
}

/**/

.flow {
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
}

.flow ul:last-child {
	margin:0
}

.flow figure {
	width: 32%;
	height: auto;
}

.flow ul:before {
	content:"";
	position: absolute;
	background: #005bac;
	width: 1px;
	height: 90%;
	left: 17px;
	top: 12px;
}

.flow li:last-child {
	padding:0;
}
.flow li dd b {
	font-size: 1em;
}
.flow li dd span {
	font-size:0.8em;
}

/**/

#staff.single .box {
	padding: 0 0 30px;
	margin: 0;
}

#staff.single article {
	padding:25px;
	width: auto;
}
#staff.single article.image .honbun {
	width:100%;
	margin: 0 0 30px;
}
#staff.single article.image figure {
	max-width: 90%;
	margin: auto;
	text-align: center;
	width: 100%;
	position: relative;
	display: block;
}	
#staff.single article:last-child figure {
	max-width:60%;
}	
#staff.single article.w-100 {
	width: 100%;
}

#staff.single .titlebox .title {
	letter-spacing: 1px;
	margin: 0 0 10px;
}

#message {
	padding: 40px 0;
	margin: 50px 0 0;
}
#message .inner {
	margin: auto !important;
}
#message .messagebox {
	padding: 30px 20px;
	border-radius: 20px;
	margin: auto;
}
section#staff #message .box-title {
	left: 0;
	margin: 0 auto 20px;
	max-width: 95%;
}
section#staff #message .box-title b {
	font-size: 2em;
}
#message .messagebox figure {
	position: relative;
	right: 0;
	top: 0;
	margin: auto;
	border-radius: 20px;
	padding: 20px 0;
	text-align: center;
	max-width: 60%;
}
#message .messagebox .honbun {
	max-width: 100%;
}
#message .messagebox .honbun .titlebox .title {
	margin: 0 0 10px;
}
#message .messagebox .honbun .titlebox p {
	font-size: 0.9em;
	letter-spacing: 1px;
}
/**/
.stafflist {
	max-width: 100%;
	margin: auto;
}
.stafflist ul {
    justify-content: space-between;
    gap: 20px;
    display: block;
    max-width: 100%;
}
#staff .stafflist li {
	width: auto;
	margin: 0 0 30px;
}
.stafflist a {
    padding: 30px 0 50px 30px;
}
	.stafflist a:hover {
		margin: 0;
	}	
.stafflist figure {
	max-width: 200px;
}	
.stafflist dl{
	width: 90%;
	padding: 14px 15px 12px;
}
.stafflist dt {
	font-size: 0.8em;
}
.stafflist dd {font-size: 0.9em;}
.stafflist figure img{
	width: 100%;
}

#otherstaff .inner {
	max-width: 95%;
	margin: auto !important;
}	
#otherstaff figure {
}	
}

@media screen and (max-width: 480px) {
#staff .midashi p {
	font-size: 0.8em;
}
}