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

* {
    margin: 0;
    padding: 0;
}

body {
    background: #fff;
    color: #000;
    font-family: "Lucida Grande","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック",Osaka,sans-serif;
    font-size:13px;
}

p {
    line-height:1.8;
}

p strong {
	font-size: 110%;
	line-height: 1.8;
}

a {
    text-decoration: none; 
		color: #000; 
}

a:active {
    text-decoration: none;
    color:#09C;
}

a:visited {
    text-decoration: none;
    color:#09C;
}

a:hover {
	text-decoration: underline;
	color: #09c;
}

a img {
    border: none;
}

.clear {
    clear:both;
    font-size:0;
    height:0;
    line-height:0;
    margin:0;
    padding:0;
}



/* wrapper --------------------------------------------------------------------------------  */

div#wrapper {
    position: relative;
    width: 960px;
    margin: 0 auto;
}


/* header --------------------------------------------------------------------------------  */

div#header {
    padding: 55px 0 15px 0;
}

div#header h3 {
    text-indent: -9999px;
    background:url(../../img/common/insidepylogo.gif) no-repeat;
    width:246px;
    height:78px;
		overflow: hidden;
}

div#header h3 a {
    width:246px;
    height:78px;
		display: block;
}

div#header a.pyhome {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/backhome.gif) no-repeat;
    width:131px;
    height:47px;
    position: absolute;
    right: 0;
    top: 70px;
		overflow: hidden; 
}

div#header a.pyhome:hover {
    background:url(../../img/common/backhome_on.gif) no-repeat;
}


/* footer --------------------------------------------------------------------------------  */

div#footer {
    clear: both;
    position: relative;
    margin: 20px 0;
    padding: 5px 0;
    border-top: solid 1px #ccc;
}

div#footer a.pyhome {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/flogo.gif) no-repeat;
    width:192px;
    height:21px;
		overflow: hidden;
}

div#footer p.copyright {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/fcr.gif) no-repeat;
    width:430px;
    height:21px;
    position: absolute;
    top: 4px;
    left: 195px;
		overflow: hidden;
}

div#footer a.policy {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/ftokusho.gif) no-repeat;
    width:144px;
    height:21px;
    position: absolute;
    top: 4px;
    right: 195px;
		overflow: hidden;
}

div#footer a.howto {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/fhowto.gif) no-repeat;
    width:193px;
    height:21px;
    position: absolute;
    top: 4px;
    right: 0;
		overflow: hidden;
}

div#footer a.dotcomlogo {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/fyodocom.gif) no-repeat;
    width:200px;
    height:49px;
    margin: 30px auto;
		overflow: hidden;
}



/* contents --------------------------------------------------------------------------------  */

#content {
    padding: 0 0 40px 0;
}

#content h1, #content h2 {
    margin: 35px 0;
}

#content h2 {
	text-align: left;
	border-bottom: solid 1px #ccc;
	padding: 0 0 5px 0;
}

#content h1 {
    text-align: center;
    font-weight: bold;
    font-size: 18pt;
}

#content h1 span {
	font-size: 13pt;
	font-weight: bold;
}

#content h1 a {
    color:#09C;
}


#content p {
    margin: 0 0 40px 0;
		text-align: justify; 
}

#content p.photo {
    text-align: center;
    margin: 0 0 20px 0;
}

#content p.sign {
    text-align: right;
    margin: -20px 0 40px 0;
}

#content p.separator {
    display: block;
    text-indent: -9999px;
    background:url(../../img/common/kugiri.gif) no-repeat;
    width:960px;
    height:120px;
    margin: 0 auto;
		overflow: hidden;
}


div.left {
    float: left;
    width: 470px;
}
div.right {
    float: right;
    width: 470px;
}
.clear {
    clear: both;
}


/* cart --------------------------------------------------------------------------------  */

p.price {
	color:red;
	font-weight:bold;
	line-height:1.2;
}

p.fixedprice,
span.tax {
	color:#888888;
}


div.shoppingL {
	width:450px;
	float:left;
	margin-bottom:40px;
}

div.shoppingR {
	width:450px;
	float:right;
	margin-bottom:40px;
}

div.shoppingL p,
div.shoppingR p {
	margin:0;
	padding:0;
}

p.ptitle {
	font-weight:bold;
}

a.Prd-productUrlRef {
	color: #000;
}

p.pread {
margin-bottom:10px !important;
}

div.shoppingimg {
text-align:center;
}

div.cartBtnImg {
	text-align:right;
}

div.cartBtnImg input {
margin-top:20px;
}

