@charset "UTF-8";

/* * * * * * * * * * * * * * * * * *
 style.css
* * * * * * * * * * * * * * * * * */

/* life
--------------------------------- */
#life h1{
	font-size: 38px;
	line-height: 1;
	font-weight: bold;
	text-align: center;
	padding-bottom: 27px;
	background: url(../img/life/line.png) left bottom repeat-x;
}
#life h1 span{
	padding-top: 27px;
	background: url(../img/life/line.png) left top repeat-x;
	display: block;
	width: 100%;
}
#life #main #navi p{
	padding: 30px 35px 56px 35px;
	text-align: center;
}
#life #main #navi ul{
	text-align: center;
	margin: 17px auto 10px;
}
#life #main #navi ul li{
	display: inline-block;
	width: 200px;
	height: 68px;
	text-align: center;
	border-right: 1px solid #000;
}
#life #main #navi ul li:last-child{
	border-right: none;
}
#life #main #navi ul li a{
	display: inline-block;
	padding-right: 63px;
	background: url(../img/life/navi_arrow.png) right center no-repeat;
}

#life article{
	width: 1024px;
	margin: 0 auto 80px;
}
#life article h3{
	margin-left: 0;
	text-indent: -1em;
	font-size: 28px;
	font-weight: bold;
}
#life article h4{
	margin: 0 0 15px;
	font-size: 24px;
	font-weight: bold;
}
#life article figure > img {
	margin-bottom: 12px;
}
#life article .keyVisual {
	display: block;
	max-width: 516px;
}
#life article div.text{
	margin-bottom: 55px;
}
#life article .txtq{
	font-weight: bold;
	margin-top: 1em;
	margin-bottom: .5em;
}
#life article .txtq:first-child{
	margin-top: 0;
}
#life article .prof{
	width: 228px;
	margin-top: 10px;
}
#life article .ttl_prof{
	font-weight: bold;
	margin-bottom: 10px;
	line-height: 1.4;
}
#life article .ttl_prof span{
	font-size: 14px;
	font-weight: normal;
}
#life article .ttl_prof strong{
	font-size: 18px;
}
#life article .memory{
	background: #f0efe2;
	padding: 25px 20px 35px;
	position: relative;
}
#life article .memory h3{
	font-size: 24px;
	padding: 0;
	margin: 0;
}

#life article .memory .message h3 {
  padding: 20px 0 0 40px;
  float: left;
  width: 330px;
  text-indent: 0;
}

#life article .memory h3 span{
	font-size: 15px;
	display: block;
}

#life article .memory .box{
	background: #FFF;
	padding: 38px 25px;
	box-sizing: border-box;
}

#life article .memory img{
	float: left;
}

#life article .introduction {
	display: flex;
	gap: 40px;
	flex-wrap: wrap;
	margin-bottom: 32px;
}

#life article .introduction .prof {
	margin-top: 0;
}

#life article .introduction .text-block {
	flex: 1;
	display: grid;
	align-content: space-between;
}

#life article .introduction .text-block .chronology {
	width: 228px;
}

#life article .column {
	display: grid;
	gap: 20px;
	grid-template-columns: 200px auto;
	grid-template-rows: 20px auto;
	padding: 24px;
	border: 1px solid #ccc;
	margin-bottom: 80px;
}

#life article .column > img {
	width: 150px;
	grid-row: 1 / 3;
	grid-column: 1 / 2;
}

#life article .column .title {
	padding-left: 237px;
	margin-bottom: 16px;
	grid-row: 1 / 2;
	grid-column: 2 / 3;
}

#life article .column .text {
	grid-row: 2 / 3;
	grid-column: 2 / 3;
}

#life article .interview {
	display: flex;
	gap: 50px;
	justify-content: space-between;
	align-items: flex-start;
}

#life article .interview + .interview {
	margin-top: 60px;
}

#life article .interview .text {
	margin-bottom: 0;
}

#life article .interview img {
	max-width: 460px;
}

#life article .interview.img-only img {
	max-width: 100%;
	width: 100%;
}

#life article .imgs {
	display: grid;
	gap: 32px;
	grid-template-columns: repeat(3, 1fr);
	margin-bottom: 60px;
	margin-top: 60px;
}

#life #life01{
	background: url(../img/life/ttl_01.png) left top no-repeat;
	background-size: contain;
	padding-top: 174px;
}
#life #life01 .intro {
	background: url(../img/life/img01_01.jpg) right top no-repeat;
	height: 525px;
}
#life #life01 .intro .harf{
	height: 100%;
	position: relative;
}
#life #life01 .intro .harf .prof{
	position: absolute;
	bottom: 5px;
	left: 52%;
}
#life #life01 .memory .onoff .on img {
    right: 3px;
    top: 30px;
}
#life #life01 .memory .onoff .off img {
    right: -9px;
    top: 30px;
}

