@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Great+Vibes&family=Lato:wght@100;400&family=Noto+Sans+JP:wght@300;500&family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap");
/***reset***/
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

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;
  background: transparent; }

body {
  line-height: 1; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; }

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

input, select {
  vertical-align: middle; }

/***setting***/
.floatbox {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  transition: 0.2s ease-in-out; }

*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

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, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline; }

html, body {
  height: 100%; }

body {
  position: relative;
  padding: 0 0 0;
  line-height: 1;
  text-align: center;
  color: #2b2d29;
  background: white;
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif, 'Font Awesome', 'Font Awesome 5 Free','Font Awesome 5 Brands', 'Font Awesome';
  font-weight: 300;
  scroll-behavior: smooth; }

article, aside, dialog, figure, footer, header, hgroup, nav, section {
  display: block; }

ul, ol {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none; }

a {
  margin: 0;
  padding: 0;
  color: #2b2d29;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  border: 0; }

a:hover {
  color: #2ba3a3; }

a:hover img {
  opacity: 0.5; }

a:focus, *:focus {
  outline: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

:root {
  font-size: 13px !important; }

/* wrapper
--------------------------- */
#wrapper {
  padding: 4rem 0 0 0;
  min-height: 100%; }

/* stage
--------------------------- */
.stage {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: center; }

/* panel
--------------------------- */
.panel1 {
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  max-width: 1000px; }

.panel, .panel2 {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1000px; }

/* Floatバグ回避用
--------------------------- */
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

/* タイトルスタイル
--------------------------- */
.ttl-type01 {
  padding: 3.5em 0.5em 1em;
  font-size: 2.4em;
  line-height: 1.2em;
  font-weight: 300;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2); }

/* toTop
--------------------------- */
#toTop {
  position: fixed;
  right: 5%;
  bottom: 3%;
  opacity: 0;
  z-index: 1000;
  text-align: center;
  transition: all 0.4s ease-in-out;
  z-index: 8887; }

.to-top-on #toTop {
  bottom: 2%;
  opacity: 1; }

#toTop a {
  display: block;
  width: 60px;
  height: 60px;
  color: rgba(41, 49, 47, 0.8);
  font-size: 24px;
  line-height: 60px;
  text-decoration: none;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
  cursor: default; }

.to-top-on #toTop a {
  cursor: pointer; }

#toTop a:hover {
  background-color: rgba(255, 255, 255, 0.8); }

#pos {
  position: absolute;
  left: -9999px;
  top: -9999px;
  height: 0;
  visibility: hidden; }

@media screen and (min-width: 0\0 ) and (min-resolution: 72dpi) {
  /*IE9-11用ハック*/
  body {
    padding: 4em 0 0; }

  #wrapper {
    padding: 0; } }
.symbols, #infoLive dt figure::before, #infoLive dt figure::after, #infoLive dd a::before, #infoLive dd span::before, #archiveLive dl.thum dt a figure::after, #archiveLive dd a::before {
  font-family: 'Material Symbols Outlined';
  font-weight: 300;
  font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' -25, 'opsz' 24; }

body {
  color: #534741;
  background: #f4f3e9; }
  body a:hover {
    color: #c5497b; }

header {
  padding: 3rem 0;
  width: 100%; }
  header #liveTitle {
    margin: 0 auto;
    position: relative;
    width: 96%;
    max-width: 540px; }
    header #liveTitle h1 {
      padding: 0 0 2rem;
      width: 100%; }
      header #liveTitle h1 img {
        margin: 0;
        width: 75%;
        max-width: 420px; }
    header #liveTitle h2 {
      position: relative;
      margin: 0 autos;
      width: 100%;
      padding: 0.8rem;
      font-size: 1.6rem;
      font-weight: 300;
      border-radius: 0 0 0.8rem 0.8rem;
      z-index: 100;
      color: white;
      background: linear-gradient(125deg, #c5497b, #80284b); }
      header #liveTitle h2 em {
        position: relative;
        font-style: normal;
        font-weight: 500; }
      header #liveTitle h2 span {
        margin-left: 0.8em;
        font-size: 0.7em; }
    header #liveTitle p {
      position: relative;
      width: 100%;
      text-align: left;
      display: block;
      padding: 2.4em 0.8em 0;
      font-size: 1.1rem;
      line-height: 1.8em; }
    header #liveTitle #movieBox {
      position: relative;
      display: block;
      padding: 56.25% 0 0;
      width: 100%;
      background: rgba(0, 0, 0, 0.1);
      border-radius: 0.8rem 0.8rem 0 0;
      overflow: hidden; }
      header #liveTitle #movieBox iframe#newlive {
        position: absolute;
        margin: auto;
        top: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1; }

