@charset "UTF-8";

/* ========================================
    リセットcss
========================================= */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style:normal;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}
html{overflow-y: scroll;}
blockquote, q {quotes: none;}
blockquote:before, blockquote:after,q:before, q:after {content: ''; content: none;}
input, textarea{margin: 0; padding: 0;}
ol, ul{list-style:none;}
table{border-collapse: collapse; border-spacing:0;}
caption, th{text-align: left;}
a:focus {outline:none;}

/* micro clearfix */
.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {clear: both;}
.cf {*zoom: 1;}


/* ========================================
    全体
========================================= */

 .me {
  border-radius: 50%;  /* 角丸半径を50%にする(=円形にする) */
    width: 160px;       /* ※縦横を同値に */
    height: 160px;       /* ※縦横を同値に */
    opacity: 0.8;
}

.js_logo {
    width: 100px;
    height: 100px;
    border-radius: 20px;
/*    background-color: red;*/
  }


/*------------------*/


body {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  width: 960px;
  height: auto;
  margin: 0 auto;
}


#welcom {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  height: 550px;
  font-size: 90px;
  text-align: center;
  color: #696969;

  margin-bottom: 30px;
}
/*------------------*/
  div#main {
    position: relative;
  /* opacity: 0.8; */
  max-width: 960px;
  margin: 0 auto;
}

div p.portfolio {
  display: none;
  font-family: 'Lato', sans-serif;
  font-weight: 500;
  position: absolute;
  top: 900px;
  left: 300px;
  font-size: 90px;
  color: white;
}





.logo-top {
  width: 960px;
  margin-top: 50px;
}
a.sns {
  transition: opacity 0.5s ease-out;
}
a.sns:hover {
  opacity: 0.3;
}
a.nav{
  position: relative;
  display: inline-block;
  text-decoration: none;
  color: #333333;
  text-decoration: none;

}

a.nav:visited {
  color: #333333;
  text-decoration: none;
}

a.nav::after {
  position: absolute;
  bottom: -7px;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background: #333;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .3s;
}
a.nav:hover::after {
  transform: scale(1, 1);
}

header {
  width: 960px;
  height: 210px;
  margin: 0 auto;
}

.logo {
  float: left;
}

img.twitter {
  width: 22px;
  height: 22px;
  margin:0 0 0 15px;

}

img.facebook {
  width: 22px;
  height: 22px;
  margin:0 0 0 15px;
}

.SNS {
  float: right;
  margin-top: 10px;
  margin-bottom: 30px;

}

.clear {
  clear: both;
}

.grobal-nav {
  font-size: 15px;
  float: right;
  margin-top: 40px
}

.grobal-nav li {
  letter-spacing: 0.1em;
  float: left;
  margin: 0 0 0 40px ;
  list-style: none;
  color: #3b3b3b;
}

.mainimage {
  width: 960px;
  height: auto;


}


section h2, div h2{
  font-family: 'Lato', sans-serif;
  font-size: 46px;
  font-weight: lighter;
  color: #333333;
  margin-bottom: 40px;
  line-height: 1.0;
  letter-spacing: 0.05em;

}


section#skill h2 {
  padding-bottom: 50px;

}

div#about {
  transform: translateY(70px);
  opacity:0;
  width: 960px;
  margin: 0 auto;
  transition: opacity 1s,transform 2s ;
}
.about_content {
  margin-left: 140px;
}


.fadein{
  transform: translateY(0px) !important;
  opacity:1 !important;
}

p {
  display: block;
  font-weight: 200;
  line-height: 27px;
  font-size: 15px;
  /* font-family: helevetica; */



}

.textbox {
  margin-bottom: 50px;


}

.profimg {
  margin-right: 50px;
  float: left;

}

.prof {
  float: left;

}

.profme {
  width: 960px;

}

.skill {
  transform: translateY(70px);
  opacity:0;
  width: 960px;
  margin: 0 auto;
  transition: opacity 1s,transform 2s ;
  margin: 0 auto;
  width: 960px;
  clear: both;

}

dt {
  float: left;
  width: 200px;
  font-weight: bold;


}

dd.dd_prf{
  width: 600px;
}

h2 {
  margin-top: 50px;
  margin-bottom: 50px;
}

dd p a {
  color: #68b0ab;
  text-decoration: none;
}
dd p a:visited{
  color:#68b0ab;
}

.img1_footer a {
  color: #68b0ab;
  text-decoration: none;
}

.img1_footer a:visited{
  color: #68b0ab;
  text-decoration: none;
}



/* ========================================
    skill
========================================= */

div#clear {
  clear: both;
}


div#skill_wrapper ul li {
  width: 250px;
  height: 120px;
  float: left;
  margin: 20px 10px 50px 10px;
  padding-left: 50px;
}
.skill_img {
  width: 90px;
  padding: 15px 10px;
  opacity: 0.6;
}



/* ========================================
    work
========================================= */
#work {
  transform: translateY(70px);
  opacity:0;
  width: 960px;
  transition: opacity 1s,transform 2s ;
  /* background-color: lightgreen; */
}

.work_skill {
  width: 30px;
  margin-right: 8px;
  margin-bottom: 8px;
  opacity: 0.6;
}



.work_skill:last-child {
  margin-right: 0;
}

section#work ul li img.work_img {
  width: 275px;
  height: auto;
  /* margin: 0 25px 60px 0 ; */
  border: 1px solid #DDDDDD;
  padding: 5px 5px;
}
.work_ul {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;  
} 

.work_li {
  width: 290px;
  height: 420px;
  margin-bottom: 70px;
  margin-top: 30px;

}

.img1_footer {
  margin-top: 93px;

}

.img2_footer {
  margin-top: 65px;
}

.img55 {
  margin-bottom: 6px;
}

.img7,.img8,.img9 {
  margin-top: 100px;
}

.dd_title {
  font-weight: 800;
  margin-top: 16px;
  padding-bottom: 5px;
  width: 70%;
  font-size: px;
  border-bottom: 1px dotted #DDD;
}
.dd_sub {
  font-size: 12px;
  margin-bottom: 20px;
  margin-top: 10px;
}

#dd_sub2{
  font-size: 12px;
  margin-top: 0;
}


/* ========================================
お問い合わせ
========================================= */

section.contact {
  width: 960px;
}
.contact_content {
  width: 100%;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.contact_title {
  margin-right: 10px;
}
.contact_mail {
  color: #d54062;
}
.contact_mail:visited {
  color: #d54062;
}


/* ========================================
フッター
========================================= */

footer {
  color: #3b3b3b;
  width: 100%;
  margin-bottom: 5px;
  padding-top: 90px;
  text-align: center;
}

/* footer p {
  line-height: 120px;

} */


#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 77%;
}
#page-top a {
  background: #666;
  text-decoration: none;
  color: #fff;
  width: 100px;
  padding: 30px 0;
  text-align: center;
  display: block;
  border-radius: 5px;
}
#page-top a:hover {
  text-decoration: none;
  background: #999;
}

#graydisplay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  /* max-width: 100%!important; */
  height: 100%;
  background: rgba(0,0,0,0.6);
}
#graydisplay img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  max-width: 95%;
  max-height: 95%;
  height: 95%;
}