@import url(fonts.css);
@font-face {
	font-family: 'MP1Cthin';
	src:url('fonts/mplus-1c-thin.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'MP1Clight';
	src:url('fonts/mplus-1c-light.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

* {
	box-sizing: border-box;
}

html, body {
	position: relative;
	height: 100%;
	min-height: 100%;
	margin: 0;
	padding: 0;
	border: 0;
}

body {
	background: #fff;
	font-family: "Lato", "MP1Clight", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	font-weight: 300;
	font-size: 16px;
}

.wrapper {
	overflow: hidden;
}

a {
	transition: all 0.2s ease-in-out;
	color: rgba(135, 76, 223, 1);
}

a:hover, a:active {
	color: rgba(86, 61, 124, 1);
}

p {
	line-height: 2em;
}

section {
	display: block;
	margin: 0;
	height: auto;
}

section.presentation {
	overflow: hidden;
	position: relative;
}

.container {
	max-width: 1024px;
	position: relative;
}

header {
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 2000;
	background: rgba(255,255,255,.8);
	border-bottom: 1px solid #e7e7e7;
	font-weight: 300;
}

footer {
	clear: both;
	text-align: center;
	padding-top: 40px;
	padding-bottom: 40px;
}

h1, h2, h3, h4 {
	font-weight: 300;
}

h1 {
	line-height: 1.5em;
}

header p {
	font-size: 22px;
	margin-top: 0.25em;
	margin-bottom: 0;
}

header a, header .btn-link {
	color: rgba(86, 61, 124, 1);
}

header a:hover, header a:active,
header .btn-link:hover, header .btn-link:active {
	color: rgba(66, 45, 99, 1);
	text-decoration: none;
}

header a.active {
	color: #ffcc00;
}

header .btn {
	margin: 10px 0;
}

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

.top {
	display: block;
	height: auto;
	margin: 0;
	padding: 0;
	position: relative;
	top: 0;
	background-color: #fff;
	z-index: 1000;
}

.top section {
	text-align: center;
	padding: 100px 0;
}

.top > section {
	position: relative;
	z-index: 5;
}

.cerf {
	background-image: url(../images/cerf.png);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 25%;
}

.bg-glass {
	background: rgba(255, 255, 255, 0.7);
	border: 1px solid #baad32;
	color: #1d1d1d;
}

.nav-cs {
	display: block;
	text-align: center;
	position: absolute;
	bottom: 0;
	z-index: 100;
	width: 100%;
	margin-left: 0;
	padding-left: 0;
}

.nav-cs li {
	display: inline-block;
	list-style: none;
	margin: 15px;
}

.li-nav {
	width: 1em;
	height: 1em;
	border-radius: 50%;
	background: rgba(255,255,255,.8);
}

.round1 {
	display: block;
	margin: 0;
	width: 100%;
	height: 60%;
	border-radius: 100% 0 0 0;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 3;
}

.round2 {
	display: block;
	margin: 0;
	width: 100%;
	height: 100%;
	border-radius: 100% 0 0 0;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
}

.spot {
	background: -webkit-gradient(radial, 50% 46%, 0, 50% 46%, 120, color-stop(1.00, #ddd), color-stop(0.65, #fafafa), color-stop(0.00, #fff));
	background: -webkit-radial-gradient(50% 46%, circle, #fff 0%, #fafafa 65%, #ddd 100%);
	background: -moz-radial-gradient(50% 46%, circle, #fff 0%, #fafafa 65%, #ddd 100%);
	background: radial-gradient(50% 46%, circle, #fff 0%, #fafafa 65%, #ddd 100%);*/
	background: -webkit-gradient(linear, left top, right bottom, color-stop(0%,#ffdb4c), color-stop(100%,#ffcd02)); */
	margin: 0;
	padding: 20px;
	border: 0;
	color: #1d1d1d;
}

.presentation h1 {
	margin-bottom: 20px;
}

.bg-image {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.proCoding {
	background-color: #fff;
	position: relative;
}

.proCoding .bg-image.left {
	background-image: url(../images/bg-grad-yellow.jpg);
	background-repeat: repeat-x;
	background-size: 50% 100%;
	background-position: left bottom;
	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 100%;
}

.proCoding .bg-image.right {
	background-image: url(../images/bg-grad-yellow2.jpg);
	background-repeat: repeat-x;
	background-size: 50% 100%;
	background-position: left bottom;
	position: absolute;
	top: 0;
	left: 50%;
	width: 50%;
	height: 100%;
}

.proCoding .bg-image.center {
	background-image: url(../images/F71513530.jpg);
	background-size: auto 100%;
	background-position: left bottom;
	position: absolute;
	top: 0;
	left: 45%;
	width: auto;
	min-width: 55%;
	height: 100%;
}

.bg-white {
	background: #fff;
}

.bg-black {
	background: #000;
}

.bg-lightgrey {
	background: #f7f7f7;
}

.thumbnail {
	padding-top: 20px;
	border: none;
	background: #fff;
}

.bg-blue {
	background: #007aff;
}

.bg-green {
	background: #4CD964;
}

.bg-orange {
	background: #ff9500;
}

.bg-yellow {
	background: #ffcc00;
}

.bg-beige {
	background: #e4ddca;
}

.bg-cream {
	background: #fbf9ef;
}

.bg-purple {
	background: #5856d6;
}

.bg-lightblue {
	background: #d1eefc;
}

.btnArea {
	position: relative;
	z-index: 1000;
}

.front {
	width: 100%;
	position: relative;
	margin: 0;
	bottom: 0;
	z-index: 5;
}

.top .btnArea {
	margin-top: 100px;
}

.h2icon {
	font-size: 4.5em;
}

.fadeIn {
 -webkit-animation-fill-mode: forwards;
 animation-fill-mode: forwards;
 -webkit-animation-duration:1s;
 animation-duration:1s;
 -webkit-animation-iteration-count: 1;
 animation-iteration-count: 1;
 -webkit-animation-name: fadeIn;
 animation-name: fadeIn;
 visibility: visible !important;
}
@-webkit-keyframes fadeIn {
 0% { opacity: 0; }
 100% { opacity: 1; }
}
@keyframes fadeIn {
 0% { opacity: 0; }
 100% { opacity: 1; }
}

.fadeInDown {
 -webkit-animation-fill-mode: forwards;
 animation-fill-mode: forwards;
 -webkit-animation-duration:1s;
 animation-duration:1s;
 -webkit-animation-iteration-count: 1;
 animation-iteration-count: 1;
 -webkit-animation-name: fadeInDown;
 animation-name: fadeInDown;
 visibility: visible !important;
}
@-webkit-keyframes fadeInDown {
 0% { opacity: 0; -webkit-transform: translateY(-20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); }
}
@keyframes fadeInDown {
 0% { opacity: 0; -webkit-transform: translateY(-20px); transform: translateY(-20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }
}

#catch {
	position: relative;
	z-index: 400;
}

.form {
	margin: 40px;
	text-align: left;
}

.form .form-group label {
	font-weight: 400;
}

.dl-horizontal dt {
	font-weight: 600;
}

/* #responsive-animation */
#responsive-animation {
	-webkit-backface-visibility: hidden;
	display: block;
	width: 600px;
	height: 500px;
	margin: auto;
}

#screen {
	display: block;
	width: 100%;
	height: 350px;
	background: #000;
	border: 1px solid #000;
	border-radius: 15px 15px 0 0;
	margin-bottom: 0;
}

#screen.radius-all {
	border-radius: 15px;
}

.inner-box {
	display: block;
	margin: 20px;
	width: 560px;
	height: 310px;
	background: #fff;
	overflow: hidden;
	text-align: center;
}

#pied {
	display: block;
	width: 100%;
	height: 100%;
	margin-top: 0;
	background: no-repeat center top;
}

#pied.imac {
	background-image: url(../images/imac-pied.png);
	background-size: 600px 125px;
}

#pied.macbook {
	background-image: url(../images/macbook-pied.png);
	background-size: 600px 26px;
}

#caption {
	position: absolute;
	top: 560px;
	left: 0;
	width: 100%;
	text-align: center;
	font-size: 18px;
	z-index: 1;
}

/**  .inner-box内コンテンツ **/
.inner-box .header {
	display: block;
	margin: 0;
	height: 30%;
	background: #e4ddca;
}

.inner-box .body {
	display: block;
	margin-top: 10px;
	height: 70%;
}

.inner-box .body .box {
	display: inline-block;
	width: 25%;
	height: 70%;
	margin: 10px;
	background: #efefef;
	position: relative;
}

.inner-box .body.tablet-h .box {
	width: 40%;
	height: 75%;
	margin-top: 18px;
}

.inner-box .body.tablet-v .box {
	display: block;
	width: auto;
	height: 100%;
	margin-top: 25px;
}

.inner-box .body.mobile .box {
	display: block;
	width: 100%;
	height: 200%;
}

.box .img {
	display: inline-block;
	width: 50%;
	height: 50%;
	position: absolute;
	top: 0;
	left: 0;
/*	background: #f1ffd0;*/
	background: #f7f7f7;
	border-right: 10px solid #fff;
	border-bottom: 10px solid #fff;
}

.tablet-v .box .img {
	width: 40%;
	height: 60%;
	left: 40px;
	margin-left: 75px;
}

.mobile .box .img {
	width: 55%;
	height: 60%;
	border-left: 20px solid #fff;
	border-right: 20px solid #fff;
	border-bottom: 20px solid #fff;
	margin-left: 175px;
}

#screen .footer {
	display: block;
	margin: 5px 0 0;
	height: 30px;
	background: #999;
}
/* #responsive-animation ここまで */

.btn-default.special {
  background-color: rgba(255, 255, 255, 1);
  color: #1d1d1d;
  border-radius: 0;
}
.btn-default.special:hover,
.btn-default.special:active,
.btn-default.active.special,
.open > .dropdown-togglebtn-default.special {
  background-color: rgba(255, 255, 255, 0.95);
}
.btn-default.special:active,
.btn-default.special.active,
.open > .dropdown-togglebtn-default.special {
  background-image: none;
}

.btn-special {
  color: #fff;
  /*background-color: rgba(0, 82, 194, 0.7);*/
  background-color: rgba(86, 61, 124, 0.9);
  border: none;
  border-radius: 0;
}
.btn-special:hover,
.btn-special:active,
.btn-special.active,
.open > .dropdown-togglebtn-special {
  color: #fff;
  background-color: rgba(86, 61, 124, 1);
  border: none;
}
.btn-special:focus,
.btn-special.focus {
	color: #fff;
}
@-moz-document url-prefix() {
	.cerf .btn-special {
		box-shadow: 0 6px 8px 3px rgba(86, 61, 124, 0.35);
	}
	.cerf .btn-special:active {
		box-shadow: 0 2px 4px rgba(86, 61, 124, 0.4);
	}
}
.cerf .btn-special {
	visibility: hidden;
}
.btn-special:active,
.btn-special.active,
.open > .dropdown-togglebtn-special {
  background-image: none;
}
.btn-special.disabled,
.btn-special[disabled],
fieldset[disabled] .btn-special,
.btn-special.disabled:hover,
.btn-special[disabled]:hover,
fieldset[disabled] .btn-special:hover,
.btn-special.disabled:focus,
.btn-special[disabled]:focus,
fieldset[disabled] .btn-special:focus,
.btn-special.disabled.focus,
.btn-special[disabled].focus,
fieldset[disabled] .btn-special.focus,
.btn-special.disabled:active,
.btn-special[disabled]:active,
fieldset[disabled] .btn-special:active,
.btn-special.disabled.active,
.btn-special[disabled].active,
fieldset[disabled] .btn-special.active {
  background-color: #eac166;
  border-color: #e2b960;
}
.btn-special .badge {
  color: rgba(231, 166, 0, 0.5);
  background-color: #fff;
}

.noBoxShadow {
	animation-fill-mode: forwards;
	animation-duration: .5s;
	animation-name: noBoxShadow;
}

.addBoxShadow {
	animation-fill-mode: backwards;
	animation-duration: .5s;
	animation-name: noBoxShadow;
}

@keyframes noBoxShadow {
	from {
		box-shadow: 0 6px 8px 3px rgba(86, 61, 124, 0.35);
	}
	to {
		box-shadow: none;
	}
}

#solutions h2 {
	position: relative;
	display: block;
	padding: 20px;
	width: auto;
	color: #875b5a;
	background: #fbfbfb;
	border-radius: 50px;
}

#solutions h2:before {
	content: "";
	position: absolute;
	bottom: -17px; right: 15px;
	margin-right: 0;
	display: block;
	width: 15px;
	height: 15px;
	background: #f7f7f7;
	border-radius: 50%;
	z-index: 0;
}

#solutions h2:after {
	content: "";
	position: absolute;
	bottom: -25px; right: 25px;
	margin-right: 0;
	display: block;
	width: 8px;
	height: 8px;
	background: #f7f7f7;
	border-radius: 50%;
	z-index: 0;
}

