@charset "utf-8";
/* CSS Document */

a:hover{
    transition: 0.3s;
	opacity: 0.7;
}
.font_en{
	font-family: "Century Gothic", Arial, Helvetica, "sans-serif";
	font-style:italic;
}
.font_japan{
	font-family: '游ゴシック','Yu Gothic',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Arial, Verdana, "ＭＳ Ｐゴシック", sans-serif;
}
body{
	background: url(../img/webdesigner.png) no-repeat fixed;
	font-family: '游ゴシック','Yu Gothic',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Arial, Verdana, "ＭＳ Ｐゴシック", sans-serif;
}
header {
    width: auto;
    margin: 0 auto;
    margin-left: 147px;
}
main{
width: 900px;
    margin: 80px auto;
}
img{
	width: 100%;
}
p{
    line-height: 1.6;
    padding-bottom: 8px;
	word-break: break-all;
}
section{
	clear: left;
    overflow: hidden;
}
footer{
	text-align: center;
    margin: 10px auto;
    font-size: 80%;
}

/* header */
.header_img{
    width: 900px;
	margin: 0 auto;
    text-align: center;
    height: 66vh;
    align-items: center;
    display: flex;
}

/* cat_nav */
.cat_nav{
	width: 100px;
    margin: 0 auto;
    display: block;
    position: fixed;
    padding-left: 147px;
}
.cat_nav ul li{
	font-weight: 700;
}
.cat_nav ul li:before {
    content: "-";
    line-height: 1.8;
}
.cat_nav ul li a{
    text-decoration: none;
}

/* Profile */
.name{
	font-size: 200%;
    font-weight: 700;
}
.name span{
	font-size: 50%;
    font-weight: 100;
	padding-left: 20px
}
.pro_tex{
    width: 50%;
    float: left;
    font-size: 80%;
}
.pro_img{
	width: 46%;
    float: left;
    margin-left: 4%;
}

