/* GLOBAL */
.cannes-contents {
}
.ct-pc .cannes-contents {
  padding: 0;
}
.ct-sp .cannes-contents {
  padding: 10px;
  font-size: 14px;
  line-height: 20px;
}
.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}

/* h1 */
.ct-pc .cannes-contents h1 {
  font-size: 20px;
  line-height: 30px;
}
.ct-sp .cannes-contents h1 span {
  font-size: 18px;
  line-height: 30px;
}

/* h2 */
.cannes-contents h2 a {
  color: #fff;
}
.ct-pc .cannes-contents h2 {
  background: url(./images/pc/midashi_haikei.png?v=201601130253);
  background-size: 100% 100%;
  font-size: 20px;
  line-height: 25px;
  padding: 15px 10px;
  color: #fff;
}
.ct-sp .cannes-contents h2 {
  background: url(./images/sp/midashi_haikei.png?v=201601130253);
  background-size: 100% 100%;
  font-size: 16px;
  font-weight: normal;
  line-height: 23px;
  padding: 10px;
  color: #fff;
}

/* section */
.cannes-contents .section {
  background: #F9F0D9;
  overflow: auto;
  color: #000;
}

/* listview */
.cannes-contents .listview {
  list-style: none;
  background: #F9F0D9;
}
.cannes-contents .listview li {
  border-top: 1px solid #B3AEAE;
}
.cannes-contents .listview li:first-child {
  border-top: none;
}
.cannes-contents .listview a,
.cannes-contents .listview .a {
  display: block;
  text-decoration: none;
  color: #000;
}
.cannes-contents .listview .a {
  background-color: #e8e8e8;
}
.ct-pc .cannes-contents .listview a,
.ct-pc .cannes-contents .listview .a {
  padding: 10px;
}
.ct-sp .cannes-contents .listview a,
.ct-sp .cannes-contents .listview .a {
  height: 64px;
}
.cannes-contents .listview a:hover {
  background: #fff;
}
.cannes-contents .listview a > div,
.cannes-contents .listview .a > div {
  overflow: hidden;
}
.ct-pc .cannes-contents .listview a > div,
.ct-pc .cannes-contents .listview .a > div {
  height: 80px;
}
.ct-sp .cannes-contents .listview a > div,
.ct-sp .cannes-contents .listview .a > div {
  padding-right: 10px;
}
.cannes-contents .listview .photo {
  float: left;
  margin-right: 10px;
}
.cannes-contents .listview img {
  display: block;
}
.ct-pc .cannes-contents .listview img {
  width: 80px;
}
.ct-sp .cannes-contents .listview img {
  width: 64px;
}
.cannes-contents .listview p {
  font-size: 13px;
  line-height: 20px;
  margin: 0;
}
.ct-sp .cannes-contents .listview p {
  display: none;
}
.cannes-contents .listview p.subject {
  color: #821921;
  font-weight: bold;
}
.cannes-contents .listview .a p.subject {
  color: #444;
}
.ct-sp .cannes-contents .listview p.subject {
  margin-top: 10px;
  display: block;
  font-size: 14px;
  line-height: 20px;
  height: 40px;
  overflow: hidden;
}
/* .cannes-panel */
.cannes-contents .cannes-panel {
  margin: 20px auto;
  text-align: center;
}

/* block */
.cannes-contents p {
  line-height: 140%;
  margin: 10px 0;
}
.cannes-contents .section > p,
.ct-sp .cannes-contents > p {
  margin: 10px;
}

/* openclose */
.ct-sp .openclose-target {
  display: none;
  overflow: auto;
}
.ct-sp .openclose-close {
  display: inline;
}
.ct-sp .openclose-open {
  display: none;
}
.ct-sp .ct-open .openclose-close {
  display: none;
}
.ct-sp .ct-open .openclose-open {
  display: inline;
}

/* button-link */
.button-link {
  margin: 10px auto;
  display: block;
  padding: 10px 16px;
  font-size: 1rem;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  color: #333;
  background: #fff;
  border-radius: 6px;
}
.ct-pc .button-link {
  width: 470px;
}
.ct-sp .button-link {
  width: 300px;
}

/* #medialist */
#medialist {
  box-sizing: border-box;
  margin-left: -5px;
  margin-right: -5px;
  list-style: none;
}
#medialist li {
  box-sizing: border-box;
  float: left;
  padding: 5px;
}
.ct-pc #medialist li {
  width: 33.3%;
}
.ct-sp #medialist li {
  width: 50%;
}
.ct-pc #medialist li:nth-of-type(3n+1) {
  clear: left;
}
.ct-sp #medialist li:nth-of-type(2n+1) {
  clear: left;
}
#medialist a {
  color: inherit;
  text-decoration: none;
}
#medialist a:hover {
  text-decoration: underline;
}
#medialist .photo {
  position: relative;
}
#medialist img {
  display: block;
  width: 100%;
}
#medialist .type-icon {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 20px;
  line-height: 20px;
  padding: 5px;
  background: #000;
  color: #fff;
  opacity: 0.4;
}
