@charset "UTF-8";
/* CSS Document */

/* -------------------------------------------- リセット -------------------------------------------- */

/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

body {
    line-height:1;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}

nav ul {
    list-style:none;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000;
    font-style:italic;
    font-weight:700;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;  
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}



body {
    font-family: "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
	color: black;
	font-size:14.5px;
	margin: 0;
}


/* ------------------------------ グローバルナビ -----------------------------  */
.globalbody {
    color: #910013;
    font-family: "Futura","游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    padding: 0;
    margin:0;
    position: relative;
    height:100px;
}
@media screen and (max-width:770px) {
	.globalbody { margin-top: 8px; margin-bottom:5px; }
} 

.logo {
    width:120px;
    height:auto;
    position: fixed;
    left:25px;
    top:25px;
}
@media screen and (max-width:770px) {
	.logo { width:80px; }
} 

/* -------- navi（hamburger） --------  */

#nav-drawer {
  position: fixed;
  right:35px;
  top:25px;
  z-index:99;
}
  
.nav-unshown {
  display:none;
}
  
#nav-open {
  display: inline-block;
  width: 30px;
  height: 22px;
  vertical-align: middle;
}
@media screen and (max-width:770px) {
	#nav-open { width:20px; }
} 
  
/*hamburger*/
#nav-open span, #nav-open span:before, #nav-open span:after {
    position: absolute;
    height:6.5px;
    width: 40px;
    border-radius: 2px;
    background: #910013;
    display: block;
    content: '';
    cursor: pointer;
    z-index: 999999999999;
    transition: all .4s;
}
@media screen and (max-width:770px) {
    #nav-open span, #nav-open span:before, #nav-open span:after { height: 5.5px; width: 35px; }
} 
  
#nav-open span:before {
    bottom: -15px;
}
@media screen and (max-width:770px) {
	#nav-open span:before { bottom: -13px; }
} 

#nav-open span:after {
    bottom: -30px;
}
@media screen and (max-width:770px) {
	#nav-open span:after { bottom: -27px; }
} 
  
/*click*/
#nav-open.active span {
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(20px) rotate(-45deg);
    bottom: 30px;
}
#nav-open.active span:before {
    opacity: 0;
}
#nav-open.active span:after {
    -webkit-transform: translateY(-20px) rotate(90deg);
    transform: translateY(-20px) rotate(90deg);
}
  
/*cover*/
#nav-close {
  display: none;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: .3s ease-in-out;
}
  
/*naka*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 999999;
  width: 100%;
  max-width: 400px;
  height: 100%;
  background: linear-gradient(white 100%, white 0%);
  transition: .3s ease-in-out;
  -webkit-transform: translateX(200%);
  transform: translateX(105%);
  list-style: none;
  overflow:hidden;
  overflow: scroll;
}
@media screen and (max-width:770px) {
	#nav-content { max-width:250px; }
} 
  
#nav-content ul li {
    list-style-type:none; 
    background-image:none; 
    text-align:center;
}
  
#nav-input:checked ~ #nav-close {
  display: block;
  opacity: .5;
}
  
#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
  box-shadow: 6px 0 25px rgba(0,0,0,.15);
}
  
/*link*/
.link-g {
    text-decoration: none;
    display:block;
    text-align: center;
    color: white;
    font-size:25px;
    letter-spacing:4px;
    font-weight:bold;
    line-height:70px;
    margin-right:50px;
}
@media screen and (max-width:770px) {
	.link-g span { font-size:17px; letter-spacing:1.5px; }
} 
.link-g:hover {
    text-decoration: none;
}
.link-g:link {
    color: #910013; 
}
.link-g:visited {
    color:  #910013;
}
.link-g:hover { 
    color:  #6b0116;
}
.link-g:active {
    color:  #910013;
}



 
/* -------------------------------------------- ポートフォリオ ----------------------------------------------------------------------- */ 
  
html:before,
html:after,
body:before {
    content:"";
    position:fixed;
    z-index:-1;
    top:0;
    left:0;
    right:0;
    bottom:0;
    border:10px solid #910013;
}
 