.port_list ul{
    font-size: 84%;
}
.font_large{
    margin: 120px auto 40px;
    text-align: center;
    font-size: -webkit-xxx-large;
}
.port_list ul{
	display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.port_list>ul{
    justify-content: initial;	
}
.port_list > ul > li{
	width: 23%;
	margin: 0 1%;
    padding-bottom: 40px;
}
.port_list ul li dl dd ul li{
    border: 1px solid #000000;
    padding: 2px 8px;
    margin: auto 2px;
    border-radius: 5px;
	margin-bottom: 2px;
}
.port_list ul li dl{
    display: flex;
    flex-wrap: wrap;
}
.port_list ul li dl dt{
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
    margin-top: 6px;
}
.port_list ul li dl dd:nth-child(2){
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 3;
    -webkit-order: 3;
    order: 3;
}
.port_list ul li dl dd:nth-child(3){
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 1;
    -webkit-order: 1;
    order: 1;
}
.port_list ul li dl dd:nth-child(4){
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 4;
    -webkit-order: 4;
    order: 4;
}

.work_list{
	display:block;
}
ul.work_list li dl dd a {
    display: block;
    line-height: 0;
}
ul.work_list li dl dd:nth-child(3){
	height: auto;
	width: 100%;
}
.web{
	display: block;
}


nav.port_nav ul{
	display: flex;
    justify-content: center;
    flex-wrap: wrap;
    font-weight: 700;
    margin: 40px 0;
}
.skill_box{
	margin-bottom: 40px;
}
.skill_box:last-child{
	margin-bottom: 0;
}
	
ul.soft_color {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto;
}
ul.soft_color li{color: #ffffff;padding: 6px 10px;}
ul.soft_color li:nth-child(1){border: 6px solid #1DA4D6;background: #161168;}
ul.soft_color li:nth-child(2){border: 6px solid #FF6F00;background: #432703;}
ul.soft_color li:nth-child(3){border: 6px solid #D60761;background: #4B0A0A;}
ul.soft_color li:nth-child(4){border: 6px solid #EE04A8;background: #370404;}
ul.soft_color li:nth-child(5){border: 6px solid #CC53FF;background: #4A076B;}
ul.soft_color li:nth-child(6){border: 6px solid #E6A0FB;background: #3F0572;}
ul.soft_color li:nth-child(7){border: 6px solid #55F265;background: #0B3905;}

nav.port_nav ul li{
    padding: 0 20px;
	position: relative;
}
nav.port_nav ul li a{
    text-decoration: none;
    color: #000000;
    font-weight: 700;
}
nav.port_nav ul li a:before {
    position: absolute;
    top: 0px;
    bottom: 0;
    right: 0;
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: auto;
    margin-right: 8px;
    content: '';
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 1px solid;
    border-right: 1px solid;
}
nav.port_nav ul li a:hover{
	color: #cccccc;
}

/* footer */
.footer_nav{
	background: url(../img/webdesigner.png) #E1E1E1 no-repeat fixed;
}
.footer_nav a{
	text-decoration: none;
}
.footer_nav ul li{
	line-height: 1.8;
	cursor:pointer;
}
.footer_nav > ul{
    width: 900px;
	margin: 0 auto;
	padding: 60px 0;
}
.footer_nav > ul > li:nth-child(1){
	font-size: 120%;
	padding-bottom: 30px;
}
.footer_nav > ul > li{
	font-weight: 700;
}
.footer_nav > ul > li:nth-child(5){
	font-weight: 100;
}
.footer_nav ul li ul li:before{
	content: "-";
}
.footer_nav ul li ul li a{
	text-decoration: none;
}

/* template */
.tmp_head{
    text-align: left;
    font-size: 500%;
    display: grid;
    align-items: initial;
    height: auto;
	width: 100%;
    margin: 40px auto;
}
.tmp_head img{
	width:400px;
}

/* contents */
.port_main_img{
	height: 480px;
	width: auto;
	display: table;
    margin: 0 auto;
}
.port_main_img img{
	height: 480px;
    width: auto;
}
hr{
	margin: 40px auto;
}
.contents{
    width: 900px;
	margin: 0 auto;
}
.left_contents h2{
	font-size: 120%;
    line-height: 1.4;
	margin-bottom: 10px;
}
.left_contents p{
	margin-bottom: 40px;
}
.left_contents{
	width: 100%;
	margin-bottom: 100px;
}
.right_contents{
	width: 700px;
	margin: 0 auto;
}
.right_contents img{
	width: 100%;	
}
.img_contents{
	padding-bottom: 10px;	
}
.img_contents:last-child{
    padding-bottom: 0;
}
.page_nav{
}
.page_nav ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
	margin-bottom: 20px;
}
.page_nav ul li{
    width: 48%;
}
.page_nav a{
	border: 1px solid;
    padding: 10px;
    margin: 0 auto;
    display: block;
    text-align: center;
    text-decoration: none;
    border-radius: 25px;
	position: relative;
}
.page_nav ul li a:after {
	position: absolute;
	font-family: 'Font Awesome 5 Free';
	content: '\f35d';
	font-size: 0.9em;
	margin: 0px 3px;
	font-weight: 900;
	right: 14px;
    top: 14px;
    bottom: 0;
}

/* */
.breadcrumbs{
    width: 900px;
    margin: 0 auto;
    margin-bottom: 20px;
}
.breadcrumbs ul li{
    display: inline;
}
.breadcrumbs li:after {
    content: '〉';
    padding: 0 3px;
/*    color: #ffffff;*/
}
.breadcrumbs li:last-child:after{
    content: '';
	display: block;
}
@media screen and (max-width: 1400px){

.port_main_img {
    display: block;
    width: 100%;
    height: auto;
}
.port_main_img img{
    width: 100%;
    height: auto;
}
}

@media screen and (max-width: 1330px){
.cat_nav {
    display: none;
}
}
@media screen and (max-width: 1200px){
.header_img {
    width: auto;
}
main {
	width: auto;
    margin: 80px auto;
    margin-left: 147px;
}
.port_main_img {
    display: block;
    width: 100%;
    height: auto;
}
.port_main_img img{
    width: 100%;
    height: auto;
}
.breadcrumbs{
    width: 100%;
    margin: 0 auto;
	margin-bottom: 20px;
}
.contents{
    width: 100%;
    margin: 0 auto;
    margin-bottom: 100px;
}
.footer_nav > ul{
    width: auto;
	margin-left: 147px;
}
}
@media screen and (max-width: 900px){
.footer_nav > ul ,main {
    width: 92%;
	margin: 0 auto;
}
.footer_nav {
    background-image: none;
}
.port_main_img {
    width: 100%;
}
.cat_nav {
    display: none;
}
body{
    background: none;
}
header {
    width: 92%;
	margin: 0 auto;
}
}
@media screen and (max-width: 768px){
	body {
    background: none;
	}
	main{
    width: 100%;
    margin: 40px auto;
    box-sizing: border-box;
	}
	.inner{
    width: 92%;
    padding: 0 4%;
	}
header {
    width: 92%;
    margin: 0 auto;
}
.font_large {
    margin: 80px auto 40px;
}
ul.soft_color li{margin-bottom: 10px;}
ul.work_list li dl dd:nth-child(3){
	height: auto;
}
nav.port_nav ul li{
    padding: 0 15px;
}
/**/
.pro_tex ,.pro_img{
    width: 100%;
    float: none;
    margin: 0 auto;
}

/* works */
.port_list > ul > li {
    width: 44%;
    padding: 0 3% 40px;
    margin: 0 auto;
}
	
.cat_nav {
    width: 100%;
    background: #000000;
    color: #ffffff;
    bottom: 0;
	padding: 0;
	display: block;
	z-index: 100;
}
.cat_nav ul{
    display: flex;
    justify-content: space-between;
    font-style: normal;
}
.cat_nav ul li{	
   padding: 10px;
}
.cat_nav ul li a{
	color:#ffffff;
}
.cat_nav ul li:before{
content:none;
}

.port_main_img {
	height: auto;
}
.port_main_img img{
	height: auto;
	width: 100%;
}
footer{
	margin-bottom: 48px;
}
.footer_nav {
    background-position: right;
    background-size: 14%;
}
.footer_nav > ul {
    width: 92%;
    padding: 60px 4%;
}
.contents{
    display: block;
}
.contents img{
	width: 100%;
}
.left_contents ,.right_contents{
	width: 92%;
	padding: 0 4%;
	}
.left_contents{
	margin-bottom: 20px;
}
.right_contents{
	width: 92%;
}
.page_nav{
	display: block;
}
.page_nav ul li{
	width: 100%;
}
.page_nav ul li:first-child{
	margin-bottom: 10px;
}
.breadcrumbs{
    width: 92%;
    margin: 0 auto;
	margin-bottom: 20px;
}
}

video {
    width: 400px;
}
@media screen and (max-width: 768px){
.tmp_head{
    line-height: 1;
    width: 60%;
    margin: 20px auto 0 0;
    display: block;
    font-size: 300%;
	padding-left: 0;
}
.tmp_head img{
	width:100%;
}
video {
    width: 100%;
}
}

/* works */
.works_nav{
	width: 900px;
	margin: 0 auto;	
}
.works_nav ul{
    display: flex;
	justify-content: initial;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.works_nav ul li{
    margin-right: 10px;
}
.works_nav ul li a{
	position: relative;
    border: 1px solid;
    padding: 10px;
    margin: 0 auto;
    display: block;
    text-align: center;
    text-decoration: none;
    border-radius: 25px;
    width: 160px;
	font-weight: 700;
}
.works_nav ul li a::before{
    position: absolute;
    top: 0px;
    bottom: 0;
    left: 16px;
    display: inline-block;
	width: 6px;
    height: 6px;
    margin: auto;
    margin-right: 8px;
    content: '';
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    border-right: 1px solid;
    border-bottom: 1px solid;
}
.works_h2{
    border-bottom: 1px solid;
    padding-bottom: 10px;
    margin-bottom: 20px;
    margin-top: 40px;
}
.works_h2:first-child{
	margin-top: 0;
}
.works_contents{
    width: 900px;
    margin: 0 auto;
}

@media screen and (max-width: 1200px){
.works_nav {
    width: 100%;
}
.works_contents {
    width: 92%;
}
}
@media screen and (max-width: 900px){
.works_contents{
    width: 92%;
    margin: 0 auto;
}
}
@media screen and (max-width: 768px){
.works_nav ul {
    justify-content: space-evenly;
}
.works_nav ul li {
    padding-bottom: 10px;
	margin-right:0;
    width: 46%;
}
.works_nav ul li a{
	width: auto;
	}
.works_nav ul li:nth-child(3),.works_nav ul li:nth-child(4){
	padding-bottom: 0;
}
}

/* pagetop */
#page-top {
    position: fixed;
    right: 10px;
    bottom: 100px;
    z-index: 100;
}
#page-top a {
    display: block;
    padding: 10px;
    text-align: center;
    color: #000;
	border: 1px solid;
    background-color: rgba(255,255,255,.5);
    text-decoration: none;
    -moz-border-radius: 60px;
    -webkit-border-radius: 60px;
    border-radius: 60px;
    font-size: 78%;
    -webkit-transition: all .2s cubic-bezier(.645,.045,.355,1);
    transition: all .2s cubic-bezier(.645,.045,.355,1);
}

.iframe_contents{
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow:auto; 
  -webkit-overflow-scrolling:touch;
  border:2px solid #ccc; 
}
.iframe_contents iframe{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    border:none;
    display:block;
}

p.supplement{
	font-size: 80%;
}
.works_more{
	
}
.works_more a{
	position: relative;
    border: 1px solid;
    padding: 10px;
    margin: 0 auto;
    display: block;
    text-align: center;
    text-decoration: none;
    border-radius: 25px;
    width: 160px;
    font-weight: 700;
}
.works_more a::before {
    position: absolute;
    top: 0px;
    bottom: 0;
    right: 16px;
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: auto;
    margin-right: 8px;
    content: '';
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 1px solid;
    border-right: 1px solid;
}

/* aside */
aside{
    width: 900px;
    margin: 0 auto 80px;
}
aside h4{
	width: 700px;
    margin: 0 auto;
    border-bottom: 1px solid;
    margin-bottom: 10px;
}
aside a{
	display: -webkit-inline-box;
    text-decoration: none;
    border: 1px solid;
    padding: 10px;
}
aside > ul{
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 700px;
    margin: 0 auto;
}
aside > ul > li{
    position: relative;
    width: 46%;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
	font-size: 80%;
}
aside > ul > li div{
	width: 32%;
    line-height: 0;
}
aside ul li dl{
	flex-wrap: wrap;
    display: flex;
    width: 62%;
    margin-left: 10px;
}
aside ul li dl dd ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
aside ul li dl dd ul li{
    border: 1px solid;
    border-radius: 5px;
    margin-right: 2px;
    padding: 0 2px;
}
aside > ul > li a:before {
    position: absolute;
    top: 0px;
    bottom: 0;
    right: 0;
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: auto;
    margin-right: 8px;
    content: '';
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 1px solid;
    border-right: 1px solid;
}
aside > ul > li a:hover:before{
	opacity: 0.7;
}
@media screen and (max-width: 1200px){
aside {
    width: auto;
    margin-left: 147px;
}
}
@media screen and (max-width: 900px){
aside{
	margin: 0 auto 80px;
}
}
@media screen and (max-width: 768px){
aside {
    width: 92%;
	margin: 0 auto 80px;
}
aside h4 {
    width: 100%;
}
aside > ul,aside > ul > li {
    width: 100%;
}
aside > ul, aside > ul > li {
    margin-bottom: 10px;
}
aside > ul, aside > ul > li:last-child{
    margin-bottom: 0;
}	
}