div.makerL {
	width:178px;
	float:left;
	background:#F2F2F2;
	padding:6px;
	border-top:1px solid #CCC;
	border-right:1px solid #CCC;
	border-left:1px solid #CCC;
}

div.makerC {
	width:178px;
	float:left;
	background:#F2F2F2;
	padding:6px;
	border-top:1px solid #CCC;
	border-right:1px solid #CCC;
}

div.makerLB {
	width:178px;
	float:left;
	background:#F2F2F2;
	padding:6px;
	border-top:1px solid #CCC;
	border-right:1px solid #CCC;
	border-bottom:1px solid #CCC;
	border-left:1px solid #CCC;
}

div.makerCB {
	width:178px;
	float:left;
	background:#F2F2F2;
	padding:6px;
	border-top:1px solid #CCC;
	border-right:1px solid #CCC;
	border-bottom:1px solid #CCC;

}

div.makerL,
div.makerC,
div.makerLB,
div.makerCB {
	text-align:center;
	font-size:12px;
}

div.makerL a,
div.makerC a,
div.makerLB a,
div.makerCB a {
	color: #000;
}

/* sns --------------------------------------------------------------------------------  */

#snsButton {
margin: 20px 0 40px 0;
text-align: left;
float: left;
}

#snsButton ul {
padding: 0;
float: left;
}

#snsButton li {
margin-right: 10px;
float: left;
}

p.date {
font-size: x-small;
color: #888;
float: right; 
}



/* photokina2014 --------------------------------------------------------------------------------  */

div#topstories { clear: both; }
div#topstories h2 { height: 24pt; margin: 10px 0 20px 0; padding: 0 0 5px 0; font-size: 20pt; line-height: 24pt; vertical-align: middle; border-bottom: solid 1px #555; }
div#topstories h2 span { margin-left: 20px; font-size: 8pt; color: #888; font-weight: normal; }
div#topstories div { width: 300px; float: left; margin: 0 30px 0 0; }
div#topstories div.end { margin-right: 0; }
div#topstories div a { color: #000; text-decoration: none; }
div#topstories div a:hover { text-decoration: underline; }
div#topstories div h3 { margin: 10px 0 8px 0; font-size: 13pt; }

div#headline { width: 700px; float: left; clear: both; }
div#headline h2 { height: 24pt; margin: 10px 0 0 0; padding: 0 0 5px 0; font-size: 20pt; line-height: 24pt; vertical-align: middle; border-bottom: solid 1px #555; }
div#headline h2 span { margin-left: 20px; font-size: 8pt; color: #888; font-weight: normal; }
div#headline ul { margin: 0; padding: 0; list-style: none; }
div#headline ul li { height: 133px; padding: 10px 0; border-bottom: solid 1px #000; }
div#headline ul li div.left { width: 200px; height: 133px; margin: 0 20px 0 0; padding: 0; float: left; } 
div#headline ul li div.right { width: 480px; height: 133px; margin: 0; padding: 0; float: right; } 
div#headline h3 { margin: 0 0 7px 0; font-size: 11pt; }
div#headline h3 a { color: #000; text-decoration: none; }
div#headline h3 a:hover { text-decoration: underline; }
div#headline p.icon {}
div#headline p.icon a { height: 1.8em; margin-right: 5px; padding: 0 5px; font-size: 8pt; color: #fff; border: none;  border-radius: 3px; background: #bbb; line-height: 1.9em; vertical-align: middle; float: left; }
div#headline p.icon a:hover { background: #888; text-decoration: none; }
div#headline p.text { margin: 7px 0; padding: 0; line-height: 1.2em; }
div#headline p.more { text-align: right; }
div#headline p.more a { height: 2em; padding: 0 5px; font-size: 8pt; color: #fff; border: none;  border-radius: 3px; background: #09c; line-height: 2.1em; vertical-align: middle; display: block; float: right; }
div#headline p.more a:hover { }
	
div#makerindex { width: 230px; float: right; }
div#makerindex h2 { height: 24pt; margin: 10px 0 0 0; padding: 0 0 5px 0; font-size: 20pt; line-height: 24pt; vertical-align: middle; border-bottom: solid 1px #555; }
div#makerindex h2 span { margin-left: 20px; font-size: 8pt; color: #888; font-weight: normal; }
div#makerindex ul { margin: 0; padding: 0; list-style: none; }
div#makerindex ul li { margin: 0; padding: 0; border-bottom: solid 1px #000; }
div#makerindex ul li.top { border-top: solid 1px #000; }
div#makerindex ul li a { height: 30px; margin: 0; padding: 6px 0; color: #000; text-align: center; line-height: 30px; vertical-align: middle; display: block; text-decoration: none; }
div#makerindex ul li a.active {  background: #eee; }
div#makerindex ul li a.category { font-weight: bold; }
div#makerindex ul li a:hover { background: #eee; border: none; border-radius: 4px; }

