@charset "UTF-8";
/* ==============================
リセットcss
============================== */
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;
  vertical-align: baseline;
  text-align: left;
}

main {
  display: block;
}

body {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}

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

ul, ol, dl {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

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

table {
  text-align: left;
  border-collapse: separate;
  border-spacing: 0;
}

input, select {
  vertical-align: middle;
}

* {
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

/* 大枠 */
html {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: none;
}

body {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  font-size: 16px;
  line-height: 1.8;
  word-wrap: break-word;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  height: 100svh;
  overflow: hidden;
}

#wrapper {
  width: 100%;
  margin: 0 auto;
  position: relative;
  height: 100svh;
  overflow: hidden;
}

.clearfix:after {
  visibility: hidden;
  display: block;
  content: " ";
  clear: both;
  height: 0;
}

@media print {
  html {
    overflow: visible !important;
  }
  html body {
    overflow: visible !important;
  }
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  vertical-align: bottom;
  -webkit-box-shadow: #000 0 0 0;
  box-shadow: #000 0 0 0;
  /* ロールオーバー対応 */
  box-shadow: #000 0 0 0;
}

/* レスポンシブ対応 */
x:-moz-any-link, x:default {
  box-shadow: #000 0 0 0;
  /* IE7対応 */
}

/* ==============================
	フォームリセット
============================== */
input, button, select, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

/* リンク */
a:link, a:visited {
  color: #eee;
  text-decoration: none;
}
a:hover, a:active {
  color: #eee;
  text-decoration: underline;
}

.mincho {
  font-family: 游明朝, "Yu Mincho", YuMincho, Georgia, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  position: relative;
  font-weight: normal;
}

.container {
  width: 100%;
  max-width: 1240px;
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
}

/*------------------------------------------
  Responsive Grid Media Queries - 1280, 1024, 768, 480
   1280-1024   - デスクトップ（デフォルトのグリッド）
   1024-768    - タブレット横長
   768-480     - タブレット縦長
   480-less    - スマホ
--------------------------------------------*/
/* ▼▼▼ ヘッダー
=====================================*/
header {
  width: 100%;
  height: 66px;
  background-color: #fff;
  position: relative;
  z-index: 10;
}
header .container {
  max-width: 100%;
  width: 100%;
  height: 66px;
  padding: 0 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  background-color: #fff;
  /*
  		.search_form_wrap {
  			.search_form {
  				width: 100%;
  				max-width: 400px;
  			}
  			.search_form_inner {
  				width: 100%;
  				max-width: 400px;
  				position: relative;
  				border-radius: 25px;
  				border: 1px solid #004EA2;
  				overflow: hidden;
  				input {
  					width: 400px;
  					height: 42px;
  					padding:0 90px 0 20px;
  					background-color: #fff;
  					&:-webkit-autofill {
  						box-shadow: 0 0 0 1000px #fff inset;
  					}
  				}
  				button {
  					width: 70px;
  					height: 42px;
  					position: absolute;
  					right: 0;
  					top: 0;
  					background-color: #004EA2;
  					cursor: pointer;
  					padding: 0;
  					display: inline-flex;
  					justify-content: center;
  					align-items: center;
  					svg {
  						width: 20px;
  					}
  				}
  			}
  		}
  */
}
header .container .site_title {
  margin-right: auto;
  width: 140px;
}
header .container .page_title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  text-align: center;
  font-size: 28px;
  line-height: 1.2;
  color: #004EA2;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: calc(100% - 400px);
  height: 66px;
}
header .container .h_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .container .h_wrap > div:not(:first-child) {
  margin-left: 20px;
}
header .container .user {
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  position: relative;
  background-color: #fff;
  width: 6em;
  overflow: hidden;
}
header .container .user a {
  color: #666;
  position: relative;
  text-decoration: none;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
}
header .container .user a .icon {
  width: 28px;
  height: 28px;
  margin: 0 0 4px;
  overflow: hidden;
  border-radius: 50%;
}
header .container .user a .icon img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
header .container .user a .icon + span {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  text-align: center;
  width: 6em;
}
header .container .log_out {
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  position: relative;
  background-color: #fff;
}
header .container .log_out a {
  color: #666;
  position: relative;
  text-decoration: none;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
}
header .container .log_out a .icon {
  width: 28px;
  height: 28px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 0 4px;
}
header .container .log_out a .icon svg {
  width: 28px;
}
header .container .search_wrap {
  position: absolute;
  right: 190px;
  top: 0;
}
header .container .search_wrap .search_form_wrap {
  position: absolute;
  top: 8px;
  right: 0;
  background-color: #fff;
  padding: 0;
  -webkit-transition: top 0.6s;
  transition: top 0.6s;
  z-index: 1;
}
header .container .search_wrap .search_form_wrap .search_form {
  width: 100%;
  max-width: 400px;
}
header .container .search_wrap .search_form_wrap .search_form_inner {
  width: 100%;
  max-width: 400px;
  position: relative;
  background-color: #fff;
  border-radius: 25px;
  border: 1px solid #004EA2;
  overflow: hidden;
}
header .container .search_wrap .search_form_wrap .search_form_inner input {
  width: 400px;
  height: 48px;
  padding: 0 90px 0 20px;
}
header .container .search_wrap .search_form_wrap .search_form_inner input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
          box-shadow: 0 0 0 1000px #fff inset;
}
header .container .search_wrap .search_form_wrap .search_form_inner button {
  width: 70px;
  height: 48px;
  position: absolute;
  right: 0;
  top: 0;
  background-color: #004EA2;
  cursor: pointer;
  padding: 0;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .container .search_wrap .search_form_wrap .search_form_inner button svg {
  width: 20px;
}
header .container .search_btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  color: #666;
  background-color: #fff;
  display: none;
}
header .container .search_btn .icon {
  width: 28px;
  height: 28px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 0 4px;
  background-image: url("data:image/svg+xml,%3Csvg id='_レイヤー_2' data-name='レイヤー 2' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cdefs%3E%3Cstyle%3E .cls_search %7B fill: %23666; stroke-width: 0px; %7D %3C/style%3E%3C/defs%3E%3Cg id='_レイヤー_1-2' data-name='レイヤー 1'%3E%3Cpath class='cls_search' d='m23.5,21.07l-4.72-4.72s-.04-.03-.07-.05c1.21-1.69,1.92-3.75,1.92-5.98C20.63,4.62,16.02,0,10.32,0S0,4.62,0,10.32s4.62,10.32,10.32,10.32c2.23,0,4.29-.72,5.98-1.92.02.02.03.04.05.07l4.72,4.72c.67.67,1.75.67,2.42,0,.67-.67.67-1.75,0-2.42Zm-13.18-3.84c-3.81,0-6.92-3.1-6.92-6.92s3.1-6.92,6.92-6.92,6.92,3.1,6.92,6.92-3.1,6.92-6.92,6.92Z'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 25px 25px;
  -webkit-transition: background-image 0.2s;
  transition: background-image 0.2s;
}
header .container .search_btn.close .icon {
  width: 28px;
  height: 28px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 0 4px;
  background-image: url("data:image/svg+xml,%3Csvg id='_レイヤー_2' data-name='レイヤー 2' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Cdefs%3E%3Cstyle%3E .cls-1 %7B fill: %23666; stroke-width: 0px; %7D %3C/style%3E%3C/defs%3E%3Cg id='_レイヤー_1-2' data-name='レイヤー 1'%3E%3Cpath class='cls-1' d='m13.53,11l7.93-7.95c.7-.7.7-1.83,0-2.53h0c-.7-.7-1.83-.7-2.53,0l-7.93,7.95L3.05.54c-.7-.7-1.83-.7-2.53,0h0c-.7.7-.7,1.83,0,2.53l7.95,7.93L.54,18.95c-.7.7-.7,1.83,0,2.53s1.83.7,2.53,0l7.93-7.95,7.95,7.93c.7.7,1.83.7,2.53,0h0c.7-.7.7-1.83,0-2.53l-7.95-7.93Z'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 24px 24px;
}

/* ▼▼▼ メイン 「コンテンツとサイドを囲む要素」
=====================================*/
#main {
  width: 100%;
  max-width: 1920px;
  background-color: #E5ECF4;
  padding: 20px 0 0;
  height: calc(100svh - 104px);
  overflow: hidden;
}
#main .anchor_wrap .anchor_button_btn {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: #004EA2;
  position: absolute;
  left: -30px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: 0 11px;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
#main .anchor_wrap .anchor_button_btn svg {
  width: 11px;
}
#main .anchor_wrap:hover .anchor_button_btn {
  opacity: 0;
}
#main .anchor_wrap:hover .anchor_button {
  left: 0;
}
#main .anchor_button {
  position: absolute;
  left: -200px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 10;
  -webkit-transition: all 0.2s linear;
  transition: all 0.2s linear;
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
  overflow: hidden;
}
#main .anchor_button:hover {
  width: auto;
  height: auto;
  border-radius: 0;
  background-color: transparent;
}
#main .anchor_button:hover .a_btn {
  display: block;
  margin: 10px 0;
}
#main .anchor_button .a_btn {
  background-color: #fff;
  border-radius: 0 20px 20px 0;
}
#main .anchor_button .a_btn a {
  font-size: 14px;
  font-weight: 500;
  margin: 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  width: 200px;
  min-height: 44px;
  line-height: 1.3;
  padding: 0 20px;
  background-color: #5383B7;
  border-radius: 0 20px 20px 0;
  text-decoration: none;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
#main .anchor_button .a_btn a:hover {
  opacity: 0.6;
}
#main .main_inner {
  overflow-x: auto;
  padding: 0 100px 30px;
  overflow-y: hidden;
  height: 100%;
}
#main .main_inner:has(#user) {
  overflow: hidden;
}
#main .main_inner::-webkit-scrollbar {
  width: 6px;
  height: 6px;
  border-radius: 3px;
}
#main .main_inner::-webkit-scrollbar-thumb {
  background-color: #666;
  width: 6px;
  height: 6px;
  border-radius: 3px;
}
#main .main_inner::-webkit-scrollbar-track {
  background: transparent; /* 背景色 */
}
#main.detail .main_inner {
  padding: 0 50px 30px;
}