.adjuster {
	height: 0;
}

#footer {
	background: #1d1d1d;
	color: #fff;
	
	.btn-link {
		margin-top: .5rem;
		color: #ccc;
		
		&:hover, &:focus {
			color: #fff;
		}
	}
}

#footer p {
	padding: 10px 0;
	margin: 0;
	font-size: 0.8em;
}

.bottom-menu {
	background: #404040;
}	

.bottom-menu ul {
	display: block;
	font-size: 0.9em;
	padding: 30px 0;
	padding-left: 0;
	margin: 0;
}

.bottom-menu li {
	display: inline-block;
	list-style: none;
	margin: 0;
}

.bottom-menu li a {
	margin: 30px;
	color: #efefef;
}

.bottom-menu li a:hover, .bottom-menu li a:active {
	color: #fff;
}

/*	typo, general */
.m-b-20 {
	margin-bottom: 20px;
}

.m-b-30 {
	margin-bottom: 30px;
}

.m-b-60 {
	margin-bottom: 60px;
}

.m-t--5 {
	margin-top: -5px;
}

.m-t--20 {
	margin-top: -20px;
}

.m-t-20 {
	margin-top: 20px;
}

.m-t-40 {
	margin-top: 40px;
}

.m-t-35 {
	margin-top: 35px;
}

