@charset "Shift_JIS";
/**
 * default.css
 * modified : 2014.06.23
 */

/*--------------------------------------------------------------------------------
	.mod-contentContainer
--------------------------------------------------------------------------------*/
.mod-contentContainer {
	margin: 20px auto 80px;
	font-size: 100%;
	font-family: YuGothic,"ŸàƒSƒVƒbƒN","\30D2\30E9\30AE\30CE\89D2\30B4\20\50\72\6F\20\57\33","Hiragino Kaku Gothic Pro",
	"\30E1\30A4\30EA\30AA",Meiryo,"\FF2D\FF33\20\FF30\30B4\30B7\30C3\30AF",'Droid Sans',sans-serif;
	color: #fff;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
}
.mod-contentContainer a img.hover {
	transition: opacity 0.2s;
	-webkit-transition: opacity 0.2s;
	-moz-transition: opacity 0.2s;
	-ms-transition: opacity 0.2s;
}
.mod-contentContainer a:hover img.hover {
	opacity: 0.7;
}
html.no-opacity .mod-contentContainer a:hover img.hover {
	filter: alpha(opacity=70);
}

@media(max-width:640px) {
	.mod-contentContainer {
		margin-bottom: 30px;
	}
}

/*--------------------------------------------------------------------------------
	reset
--------------------------------------------------------------------------------*/
.mod-contentContainer h2,.mod-contentContainer h3,.mod-contentContainer h4,.mod-contentContainer h5,.mod-contentContainer p,.mod-contentContainer ul,.mod-contentContainer ol,.mod-contentContainer li{margin:0;padding:0;}.mod-contentContainer h2,.mod-contentContainer h3,.mod-contentContainer h4,.mod-contentContainer h5,.mod-contentContainer{font-weight:normal;}.mod-contentContainer li{list-style: none;}

/*--------------------------------------------------------------------------------
	.mainvisual
--------------------------------------------------------------------------------*/
.mainvisual {
	padding-bottom: 45px;
	background: #000;
}
.mainvisual ul {
	position: relative;
	margin: -134px 0 0 46px;
	*zoom: 1;
}
.mainvisual ul:after {
	clear: both;
	display: block;
	content: "";
}
.mainvisual li {
	float: left;
	margin-right: 14px;
}
.mainvisual li a {
	display: block;
	padding: 31px 0 30px;
	width: 277px;
	font-size: 150%;
	color: #fff;
	letter-spacing: 0.06em;
	text-align: center;
	background: url("../img/mainvisual_arrow.png") no-repeat right bottom #272727;
	transition: background-color 0.2s;
	-webkit-transition: background-color 0.2s;
	-moz-transition: background-color 0.2s;
	-ms-transition: background-color 0.2s;
	*zoom: 1;
}
.mainvisual li.common a {
	padding: 18px 0 16px;
}
.mainvisual li a:hover {
	background-color: #444;
	text-decoration: none;
}

.mainvisual .maincp {
	margin:40px 0 0 133px;
}
.mainvisual a .maincp:hover{
    opacity: 0.7; 
    filter: alpha(opacity=70); 
    -moz-opacity: 0.7;
}



@media(max-width:640px) {
	.mainvisual {
		padding-bottom: 0;
	}
	.mainvisual img.main {
		width: 100%;
	}
	.mainvisual ul {
		margin: -10% 0 0;
		width: 100%;
		font-size: 81.3%;
	}
	.mainvisual li {
		float: none;
		margin-top: 1px;
		margin-right: 0;
	}
	.mainvisual li br {
		display: none;
	}
	.mainvisual li a {
		width: auto;
		padding: 14px 20px !important;
		text-align: left;
		background-size: 10px 10px;
	}
	.mainvisual li a:hover {
		background-color: #272727;
	}
	.mainvisual .maincp {
		margin:0px;
		width: 100%;
		height:auto;
	}
}
@media(max-width:320px) {
	.mainvisual ul {
		font-size: 75%;
	}
}