.login_wrap {
  width: 100%;
  max-width: 850px;
  margin: 0 auto;
  padding: 50px 20px;
  background-color: #fff;
  border-radius: 20px;
}
.login_wrap .page_title {
  text-align: center;
  font-size: 28px;
  line-height: 1.2;
  color: #004EA2;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 0 10px;
}
.login_wrap .login_list {
  width: 100%;
  max-width: 650px;
  margin: 0 auto;
}
.login_wrap .login_list dl + dl {
  margin-top: 30px;
}
.login_wrap .login_list dl dt {
  line-height: 1.4;
  font-weight: bold;
}
.login_wrap .login_list dl dd {
  margin-top: 10px;
}
.login_wrap .login_list dl dd input {
  background-color: #EEEEEE;
  height: 66px;
  width: 100%;
  padding: 0 20px;
}
.login_wrap .login_list dl dd input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #eee inset;
  box-shadow: 0 0 0 1000px #eee inset;
  -webkit-text-fill-color: #333;
}

.list_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto;
  height: inherit;
}

.material {
  width: -webkit-min-content;
  width: -moz-min-content;
  width: min-content;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
  margin: 0 25px;
}
.material h2 {
  height: 50px;
  font-size: 20px;
  background-color: #004EA2;
  text-align: center;
  line-height: 50px;
  color: #fff;
}
.material .material_inner {
  background-color: #fff;
  padding: 20px 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: 100%;
  height: calc(100% - 50px);
}
.material .material_inner .m_box {
  width: 370px;
}
.material .material_inner .m_box:not(:first-child) {
  margin-left: 40px;
}
.material .category + .category {
  margin-top: 30px;
}
.material .category h3 {
  color: #004EA2;
  font-size: 20px;
  line-height: 1.2;
  height: 40px;
}
.material .category .list li {
  border-bottom: 1px solid #ccc;
  height: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  padding: 0 30px 0 50px;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
}
.material .category .list li:nth-child(1) {
  border-top: 1px solid #ccc;
}
.material .category .list li.new {
  position: relative;
}
.material .category .list li.new::after {
  content: "NEW";
  font-size: 11px;
  height: 15px;
  background-color: #f09bbf;
  line-height: 15px;
  padding: 0 10px;
  border-radius: 10px;
  color: #fff;
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 5px;
  pointer-events: none;
}
.material .category .list li::before, .material .category .list li::after {
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
.material .category .list li.favorite a::before {
  background-color: rgb(255, 201, 0);
}
.material .category .list li .status {
  margin-right: 10px;
  width: 16px;
  height: 16px;
  border-radius: 2px;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
.material .category .list li .status.read {
  background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg id='_レイヤー_2' data-name='レイヤー 2' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cdefs%3E%3Cstyle%3E .cls-1 %7B fill: %23ccc; stroke-width: 0px; %7D %3C/style%3E%3C/defs%3E%3Cg id='contents'%3E%3Cg%3E%3Cpath class='cls-1' d='m8,0C3.58,0,0,3.58,0,8s3.58,8,8,8,8-3.58,8-8S12.42,0,8,0Zm4.53,12.53c-1.21,1.21-2.82,1.88-4.53,1.88s-3.32-.67-4.53-1.88-1.88-2.82-1.88-4.53.67-3.32,1.88-4.53,2.82-1.88,4.53-1.88,3.32.67,4.53,1.88,1.88,2.82,1.88,4.53-.67,3.32-1.88,4.53Z'/%3E%3Cpolygon class='cls-1' points='6.58 12.1 13.25 5.43 11.72 3.9 6.58 9.04 4.28 6.74 2.75 8.27 6.58 12.1'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-size: contain;
}
.material .category .list li .status.read + a {
  color: #999;
}
.material .category .list li .status.unread {
  background-color: #58BB51;
  border-radius: 50%;
  background-size: contain;
}
.material .category .list li a {
  overflow: hidden;
  font-size: 14px;
  font-weight: 500;
  display: block;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-height: 1.2;
  text-decoration: none;
  color: #333;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.material .category .list li a::before {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-color: #eeeeee;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg version='1.1' id='_x32_' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 512 512' style='width: 16px; height: 16px; opacity: 1;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%234B4B4B;%7D%0A%3C/style%3E%3Cg%3E%3Cpath class='st0' d='M510.698,196.593c-3.61-11.2-14.034-18.795-25.794-18.795H329.21L281.791,30.155 c-3.599-11.2-14.018-18.808-25.791-18.808c-11.772,0-22.192,7.608-25.791,18.808l-47.418,147.642H27.097 c-11.761,0-22.185,7.594-25.795,18.795c-3.599,11.2,0.436,23.449,9.999,30.302l126.246,90.643l-48.598,147.54 c-3.694,11.193,0.278,23.47,9.801,30.398c9.529,6.926,22.44,6.897,31.94-0.058L256,403.594l125.312,91.824 c9.5,6.956,22.411,6.985,31.941,0.058c9.522-6.927,13.494-19.205,9.811-30.398l-48.61-147.54L500.7,226.895 C510.262,220.042,514.298,207.792,510.698,196.593z' style='fill: rgb(238, 238, 238);'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg version='1.1' id='_x32_' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 512 512' style='width: 16px; height: 16px; opacity: 1;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%234B4B4B;%7D%0A%3C/style%3E%3Cg%3E%3Cpath class='st0' d='M510.698,196.593c-3.61-11.2-14.034-18.795-25.794-18.795H329.21L281.791,30.155 c-3.599-11.2-14.018-18.808-25.791-18.808c-11.772,0-22.192,7.608-25.791,18.808l-47.418,147.642H27.097 c-11.761,0-22.185,7.594-25.795,18.795c-3.599,11.2,0.436,23.449,9.999,30.302l126.246,90.643l-48.598,147.54 c-3.694,11.193,0.278,23.47,9.801,30.398c9.529,6.926,22.44,6.897,31.94-0.058L256,403.594l125.312,91.824 c9.5,6.956,22.411,6.985,31.941,0.058c9.522-6.927,13.494-19.205,9.811-30.398l-48.61-147.54L500.7,226.895 C510.262,220.042,514.298,207.792,510.698,196.593z' style='fill: rgb(238, 238, 238);'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
}
.material .category .list li a::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.material .category .list li.slide:before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 16px;
  background-color: #333;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='イメージ画像のアイコン素材' transform='translate(0 -19.703)'%3E%3Cpath id='パス_115' data-name='パス 115' d='M83.27,218.309H94.527a.582.582,0,0,0,.48-.914l-2.432-3.516a1.168,1.168,0,0,0-1.944.037L89.938,215l-1.928-2.788a1.167,1.167,0,0,0-1.945.036l-3.287,5.161a.583.583,0,0,0,.492.9Z' transform='translate(-79.782 -186.344)' fill='%23184655'/%3E%3Cpath id='パス_116' data-name='パス 116' d='M281.258,141.093a1.508,1.508,0,1,0-1.508-1.508A1.508,1.508,0,0,0,281.258,141.093Z' transform='translate(-269.914 -114.707)' fill='%23184655'/%3E%3Cpath id='パス_117' data-name='パス 117' d='M0,19.7v15H18v-15ZM16.22,33.1H1.78V21.31H16.22Z' fill='%23184655'/%3E%3C/g%3E%3C/svg%3E%0A");
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='イメージ画像のアイコン素材' transform='translate(0 -19.703)'%3E%3Cpath id='パス_115' data-name='パス 115' d='M83.27,218.309H94.527a.582.582,0,0,0,.48-.914l-2.432-3.516a1.168,1.168,0,0,0-1.944.037L89.938,215l-1.928-2.788a1.167,1.167,0,0,0-1.945.036l-3.287,5.161a.583.583,0,0,0,.492.9Z' transform='translate(-79.782 -186.344)' fill='%23184655'/%3E%3Cpath id='パス_116' data-name='パス 116' d='M281.258,141.093a1.508,1.508,0,1,0-1.508-1.508A1.508,1.508,0,0,0,281.258,141.093Z' transform='translate(-269.914 -114.707)' fill='%23184655'/%3E%3Cpath id='パス_117' data-name='パス 117' d='M0,19.7v15H18v-15ZM16.22,33.1H1.78V21.31H16.22Z' fill='%23184655'/%3E%3C/g%3E%3C/svg%3E%0A");
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.material .category .list li.video:before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 15px;
  background-color: #333;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='ムービー再生ボタン' transform='translate(0 -69.25)'%3E%3Cpath id='パス_118' data-name='パス 118' d='M17.059,69.25H.941A1.014,1.014,0,0,0,0,70.324V83.175A1.014,1.014,0,0,0,.941,84.25H17.059A1.014,1.014,0,0,0,18,83.175V70.324A1.015,1.015,0,0,0,17.059,69.25ZM13.486,81.482a.585.585,0,0,1-.542.619H2.35a.585.585,0,0,1-.543-.619V72.271a.585.585,0,0,1,.543-.619H12.944a.585.585,0,0,1,.542.619Zm3.15-3.51H15.049V76.16h1.586Zm-.849-4a1.021,1.021,0,1,1,.885-1.012A.955.955,0,0,1,15.787,73.97Z' fill='%234b4b4b'/%3E%3Cpath id='パス_119' data-name='パス 119' d='M168.367,200.774a.077.077,0,0,0-.117.066v3.95a.077.077,0,0,0,.117.066l3.309-1.975a.078.078,0,0,0,0-.133Z' transform='translate(-162.335 -125.932)' fill='%234b4b4b'/%3E%3C/g%3E%3C/svg%3E%0A");
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='ムービー再生ボタン' transform='translate(0 -69.25)'%3E%3Cpath id='パス_118' data-name='パス 118' d='M17.059,69.25H.941A1.014,1.014,0,0,0,0,70.324V83.175A1.014,1.014,0,0,0,.941,84.25H17.059A1.014,1.014,0,0,0,18,83.175V70.324A1.015,1.015,0,0,0,17.059,69.25ZM13.486,81.482a.585.585,0,0,1-.542.619H2.35a.585.585,0,0,1-.543-.619V72.271a.585.585,0,0,1,.543-.619H12.944a.585.585,0,0,1,.542.619Zm3.15-3.51H15.049V76.16h1.586Zm-.849-4a1.021,1.021,0,1,1,.885-1.012A.955.955,0,0,1,15.787,73.97Z' fill='%234b4b4b'/%3E%3Cpath id='パス_119' data-name='パス 119' d='M168.367,200.774a.077.077,0,0,0-.117.066v3.95a.077.077,0,0,0,.117.066l3.309-1.975a.078.078,0,0,0,0-.133Z' transform='translate(-162.335 -125.932)' fill='%234b4b4b'/%3E%3C/g%3E%3C/svg%3E%0A");
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.material .category .list li:hover .status, .material .category .list li:hover a {
  opacity: 0.6;
}
.material .category .list li:hover:before, .material .category .list li:hover:after {
  opacity: 0.6;
}

#cat_ranking h2 {
  background-color: #f09bbf;
}
#cat_ranking .m_box {
  width: 400px;
}
#cat_ranking .category h3 {
  color: #f09bbf;
}
#cat_ranking .category .list {
  padding-left: 30px;
}
#cat_ranking .category .list li .rank {
  color: #ccc;
  position: absolute;
  width: 30px;
  left: -30px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  font-size: 30px;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
}
#cat_ranking .category .list li .rank.no1 {
  color: #dcc57d;
}
#cat_ranking .category .list li .rank.no2 {
  color: #bbbbba;
}
#cat_ranking .category .list li .rank.no3 {
  color: #b88e75;
}

