@charset "UTF-8";

/* * * * * * * * * * * * * * * * * *
smart.css
* * * * * * * * * * * * * * * * * */
.inner {
    width: 90%;
}

.noSP{display: none;}
.noPC{display: inline-block;}

#header p.logo {
    float: none;
    margin:  0 auto;
}

#header p.catch {
    text-align: center;
    padding-top: 0;
    margin-top: 30px;
}

#footer .navi {
    text-align: center;
    padding: 20px 5%;
    width: 100%;
    float: none;
    margin: 20px -5% 0;
    border-top: 1px solid #ddd;
}

#footer .navi li a {
    padding: 0 0.4em;
}

#footer section {
    margin: 0;
}
#footer .navi {
    text-align: center;
    padding: 20px 5%;
    width: 100%;
    float: none;
    margin: 20px -5% 0;
    border-top: 1px solid #ddd;
}

#footer .navi li a {
    padding: 0 0.4em;
}

#footer section {
    margin: 0;
}

#footer section p.nippo {
    max-width: 300px;
    width: 47%;
    padding: 0;

}
#footer section p.nst {
    max-width: 300px;
    width: 47%;
    padding: 0;

}
#footer section p.nippo a.btn,
#footer section p.nst a.btn{
	display: block;
	height: 80px;
	width: 100%;
}
#footer section p.nippo a.btn{
	background: url(/img/common/logo_nippo.png) center center/150px no-repeat;
}
#footer section p.nst a.btn{
	background: url(/img/common/logo_nst.png) center center/121px no-repeat;
}
#footer section p.nippo span,
#footer section p.nst span{
	float: right;
	margin-left: 0px;
}
#footer section p.nippo img,
#footer section p.nst img{
	display: none;
}

/* top
--------------------------------- */


#top .logobox{
	width: 100%;
	padding-top: 20px;
	float: none;
}
#top .logobox p {
  font-size: 12px;
}

#top .enquete {
  display: block;
}
#top .enquete > img {
  width: 40%;
  height: auto;
  float: left;
  margin-right: 2%;
}
#top .enquete a,
#top .enquete div {
  width: 100%;
  display: inline-block;
  margin-bottom: 10px;
}

#top .bnrbox{
	width: 90%;
	padding-top: 20px;
	float: none;
	margin: 0 auto;
}
#top .bnrbox li{
	margin-bottom: 18px;
	width: 100%;
}


#main{
	width: 100%;
	margin: 0px auto 50px;
}
#main .tabs{
	height: auto;
}
#main .tabs li{width: 50%;}
#main .tabs li .smallSP{font-size: 12px;}
#main .tabs li a{font-size: 16px;line-height: 35px;}

#main .tabbox{width: 100%;}
#main .tabbox li{
	width: 50%;
	padding: 10px 10px 30px;
	height: auto;
	min-height: 183px;
	position: relative;
}

a.zoom {
  position: absolute;
  bottom: 0;
  right: 0;
}

a.zoom::after {
  width: 40px;
  height: 40px;
}

.zoom img {
    display: none;
}

#tab4 .zoom img {
    display: block;
}

#tab4 a.zoom {
    width: auto;
    height: auto;
    background: none;
    position: relative;
}

#main .tabbox li p{
	font-size: 10px;
}
#main .tabbox li p.name{
	margin-top: 10px;
	padding: 0;
	height: 40px;
}
#main .tabbox li p.name img {
    max-height: 100%;
    width: auto;
}





/* life
--------------------------------- */
#life h1 {
    font-size: 27px;
}

#life #main #navi p {
    padding: 23px 0 40px 0;
}

#life #main #navi ul li {
    width: 20%;
    box-sizing: border-box;
    height: auto;
    padding: 0 15px;
}

#life #main #navi ul li a {
    padding: 0 0 30px;
    background-position: center bottom;
    background-size: 30px auto;
    display: block;
}


#life article {
    width: auto;
}
#life article .memory img{width: 20%;}
#life .intro {
    background: none!important;
    height: auto!important;
}

#life .intro .harf {
    width: 100%!important;
    float: none!important;
}
#life article h3 {
    margin-top: 40px;
    font-size: 20px;
}

#life article h4 {
    margin-top: 30px;
    font-size: 16px;
}

#life article .keyVisual {
  max-width: 90%;
  margin: 0 auto;
}
#life article .harf {
    width: auto;
}

#life article p.text {
    margin-bottom: 20px;
}
#life article .prof {
    width: 100%;
    position: relative!important;
    left: 0!important;
}
#life article .memory h3 {
    font-size: 18px;
}
#life article .memory .message h3 {padding: 0px 0 0 3%;width: 77%;}
#life article .memory .onoff h3 {
  width: 100%;
  float:  none;
  margin-top:  20px;
}

