/*! HTML5 Boilerplate v5.0 | MIT License | http://h5bp.com/ */

html {
    color: #333333;
    font-size: 16px;
    line-height: 1.8em;
}

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: vertical;
}

.browserupgrade {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}


/* ==========================================================================
   Author's custom styles
   ========================================================================== */


/* Base --------------------------------------------------------------------- */


body {
	font-family: 'Noto Sans Japanese', "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

h1, h2 {
	padding: 0;
	margin: 0;
}

ul, li {
	padding: 0;
	margin: 0;
	list-style: none;
}

p {
	margin: 50px 100px;
}

a {
	color: #09F;
}

a:hover {
	text-decoration: none;
}


header {
	text-align: center;
}

header img {
	width: 100%;
	height: auto;
}

.wrap {
	background: #FFFFFF;
	width: 900px;
	margin: 0 auto;
}

.wrap h2 img {
	margin-bottom: 20px;
}

.block {
	background: #FFFFFF;
	width: 800px;
	margin: 0 auto;
	padding-bottom: 10px;
}



footer {
	clear: both;
	background: #111111;
	padding: 10px 0 5px;
	text-align: center;
	color: #FFFFFF;
	font-size: 60%;
	line-height: 2.0em;
}

footer a {
	color: #FFFFFF;
}

address {
	font-style: normal;
	color: #555555;
}






/* Unique ------------------------------------------------------------------- */

.cd_obi {
	background:#000;
	padding:15px 0;
	text-align:center;
	color:#fff;}
.cd_obi p {
    margin: 0 auto 15px;
    font-size: 150%;
}

.cdarea {
    font-family: 'Century Gothic';
    background-image: linear-gradient(to right, #454545 0%, #040404 100%);
    background-color: #000;
    padding: 20px 0 15px;
    text-align: center;
    color: yellow;
    font-weight: normal;
    font-size: 160%;
    position: relative;
    z-index: 0;
    width: 750px;
    border-radius: 15px;
    margin: 0 auto;
}

.cdarea span {
	margin: 0 0 0 10px;
	font-size: 200%;
	vertical-align: -35%;
	color:yellow;
}

.letter {
	background: url(../img/bg_letter.jpg) top center no-repeat;
	background-attachment: fixed;
	text-align: center;
	padding: 50px 0;
}

.priv {
	background: url(../img/bg_priv.jpg) top center no-repeat;
	background-attachment: fixed;
	background-size: cover;
	padding: 50px 0;
}


.cv {
	background: url(../img/bg_cv.jpg) top center no-repeat;
	background-attachment: fixed;
	padding: 70px 0;
}

.cv .wrap p {
    color: #fff;
    text-shadow: 1px 1px 1px #000;
    font-size: 90%;
    line-height: 1.5em;
}


a.cvbtn {
	display: block;
	background: url(../img/btn.png) top center no-repeat;
	background-size: 100%;
	width: 800px;
	height: 160px;
	padding: 0;
	margin: 50px 50px 0;
	border: none;
}


.mv {
	background: url(../img/bg_mv.jpg) top center no-repeat;
	background-attachment: fixed;
	padding: 50px 0;
}


.text {
	background: url(../img/bg_text.jpg) top center no-repeat;
	background-attachment: fixed;
	padding: 50px 0;
}

.text .wrap {
	padding: 50px 0;
}




.voice_box {
	border: 5px solid #a99826;
	background:rgba(0,0,0,0.75);
	padding:0 50px 50px 50px;
	height: 500px;
    overflow-y: scroll;
}

.voice_txt {
	background:rgba(255,255,255,1);
	color:#000;
	padding: 10px 0;
}

.voice_txt p {
	margin:30px 50px;
}



.prof {
    border: 2px dotted #fff;
	padding:5%;
	background:rgba(0,0,0,0.3)
}

.prof p {
    margin:30px 50px;
}

.let_sdw {
    margin: 0 auto;
    box-shadow: 0px 0px 5px #464646;
}

.img_right {
	width:300px;
	float:right;
	margin:0 50px 50px 20px;
}

/* bg ---------------------------------------------------------------------- */

.bg_voice {
    background: url(../img/bg_voice.jpg);
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
    padding: 50px 0;	
}

.bg_bene {
    background: url(../img/bg_bene.jpg);
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
    padding: 50px 0;	
}

.bg_ebi {
    background: url(../img/bg_ebi.jpg);
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-size: cover;
    padding: 50px 0;	
}

.bg_prof {
    background: url(../img/bg_prof.jpg)no-repeat center top fixed;
    background-size: cover;
    padding: 5em 38% 5em 5%;
	color:#fff;
}

.bg_voice .wrap,
.bg_bene .wrap,
.bg_prof .wrap,
.bg_ebi .wrap {
    background:none;	
}

.cv2 {
	background: url(../img/bg_cv2.jpg) top center no-repeat;
	background-attachment: fixed;
	padding: 70px 0;
}

.cv2 .wrap p {
    color: #fff;
    text-shadow: 1px 1px 1px #000;
    font-size: 90%;
    line-height: 1.5em;
}


/* Sub ---------------------------------------------------------------------- */

.sub .wrap {
	padding: 70px 0 20px;
	margin: 50px auto;
	font-size: 90%;
}

.sub h1 {
	text-align: center;
}

.sub h2 {
	margin: 50px 100px -30px;
}

.sub p {
	margin: 50px 100px;
}

.sub table {
	width: 700px;
	margin: 50px 100px;
}

.sub table th {
	width: 24%;
	padding: 3% 0;
	border-bottom: solid 1px #DDDDDD;
}

.sub table td {
	width: 68%;
	padding: 3% 4%;
	border-bottom: solid 1px #DDDDDD;
}



/* General Purpose ---------------------------------------------------------- */

.bgw {
	background: rgba(255,255,255,0.8) !important;
}

.bgnone {
	background-color: transparent !important;
}

.center {
	text-align: center !important;
}

.bold {
	font-weight: bold !important;
}

.bgyellow {
	background: #FF0 !important;
}

.underline {
	text-decoration: underline !important;
}

.strikeline {
	text-decoration: line-through !important;
}

.red {
	color: #F00 !important;
}

.fsS {
	font-size: 80% !important;
}

.fsM {
	font-size: 150% !important;
	line-height: 1.8em !important;
}

.fsL {
	font-size: 200% !important;
	line-height: 1.8em !important;
}

.mb {
	margin-bottom: 50px !important;
}


.pc {
	display: inline;
}

.sp {
	display: none;
}

/* jump ------------------------------------------------------------------- */
  #jump_btn {
    padding: 0;
    width: 180px;
    position: fixed;
    right: 20px;
    bottom: 20px;
  }
  #jump_btn i {
    margin-right: 10px;
    font-size: 30px;
    font-size: 3rem;
  }
  #jump_btn a {
    padding: 10px 0;
    display: block;
    background-color: #1ca800;
    background-size: 100%;
    background-image: linear-gradient(to bottom, #1ca800 0%, #0b8e14 100%);
    width: 100%;
    text-align: center;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-size: 1.2rem;
    box-shadow: 0 8px 0 #176802;
    line-height: 1.4;
    font-weight: 800;
    letter-spacing: -0.1em;
    text-shadow: 0px 1px 0px #333;
    transition: all .3s ease;
    cursor: pointer;
  }
  #jump_btn a:hover {
    box-shadow: none;
    transform: translate3d(0, 8px, 0);
  }
  #jump_btn a span {
    font-weight: bold;
    color: #fff !important;
  }

	/* modal ----------------------------------------------------------------- */

  .modal_bg {
	  width:750px;
	  height:523px;
	  background:url(../img/modal.jpg);
	  background-size:cover;
	  position:relative;
	  margin-bottom:3px;}
	  
  .modal_btn {
	  position:absolute;
	  top:387px;
	  left:125px;}

	
  #modal-close {
    padding: 10px;
    font-size: 20px;
    font-size: 2rem;
    text-align: center;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    background: #666;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    position: absolute;
    left: 43%;
    bottom: 0;
    z-index: 1;
	font-weight: normal;
  }

  #modal-open {
    margin-bottom: 0;
    top: 10px;
    display: block;
    width: 100%;
    height: 20px;
    position: fixed;
    position: expression('absolute');
    top: expression(documentElement.scrollTop + 10 + 'px');
  }

  #modal-content {
    position: fixed;
    display: none;
    z-index: 7;
  }

  #modal-overlay {
    z-index: 6;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 120%;
    background-color: rgba(0, 0, 0, 0.75);
  }

  #modal-content-inner form {
    margin: 0 auto;
    width: 860px;
    height: 440px;
    background: url(../img/modal.jpg) no-repeat left top;
    position: relative;
  }
  #modal-content-inner input[type=text] {
    padding-left: 70px;
    width: 560px;
    height: 60px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    line-height: 40px;
    background: #FFF url(../images/icon-mail.png) no-repeat 10px 6px;
    position: absolute;
    left: 20px;
    bottom: 75px;
  }
  #modal-content-inner button {
    margin: 0 auto;
    padding: 10px;
    display: block;
    background-color: #1ca800;
    *zoom: 1;
    filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FF1CA800', endColorstr='#FF0B8E14');
    background-size: 100%;
    background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #1ca800), color-stop(100%, #0b8e14));
    background-image: -moz-linear-gradient(top, #1ca800 0%, #0b8e14 100%);
    background-image: -webkit-linear-gradient(top, #1ca800 0%, #0b8e14 100%);
    background-image: linear-gradient(to bottom, #1ca800 0%, #0b8e14 100%);
    width: 240px;
    text-align: center;
    color: #FFF;
    -webkit-border-radius: 50px;
    -moz-border-radius: 50px;
    border-radius: 50px;
    text-decoration: none;
    font-size: 25px;
    font-size: 2.5rem;
    box-shadow: 0 8px 0 #176802;
    line-height: 1.4;
    font-weight: 800;
    text-shadow: 0px 1px 0px #333;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
    cursor: pointer;
    position: absolute;
    right: 20px;
    bottom: 82px;
    border: none;
  }
  #modal-content-inner button:hover {
    box-shadow: none;
    transform: translate3d(0, 10px, 0);
  }
  
  
/* margin padding ---------------------------------------------------------- */

.mt0 {margin-top:0 !important;}
.mt10 {margin-top:10px !important;}
.mt20 {margin-top:20px !important;}
.mt30 {margin-top:30px !important;}
.mt40 {margin-top:40px !important;}
.mt50 {margin-top:50px !important;}
.ml0 {margin-left:0 !important;}
.ml10 {margin-left:10px !important;}
.ml20 {margin-left:20px !important;}
.ml30 {margin-left:30px !important;}
.ml40 {margin-left:40px !important;}
.ml50 {margin-left:50px !important;}
.mr0 {margin-right:0 !important;}
.mr10 {margin-right:10px !important;}
.mr20 {margin-right:20px !important;}
.mr30 {margin-right:30px !important;}
.mr40 {margin-right:40px !important;}
.mr50 {margin-right:50px !important;}
.mb0 {margin-bottom:0 !important;}
.mb10 {margin-bottom:10px !important;}
.mb20 {margin-bottom:20px !important;}
.mb30 {margin-bottom:30px !important;}
.mb40 {margin-bottom:40px !important;}
.mb50 {margin-bottom:50px !important;}
.pt0 {padding-top:0 !important;}
.pt10 {padding-top:10px !important;}
.pt20 {padding-top:20px !important;}
.pt30 {padding-top:30px !important;}
.pt40 {padding-top:40px !important;}
.pt50 {padding-top:50px !important;}
.pt100 {padding-top:100px !important;}
.pl0 {padding-left:0 !important;}
.pl10 {padding-left:10px !important;}
.pl20 {padding-left:20px !important;}
.pl30 {padding-left:30px !important;}
.pl40 {padding-left:40px !important;}
.pl50 {padding-left:50px !important;}
.pr0 {padding-right:0 !important;}
.pr10 {padding-right:10px !important;}
.pr20 {padding-right:20px !important;}
.pr30 {padding-right:30px !important;}
.pr40 {padding-right:40px !important;}
.pr50 {padding-right:50px !important;}
.pb0 {padding-bottom:0 !important;}
.pb10 {padding-bottom:10px !important;}
.pb20 {padding-bottom:20px !important;}
.pb30 {padding-bottom:30px !important;}
.pb40 {padding-bottom:40px !important;}
.pb50 {padding-bottom:50px !important;}
.pb100 {padding-bottom:100px !important;}



@media screen and (max-width: 640px) {


	/* Base ----------------------------------------------------------------- */

	body {
		background: #111111;
		width: 100%;
	}

	.wrap {
		width: 100%;
	}

	img {
		width: 100%;
		height: auto;
	}

	p {
		margin: 7% 5%;
	}

	/*p br {
		display: none;
	}*/

	.block {
		width: 100%;
		padding-bottom: 5%;
		margin: 0;
	}
	
	.block p {
		margin: 5%;
	}

	footer {
		margin: 0;
		padding: 2% 0 1%;
	}
	
	address {
	margin-bottom:75px;}


    .bgw {
        background: #FFFFFF!important;
    }
	/* Unique --------------------------------------------------------------- */

	.cdarea {
		padding: 2% 0;
		font-size: 95%;
		width:96%;
		margin:0 2%;
		font-weight:bold;
	}
	
	.cdarea span {
		margin: 0 0 0 1%;
		font-size: 150%;
		vertical-align: -5%;
	}
	
	.cd_obi {
    background: #000;
    padding: 3% 0;}
	
	.cd_obi p {
    margin: 0 auto 2%;
    font-size: 95%;
    line-height: 1.5em;}

	.letter {
		background: url(../img/bg_letter.jpg) top center no-repeat;
		background-size: cover;
		padding: 0 0 5%;
	}

	.priv {
		background: url(../img/bg_priv.jpg) top center no-repeat;
		background-size: cover;
		padding: 5% 0;
	}
	

	.priv img {
		width: 96%;
		margin: 0 2%;
	}

	.cv {
		background: url(../img/bg_cv.jpg) top center no-repeat;
		background-size: cover;
		padding: 6% 0;
	}
	
	.cv2 {
		background: url(../img/bg_cv2.jpg) top center no-repeat;
		background-size: cover;
		padding: 6% 0;
	}
	
	.cv .wrap p {
    font-size: 60%;
    line-height: 1.5em;
    margin: 0 5%;}
	
	a.cvbtn {
		display: block;
		background: url(../img/btn.png) top center no-repeat;
		background-size: 100%;
		width: 90%;
		height: 100px;
		padding: 0;
		margin: 5% 5% 0;
		border: none;
	}
	
	
	.text {
		background: none;
		padding: 0;
	}
	
	.text .wrap {
		padding: 0;
	}

    .bgimg {
        background: url("../img/bgimg.jpg")no-repeat bottom center!important;
    }

/*	#jump {
		width: 15%;
		bottom: 1%;
		right: 1%;
	}*/
	
	.voice_box {
    padding: 3%;
    height: 400px;}
	
	.bg_voice,
	.bg_bene,
	.bg_prof,
	.bg_ebi {
    background-attachment: scroll;
	background-position: 0px;
    padding: 3% 2% 5%;}
	
	.bg_prof {
		padding:5% 2% !important;}
		
	.img_right {
    width: 35%;
    float: right;
    margin: 5% 5% 5% 5%;}
	

	/* Sub ---------------------------------------------------------------------- */
	
	.sub .wrap {
		padding: 10% 0 3%;
		margin: 0;
		font-size: 90%;
		line-height: 1.5em;
	}
	
	.sub h1 {
		text-align: center;
		font-size: 150%;
	}
	
	.sub h2 {
		margin: 7% 5% -4%;
		font-size: 120%;
	}
	
	.sub p {
		margin: 7% 5%;
	}
	
	.sub table {
		width: 95%;
		margin: 7% 2%;
		border-bottom: solid 1px #EEEEEE;
	}
	
	.sub table th {
		display: block;
		clear: both;
		width: 100%;
		background: #FAFAFA;
		padding: 0.5% 0;
		border: solid 1px #EEEEEE;
		border-bottom: none;
	}
	
	.sub table td {
		display: block;
		clear: both;
		width: 90%;
		padding: 2% 5%;
		border: solid 1px #EEEEEE;
		border-bottom: none;
	}
	
	/* jump ------------------------------------------------------------------- */
	
	#jump_btn {
    padding: 0;
    width: 130px;
    position: fixed;
    right: 20px;
    bottom: 20px;}
    #jump_btn i {
    margin-right: 10px;
    font-size: 30px;
    font-size: 3rem;}
    #jump_btn a {
    padding: 10px 0;
    display: block;
    background-color: #1ca800;
    background-size: 100%;
    background-image: linear-gradient(to bottom, #1ca800 0%, #0b8e14 100%);
    width: 100%;
    text-align: center;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-size: 85%;
    box-shadow: 0 8px 0 #176802;
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: -0.1em;
    text-shadow: 0px 1px 0px #333;
    transition: all .3s ease;
    cursor: pointer;}
    #jump_btn a:hover {
    box-shadow: none;
    transform: translate3d(0, 5px, 0);}
    #jump_btn a span {
    font-weight: bold;
    color: #fff !important;}




	/* General Purpose ------------------------------------------------------ */


	.mb {
		margin-bottom: 5% !important;
	}

	.pc {
		display: none;
	}
	
	.sp {
		display: inline;
	}
	
	.brsp {display:inline;}
	
	/* margin padding ---------------------------------------------------------- */

	.mt10 {margin-top:1% !important;}
	.mt20 {margin-top:2% !important;}
	.mt30 {margin-top:3% !important;}
	.mt40 {margin-top:4% !important;}
	.mt50 {margin-top:5% !important;}
	.ml10 {margin-left:1% !important;}
	.ml20 {margin-left:2% !important;}
	.ml30 {margin-left:3% !important;}
	.ml40 {margin-left:4% !important;}
	.ml50 {margin-left:5% !important;}
	.mr10 {margin-right:1% !important;}
	.mr20 {margin-right:2% !important;}
	.mr30 {margin-right:3% !important;}
	.mr40 {margin-right:4% !important;}
	.mr50 {margin-right:5% !important;}
	.mb10 {margin-bottom:1% !important;}
	.mb20 {margin-bottom:2% !important;}
	.mb30 {margin-bottom:3% !important;}
	.mb40 {margin-bottom:4% !important;}
	.mb50 {margin-bottom:5% !important;}
	.pt10 {padding-top:1% !important;}
	.pt20 {padding-top:2% !important;}
	.pt30 {padding-top:3% !important;}
	.pt40 {padding-top:4% !important;}
	.pt50 {padding-top:5% !important;}
	.pt100 {padding-top:8% !important;}
	.pl0 {padding-left:0 !important;}
	.pl20 {padding-left:2% !important;}
	.pl30 {padding-left:3% !important;}
	.pl40 {padding-left:4% !important;}
	.pl50 {padding-left:5% !important;}
	.pr10 {padding-right:1% !important;}
	.pr20 {padding-right:2% !important;}
	.pr30 {padding-right:3% !important;}
	.pr40 {padding-right:4% !important;}
	.pr50 {padding-right:5% !important;}
	.pb10 {padding-bottom:1% !important;}
	.pb20 {	padding-bottom:2% !important;}
	.pb30 {padding-bottom:3% !important;}
	.pb40 {padding-bottom:4% !important;}
	.pb50 {padding-bottom:5% !important;}
	.pb100 {padding-bottom:8% !important;}

	
	
}




/* ==========================================================================
   Media Queries
   ========================================================================== */

@media only screen and (min-width: 35em) {

}

@media print,
       (-o-min-device-pixel-ratio: 5/4),
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 120dpi) {

}

/* ==========================================================================
   Helper classes
   ========================================================================== */

.hidden {
    display: none !important;
    visibility: hidden;
}

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

.invisible {
    visibility: hidden;
}

.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    *zoom: 1;
}

/* ==========================================================================
   Print styles
   ========================================================================== */

@media print {
    *,
    *:before,
    *:after {
        background: transparent !important;
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]:after {
        content: " (" attr(href) ")";
    }

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: "";
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    thead {
        display: table-header-group;
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    img {
        max-width: 100% !important;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}