@media screen and (min-width: 600px) {
  header #liveTitle {
    min-width: 540px;
    max-width: 760px; }
    header #liveTitle h1 {
      padding: 0 0 3rem; }
    header #liveTitle h2 {
      margin: 0 auto;
      padding: 0 1.6rem;
      height: 4rem;
      line-height: 4rem; }
    header #liveTitle p {
      font-size: 1.4rem;
      padding: 2.4em 0 1.6em; }
    header #liveTitle #movieBox {
      border-radius: 0.8rem 0.8rem 0 0; } }
@media screen and (min-width: 1280px) {
  header {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    padding: 6rem 3rem;
    width: 100%;
    max-width: 1600px; }
    header #liveTitle {
      position: relative;
      padding: 0 0 0 40%;
      width: 100%;
      max-width: 1600px; }
      header #liveTitle h1 {
        position: absolute;
        top: 0;
        left: 0;
        width: 40%;
        padding: 1rem 0 3rem 2rem;
        text-align: left;
        border-bottom: 1px solid #c5497b; }
        header #liveTitle h1 img {
          margin: 0;
          width: 75%; }
      header #liveTitle h2 {
        position: absolute;
        left: 5%;
        bottom: 1.2rem;
        width: calc(35% - 2rem);
        border-radius: 0.6rem 0 0 0.6rem;
        text-align: left; }
        header #liveTitle h2::before {
          content: "";
          position: absolute;
          top: 0;
          right: -1.4rem;
          background: #80284b;
          width: 1.4rem;
          height: 4rem;
          clip-path: polygon(0 0, 100% 50%, 0 100%);
          z-index: 2; }
      header #liveTitle p {
        position: absolute;
        top: 48%;
        left: 0;
        width: 40%;
        padding: 1.6em 0.8em;
        text-align: left; }
      header #liveTitle #movieBox {
        border-radius: 0.8rem; } }
main {
  position: relative;
  display: block;
  width: 100%; }

#infoLive.show-ols .csk, #infoLive.show-csk .ols, #archiveLive.show-ols .csk, #archiveLive.show-csk .ols {
  display: none; }