#life #life01 h4,
#life #life01 div .text strong {
	color: #00A7DB;
}

#life #life01 .txtq {
	background-color: #00A7DB;
	color: #fff;
	display: inline-block;
	padding: 0 7px;
}


#life #life02{
	background: url(../img/life/ttl_02.png) left top no-repeat;
	background-size: contain;
	padding-top: 174px;
}
#life #life02 .intro {
	background: url(../img/life/img02_01.jpg) left top no-repeat;
	height: 545px;
	position: relative;
}
#life #life02 .intro .harf{
	float: right;
	height: 100%;
}
#life #life02 .intro .harf .prof{
	position: absolute;
	bottom: 5px;
	left: 52%;
}
#life #life02 .flex {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	justify-content: space-between;
	margin-bottom: 50px;

}
#life #life02 .flex img {
	object-fit: contain;
}
#life #life02 .flex span:first-of-type {
	width: 35%;
}
#life #life02 .flex span:last-of-type {
	width: 60%;
}
#life #life02 .memory .onoff .on img {
    right: 3px;
    top: 12px;
}
#life #life02 .memory .onoff .off img {
    right: -9px;
    top: -8px;
}
#life #life02 .imgs_rcap {
	text-align: right;
	display: block;
}
#life #life02 .box-about {
	padding: 20px;
	margin: 60px 0;
	border: 1px solid #ccc;
}
#life #life02 .box-about-ttl {
	text-align:center;
}
#life #life02 .box-about-content {
	display: flex;
	justify-content: center;
	margin-top: 10px;
}
#life #life02 .box-about-content > div {
	margin-left: 60px;
}
#life #life02 .box-about-content > div:first-child {
	margin-left: 0;
}
#life #life02 .box-about h4 {
	margin-top: 0;
}
#life #life02 .box-about dl {
	display: flex;
	justify-content: flex-start;
}
#life #life02 .box-about dt {
	font-weight: bold;
	white-space: nowrap;
	margin-right: 1em;
}

#life #life02 h4,
#life #life02 .txtq {
	color: #E95383;
}

#life #life02 div .text strong {
  background: linear-gradient(transparent 70%, #FFED7C 0);
  display: inline;
	font-weight: 400;
	margin-right: 5px;
	margin-left: 5px;
}

#life #life02 .introduction .text-block h3 {
	margin-left: 0;
}


#life #life03{
	background: url(../img/life/ttl_03.png) left top no-repeat;
	padding-top: 165px;
}
#life #life03 .intro {
	background: url(../img/life/img03_01.jpg) right top no-repeat;
	height: 525px;
}
#life #life03 .intro .harf{
	height: 100%;
	position: relative;
}
#life #life03 .intro .harf .prof{
	position: absolute;
	bottom: 5px;
	left: 52%;
}
#life #life03 .memory .onoff .on img {
    right: -15px;
    top: 30px;
}
#life #life03 .memory .onoff .off img {
    right: -9px;
    top: 12px;
}


#life #life04{
	background: url(../img/life/ttl_04.png) left top no-repeat;
	padding-top: 165px;
}
#life #life04 .intro {
	background: url(../img/life/img04_01.jpg) left top no-repeat;
	height: 525px;
}
#life #life04 .intro .harf{
	float: right;
	height: 100%;
}
#life #life04 .intro .harf .prof{
	position: absolute;
	bottom: 5px;
	left: 52%;
}
#life #life04 .memory .onoff .on img {
    right: 3px;
    top: 12px;
}
#life #life04 .memory .onoff .off img {
    right: -9px;
    top: 30px;
}

#life #life05{
	background: url(../img/life/ttl_05.png) left top no-repeat;
	padding-top: 165px;
}
#life #life05 .intro {
	background: url(../img/life/img05_01.jpg) right top no-repeat;
	height: 525px;
}
#life #life05 .intro .harf{
	height: 100%;
	position: relative;
}
#life #life05 .intro .harf .prof{
	position: absolute;
	bottom: 5px;
	left: 52%;
}
#life #life05 .memory .onoff .on img {
    right: 3px;
    top: 24px;
}
#life #life05 .memory .onoff .off img {
    right: -3px;
    top: 20px;
}


/* form
--------------------------------- */
#form #main{
	padding: 35px 0 70px;