/*--------------------------------------------------------------------------------
	#Common
--------------------------------------------------------------------------------*/
/* .intro
--------------------------------------------------------------------------------*/
#Common .intro {
	border-bottom: 3px solid #de5c16;
	background: url("../img/cmn_intro_bg.png") no-repeat right top #1c1c1c;
}
#Common .intro .inner {
	margin: 0 79px 0;
	padding: 50px 0 55px;
}
#Common .intro .inner h3 {
	position: relative;
	padding-left: 22px;
	font-size: 212.5%;
	line-height: 1.3;
}
#Common .intro .inner h3 span {
	position: absolute;
	top: 2px;
	left: 0;
	display: block;
	width: 7px;
	height: 79%;
	color: #de5c16;
	text-indent: -9999em;
	background: #de5c16;
}
#Common .intro .inner p {
	margin: 15px 0 0;
	font-size: 131.3%;
	line-height: 1.9;
}
#Common .intro .inner hr {
	margin: 45px 0 0;
	height: 1px;
	border: none;
	border-top: 1px solid #b2b2b2;
}
#Common .intro .inner ol {
	position: relative;
	margin-left: -28px;
}
#Common .intro .inner ol:after {
	clear: both;
	display: block;
	content: "";
}
#Common .intro .inner ol li {
	display: inline-block;
	margin: 40px 0 0 0;
	padding-left: 25px;
	width: 382px;
	vertical-align: middle;
	*display: inline;
	*zoom: 1;
}
#Common .intro .inner ol li a {
	display: block;
	color: #fff;
	cursor: pointer;
	*display: inline;
	*zoom: 1;
}
#Common .intro .inner ol li a:hover {
	color: #ccc;
	text-decoration: none;
}
#Common .intro .inner ol li span {
	display: inline-block;
	width: 44px;
	height: 25px;
	text-indent: -9999em;
	background-repeat: no-repeat;
	background-position: center top;
	vertical-align: middle;
	*float: left;
	*display: block;
}
#Common .intro .inner ol p {
	display: inline-block;
	margin: 0 0 0 15px;
	width: 323px;
	font-size: 125%;
	font-weight: bold;
	line-height: 1.7;
	vertical-align: middle;
	*float: left;
	*display: block;
}
#Common .intro .inner ol li.n01 span {
	background-image: url("../img/cmn_intro_no01.png");
}
#Common .intro .inner ol li.n02 span {
	background-image: url("../img/cmn_intro_no02.png");
}
#Common .intro .inner ol li.n03 span {
	background-image: url("../img/cmn_intro_no03.png");
}
#Common .intro .inner ol li.n04 span {
	background-image: url("../img/cmn_intro_no04.png");
}

@media(max-width:640px) {
	#Common .intro {
		font-size: 75%;
		background-size: 45% auto;
	}
	#Common .intro .inner {
		margin: 0;
		padding: 65px 15px 30px 20px;
		width: auto;
	}
	#Common .intro .inner h3 {
		padding-left: 15px;
		text-shadow: 0px 0px 8px rgba(0,0,0,1.0);
	}
	#Common .intro .inner p {
		text-shadow: 0px 0px 4px rgba(0,0,0,1.0);
	}
	#Common .intro .inner p br {
		display: none;
	}
	#Common .intro .inner hr {
		margin: 25px 0 0;
	}
	#Common .intro .inner ol {
		margin-left: 0;
	}
	#Common .intro .inner ol li {
		display: table;
		margin: 20px 0 0 0;
		padding-left: 0;
		width: 100%;
	}
	#Common .intro .inner ol li span {
		display: table-cell;
		width: 28px;
		height: 100%;
		background-size: 28px auto;
		background-position: left center;
	}
	#Common .intro .inner ol p {
		display: table-cell;
		margin: 0;
		padding-left: 13px;
		width: auto;
	}
}
@media(max-width:320px) {
	#Common .intro {
		font-size: 68.8%;
	}
}