#infoLive {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin: 0 auto;
  padding: 2rem 0 6rem;
  width: 96%;
  max-width: 400px; }
  #infoLive dl {
    position: relative;
    margin: 0 1rem 2rem;
    padding: 0 0 2.4rem;
    width: 100%;
            /*
background: $white1;*/ }
    #infoLive dl.before dt figure::before {
      content: "\e032";
      width: 1em;
      height: 1em;
      background: rgba(41, 49, 47, 0);
      border-radius: 0;
      opacity: 0; }
    #infoLive dl.before dt figure::after {
      opacity: 0; }
    #infoLive dl.before dt span::after {
      content: "生配信予告";
      color: #86ad43; }
    #infoLive dl.before dt a:hover {
      color: #86ad43; }
      #infoLive dl.before dt a:hover figure::before {
        opacity: 1; }
      #infoLive dl.before dt a:hover figure::after {
        opacity: 0; }
  #infoLive dt {
    text-align: left; }
    #infoLive dt figure {
      position: relative;
      padding: 56.25% 0 0;
      text-align: center;
      border-radius: 0.8rem;
      overflow: hidden;
      box-shadow: 0 0.2rem 0.6rem rgba(41, 49, 47, 0.2); }
      #infoLive dt figure img {
        display: block;
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        width: 100%;
        height: auto;
        transition: filter 0.2s ease-in-out;
        z-index: 1; }
      #infoLive dt figure::before, #infoLive dt figure::after {
        display: block;
        content: "";
        margin: auto;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        color: #f4f3e9;
        font-size: 6rem;
        opacity: 0.9;
        transition: opacity 0.2s ease-in-out; }
      #infoLive dt figure::before {
        left: 0;
        width: 0.75em;
        height: 0.75em;
        background: rgba(41, 49, 47, 0.5);
        border-radius: 50%;
        z-index: 10; }
      #infoLive dt figure::after {
        left: 2%;
        background: #f4f3e9;
        width: calc(tan(60deg) * 2rem / 2);
        height: 2rem;
        clip-path: polygon(0 0, 100% 50%, 0 100%);
        opacity: 0.9;
        z-index: 20; }
    #infoLive dt strong,
    #infoLive dt em,
    #infoLive dt span {
      max-width: 100%;
      overflow: hidden; }
    #infoLive dt span {
      display: block;
      padding: 1rem 0.5rem 0;
      font-size: 1rem; }
      #infoLive dt span::after {
        padding-left: 0.5em;
        content: "見逃し配信";
        color: #c5497b;
        font-size: 0.8em;
        font-weight: 500; }
    #infoLive dt strong {
      display: block;
      padding: 0.5rem;
      line-height: 1.3em;
      white-space: nowrap; }
    #infoLive dt em {
      display: block;
      padding: 0 0.5rem;
      font-size: 0.8em;
      line-height: 1.5em;
      font-style: normal;
      white-space: nowrap; }
    #infoLive dt a {
      display: block;
      padding: 0 0 1rem; }
      #infoLive dt a:hover {
        color: #c5497b; }
        #infoLive dt a:hover figure img {
          filter: brightness(70%);
          opacity: 1; }
        #infoLive dt a:hover figure::before {
          opacity: 0; }
        #infoLive dt a:hover figure::after {
          opacity: 1; }
  #infoLive dd {
    display: flex;
    flex-wrap: wrap;
    position: relative;
    width: 100%;
    padding: 0;
    font-size: 0; }
    #infoLive dd a, #infoLive dd span {
      position: relative;
      display: inline-block;
      margin: 0;
      padding: 0 0.8rem;
      width: 100%;
      font-size: 1.4rem;
      font-weight: 300;
      line-height: 3rem;
      color: white;
      border-radius: 0.5rem;
      background: rgba(83, 71, 65, 0.6); }
      #infoLive dd a::before, #infoLive dd span::before {
        content: "\f090";
        display: block;
        position: absolute;
        margin: auto;
        top: 0;
        left: 0;
        bottom: 0;
        width: 3rem;
        height: 1em;
        font-size: 2.4rem;
        line-height: 1em;
        text-align: center; }
      #infoLive dd a.book, #infoLive dd span.book {
        margin-right: 0.5rem;
        width: 3rem;
        height: 3rem;
        line-height: 3rem;
        /*f1c6 e415 f090*/ }
        #infoLive dd a.book::before, #infoLive dd span.book::before {
          content: "\ea19"; }
      #infoLive dd a.book + .cal, #infoLive dd a.book + .play, #infoLive dd span.book + .cal, #infoLive dd span.book + .play {
        width: calc(100% - 3.5rem); }
    #infoLive dd a {
      transition: color 0.2s ease-in-out, font-weight 0.2s ease-in-out, background 0.2s ease-in-out;
      box-shadow: 0 0.2rem 0.6rem rgba(41, 49, 47, 0.2); }
      #infoLive dd a:hover {
        color: white;
        font-weight: 500;
        background: #534741; }
      #infoLive dd a.cal {
        background: #86ad43; }
        #infoLive dd a.cal::before {
          content: "\ebcc"; }
        #infoLive dd a.cal:hover {
          background: rgba(134, 173, 67, 0.7); }
      #infoLive dd a.play {
        background: #c5497b; }
        #infoLive dd a.play::before {
          content: "\e04a"; }
        #infoLive dd a.play:hover {
          background: #80284b; }
    #infoLive dd span {
      background: rgba(41, 49, 47, 0.2); }
      #infoLive dd span.book {
        cursor: not-allowed; }

@media screen and (min-width: 640px) {
  #infoLive {
    max-width: 800px; }
    #infoLive dl {
      width: calc(50% - 2rem); } }
@media screen and (min-width: 960px) {
  #infoLive {
    max-width: 1200px; }
    #infoLive dl {
      width: calc(33.33% - 2rem); } }
@media screen and (min-width: 1280px) {
  #infoLive {
    max-width: 1600px; }
    #infoLive dl {
      width: calc(25% - 2rem); } }