.p-b-5 {
	padding-bottom: 5px;
}

.p-b-30 {
	padding-bottom: 30px;
}

.p-t-5 {
	padding-top: 5px;
}

.p-t-60 {
	padding-top: 60px;
}

footer a {
	font-size: 1.3em;
}

.text-white {
	color: #fff;
}

.text-blue {
	color: #007aff;
}

.text-orange {
	color: #f09308;
}

.icon-facebook {
	display: inline-block;
	background: #3c5a99;
	color: #fff;
	width: 4rem;
	height: 4rem;
	position: relative;
}

.icon-f {
	position: absolute;
	top: .2em;
	left: .1em;
	color: #fff;
}

a.icon-facebook:hover, a.icon-facebook:active {
	text-decoration: none;
}

.hgrkk {
	font-family: "HGRKK", serif;
}

.font-size-lg {
	float: left;
	font-size: 1.5em;
	position: relative;
	top: 0;
	margin-right: 5px;
}

.font-size-xl {
	font-size: 3em;
}

.font-size-xxl {
	font-size: 4em;
}

.h-4em {
	width: 4em;
	height: 4em;
	position: relative;
	top: 0;
	transition: all 0.2s;
}

.h-4em:hover {
	top: -0.5em;
}

.nw {
	white-space: nowrap;
}

