@charset "utf-8";
/*--------------------------------------------
 Reset
--------------------------------------------*/
a img { border: none; }
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td { padding: 0; margin: 0; }
img, a img { max-width: 320px; height: auto; vertical-align: top; border: 0 none; }
a { outline: none; -webkit-touch-callout: none; -webkit-tap-highlight-color: rgba(0,0,0,0); }
li { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: normal; }
/*--------------------------------------------
 Base
--------------------------------------------*/
.left {
  float: left;
}
.right {
  float: right;
}
.clearfix {
  display: inline-block;
}
.clearfix::after {
  content: '・';
  display: block;
  clear: both;
  height: 0;
  line-height: 0;
  visibility: hidden;
}
/* Hides from IE-mac \*/
* html.clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */
/*--------------------------------------------
 Common
--------------------------------------------*/
html, body {
  padding: 0;
  margin: 0;
  background: #eff7fb;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
p {
  font-size: 11px;
  letter-spacing: 1.2px;
  line-height: 1.46;
}
p.add_cap {
  font-size: 8px;
  letter-spacing: 0.08em;
  line-height: 1.65em;
  margin: 15px 0 -10px;
}
.lnk_blank {
  color: #10068d;
  font-size: 9px;
  float: left;
  margin-top: -1px;
}
.lnk_blank::before {
  content: '';
  display: block;
  float: left;
  width: 11px;
  height: 11px;
  margin-right: 5px;
  background: url("../images/arrow_r.gif") no-repeat left top;
  background-size: contain;
}
.lnk_blank::after {
  content: '';
  display: block;
  float: right;
  width:9px;
  height:9px;
  margin-left: 2px;
  background: url("../images/blank.gif") no-repeat left top;
  background-size: 80% auto;
}
.touchstart {
  opacity: 0.5;
}
.touchend {
  opacity: 1;
}
/* コンテナー
----------------------------------------*/
#baseWrap {
  position: relative;
  width: 320px;
  margin: 0 auto;
  background: #f2f9fc;
  overflow: hidden;
}
#bgwrap1 {
  background: url(../images/bgwrap1.png) no-repeat;
  background-position:center 125px;
  background-size: contain;
}
#bgwrap2 {
  background: url(../images/bgwrap2.png) no-repeat;
  background-position:center bottom;
  background-size: cover;
}
/* TOPボタン
----------------------------------------*/
.totop {
  display: block;
  width: 45px;
  margin: 35px auto 0;
}
#cts03_2 + .totop {
  margin-top: 55px;
}
/* #anchor
----------------------------------------*/
#anchor > ul {
  width: 320px;
  margin: 0 auto;
}
#anchor > ul > li > a {
  display: block;
}
/* #products
----------------------------------------*/
.products {
  margin-top: 40px;
}
.products > li > a {
  display: block;
}
/*--------------------------------------------
 Header
--------------------------------------------*/
header {
  position: relative;
  width: 300px;
  line-height: 1;
  padding: 10px 10px 15px;
  background: url(../images/kv_42.jpg) no-repeat center top;
  background-size: contain;
}
header > h1 {
  display: block;
  width: 43px;
  line-height: 1;
}
header > h1 > * > img {
  display: block;
}
header #mainvisual > h2 {
  width: 100%;
  text-align: center;
  padding-bottom: 70px;
  margin: -4px auto 0;
}
header #mainvisual > h2 > img + img {
  margin-top: -1.6px;
  margin-left: -1px;
}
header #mainvisual #mv_newaward {
  margin-top: 30px;
}
header #mainvisual #mv_newaward > img {
  display: block;
  margin: 0 auto;
}
header #mainvisual #mv_about > img {
  display: block;
  margin: 20px auto 0;
}
/*--------------------------------------------
 #Cts01（募集要項・スケジュール）
--------------------------------------------*/
#cts01 .tl > h2 {
  width: 291px;
  height: 38px;
  padding: 80px 0 0;
  margin: 35px auto 0;
  background: url(../images/cts01tl_img.png?2) center top no-repeat;
  background-size: auto 51.3%;
}
#cts01 .tl > h2 > img {
  display: block;
  margin: 0 auto;
}
/* 共通
----------------------------------------*/
#cts01 .container {
  margin: 0px 25px;
}
#cts01 .container h3 {
  width: 285px;
  height: 13px;
  padding: 6px 0 6px 10px;
  background: url(../images/cts01h3_bg.png) left top no-repeat;
  background-size: contain;
}
#cts01 .container .photo_p {
  width: 320px;
  margin: 20px  0 0 -9px;
}
#cts01 .container .photo_dl {
  width: 270px;
  margin: 0px auto;
}
#cts01 .container .photo_dl .img {
  display: block;
  margin: 20px auto 0;
}
#cts01 .container .photo_dl .cap {
  font-size: 8px;
  letter-spacing: 0.1px;
  margin-top: 5px;
}
#cts01 .container > * > * > ul {
  margin: 15px 0 0 0;
}
#cts01 .container > * > * > ul > li {
  position: relative;
  font-size: 11px;
  letter-spacing: 0.05em;
  line-height: 1.5em;
  padding-left: 1em;
  margin-top: 1.5em;
}
#cts01 .container > * > * > ul > li > a {
  font-size: 9.5px;
  text-decoration: underline;
  word-break: break-all;
}
#cts01 .container > * > * > ul > li > small {
  font-size: 8px;
}
#cts01 .container > * > * > ul > li::before {
  content: '・';
  position: absolute;
  left: -0.1em;
  font-size: 10px;
}
/* イントロ
----------------------------------------*/
#cts01 .intro > p {
  margin-top: 25px;
}
#cts01 .intro > p + p {
  margin-top: 0.9em;
}
#cts01 .intro .prevbtn {
  margin-top: 25px;
}
#cts01 .intro .prevbtn > a {
  display: block;
}
#cts01 .intro .category {
  display: block;
}
#cts01 .intro .p1 .category {
  margin: 40px auto 0;
}
#cts01 .intro .p2 .category {
  margin: 20px auto 0;
}
#cts01 .intro > * > h4 {
  text-align: center;
  margin-top: 7.5px;
}
#cts01 .intro .p1 > p,
#cts01 .intro .p2 > p {
  font-size: 0.58em;
  letter-spacing: 0.1em;
  line-height: 1.9em;
  margin-top: 13px;
}
#cts01 .intro .p1 >  p + p,
#cts01 .intro .p2 >  p + p {
  margin-top: 0.9em;
}
#cts01 .intro .images {
  margin: 35px 0 0 -11px;
}
/* 最優秀賞 ソニー4K賞
----------------------------------------*/
#cts01 .award1 .category {
  display: block;
  margin: 50px auto 0;
}
#cts01 .award1 h2 {
  text-align: center;
  margin-top: 12.5px;
}
#cts01 .award1 h3 {
  margin: 0 auto;
}
#cts01 .award1 .clm01 > h3 {
  margin-top: 25px;
}
#cts01 .award1 .clm02 > h3 {
  margin-top: 15px;
}
#cts01 .award1 .clm03 > h3 {
  margin-top: 30px;
}
#cts01 .award1 p {
  margin-top: 12px;
}
#cts01 .award1 p + p {
  margin-top: 0.7em;
}
#cts01 .award1 p.tip {
  font-size: 7.8px;
  line-height: 1.8em;
  margin-top: -7px;
}
#cts01 .award1 .btnarea {
  margin-top: 25px;
}
#cts01 .award1 .btnarea > a {
  display: block;
}
/* ソニーネクストフォトグラファー賞
----------------------------------------*/
#cts01 .award2 .category {
  display: block;
  margin: 55px auto 0;
}
#cts01 .award2 h2 {
  text-align: center;
  margin-top: 12.5px;
}
#cts01 .award2 h3 {
  margin: 0 auto;
}
#cts01 .award2 .p1 > h3 {
  width: 287px;
  height: 30px;
  padding: 9px 0 8px 9px;
  margin-top: 25px;
  background: url(../images/cts02h3_bg.png) left top no-repeat;
  background-size: contain;
}
#cts01 .award2 .p3 h3 {
  margin-top: 30px;
}
#cts01 .award2 p {
  margin-top: 12px;
}
#cts01 .award2 p + p {
  margin-top: 0.7em;
}
#cts01 .award2 .p1 .img {
  margin: 7px 0 0 50px;
}
#cts01 .award2 .cap h5{
  font-weight: bold;
  margin-bottom: 4px;
}
#cts01 .award2 .cap p {
  font-size: 8px;
  line-height: 10px;
  margin-bottom: 5px;
  opacity: 1 !important;
}
#cts01 .award2 .btnarea {
  margin-top: 25px;
}
#cts01 .award2 .btnarea > a {
  display: block;
}
/*--------------------------------------------
 #cts2（4Kテレビでの～新スタイル）
--------------------------------------------*/
#cts02 .tl > h2 {
  width: 212px;
  height: 38px;
  padding: 62px 0 0;
  margin: 35px auto 0;
  background: url(../images/cts02tl_img.png?2) center top no-repeat;
  background-size: auto 46.07%;
}
#cts02 .tl > h2 > img {
  display: block;
  margin: 0 auto;
}
#cts02 .tl .kv {
  width: 270px;
  margin: 20px auto 0;
}
/* 共通
----------------------------------------*/
#cts02 .container {
  margin: 0px 25px;
}
#cts02 .container h3 {
  width: 287px;
  height: 30px;
  padding: 8px 0 8px 8px;
  margin-top: 14px;
  background: url(../images/cts02h3_bg.png) left top no-repeat;
  background-size: contain;
}
#cts02 .container .clm01 > h3 {
  margin-top: 18px;
}
#cts02 .container .clm02 > h3 {
  height: 33px;
  padding: 6px 0 7px 10px;
}
#cts02 .container .clm03 > h3,
#cts02 .container .clm04 > h3 {
  height:29px;
  padding: 9px 0 8px 10px;
}
#cts02 .container .txt_p1 {
  margin-top: 12px;
}
#cts02 .container .clm03 .clm03txt {
  letter-spacing: 1.0px;
}
#cts02 .container .clm04 .clm04txt {
  letter-spacing: 0.8px;
}
#cts02 .container p + small.indent {
  display: block;
  font-size: 0.66em;
  line-height: 1.6;
  text-indent: -1em;
  padding-left: 1em;
  margin-top: 2px;
}
#cts02 .container .photo_p {
  width: 270px;
  text-align: center;
  margin-top: 20px;
}
/* 豊富な 画質調整
----------------------------------------*/
#cts02 .container .clm05 #enhancement {
  position: relative;
  width: 320px;
  height: 169px;
  margin-bottom: 40px;
}
#cts02 .container .clm05 #enhancement h3 {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 102px;
  height: 70px;
  text-align: center;
  padding: 32px 0 0 0;
  margin: -51px 0 0 -51px;
  background: url(../images/cts02stl05_bg.gif) center center no-repeat;
  background-size: contain;
}
#cts02 .container .clm05 #enhancement ul li {
  position: absolute;
  line-height: 1.0;
}
#cts02 .container .clm05 #enhancement .big {
  color: #2c4594;
  font-size: 13px;
  letter-spacing: -0.03em;
  line-height: 1.1em;
}
#cts02 .container .clm05 #enhancement .small {
  color: #2c4594;
  font-size: 10px;
  opacity: 0.6;
}
#cts02 .container .clm05 #enhancement #ehc01 {
  top: 2px;
  left: 24px;
  text-align: right;
}
#cts02 .container .clm05 #enhancement #ehc02 {
  top: 34px;
  left: 57px;
}
#cts02 .container .clm05 #enhancement #ehc03 {
  top: 65px;
  left: 53px;
}
#cts02 .container .clm05 #enhancement #ehc04 {
  top: 88px;
  left: 58px;
}
#cts02 .container .clm05 #enhancement #ehc05 {
  top: 100px;
  left: 24px;
}
#cts02 .container .clm05 #enhancement #ehc06 {
  top: 121px;
  left: 40px;
  text-align: right;
}
#cts02 .container .clm05 #enhancement #ehc07 {
  top: 155px;
  left: 111px;
}
#cts02 .container .clm05 #enhancement #ehc08 {
  top: 5px;
  left: 169px;
}
#cts02 .container .clm05 #enhancement #ehc09 {
  top: 25px;
  left: 209px;
}
#cts02 .container .clm05 #enhancement #ehc10 {
  top: 62px;
  left: 229px;
}
#cts02 .container .clm05 #enhancement #ehc11 {
  top: 83px;
  left: 228px;
}
#cts02 .container .clm05 #enhancement #ehc12 {
  top: 106px;
  left: 256px;
}
#cts02 .container .clm05 #enhancement #ehc13 {
  top: 123px;
  left: 215px;
}
#cts02 .container .clm05 #enhancement #ehc14 {
  top: 143px;
  left: 192px;
}
/* あなたも４Kで見る写真体験！
----------------------------------------*/
#cts02 .container .clm06 > h3 {
  width: 270px;
  height: auto;
  text-align: center;
  padding: 0;
  margin-top: 30px;
  background: none;
}
#cts02 .container .clm06 > h3 #clm06tl1 {
  margin: 23px 0 5px 6px;
}
#cts02 .container .clm06 > h3 #clm06tl3 {
  margin-left:-2px;
}
#cts02 .container .clm06 > h3 #clm06tl2_prefix {
  margin-bottom: 6px;
}
#cts02 .container .clm06 > h4 {
  margin-top: 30px;
}
#cts02 .container .clm06 > h4 > img {
  display: block;
  margin: 0 auto;
}
#cts02 .container .clm06 #exp_place {
  width: 270px;
  margin: 0 auto;
}
#cts02 .container .clm06 #exp_place > li {
  margin-top: 15px;
}
#cts02 .container .clm06 #exp_place > li:first-child {
  margin-top: 20px;
}
#cts02 .container .clm06 #exp_place > li > dl .place_img {
  margin-right: 15px;
}
#cts02 .container .clm06 #exp_place > li > dl .place_nm {
  font-size: 10.4px;
  line-height: 1.2;
  margin-bottom: 4px;
}
#cts02 .container .clm06 #exp_place > li > dl .kochira .lnk_blank {
  width: 97px;
}
#cts02 .container .clm06 > h5 {
  width: 270px;
  color: #2c4594;
  font-size: 0.66em;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-align: left;
  margin: 22px auto 0;
}
#cts02 .container .clm06 #attention {
  width: 270px;
  margin: 8px auto 0;
}
#cts02 .container .clm06 #attention > li {
  font-size: 8px;
  letter-spacing: 0.8px;
  line-height: 1.6em;
  text-indent: -1em;
  padding-left: 1em;
}
/*--------------------------------------------
 #cts3（募集要項・スケジュール）
--------------------------------------------*/
/* 募集要項・スケジュール
----------------------------------------*/
/* タイトル
-----------------------------*/
#cts03 .tl > h2:not(#exhibition) {
  width: 220px;
  height: 15px;
  text-align: center;
  padding: 76px 0 0;
  margin: 35px auto 0;
  background: url(../images/cts03tl_bg1.png?2) calc(50% + 6px) top no-repeat;
  background-size: 25.5%;
}
#cts03 .tl > h2 > img {
  display: block;
  margin: 0 auto;
}
/* 募集要項
-----------------------------*/
#cts03 .term {
  text-align: center;
  margin-top: 22px;
}
#cts03 .host {
  font-size: 8.1px;
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: center;
  white-space: nowrap;
  margin-top: 20px;
}
#cts03 .host a {
  color: #000;
  text-decoration: underline;
}
#cts03 .lnk_btn {
  padding: 0 25px;
  margin-top: 23px;
}
#cts03 .lnk_btn > a,
#cts03 .lnk_btn > a > img {
  display: block;
}
/* スケジュール
-----------------------------*/
#cts03 .schedule > h4 {
  color: #2c4594;
  font-size: 1em;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-align: center;
  margin-top: 30.5px;
}
#cts03 .schedule dl {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  width: 270px;
  margin: 7px auto 0;
  border-top: #2c4594 1px solid;
}
#cts03 .schedule dt {
  display: flex;
  align-items: center;
  width: 85px;
  color: #2c4594;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0;
  text-align: left;
  padding: 5px 0;
  border-bottom: #2c4594 1px solid;
}
#cts03 .schedule dd {
  width: 185px;
  color: #1a1a1a;
  font-size: 9px;
  letter-spacing: 0;
  text-align: left;
  padding: 5px 0;
  border-bottom: #2c4594 1px solid;
}
/*--------------------------------------------
 #cts_tech（撮影テクニック）
--------------------------------------------*/
#cts_tech {
  margin: 0 25px;
}
#cts_tech > h3 {
  margin: 22px auto 0;
  padding: 57.5px 0 0;
  background: url(../images/cts_tech_tl_img.png?2) center top no-repeat;
  background-size: auto 55.3%;
}
#cts_tech > h3 > img {
  display: block;
  margin: 0 auto;
}
#cts_tech > p {
  font-size: 10.5px;
  line-height: 1.45;
  margin-top: 15px;
}
#cts_tech .lnk_btn {
  margin-top: 23px;
}
#cts_tech .lnk_btn > a,
#cts_tech .lnk_btn > a > img {
  display: block;
}
#cts_tech .cap {
  font-size: 8px;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1.6;
  white-space: nowrap;
  margin-top: 15px;
}
/*--------------------------------------------
 #cts3_2（関連製品はこちら）
--------------------------------------------*/
#cts03_2 .container .clm03 {
  letter-spacing: 0.09em;
}
#cts03_2 .container .clm03 > h3 {
  width: 270px;
  margin: 50px auto 0;
}
#cts03_2 .container .clm03 > h3 > img {
  display: block;
  margin: 0 auto;
}
#cts03_2 .container .clm03 > ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 320px;
  margin: 0 auto;
}
#cts03_2 .container .clm03 > ul > li {
  width: 160px;
  margin-top: 42.5px;
}
#cts03_2 .container .clm03 > ul > li:nth-child(-n + 2) {
  margin-top: 30px;
}
#cts03_2 .container .clm03 > ul > li #tv_img {
  margin: 5px 0 0 29px;
}
#cts03_2 .container .clm03 > ul > li #tv_txt {
  margin: 8px 0 0 48px;
}
#cts03_2 .container .clm03 > ul > li #camera_img {
  margin: 7px 0 8px 30.5px;
}
#cts03_2 .container .clm03 > ul > li #camera_txt {
  margin: 23px 0 0 9px;
}
#cts03_2 .container .clm03 > ul > li #camera_txt .lnk_blank::before {
  margin-right: 2px;
}
#cts03_2 .container .clm03 > ul > li.center {
  clear: both;
  width: 100%;
  text-align: center;
}
#cts03_2 .container .clm03 > ul > li #lenz_txt {
  margin: 10px 0 0 93px;
}
/*--------------------------------------------
 Footer
--------------------------------------------*/
footer {
  position: relative;
  margin: 38px 0 13px;
}
/* 特別企画審査員写真家による講評会
----------------------------------------*/
#enquete:not(.reset) a img {
  position: fixed;
  right: 24px;
  bottom: -80px;
  font-size: 0;
  margin: 0;
  transition: bottom .5s cubic-bezier(0.35, 0.15, 0.2, 1);
  z-index: 1;
}
#enquete.fix a img {
  bottom: 0;
}
footer #comment .lnk_btn {
  width: 270px;
  margin: 0 auto;
}
/* コピーライト
----------------------------------------*/
footer #copyright {
  margin-top: 35px;
}
footer #copyright > img {
  display: block;
  margin: 0 auto;
}