@charset "UTF-8";
/*
 Share Style <
-------------------------------------------------
*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  box-sizing: border-box;
}
ul {
  list-style: none;
}
div,
p,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
table {
  padding: 0;
  margin: 0;
}
body {
  background: url("../images/back.png") repeat top left, linear-gradient(180deg, rgba(119, 205, 255, 1) 0%, rgba(186, 226, 249, 1) 15%);
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 750px) {
  body {
    background-position: top center, top;
    background-size: 38%, auto;
  }
}

#wrap {
  background-color: #fff;
  max-width: 700px;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  box-shadow: 0 0 20px rgba(51, 51, 51, 0.3);
}
#wrap img {
  max-width: 100%;
  width: auto;
  height: auto;
}
#wrap a,
#wrap a:link {
  color: #e67500;
}
#wrap a:hover {
  text-decoration: none;
}

@media screen and (max-width: 850px) {
  #wrap {
    width: 92%;
  }
}

/*=== header ===*/
#wrap header {
  max-width: 700px;
  position: relative;
  margin-inline: auto;
  background: #fff url("../images/headerBack.png") no-repeat bottom center;
  background-size: 110%;
}
#wrap header h1 {
  position: relative;
  top: 20px;
  left: -12%;
  width: 120%;
}
#wrap header .date {
  padding: 50px;
}
#wrap .tver {
  text-align: center;
  padding-bottom: 30px;
}
#wrap .tver span {
  display: block;
  font-size: clamp(0.7rem, 2.5vw, 0.9rem);
}
#wrap .tver span strong {
  font-size: clamp(0.8rem, 2.5vw, 0.95rem);
}

@media screen and (max-width: 850px) {
  #wrap header {
    background-size: 110%;
  }
  #wrap header h1 {
    top: 0;
    left: -6%;
    padding: 20px 0 0;
    width: 106%;
  }
  #wrap header .date {
    padding: 3% 5% 5%;
  }
  #wrap .tver {
    /* width: 50px; */
    margin: 0 auto;
    padding-bottom: 3%;
  }
}
@media screen and (max-width: 450px) {
  #wrap .tver img {
    width: 50px;
  }
}

#wrap .sectionBlock {
  margin-top: 50px;
  padding-bottom: 150px;
  z-index: 100;
  position: relative;
  max-width: 700px;
}
#wrap .sectionWrap {
  max-width: 700px;
  background-color: #fff;
  margin: 0 auto;
  padding: 50px 0 0;
  overflow: hidden;
}
#wrap .contentsWrap {
  position: relative;
}
#wrap .sectionBlock p {
  max-width: 600px;
  margin-inline: auto;
}

@media screen and (max-width: 750px) {
  #wrap .sectionBlock p {
    width: 90%;
  }
}

/* 番組内容 */
#wrap .sectionBlock.blue {
  background-color: #00a0e9;
}
#wrap .sectionBlock.blue::before {
  content: "";
  position: absolute;
  display: block;
  width: 110%;
  height: 150px;
  top: -50px;
  left: -5%;
  z-index: -1;
  background-color: #00a0e9;
  border-radius: 50% 50% 0 0;
}
#wrap .sectionBlock .icon_p {
  display: block;
  position: absolute;
  top: -80px;
  left: 0;
  right: 0;
  margin: auto;
  width: fit-content;
  margin: 0 auto;
}
#wrap .sectionBlock.blue h2 {
  text-align: center;
  padding: 20px 0 30px;
  margin-bottom: 20px;
  background: url("../images/line.png") no-repeat bottom center;
}
#wrap .sectionBlock.blue p {
  color: #fff;
  line-height: 1.9;
  font-size: clamp(0.85rem, 2.5vw, 1.1rem);
}
#wrap .oaPhoto {
  max-width: 600px;
  margin: 30px auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
}
#wrap .oaPhoto li {
  width: 48.5%;
  line-height: 0;
  margin-bottom: 2%;
}
#wrap .oaPhoto li img {
  border-radius: 20px;
}
@media screen and (max-width: 750px) {
  #wrap .sectionBlock.blue h2 img {
    width: 200px;
  }
  #wrap .oaPhoto {
    width: 90%;
  }
}
@media screen and (max-width: 450px) {
  #wrap .oaPhoto {
    flex-direction: row;
  }
  #wrap .oaPhoto li {
    width: 100%;
  }
}