div#content > p.icon { clear: both; float: left; }
div#content > p.icon a { height: 1.8em; margin-right: 5px; padding: 0 5px; font-size: 8pt; color: #fff; border: none;  border-radius: 3px; background: #bbb; line-height: 1.9em; vertical-align: middle; float: left; }
div#content > p.icon a:hover { background: #888; text-decoration: none; }

table.spec { width: 960px; border-collapse: collapse; table-layout: fixed; }
table.spec th { padding: 5px 10px; line-height: 1.5; text-align: left; border-top: solid 1px #ddd; border-bottom: solid 1px #ddd; }
table.spec td { padding: 5px 10px; line-height: 1.5; border-top: solid 1px #ddd; border-bottom: solid 1px #ddd; }

div#header a.cpplus2015home { width:163px; height:47px; background:url(common/backhome.gif) no-repeat; text-indent: -9999px; display: block; position: absolute; right: 0; top: 70px; overflow: hidden; }
div#header a.cpplus2015home:hover { background:url(common/backhome_on.gif) no-repeat; }

p.qa_q { margin: 10px 0 5px 0 !important; padding: 10px 0 10px 20px; color: #626060; border-left: solid 8px #626060; }
p.qa_q a { color: #09c; }
p.qa_a { margin: 5px 0 20px 0 !important; padding: 10px 0 10px 28px; }
p.qa_a a { color: #09c; }
p.qa_comment { margin: 30px 0 20px 0 !important; padding-left: 28px; color: #626060; }

ul#interview_index { margin: 60px 0 0 0; padding: 0; font-size: 9pt; list-style: none; }
ul#interview_index li { width: 239px; height: 2.5em; margin: 0 1px 1px 0; line-height: 2.6em; overflow: hidden; float: left; }
ul#interview_index li a { width: 239px; height: 2.5em; background: #626060; color: #fff; text-align: center; display: block; }
ul#interview_index li a.active { background: #b5b5b5; }
ul#interview_index li a:hover { background: #959595; text-decoration: none; }
ul#interview_index li.end { width: 240px; margin: 0 0 1px 0; }
ul#interview_index li.end a { width: 240px; }


/* masonry */
#tile {
	width: 960px;
}
#tile div.item {
	display: block;
	margin-bottom: 15px;
	background: #f9f9f7;
	width:  310px;
	overflow: hidden;
    border-radius: 6px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
}
#tile div.item a {
	color: black;
	display: block;
}
#tile div.item a:hover {
	text-decoration: none;
	background: #fdfcf6;
}
#tile div.item p {
	padding: 10px;
	text-align: left;
	line-height: 1.5;
	margin: 0;
}
#tile div.item p.maker { /* ribbon微妙だったら */
	padding: 5px 10px;
	line-height: 1;
	text-align: left;
	margin: 0;
	position: absolute;
	top: 0;
	right: 0;
	background: #f00000;
	color: white;
	font-weight: bold;
}
#tile div.item img {
	max-width: 100%;
    border-radius: 6px 6px 0 0;
    -webkit-border-radius: 6px 6px 0 0;
    -moz-border-radius: 6px 6px 0 0;
}

.ribbon {
	left: 0;
	top: 0;
	position: absolute;
	height: 310px; 
	width: 310px; 
	transform: rotateZ(45deg);
}
.ribbon span {
	text-align: center;
	display: block;
	width: 100%;
	height: 30px; 
	line-height: 30px; 
	background: #f00000;
	color: white;
	font-size: 15px;
	font-weight: bold;
}
.ribbon span.blue {
	background: #3b7ad9;
}

.ribbon span.nikon {
	background: #ffdb00;
	color: #000;
}
.ribbon span.canon {
	background: #cc0000;
	color: #fff;
}
.ribbon span.sony {
	background: #fc6140;
	color: #fff;
}
.ribbon span.fujifilm {
	background: #10ab04;
	color: #fff;
}
.ribbon span.olympus {
	background: #08107b;
	color: #ffd569;
}
.ribbon span.pentax {
	background: #d7083b;
	color: #fff;
}
.ribbon span.panasonic {
	background: #0438c2;
	color: #fff;
}
.ribbon span.sigma {
	background: #000;
	color: #fff;
}
.ribbon span.tamron {
	background: #fff;
	color: #1e428a;
}
.ribbon span.cosina {
	background: #eee;
	color: #000;
}
.ribbon span.kenkotokina {
	background: #5aa1d7;
	color: #fff;
}