/* .section
--------------------------------------------------------------------------------*/
#Common .section {
	padding: 50px 0 60px;
	background: url("../img/cmn_sec_bg.png") repeat-x 0 bottom #000;
}
#Common #N04.section {
	padding-bottom: 80px;
}
#Common .section .inner {
	padding: 0 45px 0 68px;
}
#Common .section .inner h4 {
	font-size: 175%;
	font-weight: bold;
}
#Common .section .inner h4 img {
	vertical-align: baseline;
}
#Common .section .inner h4 span {
	position: relative;
	top: -3px;
	margin-left: 23px;
}
#Common .section .inner img.sec-img {
	margin-top: 50px;
}
#Common .section .inner p {
	font-size: 112.5%;
	line-height: 1.8;
}
#Common .section .inner p.mgt15 {
	margin-top: 15px;
}
#Common .section .inner p.mgt-10 {
	margin-top: -10px;
}
#Common .section .inner p.mgt50 {
	margin-top: 50px;
}

@media(max-width:640px) {
	#Common .section {
		padding: 40px 0 40px;
	}
	#Common #N04.section {
		padding-bottom: 60px;
	}
	#Common .section .inner {
		padding: 0 15px 0 20px;
	}
	
	#Common .section .inner h4 {
		font-size: 118.8%;
	}
	#Common .section .inner h4 img {
		width: 50px;
		height: auto;
	}
	#Common .section .inner h4 span {
		display: block;
		position: relative;
		top: 0;
		margin: 0 0 0 0;
	}
	#Common .section .inner img.sec-img {
		margin-top: 30px;
		width: 100%;
		height: auto;
	}
	#Common .section .inner p {
		margin-top: 20px !important;
		font-size: 100%;
	}
	#Common .section .inner p br {
		display: none;
	}
}
@media(max-width:320px) {
	#Common .section .inner h4 {
		font-size: 100%;
	}
	#Common .section .inner h4 img {
		width: 35px;
		height: auto;
	}
	#Common .section .inner p {
		font-size: 93.8%;
	}
}

/*--------------------------------------------------------------------------------
	#Feature
--------------------------------------------------------------------------------*/
#Feature {
	background: #000;
}
#Feature .intro {
	height: 226px;
	border-top: 4px solid #000;
	border-bottom: 3px solid #de5c16;
	background: url("../img/feat_intro_bg.jpg") no-repeat 0 0 #1c1c1c;
}
#Feature .intro h3 {
	position: relative;
	margin: 90px 0 0 68px;
	padding-left: 22px;
	font-size: 212.5%;
	line-height: 1.3;
}
#Feature .intro h3 span {
	position: absolute;
	top: 2px;
	left: 0;
	display: block;
	width: 7px;
	height: 79%;
	color: #de5c16;
	text-indent: -9999em;
	background: #de5c16;
}

@media(max-width:640px) {
	#Feature .intro {
		padding: 0 20px;
		height: auto;
		font-size: 75%;
		background-size: auto 100%;
		background-position: 70% 0;
	}
	#Feature .intro h3 {
		margin: 40px 0;
		text-shadow: 0px 0px 5px rgba(0,0,0,1.0);
	}
}
@media(max-width:320px) {
	#Feature .intro {
		font-size: 68.8%;
	}
}

/* .section
--------------------------------------------------------------------------------*/
#Feature .inner {
	padding: 45px 45px 30px;
}
#Feature .inner p {
	margin-top: 20px;
	font-size: 125%;
	font-weight: bold;
}
#Feature .inner .img-box {
	margin-top: 20px;
}
#Feature .inner .btn-box {
	margin-top: 20px;
}
#Feature .inner .btn-box img {
	width: 177px;
	height: auto;
	margin-right:10px;
}
#Feature .inner .btn-txt {
	margin: 0px 0 0 190px;
}

#RX100 {
	min-height: 464px;
	background: url("../img/feat_rx100.jpg") no-repeat 0 0 #1c1f1f;
}
#RX100M2 {
	min-height: 469px;
	background: url("../img/feat_rx100m2.jpg") no-repeat 0 0;
}
#RX100M3 {
	min-height: 466px;
	background: url("../img/feat_rx100m3.jpg") no-repeat 0 0 #10081b;
}