#archiveLive {
  display: block;
  margin: 3rem auto 6rem;
  width: 96%;
  max-width: 600px;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 0.8em;
  box-shadow: 0 0 0.8rem rgba(41, 49, 47, 0.2);
  overflow: hidden; }
  #archiveLive dl {
    min-height: 11.1rem;
    position: relative;
    border-top: 1px solid rgba(41, 49, 47, 0.2);
    background: white; }
    #archiveLive dl:first-child {
      border-top: none; }
    #archiveLive dl.thum dt {
      padding: 1rem 1.6rem 1rem 12rem !important; }
      #archiveLive dl.thum dt a figure {
        display: block;
        position: absolute;
        margin: auto;
        top: 1rem;
        left: 1rem;
        width: auto;
        height: 7rem; }
        #archiveLive dl.thum dt a figure img {
          width: auto;
          height: 100%;
          transition: filter 0.2s ease-in-out; }
        #archiveLive dl.thum dt a figure::after {
          display: block;
          margin: auto;
          position: absolute;
          top: 0;
          right: 0;
          bottom: 0;
          left: 0;
          font-size: 3rem;
          line-height: 1em;
          color: #f4f3e9;
          width: 1em;
          height: 1em;
          content: "\e1c4";
          opacity: 0;
          transition: opacity 0.2s ease-in-out; }
      #archiveLive dl.thum dt a:hover figure img {
        filter: brightness(70%);
        opacity: 1; }
      #archiveLive dl.thum dt a:hover figure::after {
        opacity: 1; }
  #archiveLive dt {
    display: block;
    position: relative;
    padding: 0 1.6rem;
    height: 100%;
    text-align: left;
    vertical-align: middle; }
    #archiveLive dt a {
      display: block;
      width: 100%;
      height: 100%; }
    #archiveLive dt figure {
      display: none; }
    #archiveLive dt span {
      display: block;
      font-size: 1.4rem;
      font-weight: 300; }
    #archiveLive dt strong {
      display: block;
      padding: 0.5em 0;
      font-size: 1.4rem;
      line-height: 1.3em; }
    #archiveLive dt em {
      display: block;
      font-size: 1rem;
      line-height: 1.5em;
      font-style: normal;
      font-weight: 300; }
  #archiveLive dd {
    position: absolute;
    margin: auto;
    top: 8.5rem;
    left: 1rem; }
    #archiveLive dd a {
      display: inline-block;
      padding: 0.4em 0.8em 0.6em 1.5em;
      width: 9.33rem;
      font-size: 0.8rem;
      line-height: 1em;
      text-align: right;
      border-radius: 0.5em;
      color: white;
      background: rgba(83, 71, 65, 0.6);
      transition: background 0.2s ease-in-out; }
      #archiveLive dd a::before {
        content: "\ea19";
        display: block;
        position: absolute;
        margin: auto;
        top: 0;
        left: 0;
        bottom: 0;
        width: 1.5em;
        height: 1em;
        font-size: 1.6em;
        line-height: 1em;
        text-align: center; }
      #archiveLive dd a:hover {
        background: #534741; }
      #archiveLive dd a::after {
        content: "セミナーテキスト"; }

@media screen and (min-width: 960px) {
  #archiveLive {
    display: flex;
    flex-wrap: wrap;
    margin: 3rem auto 6rem;
    width: 96%;
    max-width: 1280px; }
    #archiveLive dl {
      position: relative;
      margin: 0 1px 2px;
      width: calc(50% - 2px);
      border-top: none;
      background: white;
      box-shadow: 0 0 0.3rem rgba(41, 49, 47, 0.2); } }
@media screen and (min-width: 1440px) {
  #archiveLive {
    display: flex;
    flex-wrap: wrap;
    margin: 3rem auto 6rem;
    width: 96%;
    max-width: 1920px; }
    #archiveLive dl {
      position: relative;
      margin: 0 1px 2px;
      width: calc(33.33% - 2px);
      border-top: none;
      background: white;
      box-shadow: 0 0 0.3rem rgba(41, 49, 47, 0.2); } }