/* 出演者 */
#wrap .sectionBlock.yellow {
  background-color: #fff100;
}
#wrap .sectionBlock.yellow::before {
  content: "";
  position: absolute;
  display: block;
  width: 110%;
  height: 150px;
  top: -130px;
  left: -5%;
  z-index: -1;
  background-color: #fff100;
  border-radius: 50% 50% 0 0;
}
#wrap .sectionBlock.yellow .contentsWrap {
  background-image: url(../images/icon_c01.png), url(../images/icon_c02.png);
  background-size: auto;
  background-repeat: no-repeat;
  background-position: 5% 0, bottom 0 right 20px;
}

#wrap .sectionBlock.yellow h2 {
  display: block;
  position: absolute;
  top: -180px;
  left: 0;
  right: 0;
  margin: auto;
  width: fit-content;
  margin: 0 auto;
}
#wrap .sectionBlock.yellow .castText {
  padding: 40px 0 10px;
  text-align: center;
  color: #333;
  line-height: 1.2;
  font-size: clamp(1.3rem, 3.5vw, 2rem);
  font-weight: 800;
}
#wrap .sectionBlock.yellow .castText ul li {
  padding: 10px 0;
}
#wrap .sectionBlock.yellow .castText span {
  display: block;
  font-size: clamp(0.9rem, 3.5vw, 1.4rem);
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  #wrap .sectionBlock.yellow h2 {
    width: 300px;
  }
  #wrap .sectionBlock.yellow .castText {
    padding: 0 0 30px;
  }
  #wrap .sectionBlock.yellow .castText ul li {
    padding: 8px 0;
  }
  #wrap .sectionBlock.yellow {
    padding-bottom: 100px;
  }
  #wrap .sectionBlock.yellow .contentsWrap {
    background-size: 50px, 60px;
  }
}
@media screen and (max-width: 450px) {
  #wrap .sectionBlock.yellow .contentsWrap {
    background-size: 30px, 40px;
    background-position: 10px 5px, bottom 10px right 10px;
  }
}

/* カンパニー一覧 */
#wrap .sectionBlock.green {
  padding-bottom: 50px;
  background-color: #45b035;
}
#wrap .sectionBlock.green::before {
  content: "";
  position: absolute;
  display: block;
  width: 110%;
  height: 150px;
  top: -130px;
  left: -5%;
  z-index: -1;
  background-color: #45b035;
  border-radius: 50% 50% 0 0;
}

#wrap .sectionBlock.green h2 {
  display: block;
  position: absolute;
  top: -70px;
  left: 0;
  right: 0;
  width: fit-content;
  margin: 0 auto;
}
#wrap .movieArea {
  padding-top: 60px;
}
#wrap .movieArea li {
  background-color: #fff;
  border: 1px solid #333;
  max-width: 600px;
  margin: 0 auto 30px;
  padding: 30px 30px 15px;
  border-radius: 30px;
}

#wrap .youtube {
  margin: 0 auto;
}
#wrap .youtubearea {
  width: 100%;
  aspect-ratio: 16 / 9;
}
#wrap .youtubearea iframe {
  width: 100%;
  height: 100%;
}
#wrap .title {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#wrap .title .name {
  color: #333;
  font-size: clamp(1rem, 3.5vw, 1.6rem);
  font-weight: 700;
}
#wrap .link {
  position: relative;
}
#wrap .link::before {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  left: -23px;
  width: 18px;
  height: 18px;
  background: url("../images/link.png") no-repeat left top;
  background-size: cover;
}

@media screen and (max-width: 750px) {
  #wrap .sectionBlock.green h2 {
    width: 90%;
    top: -90px;
  }
  #wrap .movieArea {
    padding-top: 20px;
    width: 90%;
    margin: 0 auto;
  }
  #wrap .movieArea li {
    max-width: 600px;
    padding: 15px 15px 15px;
    border-radius: 30px;
  }
  #wrap .title {
    flex-direction: column;
  }
  #wrap .title .name {
    padding-bottom: 2px;
  }
  #wrap .link {
    font-size: clamp(0.7rem, 3.5vw, 0.8rem);
  }
  #wrap .link::before {
    top: 5px;
    left: -17px;
    width: 13px;
    height: 13px;
  }
}
