@charset "UTF-8";

/* reset styles */
html, body, div, h1, h2, h3, h4, h5, h6,
p, blockquote, pre, address,
ul, ol, li, dl, dt, dd,
table, th, td,
form, fieldset {
	margin: 0;
	padding: 0;
	font-family: 'Roboto', 'Noto Sans JP', sans-serif;
	line-height: 1.5;
	list-style-type: none;
}

/* new HTML5 elements */
section, nav, article, aside, hgroup, header, footer,
figure, figcaption, summary {
	display: block;
	margin: 0;
	padding: 0;
	font-family: 'Roboto', 'Noto Sans JP', sans-serif;
	line-height: 1.5;
}
em{
	font-style: normal;
}

br.for-SP{
	display: none;
}

hr{
	display: none;
}

/* clearfix */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
 
.clearfix:before {
 content: "";
	display: block;
	clear: both;
}
 
.clearfix {
	display: block;
}

/*----- common -----*/
body{
	background: #EAEDF0;
	color: #17191E;
	line-height: 1.5;
}

a:link,
a:visited{ color: #17191E; text-decoration: none;}
a:hover,
a:active { color: #666666; text-decoration: none;}

::selection {
 background: #F8E71C;
 color: #17191E;
}
::-moz-selection {
 background: #F8E71C;
 color: #17191E;
}

/*----- structure -----*/
.wrapper{
	position: relative;
	max-width: 980px;
	margin: 0 auto;
}

/*----- header -----*/
header{
	max-width: 980px;
	margin: 0 auto;
	padding-top: 40px;
}
header nav .global-nav{
	display: flex;
	justify-content: flex-end;
}

header nav .global-nav li{
	display: inline-block;
	margin-right: 40px;
	font-weight: 500;
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 2;
}

header nav .global-nav li.active{
 border-bottom: 3px #17191E solid;
}

/*----- greeting -----*/
.greeting{
	max-width: 900px;
	min-height: 240px;
	margin: 16px 20px 0;
	padding: 40px 20px 40px 40px;
	background: url("../images/signature.svg") no-repeat bottom right;
	background-size: contain;
}

.greeting h1{
	display: inline-block;
	height: 68px;
	margin-bottom: 16px;
	padding-right: 68px;
	font-weight: 900;
	font-size: 48px;
	letter-spacing: 2px;
	background: url("../images/daichan.svg") no-repeat right top;
}

.greeting p{
	padding-left: 4px;
	font-weight: 400;
	font-size: 20px;
	letter-spacing: 1px;
}

/*----- works-list -----*/
.works-list{
	box-sizing: border-box;
	max-width: 940px;
	margin: 40px auto 0;
	padding: 0 20px;
}

.works-list .card{
	width: 48%;
	margin-bottom: 72px;
}

.works-list .card#works-RT,
.works-list .card#works-CM,
.works-list .card#works-MN,
.works-list .card#works-SW,
.works-list .card#works-ET,
.works-list .card#works-DS{float: left;}
.works-list .card#works-CS,
.works-list .card#works-RK,
.works-list .card#works-CL,
.works-list .card#works-ES,
.works-list .card#works-GH{float: right;}

.works-list .card#works-CS{margin-top: 120px;}
.works-list .card#works-ES{margin-top: 60px;}

.works-list .card.clickable{
	cursor: pointer;
}

.works-list .card .visual{
	display: flex;
 justify-content: center;
 align-items: center;
	background: #FFF;
	border-radius: 10px;
	overflow: hidden;
	position: relative;
	z-index: 1;
}
.works-list .card .visual.small{ height: 242px;}
.works-list .card .visual.middle{ height: 332px;}
.works-list .card .visual.large{ height: 526px;}
.works-list .card#works-CM .visual{ align-items: flex-end;}


.works-list .card .visual img{
	transition: 0.5s;
}

.works-list .card .visual img:hover{
	transform: scale(1.05,1.05);
}

.works-list .card#works-RT .visual img{ width:80px; height:80px;}
.works-list .card#works-CS .visual img,
.works-list .card#works-RK .visual img{ width:88%; height:auto;}
.works-list .card#works-CM .visual img,
.works-list .card#works-ET .visual img,
.works-list .card#works-GH .visual img{ width:92%; height:auto;}
.works-list .card#works-MN .visual img{ width:80%; height:auto;}
.works-list .card#works-ES .visual img,
.works-list .card#works-DS .visual img{ width:88%; height:auto;}
.works-list .card#works-CL .visual img,
.works-list .card#works-SW .visual img{ width:150px; height:136px;}

.works-list .card .info{
	position:relative;
	margin-top: -40px;
	padding-left: 16px;
	position: relative;
	z-index: 2;
}
.works-list .card .info .year{
	font-weight: 900;
	font-size: 16px;
}
.works-list .card .info .work-title{
	margin-bottom: 8px;
	font-weight: 900;
	font-size: 32px;
	line-height: 1.0;
	letter-spacing: 2px;
}
.works-list .card .info .tags{
	
}
.works-list .card .info .tags li,
.iziModal .iziModal-content dl dd li{
	display: inline-block;
	margin-right: 4px;
	padding: 4px 8px;
	background: #DFE4E8;
	border: 1px solid #586674;
	border-radius: 4px;
	font-size: 14px;
	color: #586674;
}
.works-list .card .info .note{
	margin-top: 16px;
	font-size: 12px;
}

.works-list .card .info:after{
	content: "";
	position:absolute;
	display: block;
	z-index: 3;
	top: 16px;
	right: 16px;
	width: 48px;
	height: 48px;
 background:#586674 url("../images/ic-popup.svg") no-repeat center;
	border-radius: 100%;
}

/*.works-list .card#works-RT .info:after{
	background:#586674 url("../images/ic-lock.svg") no-repeat center;
}*/

/*----- iziModal -----*/
.iziModal .iziModal-content img.main-visual{
	width: 100%;
	height: auto;
	border-radius: 10px 0 0 0;
	vertical-align: top;
}

.iziModal .iziModal-content .detail{
	padding: 40px 24px 16px;
}

.iziModal .iziModal-content .detail .modal-title{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 24px;
	line-height: 1.0;
	letter-spacing: 0;
}
.iziModal .iziModal-content .detail .modal-subtitle{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 20px;
	line-height: 1.0;
	letter-spacing: 0;
}

.iziModal .iziModal-content .detail img{
	box-sizing: border-box;
	width: 100%;
	height: auto;
	border: 10px solid #EAEDF0;
	vertical-align: top;
	margin-bottom: 24px;
}

.iziModal .iziModal-content .detail p{
	font-size: 14px;
	margin-bottom: 24px;
}
.iziModal .iziModal-content .detail ul,
.iziModal .iziModal-content .detail ol{
	font-size: 14px;
	margin-bottom: 24px;
}
.iziModal .iziModal-content .detail ul li{
	list-style: disc;
	list-style-position: inside;
}
.iziModal .iziModal-content .detail ol li{
	list-style: decimal;
	list-style-position: inside;
}

.iziModal .iziModal-content dl{
	box-sizing: border-box;
	width: 100%;
	padding: 24px 24px 40px;
	background: #EAEDF0;
	border-radius: 0 0 10px 10px;
	font-size: 14px;
}
.iziModal .iziModal-content dl dt{
	float: left;
	width: 25%;
	margin-top: 16px;
}
.iziModal .iziModal-content dl dt.my-role{
	padding: 4px 0;
}
.iziModal .iziModal-content dl dd{
	float: left;
	width: 75%;
	margin-top: 16px;
}

/*----- introduction -----*/
.introduction{
	max-width: 700px;
	min-height: 420px;
	margin: 40px auto 0;
	padding: 16px 220px 0 20px;
	background: url("../images/daisuke.png") bottom right no-repeat;
	background-size: 210px 420px;
}

.introduction h1{
	margin-bottom: 8px;
	font-weight: 900;
	font-size: 48px;
	line-height: 1.0;
	letter-spacing: 2px;
}
.introduction .name{
	margin-bottom: 32px;
	font-size: 20px;
}

.introduction .description{
	font-size: 16px;
	line-height: 1.75;
}

/*----- job, seminar, book -----*/
.resume-box{
	box-sizing: border-box;
	width: 100%;
	padding: 40px 20px;
}
.resume-box.job,
.resume-box.book{
	background: #DFE4E8;
}

.resume-box a:hover{
	text-decoration: underline;
}

.resume-box article{
	max-width: 900px;
	margin:0 auto;
	padding: 0;
}

.resume-box h2{
	float: left;
	width: 180px;
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 32px;
	line-height: 1.0;
	letter-spacing: 2px;
}

.resume-box .inner{
	float: right;
	width: 600px;
}

.resume-box .date{
	font-size: 12px;
}
.resume-box h3{
	margin-bottom: 16px;
	font-size: 20px;
	font-weight: normal;
}
.resume-box .description{
	font-size: 14px;
	line-height: 1.75;
}

.resume-box .button{
	width: auto;
 margin-top: 24px;
}

.resume-box .button a{
	position: relative;
	display: inline-block;
	padding: 4px 16px 4px 32px;
	background: #586674;
	background-size: 16px;
	border-radius: 16px;
	border: none;
	color: #FFF;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 1px;
}

.resume-box .button a:hover{
 background: #7A8590;
}

.resume-box .button a:after{
	content: "";
	position: absolute;
	top: 2px;
	left: 4px;
	width: 24px;
	height: 24px;
	background: url("../images/ic-lock.svg") no-repeat center;
	background-size: 16px;
}

.resume-box .note{
	margin-top: 8px;
	font-size: 12px;
}


.resume-box .slide,
.resume-box .visual{
	margin-bottom: 24px;
}

.resume-box .last .slide,
.resume-box .last .visual{
	margin-bottom: 0;
}

.resume-box .visual img{
	width: 600px;
	height: auto;
	border-radius: 5px;
}

/*----- rakuten travel -----*/
.rt-outline{
	margin-top: 56px;
}

.rt-outline h1{
	max-width: 900px;
	margin: 0 auto 40px;
	padding: 0 20px;
	font-weight: 900;
	font-size: 40px;
	line-height: 1.0;
	letter-spacing: 1px;
}

.rt-outline img{
	width: 100%;
	height: auto;
	vertical-align: top;
}

.rt-outline .sentence,
.rt-manager .inner{
	max-width: 900px;
	padding: 40px 20px;
	margin: 0 auto;
}

.rt-outline .sentence p,
.rt-manager p{
 margin-bottom: 24px;
	font-size: 16px;
	line-height: 1.75;
}
.rt-outline .sentence p:last-child,
.rt-manager p:last-child{
	margin-bottom: 0;
}

.rt-manager{
	background: #DFE4E8;
}

.rt-subtitle{
	margin-bottom: 40px;
	font-weight: 400;
	font-size: 28px;
	line-height: 1.0;
	letter-spacing: 0;
}
.rt-manager h3{
	margin-bottom: 24px;
	font-weight: 900;
	font-size: 20px;
	line-height: 1.0;
	letter-spacing: 0;
}
.rt-manager p + h3{
	margin-top: 72px;
}

.rt-manager img{
	width: 100%;
	height: auto;
	margin-bottom: 24px;
	vertical-align: top;
}

/*----- footer -----*/
footer{
	width: 100%;
	padding: 40px 0;
	background-color: #17191E;
	color: #FFF;
}

footer .sns{
	display: flex;
	justify-content: center;
	margin-bottom: 32px;
}

footer .sns li{
	width: 30px;
	height: 30px;
	margin: 0 16px;
}

footer .sns li :hover img{
	opacity: 0.8;
}

footer .sns li span{
	display: none;
}

footer p{
	text-align: center;
	font-size: 14px;
	color: #FFF;
}