@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: 'Source Sans Pro', 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: 'Source Sans Pro', sans-serif;
	line-height: 1.5;
}

em{
	font-style: normal;
}

br.for-PC{
	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;
}

/*----- header -----*/
header{
	margin: 0 16px;
	padding-top: 24px;
}
header nav .global-nav{
	display: flex;
	justify-content: flex-end;
}

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

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

/*----- greeting -----*/
.greeting{
	min-height: 240px;
	margin: 0 16px 24px 0;
	padding: 40px 0 24px 24px;
	background: url("../images/signature.svg") no-repeat bottom right;
	background-size: 120%;
}

.greeting h1{
	display: inline-block;
	height: 46px;
	margin-bottom: 16px;
	padding-right: 40px;
	font-weight: 900;
	font-size: 40px;
	line-height: 1.25;
	letter-spacing: 1px;
	background: url("../images/daichan.svg") no-repeat right top;
	background-size: 33.3px 45.3px;
}

.greeting p{
	font-weight: 400;
	font-size: 16px;
	letter-spacing: 1px;
}

/*----- works-list -----*/
.works-list{
	margin: 40px 16px 0;
}

.works-list .card{
	margin-bottom: 40px;
}

.works-list .card .visual{
	display: flex;
 justify-content: center;
 align-items: center;
	padding: 0 24px;
	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: 242px;}
.works-list .card .visual.large { height: 400px;}

.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:72%; 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: 1px;
}
.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: 12px;
	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: 2;
	top: 24px;
	right: 8px;
	width: 40px;
	height: 40px;
 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{
	width: 90%;
}

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

.iziModal .iziModal-content .detail{
	padding: 25px 16px 8px;
}

.iziModal .iziModal-content .detail .modal-title{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 24px;
	line-height: 1.25;
	letter-spacing: 0;
}
.iziModal .iziModal-content .detail .modal-subtitle{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 20px;
	line-height: 1.25;
	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;
	line-height: 1.75;
}

.iziModal .iziModal-content .detail ul{
	font-size: 14px;
	margin-bottom: 24px;
	line-height: 1.75;
}
.iziModal .iziModal-content .detail li{
	list-style: disc;
	list-style-position: inside;
}

.iziModal .iziModal-content dl{
	box-sizing: border-box;
	width: 100%;
	padding: 16px 16px 24px;
	background: #EAEDF0;
	border-radius: 0 0 10px 10px;
	font-size: 14px;
}
.iziModal .iziModal-content dl dt{
	margin-top: 16px;
}

.iziModal .iziModal-content dl dd{
	margin-top: 4px;
	padding-left: 1em;
}

/*----- introduction -----*/
.introduction{
	position: relative;
	margin-left: 16px;
	padding: 40px 140px 0 0;
	background: url("../images/daisuke.png") bottom right no-repeat;
	background-size: 140px 280px;
}

.introduction h1{
	width: 304px;
	margin-bottom: 4px;
	font-weight: 900;
	font-size: 32px;
	line-height: 1.0;
	letter-spacing: 1px;
}
.introduction .name{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 16px;
}

.introduction .description{
	padding-bottom: 16px;
	font-size: 14px;
}

/*----- 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{
	margin:0 auto;
	padding: 0;
}

.resume-box h2{
	margin-bottom: 16px;
	font-weight: 900;
	font-size: 24px;
	line-height: 1.0;
	letter-spacing: 1px;
}

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

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

.resume-box .button a{
	position: relative;
	display: inline-block;
	padding: 8px 24px 8px 32px;
	background: #586674;
	background-size: 16px;
	border-radius: 24px;
	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: 6px;
	left: 6px;
	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: 16px;
}

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

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

/*----- rakuten travel -----*/
.rt-outline{
	width: 100%;
	margin-top: 40px;
	overflow: hidden;
}

.rt-outline h1{
	margin: 0 16px 24px;
	font-weight: 900;
	font-size: 24px;
	line-height: 1.0;
	letter-spacing: 1px;
}

.rt-outline img{
	width: 150%;
	height: auto;
	max-height: 320px;
	margin-left: -25%;
	vertical-align: top;
}

.rt-outline .sentence{
	padding: 24px 16px 40px;
	margin: 0 auto;
}

.rt-manager .inner{
	padding: 40px 16px;
	margin: 0 auto;
}

.rt-outline .sentence p,
.rt-manager p{
 margin-bottom: 16px;
	font-size: 14px;
	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: 24px;
	line-height: 1.0;
	letter-spacing: 0;
}
.rt-manager h3{
	margin-bottom: 16px;
	padding-left: 1em;
	text-indent: -1em;
	font-weight: 900;
	font-size: 18px;
	line-height: 1.25;
	letter-spacing: 0;
}
.rt-manager p + h3{
	margin-top: 64px;
}

.rt-manager img{
	width: 100%;
	height: auto;
	margin-bottom: 16px;
	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: 24px;
	height: 24px;
	margin: 0 8px;
}

footer .sns li img{
	width: 24px;
	height: 24px;
}
footer .sns li :hover img{
	opacity: 0.8;
}

footer .sns li span{
	display: none;
}

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