@media(max-width:640px) {
	#Feature .section {
		border-top: 1px solid #333;
		min-height: 1px;
		overflow: hidden;
	}
	#Feature .inner {
		padding: 48% 20px 40px;
	}
	#Feature .inner h4 img {
		width: 110px;
		height: auto;
	}
	#Feature .inner p {
		margin-top: 15px;
		font-size: 106.3%;
	}
	#Feature .inner .img-box {
		margin-top: 25px;
		text-align: center;
	}
	#Feature .inner .img-box img {
		width: 100%;
		max-width: 400px;
	}
	#Feature #RX100M3 .inner .img-box img {
		width: 115%;
		max-width: 400px;
	}
	#Feature .inner .btn-box {
		margin-top: 30px;
	}
	#Feature .inner .btn-txt {
		margin: 0px 0 0 193px;
	}
	#RX100 {
		background-position: right 0;
		background-size: 140% auto;
	}
	#RX100M2 {
		background-position: right 0;
		background-size: 130% auto;
	}
	#RX100M3 {
		background-position: right 0;
		background-size: 135% auto;
	}
}
@media(max-width:469px) {
	#Feature .inner {
		padding: 55% 20px 40px;
	}
	#Feature .inner p br {
		display: none;
	}
	#Feature .inner .btn-box {
		text-align: center;
	}
	#Feature .inner .btn-box img {
		width: 200px;
		height: auto;
		margin:10px 0 0 0;
	}
	#Feature .inner .btn-txt {
		margin: 0px;
		text-align: center;
	}
}
@media(max-width:320px) {
	#Feature .inner p {
		font-size: 93.8%;
	}
}

/*--------------------------------------------------------------------------------
	#Spec
--------------------------------------------------------------------------------*/
#Spec {
	padding-bottom: 40px;
	background: #000;
}
#Spec .intro {
	height: 226px;
	border-top: 4px solid #000;
	border-bottom: 3px solid #de5c16;
	background: url("../img/spec_intro_bg.jpg") no-repeat 0 0 #080808;
}
#Spec .intro h3 {
	position: relative;
	margin: 90px 0 0 68px;
	padding-left: 22px;
	font-size: 212.5%;
	line-height: 1.3;
}
#Spec .intro h3 span {
	position: absolute;
	top: 2px;
	left: 0;
	display: block;
	width: 7px;
	height: 79%;
	color: #de5c16;
	text-indent: -9999em;
	background: #de5c16;
}

@media(max-width:640px) {
	#Spec .intro {
		padding: 0 20px;
		height: auto;
		font-size: 75%;
		background-size: 100% auto;
	}
	#Spec .intro h3 {
		margin: 40px 0;
		text-shadow: 0px 0px 5px rgba(0,0,0,1.0);
	}
}
@media(max-width:320px) {
	#Spec .intro {
		font-size: 68.8%;
	}
}

/* table
--------------------------------------------------------------------------------*/
#Spec .inner {
	padding: 70px 45px 0;
}
#Spec table {
	table-layout: fixed;
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	border-bottom: 1px solid #787878;
}
#Spec table thead th {
	padding-bottom: 30px;
}
#Spec table tbody th {
	padding: 20px 0 20px 25px;
	height: 80px;
	font-size: 112.5%;
	font-weight: normal;
	text-align: left;
	border-top: 1px solid #787878;
	background: url("../img/spec_spt.png") no-repeat right center;
}
#Spec table tbody tr td {
	padding: 20px 0;
	height: 80px;
	font-size: 125%;
	text-align: center;
	border-top: 1px solid #787878;
	background: url("../img/spec_spt.png") no-repeat right center;
}
#Spec table tbody tr td.last-child {
	background-image: none;
}
#Spec table .large {
	font-size: 112.5%;
}
#Spec table .xsmall {
	font-size: 87.5%;
}
#Spec table .xxsmall {
	font-size: 75%;
}
#Spec p.note {
	margin-top: 30px;
	font-size: 81.3%;
}
#Spec img.media {
	margin-right: 10px;
	width: 72px;
	height: auto;
}