#life article .memory {
    padding: 10px 20px 20px;
}
#life article .memory h3 span {
    font-size: 11px;
}

#life article .memory .box {
    padding: 15px;
    margin-top: 10px;
}

#life article .memory .message{
	margin-top: 10px;
	position: relative;
}

#life article .introduction {
    flex-direction: column;
	gap: 24px;
}

#life article .introduction .text-block {
	gap: 24px;
}

#life article .column {
    margin-bottom: 10px;
	grid-template-columns: 100px auto;
	grid-template-rows: 100px auto;
    padding: 20px;
}

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

#life article .column .title {
	padding-left: 0;
	margin-bottom: 0;
	grid-row: 1 / 2;
	grid-column: 2 / 3;
    display: grid;
    align-content: center;
}

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

#life article .interview {
    flex-direction: column;
    gap: 32px;
}

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

#life article .interview.andImg img {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    display: block;
}

#life article .interview.andImg.moveImg img {
    order: 1;
}

#life article .imgs {
	gap: 40px;
	grid-template-columns: repeat(1, 1fr);
}

#life article .imgs img,
#life article .imgs figure > img {
    width: 240px;
    margin-left: auto;
    margin-right: auto;
    display: block;
}


#life #life01 {
    background: url(../img/life/ttl_01_sp.png) left top no-repeat;
    background-size: 100% auto;
    padding-top: 25%;
}

#life #life02 {
    background: url(../img/life/ttl_02_sp.png) left top no-repeat;
    background-size: 100% auto;
    padding-top: 25%;
}

#life #life03 {
    background: url(../img/life/ttl_03_sp.png) left top no-repeat;
    background-size: 100% auto;
    padding-top: 9%;
}

#life #life04 {
    background: url(../img/life/ttl_04_sp.png) left top no-repeat;
    background-size: 100% auto;
    padding-top: 9%;
}

#life #life05 {
    background: url(../img/life/ttl_05_sp.png) left top no-repeat;
    background-size: 100% auto;
    padding-top: 9%;
}

#life #life02 .box-about {
	margin: 5px 20px;
	padding:15px;
}
#life #life02 .box-about-ttl {
	font-size: 11px;
}
#life #life02 .box-about-content {
	display: block;
}
#life #life02 .box-about-content > div {
	margin-left: 0;
}
#life #life02 .introduction .text-block h3 {
	margin-top: 0;
}
/* form
--------------------------------- */
#form #main{
	padding: 35px 0 40px;
}
#form h1{
	font-size: 20px;
	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 20px 0px;
}
#form #main dl dt{
	font-size: 18px;
	margin-bottom: 10px;
	padding-left: 2.5em;
}
#form #main dl dt strong{
	width: 0;
	text-indent: -3.0em;
}
#form #main dl dt span{
	font-size: 15px;
	margin-left: 10px;
}
#form #main dl dd{
	font-size: 18px;
}

#form #main .prof{
	background: #efefef;
	padding: 40px 20px;
	margin-top: 40px;
}
#form #main .prof dl{
	margin: 25px 0 0;
}
#form #main .prof dl dt{
	font-size: 17px;
	padding: 0;
}
#form #main .prof dl dd{
	padding-left: 1.5em;
	font-size: 20px;
}
#form #main input,
#form #main textarea,
#form #main label{
	font-size: 16px;
}
#form #main textarea{
	padding: 10px;
}
#form #main input[type="text"]{
	width: 100%;
	padding: 10px;
	height: 47px;
	border: 1px solid #000;
	box-sizing: border-box;
}
#form #main input[type="radio"],
#form #main input[type="checkbox"]{
    top: 0;
}
#form #main button{
	max-width: 434px;
	width: 100%;
	height: 68px;
	line-height: 68px;
	border-radius: 40px;
	font-size: 25px;
}
#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{
	padding-right: 35px;
	background-size: 25px auto;
}
#form #main button span.prev{
	padding-left: 35px;
	background-size: 25px auto;
}


/* snap
--------------------------------- */
#snap .images li{
  width: 50%;
}

/*20190327追加*/
div.close-txt {
  font-size: 30px;
  padding: 4% 0;
}




#main .inner2 {
	display: block;
    margin: 0 auto;
    width: 90%;
}

#main .timeline {
	max-width: 100%;
    width: auto;
    margin-bottom: 40px;
    margin-right: 0;
}

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

#main  #life01 .tow-column {
	max-width: 100%;
    width: auto;
    margin: 0;
}

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

#main  #life01 .tow-column img {
	width: 100%;
}

.imgs2 {
	display: block;
    margin: 40px auto;
}

.imgs2 figure img {
	width: 100%;
}

.imgs2 .schedule{
	width: 100%;
	object-fit: cover;
	margin-right: 0;
    margin-bottom: 32px;
}