.btn {
  width: 350px;
  margin: 50px auto 0;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  height: 70px;
  background-color: #fff;
  border: 4px solid #5383B7;
  border-radius: 35px;
  text-align: center;
  position: relative;
}
.btn:after {
  content: "";
  display: inline-block;
  width: 26px;
  height: 8px;
  background-color: #5383B7;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='8' viewBox='0 0 26 8'%3E%3Cpath id='パス_96' data-name='パス 96' d='M2247.523,451.268h-24.016a1.041,1.041,0,0,1,0-2.08h20.207l-6.781-3.972a1.067,1.067,0,0,1-.382-1.415.968.968,0,0,1,1.35-.4l10.106,5.92a1.061,1.061,0,0,1,.476,1.17A1,1,0,0,1,2247.523,451.268Z' transform='translate(-2222.515 -443.268)' fill='%235383b7'/%3E%3C/svg%3E%0A");
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='8' viewBox='0 0 26 8'%3E%3Cpath id='パス_96' data-name='パス 96' d='M2247.523,451.268h-24.016a1.041,1.041,0,0,1,0-2.08h20.207l-6.781-3.972a1.067,1.067,0,0,1-.382-1.415.968.968,0,0,1,1.35-.4l10.106,5.92a1.061,1.061,0,0,1,.476,1.17A1,1,0,0,1,2247.523,451.268Z' transform='translate(-2222.515 -443.268)' fill='%235383b7'/%3E%3C/svg%3E%0A");
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.btn input, .btn a {
  display: block;
  height: 62px;
  line-height: 62px;
  width: 100%;
  color: #5383B7;
  font-size: 20px;
  font-weight: bold;
  -webkit-transition: color 0.2s linear;
  transition: color 0.2s linear;
  cursor: pointer;
  text-decoration: none;
}
.btn:hover {
  background-color: #5383B7;
}
.btn:hover:after {
  background-color: #fff;
}
.btn:hover input, .btn:hover a {
  color: #fff;
}

#detail {
  width: 1820px;
  background-color: #fff;
  border-radius: 20px;
  padding: 50px;
  height: inherit;
  position: relative;
}
#detail .btn_back {
  position: absolute;
  right: 10px;
  bottom: 10px;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  z-index: 10;
  background-color: #fff;
  width: 60px;
  height: 60px;
  border: 1px solid #004EA2;
  border-radius: 50%;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
#detail .btn_back:hover {
  opacity: 0.6;
}
#detail .btn_back a {
  width: 60px;
  height: 60px;
  color: #004EA2;
  position: relative;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  cursor: pointer;
}
#detail .btn_back a .icon {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 0 4px;
}
#detail .btn_back a .icon svg {
  width: 26px;
}
#detail .detail_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#detail .about_contents, #detail .side {
  width: 350px;
}
#detail .about_contents .cat_wrap, #detail .side .cat_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
#detail .about_contents .cat_wrap .title, #detail .side .cat_wrap .title {
  color: #004EA2;
  font-size: 18px;
  font-weight: 700;
}
#detail .about_contents .cat_wrap .major_category, #detail .side .cat_wrap .major_category {
  font-size: 18px;
  font-weight: bold;
  padding: 0 20px;
  display: inline-block;
  height: 30px;
  line-height: 30px;
  background-color: #333;
  color: #fff;
}
#detail .about_contents .cat_wrap .mta, #detail .side .cat_wrap .mta {
  height: 28px;
  line-height: 28px;
  font-size: 16px;
  color: #fff;
  padding: 0 30px;
  background-color: #eee;
}
#detail .about_contents .cat_wrap .mta.video, #detail .side .cat_wrap .mta.video {
  background-color: #F4A105;
}
#detail .about_contents .cat_wrap .mta.slide, #detail .side .cat_wrap .mta.slide {
  background-color: #0B9887;
}
#detail .about_contents .cat_wrap .watching, #detail .side .cat_wrap .watching {
  font-size: 13px;
  font-weight: 500;
  color: #aaa;
  margin-left: auto;
  height: 22px;
  padding: 0 20px;
  line-height: 22px;
  background-color: #eee;
  border-radius: 11px;
}
#detail .about_contents .title_wrap, #detail .side .title_wrap {
  margin-top: 20px;
}
#detail .about_contents .title_wrap .cat, #detail .side .title_wrap .cat {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 5px;
  line-height: 1.2;
}
#detail .about_contents .title_wrap .detail_title, #detail .side .title_wrap .detail_title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
  text-align: justify;
}
#detail .about_contents .title_wrap + .side_wrap, #detail .side .title_wrap + .side_wrap, #detail .about_contents .side_wrap + .side_wrap, #detail .side .side_wrap + .side_wrap {
  margin-top: 40px;
}
#detail .about_contents .side_wrap h2, #detail .side .side_wrap h2 {
  background-color: #004EA2;
  height: 50px;
  text-align: center;
  color: #fff;
  line-height: 50px;
  font-size: 20px;
  margin: 0 0 15px;
}
#detail .about_contents .side_wrap .text, #detail .side .side_wrap .text {
  font-weight: 500;
  text-align: justify;
}
#detail .about_contents .side_wrap dl, #detail .side .side_wrap dl {
  line-height: 1.2;
}
#detail .about_contents .side_wrap dl + dl, #detail .side .side_wrap dl + dl {
  margin-top: 40px;
}
#detail .about_contents .side_wrap dl dt, #detail .side .side_wrap dl dt {
  color: #004EA2;
  font-size: 18px;
  font-weight: 500;
  margin: 0 0 10px;
}
#detail .about_contents .side_wrap dl dd .btn_radio, #detail .side .side_wrap dl dd .btn_radio {
  font-weight: 500;
}
#detail .about_contents .side_wrap dl dd .btn_radio + .btn_radio, #detail .side .side_wrap dl dd .btn_radio + .btn_radio {
  margin-top: 10px;
}
#detail .about_contents .side_wrap dl dd .btn_radio input[type=radio], #detail .side .side_wrap dl dd .btn_radio input[type=radio] {
  position: relative;
  width: 24px;
  height: 24px;
  border: 1px solid #333333;
  border-radius: 50%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  margin: 0 10px 0 0;
}
#detail .about_contents .side_wrap dl dd .btn_radio input[type=radio]:checked:before, #detail .side .side_wrap dl dd .btn_radio input[type=radio]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #333333;
  content: "";
}
#detail .about_contents .side_wrap dl dd .btn_radio label, #detail .side .side_wrap dl dd .btn_radio label {
  vertical-align: middle;
}
#detail .about_contents .side_wrap dl dd textarea, #detail .side .side_wrap dl dd textarea {
  border: 1px solid #ccc;
  background-color: #fff;
  min-height: 100px;
  height: 150px;
  border-radius: 4px;
  width: 100%;
  padding: 10px 10px;
  resize: vertical;
}
#detail .about_contents .side_wrap dl dd .btn.save, #detail .side .side_wrap dl dd .btn.save {
  width: 220px;
  margin-top: 15px;
  height: 50px;
  border: 3px solid #5383B7;
}
#detail .about_contents .side_wrap dl dd .btn.save:after, #detail .side .side_wrap dl dd .btn.save:after {
  content: none;
  display: none;
}
#detail .about_contents .side_wrap dl dd .btn.save input, #detail .side .side_wrap dl dd .btn.save input {
  line-height: 44px;
  height: 44px;
  font-size: 16px;
}
#detail .about_contents .side_wrap .tag_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#detail .about_contents .side_wrap .tag_list li {
  margin-bottom: 10px;
}
#detail .about_contents .side_wrap .tag_list li:not(:last-child) {
  margin-right: 10px;
}
#detail .about_contents .side_wrap .tag_list li a {
  color: #333;
  text-decoration: none;
  display: block;
  height: 28px;
  padding: 0 10px;
  font-size: 13px;
  line-height: 26px;
  border: 1px solid #004EA2;
  border-radius: 14px;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