.visible-xxs {
	display: none;
}

#langMenu {
	display: block;
	height: 0;
	visibility: hidden;
}

#check-accept-google-analytics {
	display: block;
	width: 100%;
	background-color: rgba(0,0,0, .8);
	color: #f5f5f5;
	line-height: 1.5;
	margin: 0;
	padding: 2rem;
	opacity: 0;
	transition: all .8s ease;
	position: fixed;
	bottom: -500px;
	left: 0;
	
	a:hover, a:focus {
		color: rgba(155, 124, 203, 1);
	}
	
	.btn {
		margin-top: 1rem;
		
		&:first-child {
			margin-right: 1rem;
		}
	}
	
	.btn-link {
		color: #ccc;
	}
	
	&.show {
		opacity: 1;
		bottom: 0;
		z-index: 1000;
	}
}

@media screen and (max-width: 1100px){
	.proCoding .bg-image.center {
		width: 70%;
		left: 30%;
	}
}

@media screen and (max-width: 991px){
	.proCoding .bg-image.center, .proCoding .bg-image.right, .proCoding .bg-image.left {
		background-image: none;
	}
	
	.h2icon {
		margin-left: 0;
		font-size: 3.5em;
	}
}

@media screen and (max-width: 980px){
	.bottom-menu ul {
		text-align: center;
	}
	
	.bottom-menu li {
		display: list-item;
		margin: 1em;
	}
}