html:after {
    z-index:10;
    top:auto;
    border-width:0 0 10px;
}
 
body:before {
    z-index:10;
    bottom:auto;
    border-width:10px 0 0;
}

/* ---- 基本　&　共通 ---- */ 
.topbody {
    margin:0;
    color:#910013;
    height:100%;
	font-family: "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    text-align: center;
}
@media screen and (max-width:770px) {
	.topbody { background-attachment: scroll; background-repeat: repeat;  background-size: 150%; }
}


.foo.delighter {
    transition: all .3s ease-in-out;
    transform: translateY(60%);
    opacity: 0;
}
@media screen and (max-width:770px) {
	.foo.delighter { transform: translateY(5%); }
}
 .foo.delighter.started {
    transform: none;
    opacity: 1;
}



/* ---- 文字 ---- */ 

.moji-1 {
    font-family:"游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #910013;
    font-size:25px;
    font-weight: bold;
    text-align: justify;
    letter-spacing: 2px;
    margin: 0 auto;
    margin-top:100px;
    line-height:37px;
    width:80%;
}
@media screen and (max-width:770px) {
	.moji-1 { width:100%; font-size:23px; letter-spacing:0px; margin-top:50px; }
} 

.moji-2 {
    font-family:"游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #910013;
    font-size:15px;
    text-align: justify;
    line-height: 25px;
    margin: 0 auto;
    margin-top:50px;
    margin-bottom:60px;
    width:80%;
}
@media screen and (max-width:770px) {
	.moji-2 { width:100%; }
} 

.moji-3 {
    font-family:"游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #910013;
    font-size:13px;
    text-align: justify;
    line-height: 25px;
    margin-top:0px;
    margin-left:10%;
}

.moji-4 {
    font-family:"游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS Pゴシック", "MS PGothic", sans-serif;
    color: #910013;
    font-size:13px;
    text-align: justify;
    line-height: 25px;
    margin: 0 auto;
    margin-top:50px;
    width:80%;
}
@media screen and (max-width:770px) {
	.moji-4 { width:100%; }
} 


/* ---- 画像 ---- */ 
.img-1 {
    width:90%;
    max-width:1200px;
    margin-top:30px;
    margin-bottom:10px;
}
@media screen and (max-width:770px) {
	.img-1 { width:100%; max-width:100%; }
} 

.img-icon {
    width:15px;
    margin-left:7px;
}

.img-2 {
    width:80%;
    margin-top:10px;
    margin-bottom:20px;
}
@media screen and (max-width:770px) {
	.img-2 { width:100%; }
} 

/* ---- ならび ---- */ 
.narabi-1 {
    width:100%;
    max-width:1200px;
    text-align: center;
    margin:0 auto;
    margin-top:0px;
    margin-bottom:100px;
}
@media screen and (max-width:770px) {
	.narabi-1 { width:85%; max-width:85%; margin-top:0px; }
} 


/* ---- リンク ---- */ 

.link-1-p {
    text-align: left;
    color:#910013;
    margin: 0 auto;
    margin-top:30px;
    margin-bottom:50px;
    font-size :17px;
    font-weight: bold;
    width:80%;
}
@media screen and (max-width:770px) {
	.link-1-p { width:100%; }
} 


.link-1 {
    text-decoration: none;
    color:#910013;
}
.link-1:hover {
    color:#6b0116;
}
.link-1 {
    text-decoration: none;
    color:#910013;
}

.link-2 {
    text-decoration: none;
    color:#910013;
    font-weight:bold;
    display: inline-block;
    margin-right:20px;
}
.link-2:hover {
    color:#6b0116;
}

.link-3 {
    text-decoration: none;
    color:#910013;
    font-weight:bold;
    display: inline-block;
    margin-left:20px;
}
.link-3:hover {
    color:#6b0116;
}


/* ------------------------------ フッター -----------------------------  */

.footer-c {
	font-size: 10px;
	margin-top: 150px;
    margin-bottom:20px;
    color: #910013;
}