#detail .about_contents .side_wrap .tag_list li a:hover {
  opacity: 0.6;
}
#detail .favorite_btn {
  width: 100%;
  max-width: 300px;
  margin: 40px auto 0;
}
#detail .favorite_btn .favorite_btn_in {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  font-size: 14px;
  background: #fcfcfc;
  height: 60px;
  -webkit-box-shadow: 0 2px 6px 0 rgba(33, 37, 56, 0.2);
          box-shadow: 0 2px 6px 0 rgba(33, 37, 56, 0.2);
  cursor: pointer;
  border-radius: 6px;
  border: 1px solid rgba(80, 80, 80, 0.1);
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
#detail .favorite_btn .favorite_btn_in svg {
  vertical-align: middle;
  margin-right: 5px;
}
#detail .favorite_btn .favorite_btn_in:hover {
  opacity: 0.6;
}
#detail .favorite_btn.registered .favorite_btn_in {
  background-color: #004EA2;
  color: #fff;
}
#detail .favorite_btn.registered .favorite_btn_in svg .st0 {
  fill: #ffc900;
}
#detail .contents {
  width: 920px;
}
#detail .contents .movie_wrap .movie {
  width: 920px;
  height: 518px;
}
#detail .contents .movie_wrap .movie video {
  width: 100%;
}
#detail .contents .movie_wrap .control_menu {
  height: 60px;
  background-color: #333;
  border-radius: 0 0 10px 10px;
  padding: 0 30px;
}
#detail .contents .movie_wrap .control_menu .btn_wrap {
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
#detail .contents .movie_wrap .control_menu .btn_wrap .menu {
  margin-right: 20px;
}
#detail .contents .slide_wrap {
  position: relative;
  padding-bottom: 40px;
  width: 760px;
  margin: 0 auto;
}
#detail .contents .slide_wrap .swiper {
  width: 530px;
  height: 749px;
  position: relative;
}
#detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide {
  width: 530px;
  height: 749px;
}
#detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide img {
  width: 530px;
  height: 749px;
  -o-object-fit: contain;
  object-fit: contain;
  font-family: "object-fit: contain;";
}
#detail .contents .slide_wrap .swiper-button-prev, #detail .contents .slide_wrap .swiper-button-next {
  margin-top: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
}
#detail .contents .slide_wrap .swiper-button-prev::after, #detail .contents .slide_wrap .swiper-button-next::after {
  content: none;
}
#detail .contents .slide_wrap .swiper-button-prev {
  background: url(../img/button-prev.svg) no-repeat center center;
  background-size: contain;
  left: 0;
}
#detail .contents .slide_wrap .swiper-button-next {
  background: url(../img/button-next.svg) no-repeat center center;
  background-size: contain;
  right: 0;
}
#detail .contents .slide_wrap .swiper-pagination {
  bottom: 0;
  overflow: visible;
}
#detail .contents .slide_wrap .swiper-pagination span {
  width: 14px;
  height: 14px;
  margin: 0 10px;
}
#detail .contents .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
  background-color: #5383B7;
}

#user {
  background-color: #fff;
  width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
}
#user::-webkit-scrollbar {
  width: 6px;
  height: 6px;
  border-radius: 3px;
}
#user::-webkit-scrollbar-thumb {
  background-color: #666;
  width: 6px;
  height: 6px;
  border-radius: 3px;
}
#user::-webkit-scrollbar-track {
  background: transparent; /* 背景色 */
}
#user .profile {
  padding: 30px 0;
}
#user .profile .photo {
  width: 150px;
  height: 150px;
  border: 3px solid #ccc;
  border-radius: 50%;
  margin: 0 auto 10px;
  overflow: hidden;
}
#user .profile .photo img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
  width: 100%;
}
#user .profile .name {
  text-align: center;
  font-size: 24px;
  font-weight: 700;
}
#user .profile .edit a {
  color: inherit;
  display: block;
  height: 46px;
  width: 180px;
  margin: 20px auto 0;
  background-color: #eee;
  line-height: 46px;
  text-align: center;
  border-radius: 20px;
  font-size: 14px;
  text-decoration: none;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
#user .profile .edit a:hover {
  opacity: 0.6;
}
#user .material_inner {
  height: auto;
}
#user .material_inner .m_box {
  width: 100%;
}
#user .material_inner .m_box .list_title {
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  margin: 0 auto 20px;
  color: #004EA2;
}
#user .material_inner .m_box .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  max-width: 1560px;
  margin: 0 auto;
}
#user .material_inner .m_box .list li {
  height: 100px;
  border: 1px solid #ccc;
  margin: 0 20px 20px;
  width: 350px;
  padding-top: 30px;
  padding-bottom: 10px;
  border-radius: 6px;
  position: relative;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
#user .material_inner .m_box .list li:hover {
  opacity: 0.6;
}
#user .material_inner .m_box .list li:hover .status, #user .material_inner .m_box .list li:hover a {
  opacity: 1;
}
#user .material_inner .m_box .list li:hover:before, #user .material_inner .m_box .list li:hover:after {
  opacity: 1;
}
#user .material_inner .m_box .list li .cat {
  position: absolute;
  top: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  font-size: 14px;
  height: 30px;
  font-weight: 500;
}
#user .material_inner .m_box .list li .cat .parent {
  font-weight: 700;
  margin-right: 10px;
}

/* ====================
大カテゴリ設定 詳細
==================== */
.popup {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  display: none;
  z-index: 9999;
}
.popup .popup-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.popup .popup-content .movie_wrap {
  width: 70%;
  position: relative;
}
.popup .popup-content .movie_wrap .movie {
  display: contents;
}
.popup .popup-content .movie_wrap .movie video {
  width: 100%;
  display: block;
}
.popup .popup-content .movie_wrap .control_menu {
  height: 60px;
  background-color: #333;
  border-radius: 0 0 10px 10px;
  padding: 0 30px;
}
.popup .popup-content .movie_wrap .control_menu .btn_wrap {
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.popup .popup-content .movie_wrap .control_menu .btn_wrap .menu {
  margin-right: 20px;
}
.popup .popup-content .movie_wrap .popup-close {
  width: 60px;
  height: 60px;
  position: absolute;
  right: -80px;
  top: 0;
  cursor: pointer;
}
.popup .popup-content .slide_wrap {
  position: relative;
  padding-bottom: 0;
  width: 1220px;
  height: 864px;
  margin: 0 auto;
}
.popup .popup-content .slide_wrap .popup-close {
  width: 60px;
  height: 60px;
  position: absolute;
  right: -80px;
  top: 0;
  cursor: pointer;
}
.popup .popup-content .slide_wrap .swiper {
  width: 1220px;
  height: 864px;
  position: relative;
}
.popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide {
  width: 1220px;
  height: 864px;
  width: 1220px;
  height: 864px;
}
.popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide img {
  width: 1220px;
  height: 864px;
  -o-object-fit: contain;
  object-fit: contain;
  font-family: "object-fit: contain;";
}
.popup .popup-content .slide_wrap .swiper-button-prev, .popup .popup-content .slide_wrap .swiper-button-next {
  position: absolute;
  margin-top: 0;
  top: 50%;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  width: 50px;
  height: 50px;
}
.popup .popup-content .slide_wrap .swiper-button-prev::after, .popup .popup-content .slide_wrap .swiper-button-next::after {
  content: none;
}
.popup .popup-content .slide_wrap .swiper-button-prev {
  background: url(../img/button-prev.svg) no-repeat center center;
  background-size: contain;
  left: -100px;
}
.popup .popup-content .slide_wrap .swiper-button-next {
  background: url(../img/button-next.svg) no-repeat center center;
  background-size: contain;
  right: -100px;
}
.popup .popup-content .slide_wrap .swiper-pagination {
  bottom: 0;
  overflow: visible;
}
.popup .popup-content .slide_wrap .swiper-pagination span {
  width: 14px;
  height: 14px;
  margin: 0 10px;
}
.popup .popup-content .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
  background-color: #5383B7;
}