@media screen and (max-width: 767px){
	.top > section .row {
		background: none;
	}
}

@media screen and (max-width: 600px){
	.presentation h1 {
		font-size: 2em;
	}
	
	.proCoding h1 {
		font-size: 28px;
	}
	
	h2 {
		font-size: 1.5em;
	}
	
	/* #responsive-animation */
	#responsive-animation {
		width: 250px;
		height: 250px;
	}

	#screen {
		height: 146px;
		border-radius: 7px 7px 0 0;
	}

	#screen.radius-all {
		border-radius: 7px;
	}

	.inner-box {
		margin: 10px;
		width: 228px;
		height: 125px;
	}

	#pied.imac {
		background-size: 250px 63px;
	}

	#pied.macbook {
		background-size: 250px 13px;
		margin-top: 23px;
	}

	#caption {
		top: 400px;
		font-size: 14px;
	}

	/**  .inner-box内コンテンツ **/
	.inner-box .header.tablet-v, .inner-box .header.mobile {
		position: relative;
		top: 80px;
		left: 130px;
	}
	
	.inner-box .body .box {
		margin: 5px;
	}

	.inner-box .body.tablet-h .box {
		margin-top: 0;
	}

	.inner-box .body.tablet-v .box {
		margin-top: 14px;
	}

	.inner-box .body.mobile {
		position: relative;
		top: 10px;
	}
	
	.box .img {
		border-right: 5px solid #fff;
		border-bottom: 5px solid #fff;
	}

	.tablet-v .box .img {
		left: 20px;
		margin-left: 37px;
	}

	.mobile .box .img {
		border-left: 10px solid #fff;
		border-right: 10px solid #fff;
		border-bottom: 10px solid #fff;
		margin-left: 87px;
	}

	#screen .footer {
		margin: 5px 0 0;
		height: 15px;
	}
	/* #responsive-animation ここまで */
}

@media screen and (max-width: 483px){
	.presentation h1 {
		font-size: 1.5em;
	}
	
	.cerf p {
		margin-left: 20px;
		margin-right: 20px;
	}

	#caption {
		top: 360px;
	}
	
	.h2icon {
		font-size: 2.8em;
	}
	
	.visible-xxs {
		display: block !important;
	}
	
	span.visible-xxs {
		display: inline-block;
	}
	table.visible-xxs {
		display: table;
	}
	tr.visible-xxs {
		display: table-row !important;
	}
	th.visible-xxs,
	td.visible-xxs {
		display: table-cell !important;
	}
	
	.hidden-xxs {
		display: none;
	}
	
	#langMenu.opened {
		display: block;
		text-align: center;
		width: 100%;
		height: auto;
		position: fixed;
		top: -200px;
		z-index: 600;
		visibility: visible;
	}
	
	#langMenu a {
		display: block;
		padding: 10px;
		background: rgba(0,0,0,.8);
		color: #fff;
	}
	
	#langMenu a:hover, #langMenu a:active {
		background: rgba(0,0,0,.9);
	}
}