.nav-tabstyle {
  display: flex;
  justify-content: flex-start;
  position: sticky;
  top: 1rem;
  left: 0;
  right: 0;
  margin: 0 auto 1rem;
  padding: 0 1rem;
  width: calc(100% - 2rem);
  color: #f4f3e9;
  background: rgba(83, 71, 65, 0.8);
  border-radius: 0.5rem;
  z-index: 6666; }
  .nav-tabstyle h2 {
    display: inline-flex;
    font-size: 1.8rem;
    line-height: 3rem;
    padding: 0 1em; }
  .nav-tabstyle button {
    display: none; }

@media screen and (min-width: 660px) {
  .nav-tabstyle {
    margin: 0 auto 3rem;
    padding: 1rem; }
    .nav-tabstyle button {
      display: inline-flex;
      margin: 0 0.25em;
      padding: 0 0.8em;
      height: 3rem;
      font-size: 1.2rem;
      line-height: 3rem;
      color: #f4f3e9;
      background: #534741;
      border: 1px solid #534741;
      border-radius: 0.5em;
      transition: 　color 0.2s ease-in-out, background 0.2s ease-in-out,border 0.2s ease-in-out;
      cursor: pointer;
      overflow: hidden; }
      .nav-tabstyle button:hover {
        border: 1px solid #f4f3e9; }
      .nav-tabstyle button:first-of-type {
        margin-left: auto; }
      .nav-tabstyle button.active {
        color: #534741;
        background: #f4f3e9;
        border: 1px solid #f4f3e9; } }
#howtoText {
  position: relative;
  margin: 0 auto;
  padding: 0 1.6rem 6rem;
  width: 100%;
  max-width: 760px; }
  #howtoText h2 {
    padding: 0 0 1em;
    font-size: 3rem;
    font-weight: 500; }
    #howtoText h2 span {
      display: block;
      padding: 0 0 0.5em;
      font-size: 0.6em; }
    #howtoText h2 em {
      font-style: normal;
      color: #c5497b; }
  #howtoText figure {
    display: block;
    margin: 0 auto 2rem;
    width: 50%;
    max-width: 34rem; }
    #howtoText figure img {
      width: 100%;
      height: auto; }
  #howtoText p {
    padding: 0 0 1em;
    font-size: 1.4rem;
    text-align: left;
    line-height: 2em; }
  #howtoText ul {
    padding: 2.4rem 2.4rem 1.6rem 3.2rem;
    text-align: left;
    background: rgba(255, 255, 255, 0.7);
    box-shadow: 0 0.25em 0.8em rgba(41, 49, 47, 0.2); }
  #howtoText li {
    padding: 0 0 1em;
    font-size: 1.1rem;
    line-height: 1.4em;
    font-weight: 500;
    list-style: disc outside; }

@media screen and (min-width: 600px) {
  #howtoText {
    position: relative;
    margin: 0 auto;
    padding: 0 2.4rem 6rem;
    width: 100%;
    max-width: 960px; } }
@media screen and (min-width: 960px) {
  #howtoText {
    position: relative;
    margin: 0 auto;
    padding: 0 34rem 9rem 3rem;
    width: 100%;
    max-width: 1280px; }
    #howtoText h2 {
      padding: 1em 0 1em;
      font-size: 3rem;
      font-weight: 500; }
      #howtoText h2 span {
        display: block;
        padding: 0 0 0.5em;
        font-size: 0.6em; }
      #howtoText h2 em {
        font-style: normal;
        color: #c5497b; }
    #howtoText h3 {
      padding: 2em 0 0.8em;
      font-size: 1.8rem; }
    #howtoText figure {
      position: absolute;
      margin: auto;
      top: -3rem;
      right: 0;
      width: 34rem; }
      #howtoText figure img {
        width: 100%;
        height: auto; }
    #howtoText p {
      padding: 0 0 1em;
      font-size: 1.4rem;
      text-align: left;
      line-height: 2em; }
    #howtoText ul {
      padding: 2.4rem 2.4rem 1.6rem 3.2rem;
      text-align: left;
      background: rgba(255, 255, 255, 0.7);
      box-shadow: 0 0.25em 0.8em rgba(41, 49, 47, 0.2); }
    #howtoText li {
      padding: 0 0 1em;
      font-size: 1.1rem;
      line-height: 1.4em;
      font-weight: 500;
      list-style: disc outside; } }
footer {
  display: block;
  margin: 6rem 0 0;
  padding: 1.6rem;
  background: #f4f3e9; }
  footer p {
    font-size: 0.8rem; }