@media(max-width:640px) {
	#Spec .inner {
		padding: 30px 20px 0;
	}
	#Spec table {
		font-size: 43.8%;
	}
	#Spec table thead th {
		padding-bottom: 10px;
	}
	#Spec table thead th img {
		width: 75%;
	}
	#Spec table tbody th {
		padding: 15px 0;
		height: auto;
	}
	#Spec table tbody tr td {
		padding: 15px 0;
		height: auto;
	}
	#Spec table .xsmall {
		font-size: 81.3%;
	}
	#Spec img.movie1 {
		width: 95px;
	}
	#Spec img.movie2 {
		width: 50px;
	}
	#Spec img.media {
		width: 45px;
	}
	#Spec p.note {
		margin-top: 15px;
		font-size: 56.3%;
	}
}
@media(max-width:320px) {
	#Spec table {
		font-size: 37.5%;
	}
	#Spec img.movie1 {
		width: 85px;
	}
	#Spec img.movie2 {
		width: 40px;
	}
	#Spec img.media {
		width: 40px;
	}
	#Spec p.note {
		font-size: 50%;
	}
}


/* present
--------------------------------------------------------------------------------*/
#present{
	width:860px;
	margin:50px auto;
}

#present .entry .entryleft img{
	float:left;
}
#present .entry .entryright img{
	float:right;
}

#present .entry .entrymain{
	font-size:12px;
	color:#333333;
	line-height:16px;
}

#present .entry ul {
	width:530px;
	margin:20px 165px;
	list-style:none;
}
#present .entry ul .last{
	text-align:right;
}

#present .entry p{
	width:780px;
	margin:0 40px 10px 40px;
	font-size:12px;
	color:#333333;
	line-height:16px;
}
#present .entry .entrybottom {
	margin-top:40px;
}

#present .entry ul li a img:hover{
    opacity: 0.7; 
    filter: alpha(opacity=70); 
    -moz-opacity: 0.7;
}

@media(max-width:640px) {
	#present{
		width:auto;
		margin:50px auto;
	}
	#present .point img{
		width:100%;
	}
	
	#present .entry .entryleft img{
		float:left;
		width:7px;
		height:650px;
	}
	#present .entry .entryright img{
		float:right;
		width:7px;
		height:650px;
	}
	
	#present .entry .entrymain{
		font-size:12px;
		color:#333333;
		line-height:16px;
	}
	
	#present .entry ul {
		width:auto;
		margin:20px 40px;
		list-style:none;
	}
	#present .entry ul li img {
		width:100%;
	}
	#present .entry ul .last img{
		width:auto;
	}
	
	#present .entry p{
		width:auto;
		margin:0 40px 10px 40px;
		font-size:12px;
		color:#333333;
		line-height:16px;
	}
	#present .entry .entrybottom img{
		width:100%;
	}
		
}

@media(max-width:520px) {	
	#present .entry .entryleft img{
		float:left;
		width:6px;
		height:750px;
	}
	#present .entry .entryright img{
		float:right;
		width:6px;
		height:750px;
	}
}

@media(max-width:480px) {	
	#present .entry .entryleft img{
		float:left;
		width:4px;
		height:800px;
	}
	#present .entry .entryright img{
		float:right;
		width:4px;
		height:800px;
	}
}


@media(max-width:320px) {	
	#present .entry .entryleft img{
		float:left;
		width:2px;
		height:850px;
	}
	#present .entry .entryright img{
		float:right;
		width:3px;
		height:850px;
	}
}




/* contact
--------------------------------------------------------------------------------*/
#contact{
	width:860px;
	margin:50px auto;
}

#contact p {
	color:#000000;
	line-height:1.7em;
	font-size:12px;
}

#contact p a {
	color:#0b6791;
}


@media(max-width:640px) {
	#contact{
		width:auto;
		margin:50px 10px;
	}
}
