/* ▼▼▼ フッター
=====================================*/
footer {
  background-color: #5383B7;
  color: #fff;
  height: 40px;
}
footer .container {
  max-width: 100%;
  height: 40px;
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
footer .container .copyright {
  text-align: right;
  font-size: 11px;
}

/* =====================================

	▼▼▼ max-width: 1024px

===================================== */
@media screen and (max-width: 1024px) {
  /* ▼▼▼ ヘッダー
   =====================================*/
  header .container {
    max-width: 100%;
    padding: 0 20px;
  }
  header .container .page_title {
    width: calc(100% - 340px);
    height: 66px;
  }
  header .container .h_wrap > div:not(:first-child) {
    margin-left: 15px;
  }
  #main .main_inner:has(#user) {
    overflow: hidden;
    padding: 0 20px 30px;
  }
  #main.detail {
    max-width: 100%;
    min-height: inherit;
    overflow-y: auto;
  }
  #main.detail .main_inner {
    padding: 0 20px;
    height: auto;
  }
  #detail {
    border-radius: 20px;
    padding: 30px 20px;
    width: 100%;
  }
  #detail .detail_inner {
    display: block;
  }
  #detail .side {
    margin-top: 40px;
  }
  #detail .about_contents, #detail .side {
    width: 100%;
  }
  #detail .about_contents .cat_wrap, #detail .side .cat_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .about_contents .cat_wrap .title, #detail .side .cat_wrap .title {
    font-size: 18px;
    font-weight: 700;
  }
  #detail .about_contents .cat_wrap .major_category, #detail .side .cat_wrap .major_category {
    font-size: 18px;
    font-weight: bold;
    padding: 0 20px;
    display: inline-block;
    height: 30px;
    line-height: 30px;
    background-color: #333;
    color: #fff;
  }
  #detail .about_contents .cat_wrap .mta, #detail .side .cat_wrap .mta {
    height: 28px;
    line-height: 28px;
    font-size: 16px;
    color: #fff;
    padding: 0 30px;
    background-color: #eee;
  }
  #detail .about_contents .cat_wrap .mta.video, #detail .side .cat_wrap .mta.video {
    background-color: #F4A105;
  }
  #detail .about_contents .cat_wrap .mta.slide, #detail .side .cat_wrap .mta.slide {
    background-color: #0B9887;
  }
  #detail .about_contents .cat_wrap .watching, #detail .side .cat_wrap .watching {
    font-size: 13px;
    font-weight: 500;
    color: #aaa;
    margin-left: auto;
    height: 22px;
    padding: 0 20px;
    line-height: 22px;
    background-color: #eee;
    border-radius: 11px;
  }
  #detail .about_contents .title_wrap, #detail .side .title_wrap {
    margin-top: 20px;
  }
  #detail .about_contents .title_wrap .cat, #detail .side .title_wrap .cat {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 5px;
    line-height: 1.2;
  }
  #detail .about_contents .title_wrap .detail_title, #detail .side .title_wrap .detail_title {
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
    text-align: justify;
  }
  #detail .about_contents .title_wrap + .side_wrap, #detail .side .title_wrap + .side_wrap, #detail .about_contents .side_wrap + .side_wrap, #detail .side .side_wrap + .side_wrap {
    margin-top: 40px;
  }
  #detail .about_contents .side_wrap h2, #detail .side .side_wrap h2 {
    background-color: #004EA2;
    height: 50px;
    text-align: center;
    color: #fff;
    line-height: 50px;
    font-size: 20px;
    margin: 0 0 15px;
  }
  #detail .about_contents .side_wrap .text, #detail .side .side_wrap .text {
    font-weight: 500;
    text-align: justify;
  }
  #detail .about_contents .side_wrap dl, #detail .side .side_wrap dl {
    line-height: 1.2;
  }
  #detail .about_contents .side_wrap dl + dl, #detail .side .side_wrap dl + dl {
    margin-top: 40px;
  }
  #detail .about_contents .side_wrap dl dt, #detail .side .side_wrap dl dt {
    color: #004EA2;
    font-size: 18px;
    font-weight: 500;
    margin: 0 0 10px;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio, #detail .side .side_wrap dl dd .btn_radio {
    font-weight: 500;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio + .btn_radio, #detail .side .side_wrap dl dd .btn_radio + .btn_radio {
    margin-top: 10px;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio input[type=radio], #detail .side .side_wrap dl dd .btn_radio input[type=radio] {
    position: relative;
    width: 24px;
    height: 24px;
    border: 1px solid #333333;
    border-radius: 50%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0 10px 0 0;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio input[type=radio]:checked:before, #detail .side .side_wrap dl dd .btn_radio input[type=radio]:checked:before {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #333333;
    content: "";
  }
  #detail .about_contents .side_wrap dl dd .btn_radio label, #detail .side .side_wrap dl dd .btn_radio label {
    vertical-align: middle;
  }
  #detail .about_contents .side_wrap dl dd textarea, #detail .side .side_wrap dl dd textarea {
    border: 1px solid #ccc;
    background-color: #fff;
    min-height: 100px;
    height: 150px;
    border-radius: 4px;
    width: 100%;
    padding: 10px 10px;
    resize: vertical;
  }
  #detail .about_contents .side_wrap dl dd .btn.save, #detail .side .side_wrap dl dd .btn.save {
    width: 220px;
    margin-top: 15px;
    height: 50px;
    border: 3px solid #5383B7;
  }
  #detail .about_contents .side_wrap dl dd .btn.save:after, #detail .side .side_wrap dl dd .btn.save:after {
    content: none;
    display: none;
  }
  #detail .about_contents .side_wrap dl dd .btn.save input, #detail .side .side_wrap dl dd .btn.save input {
    line-height: 44px;
    height: 44px;
    font-size: 16px;
  }
  #detail .contents {
    width: 100%;
    margin-top: 40px;
  }
  #detail .contents .movie_wrap .movie {
    display: contents;
    width: 100%;
    max-width: 700px;
    max-height: 394px;
    margin: 0 auto;
  }
  #detail .contents .movie_wrap .movie video {
    width: 100%;
    display: block;
  }
  #detail .contents .movie_wrap .control_menu {
    height: 60px;
    background-color: #333;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
    width: 100%;
    margin: 0 auto;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap .menu {
    margin-right: 20px;
  }
  #detail .contents .slide_wrap {
    position: relative;
    padding-bottom: 0;
    width: 100%;
    margin: 0 auto;
  }
  #detail .contents .slide_wrap .swiper {
    width: 530px;
    height: 749px;
    position: relative;
    width: 530px;
    height: 749px;
    position: relative;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 530px;
    height: 749px;
    width: 530px;
    height: 749px;
    width: 530px;
    height: 749px;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide img {
    width: 530px;
    height: 749px;
    -o-object-fit: contain;
    object-fit: contain;
    font-family: "object-fit: contain;";
  }
  #detail .contents .slide_wrap .swiper-button-prev, #detail .contents .slide_wrap .swiper-button-next {
    margin-top: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
  }
  #detail .contents .slide_wrap .swiper-button-prev::after, #detail .contents .slide_wrap .swiper-button-next::after {
    content: none;
  }
  #detail .contents .slide_wrap .swiper-button-prev {
    background: url(../img/button-prev.svg) no-repeat center center;
    background-size: contain;
    left: 0;
  }
  #detail .contents .slide_wrap .swiper-button-next {
    background: url(../img/button-next.svg) no-repeat center center;
    background-size: contain;
    right: 0;
  }
  #detail .contents .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  #detail .contents .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  #detail .contents .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  .popup {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    display: none;
    z-index: 9999;
  }
  .popup .popup-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .popup .popup-content .movie_wrap {
    width: 90%;
    position: relative;
  }
  .popup .popup-content .movie_wrap .movie {
    display: contents;
  }
  .popup .popup-content .movie_wrap .movie video {
    width: 100%;
    display: block;
  }
  .popup .popup-content .movie_wrap .control_menu {
    height: 60px;
    background-color: #333;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap .menu {
    margin-right: 20px;
  }
  .popup .popup-content .movie_wrap .popup-close {
    width: 50px;
    height: 50px;
    position: absolute;
    right: 0;
    top: -60px;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap {
    position: relative;
    padding-bottom: 0;
    width: 80%;
    height: 80%;
    margin: 0 auto;
  }
  .popup .popup-content .slide_wrap .popup-close {
    width: 60px;
    height: 60px;
    position: absolute;
    right: -80px;
    top: 0;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap .swiper {
    position: relative;
    width: auto;
    height: 100%;
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: 100%;
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide canvas {
    width: 100%;
    height: 100%;
    max-height: 614px;
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    font-family: "object-fit: contain;";
  }
  .popup .popup-content .slide_wrap .swiper-button-prev, .popup .popup-content .slide_wrap .swiper-button-next {
    position: absolute;
    margin-top: 0;
    top: 50%;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    width: 50px;
    height: 50px;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev::after, .popup .popup-content .slide_wrap .swiper-button-next::after {
    content: none;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev {
    background: url(../img/button-prev.svg) no-repeat center center;
    background-size: contain;
    left: -60px;
  }
  .popup .popup-content .slide_wrap .swiper-button-next {
    background: url(../img/button-next.svg) no-repeat center center;
    background-size: contain;
    right: -60px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  .btn input, .btn a {
    font-size: 18px;
  }
  .btn:hover {
    background-color: #5383B7;
  }
  #user {
    background-color: #fff;
    overflow-y: auto;
    width: 100%;
    margin: 0;
  }
  #user .profile {
    padding: 30px 0;
  }
  #user .profile .name {
    font-size: 24px;
  }
  #user .material_inner {
    height: auto;
  }
  #user .material_inner .m_box {
    width: 100%;
  }
  #user .material_inner .m_box .list_title {
    font-size: 20px;
  }
  #user .material_inner .m_box .list {
    max-width: 800px;
  }
}
/* =====================================

	▼▼▼ max-width: 1024px

===================================== */
@media screen and (max-width: 1024px) {
  #main .anchor_wrap .anchor_button_btn.hidden {
    opacity: 0 !important;
  }
  #main .anchor_wrap:hover .anchor_button_btn {
    opacity: 1;
  }
  #main .anchor_wrap:hover .anchor_button {
    left: -200px;
  }
  #main .anchor_button.open {
    left: 0 !important;
  }
  #main .anchor_button.close {
    left: -200px;
  }
}
/* =====================================

	▼▼▼ max-width: 767px

===================================== */
@media screen and (max-width: 768px) {
  /* ▼▼▼ ヘッダー
   =====================================*/
  header .container {
    padding: 0 20px;
  }
  header .container .site_title {
    width: 120px;
  }
  header .container .page_title {
    font-size: 24px;
    width: calc(100% - 320px);
    height: 66px;
  }
  header .container .h_wrap > div:not(:first-child) {
    margin-left: 15px;
  }
  header .container .btn_back {
    font-size: 11px;
    width: 26px;
  }
  header .container .btn_back a {
    color: #666;
    position: relative;
    text-decoration: none;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
  }
  header .container .btn_back a .icon {
    margin-bottom: 5px;
  }
  header .container .btn_back a .icon svg {
    width: 26px;
    height: 26px;
  }
  header .container .log_out {
    font-size: 11px;
  }
  header .container .log_out a {
    position: relative;
    text-decoration: none;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
  }
  header .container .log_out a .icon {
    margin-right: 5px;
    margin-bottom: 5px;
  }
  header .container .log_out a .icon svg {
    width: 30px;
    height: 26px;
  }
  #main.login {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #main .page_title {
    font-size: 26px;
    margin: 0 auto 20px;
  }
  .popup {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    display: none;
    z-index: 9999;
  }
  .popup .popup-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .popup .popup-content .movie_wrap {
    width: 90%;
    position: relative;
  }
  .popup .popup-content .movie_wrap .movie {
    display: contents;
  }
  .popup .popup-content .movie_wrap .movie video {
    width: 100%;
    display: block;
  }
  .popup .popup-content .movie_wrap .control_menu {
    height: 60px;
    background-color: #333;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap .menu {
    margin-right: 20px;
  }
  .popup .popup-content .movie_wrap .popup-close {
    width: 50px;
    height: 50px;
    position: absolute;
    right: 0;
    top: -60px;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap {
    position: relative;
    padding-bottom: 0;
    width: 80%;
    height: 80%;
    margin: 0 auto;
  }
  .popup .popup-content .slide_wrap .popup-close {
    width: 60px;
    height: 60px;
    position: absolute;
    right: -60px;
    top: 0;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap .swiper {
    position: relative;
    width: auto;
    height: 100%;
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: 100%;
    /* 						img {display: none;} */
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide canvas {
    width: 100%;
    height: 100%;
    max-height: 819px;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev, .popup .popup-content .slide_wrap .swiper-button-next {
    position: absolute;
    margin-top: 0;
    top: 50%;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    width: 50px;
    height: 50px;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev::after, .popup .popup-content .slide_wrap .swiper-button-next::after {
    content: none;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev {
    background: url(../img/button-prev.svg) no-repeat center center;
    background-size: contain;
    left: -60px;
  }
  .popup .popup-content .slide_wrap .swiper-button-next {
    background: url(../img/button-next.svg) no-repeat center center;
    background-size: contain;
    right: -60px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  #video {
    margin-top: 50px;
  }
  #user {
    background-color: #fff;
    overflow-y: auto;
    width: 100%;
    margin: 0;
  }
  #user .profile {
    padding: 30px 0;
  }
  #user .profile .name {
    font-size: 24px;
  }
  #user .material_inner {
    height: auto;
  }
  #user .material_inner .m_box {
    width: 100%;
  }
  #user .material_inner .m_box .list_title {
    font-size: 20px;
  }
  #user .material_inner .m_box .list {
    max-width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #user .material_inner .m_box .list li {
    margin: 0 0 10px;
    width: 49%;
  }
  /* ▼▼▼ フッター
   =====================================*/
  footer {
    color: #fff;
  }
  footer .container .copyright {
    text-align: right;
    font-size: 11px;
  }
}
/* @media screen and (max-width: 768px) */
/* =====================================

	▼▼▼ max-width: 500px

===================================== */
@media screen and (max-width: 500px) {
  body {
    font-size: 13px;
    line-height: 1.6;
    overflow: visible;
    height: auto;
  }
  #wrapper {
    overflow: visible;
    height: auto;
  }
  /* ▼▼▼ ヘッダー
   =====================================*/
  header {
    width: 100%;
  }
  header .container {
    max-width: 100%;
    padding: 0 10px;
  }
  header .container .site_title {
    width: 100px;
    height: auto;
  }
  header .container .site_title img {
    height: auto;
  }
  header .container .page_title {
    font-size: 20px;
  }
  header .container .h_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  header .container .h_wrap > div:not(:first-child) {
    margin-left: 10px;
  }
  header .container .user {
    font-size: 10px;
    width: 6em;
  }
  header .container .user a {
    color: #666;
    position: relative;
    text-decoration: none;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    width: 6em;
  }
  header .container .user a .icon {
    width: 28px;
    height: 28px;
    margin: 0 0 4px;
    overflow: hidden;
    border-radius: 50%;
  }
  header .container .user a .icon img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
  header .container .btn_back {
    font-size: 10px;
    position: relative;
    z-index: 10;
    background-color: #fff;
  }
  header .container .btn_back a {
    color: #666;
    position: relative;
    text-decoration: none;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
  }
  header .container .btn_back a .icon {
    width: 28px;
    height: 28px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 0 4px;
  }
  header .container .btn_back a .icon svg {
    width: 20px;
  }
  header .container .log_out {
    font-size: 10px;
    position: relative;
    background-color: #fff;
    width: 6em;
  }
  header .container .log_out a {
    color: #666;
    position: relative;
    text-decoration: none;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    width: 6em;
  }
  header .container .log_out a .icon {
    width: 28px;
    height: 28px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 0 4px;
  }
  header .container .log_out a .icon svg {
    width: 22px;
  }
  header .container .log_out a .icon + span {
    width: 6em;
    display: block;
    text-align: center;
  }
  header .container .search_wrap {
    position: static;
  }
  header .container .search_wrap .search_form_wrap {
    position: absolute;
    top: -90px;
    right: 0;
    left: 0;
    background-color: #fff;
    padding: 20px;
    -webkit-transition: top 0.6s;
    transition: top 0.6s;
    z-index: -1;
  }
  header .container .search_wrap .search_form_wrap.open {
    top: 66px;
  }
  header .container .search_wrap .search_form_wrap .search_form {
    width: 100%;
    max-width: 400px;
  }
  header .container .search_wrap .search_form_wrap .search_form_inner {
    width: 100%;
    max-width: 400px;
    position: relative;
    background-color: #fff;
    border-radius: 25px;
    border: 1px solid #004EA2;
    overflow: hidden;
  }
  header .container .search_wrap .search_form_wrap .search_form_inner input {
    width: 400px;
    height: 48px;
    padding: 0 90px 0 20px;
  }
  header .container .search_wrap .search_form_wrap .search_form_inner input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fff inset;
            box-shadow: 0 0 0 1000px #fff inset;
  }
  header .container .search_wrap .search_form_wrap .search_form_inner button {
    width: 70px;
    height: 48px;
    position: absolute;
    right: 0;
    top: 0;
    background-color: #004EA2;
    cursor: pointer;
    padding: 0;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header .container .search_wrap .search_form_wrap .search_form_inner button svg {
    width: 20px;
  }
  header .container .search_btn {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    font-size: 10px;
    background-color: #fff;
    width: 40px;
  }
  header .container .search_btn .icon {
    width: 28px;
    height: 28px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 0 4px;
    background-image: url("data:image/svg+xml,%3Csvg id='_レイヤー_2' data-name='レイヤー 2' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cdefs%3E%3Cstyle%3E .cls_search %7B fill: %23666; stroke-width: 0px; %7D %3C/style%3E%3C/defs%3E%3Cg id='_レイヤー_1-2' data-name='レイヤー 1'%3E%3Cpath class='cls_search' d='m23.5,21.07l-4.72-4.72s-.04-.03-.07-.05c1.21-1.69,1.92-3.75,1.92-5.98C20.63,4.62,16.02,0,10.32,0S0,4.62,0,10.32s4.62,10.32,10.32,10.32c2.23,0,4.29-.72,5.98-1.92.02.02.03.04.05.07l4.72,4.72c.67.67,1.75.67,2.42,0,.67-.67.67-1.75,0-2.42Zm-13.18-3.84c-3.81,0-6.92-3.1-6.92-6.92s3.1-6.92,6.92-6.92,6.92,3.1,6.92,6.92-3.1,6.92-6.92,6.92Z'/%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 20px 20px;
    -webkit-transition: background-image 0.2s;
    transition: background-image 0.2s;
  }
  header .container .search_btn.close .icon {
    width: 28px;
    height: 28px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 0 4px;
    background-image: url("data:image/svg+xml,%3Csvg id='_レイヤー_2' data-name='レイヤー 2' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Cdefs%3E%3Cstyle%3E .cls-1 %7B fill: %23666; stroke-width: 0px; %7D %3C/style%3E%3C/defs%3E%3Cg id='_レイヤー_1-2' data-name='レイヤー 1'%3E%3Cpath class='cls-1' d='m13.53,11l7.93-7.95c.7-.7.7-1.83,0-2.53h0c-.7-.7-1.83-.7-2.53,0l-7.93,7.95L3.05.54c-.7-.7-1.83-.7-2.53,0h0c-.7.7-.7,1.83,0,2.53l7.95,7.93L.54,18.95c-.7.7-.7,1.83,0,2.53s1.83.7,2.53,0l7.93-7.95,7.95,7.93c.7.7,1.83.7,2.53,0h0c.7-.7.7-1.83,0-2.53l-7.95-7.93Z'/%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 22px 22px;
  }
  #main {
    width: 100%;
    padding: 30px 0 50px;
    height: 100%;
    overflow: visible;
  }
  #main .anchor_wrap .anchor_button_btn {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #004EA2;
    position: fixed;
    left: -30px;
    top: 50vh;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    padding: 0 11px;
    -webkit-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
    -webkit-transition-delay: 0.2s;
            transition-delay: 0.2s;
  }
  #main .anchor_wrap .anchor_button_btn.hidden {
    opacity: 0 !important;
  }
  #main .anchor_wrap .anchor_button_btn svg {
    width: 11px;
  }
  #main .anchor_wrap:hover .anchor_button_btn {
    opacity: 1;
  }
  #main .anchor_wrap:hover .anchor_button {
    left: -200px;
  }
  #main .anchor_button {
    position: fixed;
    left: -200px;
    top: 50vh;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 10;
    -webkit-transition: all 0.2s linear;
    transition: all 0.2s linear;
    -webkit-transition-delay: 0.2s;
            transition-delay: 0.2s;
    overflow: hidden;
  }
  #main .anchor_button.open {
    left: 0 !important;
  }
  #main .anchor_button.close {
    left: -200px;
  }
  #main .anchor_button:hover {
    width: auto;
    height: auto;
    border-radius: 0;
    background-color: transparent;
  }
  #main .anchor_button:hover .a_btn {
    display: block;
    margin: 10px 0;
  }
  #main .anchor_button .a_btn {
    background-color: #fff;
    border-radius: 0 20px 20px 0;
  }
  #main .anchor_button .a_btn a {
    font-size: 14px;
    font-weight: 500;
    margin: 10px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    color: #fff;
    width: 200px;
    min-height: 44px;
    line-height: 1.3;
    padding: 0 20px;
    background-color: #5383B7;
    border-radius: 0 20px 20px 0;
    text-decoration: none;
    -webkit-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
  }
  #main .anchor_button .a_btn a:hover {
    opacity: 0.6;
  }
  #main .main_inner {
    overflow-x: visible;
    padding: 0px 20px;
    height: auto;
  }
  #main .page_title {
    font-size: 26px;
    margin: 0 auto 20px;
  }
  .list_wrap {
    display: block;
    width: 100%;
  }
  .material {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    margin: 0;
    overflow: hidden;
  }
  .material:not(:first-child) {
    margin-left: 0;
    margin-top: 40px;
  }
  .material h2 {
    height: 50px;
    font-size: 20px;
    text-align: center;
    line-height: 50px;
    color: #fff;
  }
  .material .material_inner {
    display: block;
    padding: 30px 20px;
    height: auto;
  }
  .material .material_inner .m_box {
    width: 100%;
  }
  .material .material_inner .m_box:not(:first-child) {
    margin-left: 0;
    margin-top: 30px;
  }
  .material .category + .category {
    margin-top: 30px;
  }
  .material .category h3 {
    font-size: 18px;
    height: 30px;
  }
  .material .category .list li {
    border-bottom: 1px solid #ccc;
    height: 70px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    padding: 0 10px 0 50px;
    -webkit-transition: background-color 0.2s linear;
    transition: background-color 0.2s linear;
  }
  .material .category .list li a {
    font-size: 14px;
    display: block;
    overflow: hidden;
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-height: 1.3;
    text-decoration: none;
    color: #333;
  }
  .material .category .list li a::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
  }
  .material .category .list li.slide:before {
    content: "";
    display: inline-block;
    width: 18px;
    height: 16px;
    background-color: #333;
    -webkit-transition: background-color 0.2s linear;
    transition: background-color 0.2s linear;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='イメージ画像のアイコン素材' transform='translate(0 -19.703)'%3E%3Cpath id='パス_115' data-name='パス 115' d='M83.27,218.309H94.527a.582.582,0,0,0,.48-.914l-2.432-3.516a1.168,1.168,0,0,0-1.944.037L89.938,215l-1.928-2.788a1.167,1.167,0,0,0-1.945.036l-3.287,5.161a.583.583,0,0,0,.492.9Z' transform='translate(-79.782 -186.344)' fill='%23184655'/%3E%3Cpath id='パス_116' data-name='パス 116' d='M281.258,141.093a1.508,1.508,0,1,0-1.508-1.508A1.508,1.508,0,0,0,281.258,141.093Z' transform='translate(-269.914 -114.707)' fill='%23184655'/%3E%3Cpath id='パス_117' data-name='パス 117' d='M0,19.7v15H18v-15ZM16.22,33.1H1.78V21.31H16.22Z' fill='%23184655'/%3E%3C/g%3E%3C/svg%3E%0A");
    -webkit-mask-size: contain;
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='イメージ画像のアイコン素材' transform='translate(0 -19.703)'%3E%3Cpath id='パス_115' data-name='パス 115' d='M83.27,218.309H94.527a.582.582,0,0,0,.48-.914l-2.432-3.516a1.168,1.168,0,0,0-1.944.037L89.938,215l-1.928-2.788a1.167,1.167,0,0,0-1.945.036l-3.287,5.161a.583.583,0,0,0,.492.9Z' transform='translate(-79.782 -186.344)' fill='%23184655'/%3E%3Cpath id='パス_116' data-name='パス 116' d='M281.258,141.093a1.508,1.508,0,1,0-1.508-1.508A1.508,1.508,0,0,0,281.258,141.093Z' transform='translate(-269.914 -114.707)' fill='%23184655'/%3E%3Cpath id='パス_117' data-name='パス 117' d='M0,19.7v15H18v-15ZM16.22,33.1H1.78V21.31H16.22Z' fill='%23184655'/%3E%3C/g%3E%3C/svg%3E%0A");
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    position: absolute;
    top: 50%;
    left: 10px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .material .category .list li.video:before {
    content: "";
    display: inline-block;
    width: 18px;
    height: 15px;
    background-color: #333;
    -webkit-transition: background-color 0.2s linear;
    transition: background-color 0.2s linear;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='ムービー再生ボタン' transform='translate(0 -69.25)'%3E%3Cpath id='パス_118' data-name='パス 118' d='M17.059,69.25H.941A1.014,1.014,0,0,0,0,70.324V83.175A1.014,1.014,0,0,0,.941,84.25H17.059A1.014,1.014,0,0,0,18,83.175V70.324A1.015,1.015,0,0,0,17.059,69.25ZM13.486,81.482a.585.585,0,0,1-.542.619H2.35a.585.585,0,0,1-.543-.619V72.271a.585.585,0,0,1,.543-.619H12.944a.585.585,0,0,1,.542.619Zm3.15-3.51H15.049V76.16h1.586Zm-.849-4a1.021,1.021,0,1,1,.885-1.012A.955.955,0,0,1,15.787,73.97Z' fill='%234b4b4b'/%3E%3Cpath id='パス_119' data-name='パス 119' d='M168.367,200.774a.077.077,0,0,0-.117.066v3.95a.077.077,0,0,0,.117.066l3.309-1.975a.078.078,0,0,0,0-.133Z' transform='translate(-162.335 -125.932)' fill='%234b4b4b'/%3E%3C/g%3E%3C/svg%3E%0A");
    -webkit-mask-size: contain;
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='15' viewBox='0 0 18 15'%3E%3Cg id='ムービー再生ボタン' transform='translate(0 -69.25)'%3E%3Cpath id='パス_118' data-name='パス 118' d='M17.059,69.25H.941A1.014,1.014,0,0,0,0,70.324V83.175A1.014,1.014,0,0,0,.941,84.25H17.059A1.014,1.014,0,0,0,18,83.175V70.324A1.015,1.015,0,0,0,17.059,69.25ZM13.486,81.482a.585.585,0,0,1-.542.619H2.35a.585.585,0,0,1-.543-.619V72.271a.585.585,0,0,1,.543-.619H12.944a.585.585,0,0,1,.542.619Zm3.15-3.51H15.049V76.16h1.586Zm-.849-4a1.021,1.021,0,1,1,.885-1.012A.955.955,0,0,1,15.787,73.97Z' fill='%234b4b4b'/%3E%3Cpath id='パス_119' data-name='パス 119' d='M168.367,200.774a.077.077,0,0,0-.117.066v3.95a.077.077,0,0,0,.117.066l3.309-1.975a.078.078,0,0,0,0-.133Z' transform='translate(-162.335 -125.932)' fill='%234b4b4b'/%3E%3C/g%3E%3C/svg%3E%0A");
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    position: absolute;
    top: 50%;
    left: 10px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .material .category .list li:hover {
    color: #004EA2;
    background-color: #E5ECF4;
  }
  .material .category .list li:hover:before {
    background-color: #004EA2;
  }
  /* ====================
  大カテゴリ設定 一覧
  ==================== */
  #cat_ranking .material_inner .m_box {
    width: 100%;
    max-width: 400px;
  }
  #detail {
    border-radius: 10px;
    padding: 20px 20px;
    width: 100%;
  }
  #detail .detail_inner {
    display: block;
  }
  #detail .side {
    margin-top: 40px;
  }
  #detail .about_contents, #detail .side {
    width: 100%;
  }
  #detail .about_contents .cat_wrap, #detail .side .cat_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .about_contents .cat_wrap .title, #detail .side .cat_wrap .title {
    font-size: 16px;
    font-weight: 700;
  }
  #detail .about_contents .cat_wrap .major_category, #detail .side .cat_wrap .major_category {
    font-size: 14px;
    padding: 0 20px;
    height: 30px;
    line-height: 30px;
  }
  #detail .about_contents .cat_wrap .mta, #detail .side .cat_wrap .mta {
    height: 28px;
    line-height: 28px;
    font-size: 16px;
    color: #fff;
    padding: 0 30px;
    background-color: #eee;
  }
  #detail .about_contents .cat_wrap .mta.video, #detail .side .cat_wrap .mta.video {
    background-color: #F4A105;
  }
  #detail .about_contents .cat_wrap .mta.slide, #detail .side .cat_wrap .mta.slide {
    background-color: #0B9887;
  }
  #detail .about_contents .cat_wrap .watching, #detail .side .cat_wrap .watching {
    font-size: 13px;
    font-weight: 500;
    color: #aaa;
    margin-left: auto;
    height: 22px;
    padding: 0 20px;
    line-height: 22px;
    background-color: #eee;
    border-radius: 11px;
  }
  #detail .about_contents .title_wrap, #detail .side .title_wrap {
    margin-top: 20px;
  }
  #detail .about_contents .title_wrap .cat, #detail .side .title_wrap .cat {
    font-size: 16px;
  }
  #detail .about_contents .title_wrap .detail_title, #detail .side .title_wrap .detail_title {
    font-size: 18px;
    text-align: justify;
  }
  #detail .about_contents .title_wrap + .side_wrap, #detail .side .title_wrap + .side_wrap, #detail .about_contents .side_wrap + .side_wrap, #detail .side .side_wrap + .side_wrap {
    margin-top: 20px;
  }
  #detail .about_contents .side_wrap h2, #detail .side .side_wrap h2 {
    height: 40px;
    line-height: 40px;
    font-size: 18px;
    margin: 0 0 10px;
  }
  #detail .about_contents .side_wrap .text, #detail .side .side_wrap .text {
    font-weight: 500;
    text-align: justify;
  }
  #detail .about_contents .side_wrap dl, #detail .side .side_wrap dl {
    line-height: 1.2;
  }
  #detail .about_contents .side_wrap dl + dl, #detail .side .side_wrap dl + dl {
    margin-top: 40px;
  }
  #detail .about_contents .side_wrap dl dt, #detail .side .side_wrap dl dt {
    color: #004EA2;
    font-size: 18px;
    font-weight: 500;
    margin: 0 0 10px;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio, #detail .side .side_wrap dl dd .btn_radio {
    font-weight: 500;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio + .btn_radio, #detail .side .side_wrap dl dd .btn_radio + .btn_radio {
    margin-top: 10px;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio input[type=radio], #detail .side .side_wrap dl dd .btn_radio input[type=radio] {
    position: relative;
    width: 24px;
    height: 24px;
    border: 1px solid #333333;
    border-radius: 50%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0 10px 0 0;
  }
  #detail .about_contents .side_wrap dl dd .btn_radio input[type=radio]:checked:before, #detail .side .side_wrap dl dd .btn_radio input[type=radio]:checked:before {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #333333;
    content: "";
  }
  #detail .about_contents .side_wrap dl dd .btn_radio label, #detail .side .side_wrap dl dd .btn_radio label {
    vertical-align: middle;
  }
  #detail .about_contents .side_wrap dl dd textarea, #detail .side .side_wrap dl dd textarea {
    border: 1px solid #ccc;
    background-color: #fff;
    min-height: 100px;
    height: 150px;
    border-radius: 4px;
    width: 100%;
    padding: 10px 10px;
    resize: vertical;
  }
  #detail .about_contents .side_wrap dl dd .btn.save, #detail .side .side_wrap dl dd .btn.save {
    width: 220px;
    margin-top: 15px;
    height: 50px;
    border: 3px solid #5383B7;
  }
  #detail .about_contents .side_wrap dl dd .btn.save:after, #detail .side .side_wrap dl dd .btn.save:after {
    content: none;
    display: none;
  }
  #detail .about_contents .side_wrap dl dd .btn.save input, #detail .side .side_wrap dl dd .btn.save input {
    line-height: 44px;
    height: 44px;
    font-size: 16px;
  }
  #detail .contents {
    width: 100%;
    margin-top: 40px;
  }
  #detail .contents .movie_wrap .movie {
    display: contents;
    width: 100%;
    max-width: 700px;
    max-height: 394px;
    margin: 0 auto;
  }
  #detail .contents .movie_wrap .movie video {
    width: 100%;
    display: block;
  }
  #detail .contents .movie_wrap .control_menu {
    height: 60px;
    background-color: #333;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
    width: 100%;
    margin: 0 auto;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap .menu {
    margin-right: 20px;
  }
  #detail .contents .slide_wrap {
    position: relative;
    padding-bottom: 0;
    width: 100%;
    margin: 0 auto;
  }
  #detail .contents .slide_wrap .swiper {
    width: 100;
    height: auto;
    position: relative;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: auto;
    /* 							img {display: none;} */
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: 749px;
  }
  #detail .contents .slide_wrap .swiper-button-prev, #detail .contents .slide_wrap .swiper-button-next {
    margin-top: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
  }
  #detail .contents .slide_wrap .swiper-button-prev::after, #detail .contents .slide_wrap .swiper-button-next::after {
    content: none;
  }
  #detail .contents .slide_wrap .swiper-button-prev {
    background: url(../img/button-prev.svg) no-repeat center center;
    background-size: contain;
    left: 0;
  }
  #detail .contents .slide_wrap .swiper-button-next {
    background: url(../img/button-next.svg) no-repeat center center;
    background-size: contain;
    right: 0;
  }
  #detail .contents .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  #detail .contents .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  #detail .contents .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  .popup {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    display: none;
    z-index: 9999;
  }
  .popup .popup-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .popup .popup-content .movie_wrap {
    width: 90%;
    position: relative;
  }
  .popup .popup-content .movie_wrap .movie {
    display: contents;
  }
  .popup .popup-content .movie_wrap .movie video {
    width: 100%;
    display: block;
  }
  .popup .popup-content .movie_wrap .control_menu {
    height: 60px;
    background-color: #333;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .popup .popup-content .movie_wrap .control_menu .btn_wrap .menu {
    margin-right: 20px;
  }
  .popup .popup-content .movie_wrap .popup-close {
    width: 50px;
    height: 50px;
    position: absolute;
    right: 0;
    top: -60px;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap {
    position: relative;
    padding-bottom: 0;
    width: 80%;
    height: 80%;
    margin: 0 auto;
  }
  .popup .popup-content .slide_wrap .popup-close {
    width: 60px;
    height: 60px;
    position: absolute;
    right: -40px;
    top: 0;
    cursor: pointer;
  }
  .popup .popup-content .slide_wrap .swiper {
    position: relative;
    width: auto;
    height: 100%;
  }
  .popup .popup-content .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: 100%;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev, .popup .popup-content .slide_wrap .swiper-button-next {
    position: absolute;
    margin-top: 0;
    top: 50%;
    -webkit-transform: translateY(0);
    transform: translateY(0);
    width: 50px;
    height: 50px;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev::after, .popup .popup-content .slide_wrap .swiper-button-next::after {
    content: none;
  }
  .popup .popup-content .slide_wrap .swiper-button-prev {
    background: url(../img/button-prev.svg) no-repeat center center;
    background-size: contain;
    left: -40px;
  }
  .popup .popup-content .slide_wrap .swiper-button-next {
    background: url(../img/button-next.svg) no-repeat center center;
    background-size: contain;
    right: -40px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  .popup .popup-content .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  .login_wrap {
    max-width: 100%;
    padding: 30px 20px;
    border-radius: 10px;
  }
  .login_wrap .login_list {
    max-width: 100%;
  }
  .login_wrap .login_list dl + dl {
    margin-top: 30px;
  }
  .login_wrap .login_list dl dd {
    margin-top: 10px;
  }
  .login_wrap .login_list dl dd input {
    height: 50px;
    padding: 0 20px;
  }
  .btn {
    width: 100%;
    margin: 30px auto 0;
    height: 54px;
    border: 2px solid #5383B7;
    border-radius: 27px;
    text-align: center;
    position: relative;
  }
  .btn input {
    height: 50px;
    line-height: 50px;
    font-size: 16px;
  }
  #detail {
    border-radius: 10px;
    padding: 30px 20px;
  }
  #detail .contents .cat_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .contents .cat_wrap .title {
    font-size: 16px;
  }
  #detail .contents .cat_wrap .mta {
    height: 26px;
    line-height: 26px;
    font-size: 13px;
    padding: 0 20px;
    margin-left: 10px;
  }
  #detail .contents .cat_wrap .mta.video {
    background-color: #F4A105;
  }
  #detail .contents .cat_wrap .watching {
    font-size: 13px;
    height: 22px;
    padding: 0 20px;
    line-height: 22px;
  }
  #detail .contents .title_wrap {
    margin-top: 15px;
  }
  #detail .contents .title_wrap .detail_title {
    font-size: 18px;
  }
  #detail .contents .title_wrap .cat {
    font-size: 13px;
    height: 26px;
    line-height: 24px;
    margin-top: 15px;
    padding: 0 20px;
  }
  #detail .contents .movie_wrap {
    margin-top: 20px;
  }
  #detail .contents .movie_wrap .movie {
    width: 100%;
    height: 45.58vw;
  }
  #detail .contents .movie_wrap .movie video {
    width: 100%;
  }
  #detail .contents .movie_wrap .control_menu {
    height: 50px;
    padding: 0 20px;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap {
    height: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap .menu {
    height: 25px;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap .menu + .menu {
    margin-left: 20px;
  }
  #detail .contents .movie_wrap .control_menu .btn_wrap .menu img {
    height: 25px;
  }
  #detail .contents .slide_wrap {
    margin-top: 0;
    padding-bottom: 0;
  }
  #detail .contents .slide_wrap .swiper {
    width: 100%;
    height: 115vw;
    position: relative;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide {
    width: 100%;
    height: 115vw;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide canvas {
    width: 100%;
    height: 115vw;
  }
  #detail .contents .slide_wrap .swiper .swiper-wrapper .swiper-slide img {
    width: 100%;
    height: 100%;
  }
  #detail .contents .slide_wrap .swiper-button-prev, #detail .contents .slide_wrap .swiper-button-next {
    margin-top: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
  }
  #detail .contents .slide_wrap .swiper-button-prev {
    left: -20px;
  }
  #detail .contents .slide_wrap .swiper-button-next {
    right: -20px;
  }
  #detail .contents .slide_wrap .swiper-pagination {
    bottom: 0;
    overflow: visible;
  }
  #detail .contents .slide_wrap .swiper-pagination span {
    width: 14px;
    height: 14px;
    margin: 0 10px;
  }
  #detail .contents .slide_wrap .swiper-pagination span.swiper-pagination-bullet-active {
    background-color: #5383B7;
  }
  #detail .side {
    margin-top: 40px;
  }
  #detail .side .side_wrap + .side_wrap {
    margin-top: 30px;
  }
  #detail .side .side_wrap h2 {
    height: 40px;
    line-height: 40px;
    font-size: 18px;
    margin: 0 0 10px;
  }
  #detail .side .side_wrap dl + dl {
    margin-top: 30px;
  }
  #detail .side .side_wrap dl dt {
    font-size: 16px;
    margin: 0 0 10px;
  }
  #detail .side .side_wrap dl dd .btn_radio + .btn_radio {
    margin-top: 10px;
  }
  #detail .side .side_wrap dl dd .btn_radio input[type=radio] {
    position: relative;
    width: 24px;
    height: 24px;
    border: 1px solid #333333;
    border-radius: 50%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0 10px 0 0;
  }
  #detail .side .side_wrap dl dd .btn_radio input[type=radio]:checked:before {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #333333;
    content: "";
  }
  #detail .side .side_wrap dl dd .btn_radio label {
    vertical-align: middle;
  }
  #detail .side .side_wrap dl dd textarea {
    border: 1px solid #ccc;
    background-color: #fff;
    min-height: 100px;
    height: 150px;
    border-radius: 4px;
    width: 100%;
    padding: 10px 10px;
    resize: vertical;
  }
  #detail .side .side_wrap dl dd .btn.save {
    width: 100%;
    margin-top: 15px;
    height: 50px;
    border: 2px solid #5383B7;
  }
  #detail .side .side_wrap dl dd .btn.save:after {
    content: none;
    display: none;
  }
  #detail .side .side_wrap dl dd .btn.save input {
    line-height: 46px;
    height: 46px;
    font-size: 16px;
  }
  #user {
    background-color: #fff;
    overflow-y: auto;
    width: 100%;
    margin: 0;
  }
  #user .profile {
    padding: 30px 0;
  }
  #user .profile .name {
    font-size: 24px;
  }
  #user .material_inner {
    height: auto;
  }
  #user .material_inner .m_box {
    width: 100%;
  }
  #user .material_inner .m_box .list_title {
    font-size: 20px;
  }
  #user .material_inner .m_box .list {
    max-width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #user .material_inner .m_box .list li {
    margin: 0 0 10px;
    width: 100%;
  }
  /* ▼▼▼ フッター
   =====================================*/
  footer .container .copyright {
    font-size: 10px;
  }
}
/*# sourceMappingURL=base.css.map */