/* 	background: #fff885;  */
}
#form h1{
	font-size: 40px;
	font-weight: bold;
}
#form h2{
	color: #fe2121;
	font-size: 26px;
	font-weight: bold;
}
#form #main .box{
	margin: 20px 0 30px;
	border: 5px solid #000;
	background: #FFF;
}
#form #main dl{
	margin: 45px 40px 20px;
}
#form #main dl dt{
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 25px;
}
#form #main dl dt strong{
	width: 3.0em;
	display: inline-block;
	color: #1260d4;
}
#form #main dl dt span{
	color: #ff4f3b;
	margin-left: 15px;
	font-size: 18px;
}
#form #main dl dd{
	padding-left: 2.5em;
	font-size: 22px;
}

#form #main .prof{
	background: #efefef;
	padding: 50px 40px;
	margin-top: 50px;
}
#form #main .prof dl{
	margin: 25px 0 0;
}
#form #main .prof dl dt{
	font-size: 20px;
	margin-bottom: 10px;
}
#form #main .prof dl dd{
	padding-left: 1.5em;
	font-size: 20px;
}
#form #main input,
#form #main textarea,
#form #main label{
	font-size: 19px;
}
#form #main textarea{
	width: 100%;
	padding: 15px;
	height: 100px;
	border: 1px solid #000;
	box-sizing: border-box;
}
#form #main input[type="text"]{
	width: 447px;
	padding: 15px;
	height: 47px;
	border: 1px solid #000;
	box-sizing: border-box;
}
#form #main input[type="radio"],
#form #main input[type="checkbox"]{
    top: -2px;
    position: relative;
}
#form #main button{
	width: 434px;
	height: 88px;
	line-height: 88px;
	border-radius: 45px;
	border: none;
	text-align: center;
	color: #FFF;
	font-size: 30px;
	font-weight: bold;
	cursor: pointer;
	display: block;
	margin: 15px auto;
}
#form #main button.blue{
	background: #1561e0;
}
#form #main button.black{
	background: #000;
}
#form #main button.red{
	background: #e01515;
}
#form #main button span{
	height: 30px;
}
#form #main button span.next{
	background: url(../img/form/arrow_next.png) right center no-repeat;
	padding-right: 55px;
}
#form #main button span.prev{
	background: url(../img/form/arrow_prev.png) left center no-repeat;
	padding-left: 55px;
}



/* snap
--------------------------------- */
#snap #title h1{
  width: 100%;
  height: 147px;
  background: url(../img/snap/title.png) center center no-repeat;
  background-size: contain;
  text-indent: -9999px;
}
#snap #title p{
  margin: 20px 0 30px;
  text-align: center;
  font-weight: bold;
}
#snap .images li{
  width: 20%;
  float: left;
}


/*20240405 Lifeページレイアウト変更*/

#main .inner2 {
	display: flex;
	justify-content: space-between;
	margin-bottom: 40px;
}

#main  .timeline {
	width: 320px;
	height: fit-content;
	padding: 16px;
	background: #F7F4EB;
}

#main  .timeline h5 {
	color: #00A7DB;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 20px;
}

#main #life02 .timeline h5 {
	color: #E95383;
}

#main .timeline span{
	color: #00A7DB;
	margin-right: 1em;
	font-weight: bold;
}

#main #life02 .timeline span {
	color: #E95383;
}

#main #life02 .timeline-img{
	width: 50%;
}

#main .timeline dl{
	display: flex;
	line-height: 2;
}

#main .timeline dt {
	width: 64px;
}

#main .timeline dd {
	width: 200px;
}

#main  #life01 .tow-column {
	width: 60%;
	margin: 0 24px;
	padding: 24px;
	border: 1px solid #ccc;
	margin-bottom: 80px;
}

#main  #life01 .tow-column .column-inner {
	display: flex;
}

#main  #life01 .tow-column .column-inner .text {
	padding-right: 24px;
}

#main  #life01 .tow-column .cap {
	margin-top: 16px;
}

#main  #life01 .tow-column img {
	width: 50%;
	height: auto;
	object-fit: cover;
}

#main  #life01 .tow-column h5 {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 20px;
}

.imgs2 {
	display: flex;
	margin: 64px 0 ;
}

.imgs2 figure img {
	width: 460px;
}

.imgs2 .schedule{
	width: 320px;
	object-fit: cover;
	margin-right: 32px;
}


/*アンケート*/
.summary {
	cursor: pointer;
	background-color: #d0e4f7;
	padding: 2px;
	margin-bottom: 8px;
	font-size: 18px;
	font-weight: bold;
	padding-left: 10px;
	position: relative;
	list-style: none;
}
.summary span {
	font-size: 14px;
	margin-right: 8px;
}

/* Chrome、Safari */
summary::-webkit-details-marker {
	display: none;
}
