@charset "utf-8";

@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);

:root {
  --color-href: #2882DF;
  --color-katei: #CA0056;
  --color-shodo: #5700E7;
  --color-koukyo: #3054E9;
  --color-shoku: #FF5E00;
  --color-hoiku: #AC2DE2;
  --color-ifuku: #F9A102;
  --color-jyukyo: #00A23D;
  --color-shouhi: #0081B2;
  --color-kourei: #8B3B2E;
  --color-free: #F20120;
}

/* color  */
.col-red{background-color: #FF0000;}
.col-vr{background-color: #032f4a;}
.col-digital{background-color: #cf0dff;}
.col-seikatu{background-color: #00ADFA;}
.col-seinen{background-color: #0064FF;}
.col-kourei{background-color: #8B3B2E;}
.col-kyosei{background-color: #233CD0;}
.col-kankyo{background-color: #008E1A;}

.col-katei {background-color: var(--color-katei);}
.col-shodo {background-color: var(--color-shodo);}
.col-koukyo {background-color: var(--color-koukyo);}
.col-shoku {background-color: var(--color-shoku);}
.col-hoiku {background-color: var(--color-hoiku);}
.col-ifuku {background-color: var(--color-ifuku);}
.col-jyukyo {background-color: var(--color-jyukyo);}
.col-shouhi {background-color: var(--color-shouhi);}
.col-kourei {background-color: var(--color-kourei);}
.col-free {background-color: var(--color-free);}

/*html,body {
	height: 100vh;
}*/
html{
	background-color: #2C2C30;
}
body{
color: #313131;
font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
font-size: 16px;
margin: 0;
background-color: #ffffff;
overflow-x: hidden;
}
a {
	color: #2882DF;
	text-decoration: none;
}
a:hover {
	color: #2882DF;
	text-decoration: underline;
}
main {
	/*overflow: hidden;*/
}
main hr {
	color: #999999;
	margin: 0px 10px 30px;
}
img{
max-width: 100%;
height: auto;
}
ul{
	margin: 0px;
	padding: 0px;
	list-style-type: none;
}



.disp_pc {
	display: block;
}
.disp_sp {
	display: none;
}

._errtxt {
	color: red;
}

._nopaytxt {
	color: #BB1235;
}
._nowrap {
	display: inline-block;
}

._trialtxt {
  color:#b33126;
  font-size:14px;
  margin-left:10px;
  margin-bottom:0px;
  padding-left: 14px;
  text-indent: -14px;
}


._col-recome {
  color: #FFFFFF;
  padding: 10px 40px !important;
  margin: 0px -30px 6px;
  background-color: rgba(255,0,77,1.00);
  /* background-image: -webkit-linear-gradient(270deg,rgba(255,0,77,1.00) 0%,rgba(186,0,55,1.00) 100%);
  background-image: -moz-linear-gradient(270deg,rgba(255,0,77,1.00) 0%,rgba(186,0,55,1.00) 100%);
  background-image: -o-linear-gradient(270deg,rgba(255,0,77,1.00) 0%,rgba(186,0,55,1.00) 100%);
  background-image: linear-gradient(180deg,rgba(255,0,77,1.00) 0%,rgba(186,0,55,1.00) 100%); */
  text-shadow: 0px 2px 3px rgba(0,0,0,0.20);
}
._col-rank {
  color: #FFFFFF;
  padding: 10px 40px !important;
  margin: 0px -30px 6px;
  background-color: rgb(255, 115, 0);
  text-shadow: 0px 2px 3px rgba(0,0,0,0.20);
}
._col-relate {
	color: #2882DF;
	border-bottom: 1px solid #2882DF;
	padding: 10px 0px !important;
	margin: 0px 10px 6px;
}


/* ----------------- */
._ico-app {
  position: relative;
}
._ico-app:before {
	position: absolute;
  content: '';
  top: 11px;
  left: 0;
  width: 50%;
  padding-top: 20%;
  display: block;
}
._ico-app:after {
  position: absolute;
  content: '';
  top: 11px;
  left:0;
  display: block;
  width: 50%;
  height: 46px;
  background-image: url(../imgs/ico-app.png);
  background-size: contain;
  background-repeat: no-repeat;
  }



/* Rules for sizing the icon. */
.material-icons.md-22 { font-size: 2.2rem; }
.material-icons.md-26 { font-size: 2.6rem; }

.bikou_regist {
    display: block;
    background-color:#fff;
    border:1px solid #b33126;
    font-size:1.0rem;
    margin:15px;
    padding:10px;
    vertical-align:middle;
}


/* tooltip */
.tooltip {
  position: relative;
}
.tooltip::after {
  position: absolute;
  transition: all 0.3s ease 0s;
  opacity: 0;
}
.tooltip::after {
  content: attr(data-tooltip);
  display: block;
  padding: 3px;
  background: #DD5200;
  color: #fff;
  font-size: 6px;
  line-height: 10px;
  border-radius: 3px;
  top: 0px;
  left: 0;
}
.tooltip:hover::after{
  top: -4px;
  opacity: 1;
}


.tab-wrap {
  display: flex;
  flex-wrap: wrap;
  margin:5px 0px 20px;
}
.tab-wrap:after {
  content: '';
  width: 100%;
  height: 15px;
  background: #EDEDED;
	border-right: 1px solid #aaa;
  display: block;
	margin:-8px 0px 0px;
  order: -1;
}
.tab-label {
	color: #fff;
	background: #ccc;
	order: -1;
	position: relative;
	cursor: pointer;
	flex: 1;
	border-top-right-radius: 8px;
}
.tab-label:not(:last-of-type) {
  margin-right: 15px;
}
.tab-Box{
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 72px;
}
.tab-Box ._categ{
	display: flex;
	justify-content: row;
	align-items: center;
	margin-left: 0px;
	margin-top: 0px;
}
.tab-Box ._categ ._title{
	font-weight: 400;
	font-size: 1.2rem;
	line-height: 1.2rem;
}
/* アクティブなタブ */
.tab-switch:checked+.tab-label {
	color: #313131;
  background: #EDEDED;
	border-top: 1px solid #aaa;
	border-right: 1px solid #aaa;
	z-index: 3;
	transition: 0.3s;
}
.tab-switch:checked+.tab-label+.tab-content {
  opacity: 1;
	display: block;
}
.tab-switch {
  display: none;
}

.tab-content {
	width: 100%;
	overflow: hidden;
	opacity: 0;
	display: none;
}


#fixedTop {
	position: fixed;
	font-size: 1.2rem;
	line-height: 1.2rem;
	padding: 12px;
	right: 15px;
	bottom: 20px;
	color: #fff;
	text-align: center;
	display: block;
	background-color: #608BFE;
	border-radius: 50px;
	z-index: 29;
	opacity: 0.75;
}


.gp-overlay {
  display: none;
  background: rgba(0,0,0,0.3);
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 79;
}
#caumess {
  display: none;
  z-index: 100;
}
#caumess ._box {
  display: grid;
  justify-items: center;
  align-items: center;
  background: rgba(234,221,223,0.80);
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
}
#caumess ._cap {
  display: block;
	position: relative;
	color: #9C0023;
	font-weight: 600;
	font-size: 1.0rem;
	line-height: 2.0rem;
	text-align: center;
	width: 100%;
  max-width: 360px;
  padding: 20px;
  background-color: #fff;
  border: 1px solid #999;
  -webkit-box-shadow: 0px 4px 5px rgba(0,0,0,0.10);
  box-shadow: 0px 4px 5px rgba(0,0,0,0.10);
}


.main {
  width: 100%;
  height: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	padding-top: 72px;
}

.scroll-prevent {
  /*position: fixed;*/
}

.bgwrapper {
  /* width: 100vw; */
}

.wrapper{
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	/*min-height: 100vh;*/
}

header {
	width: 100%;
  margin: 0;
  padding: 0;
}

.header{
	background-color: white;
	position: fixed;
	top: 0px;
	width: 100%;
	height: 72px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 99;
	left: 0px;
}
.header_sdw{
	-webkit-box-shadow: 0px 1px 2px rgba(32,33,34,0.50);
	box-shadow: 0px 1px 2px rgba(32,33,34,0.50);
}

.siteName{
	flex-basis: 216px;
	margin-left: 20px;
}
.siteName #siteLogo{
	width: 216px;
	height: 32px;
	margin-right: 5px;
}


.globalNav{
	flex-basis: auto;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	min-width: 80px;
	margin-right: 20px;
}
.list-nav {
	color: #000;
	display: inline-block;
	overflow: hidden;
}
.list-nav ul{
	display: flex;
	align-items: center;
	text-align: center;
}
.list-nav ul li{
	margin-left: 10px;
	font-weight: 400;
	font-size: 1.0rem;
}
.list-nav ul li a{
	text-decoration: none;
}
.list-nav ul li._ico{
	margin-right: 20px;
}
.list-nav ul li._ico .material-icons{
	color: #2882DF;
	font-size: 2.6rem;
	padding-top: 8px;
}
.list-nav ul li._ico:hover{
	opacity: 0.7;
}
.list-nav ul li ._login{
	background-color: #FFFFFF;
	border: 1px solid #2882DF;
	color: #2882DF;
	padding: 10px 18px;
	line-height: 1.0rem;
}
.list-nav ul li ._login:hover{
	background-color: #E6FCFD;
	text-decoration: none;
}
.list-nav ul li ._regist{
	background-color: #2882DF;
	border: 1px solid #2882DF;
	color: #ffffff;
	padding: 10px 18px;
	line-height: 1.0rem;
}
.list-nav ul li ._regist:hover{
	background-color: #76C1FF;
}


.mobilelNav {
	display: inline-block;
}
.mobilelNav ul{
	display: flex;
	align-items: center;
	text-align: center;
}
.mobilelNav ul li._ico{
	margin-left: 10px;
}
.mobilelNav ul li._ico .material-icons{
	color: #2882DF;
	font-weight: 400;
	font-size: 36px;
	line-height: 36px;
	padding-top: 8px;
}
.mobilelNav ul li._ico:hover{
	opacity: 0.7;
}
.mobilelNav ul li._ico .act{
	color: #42C9FF !important;
}



/* ----------------- */
.mob-nav {
	position: relative;
  width: 30px;
  height: 18px;
	margin-left: 20px;
  color: #000;
  cursor: pointer;
}
.mob-nav,
.mob-nav span {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
}
.mob-nav span {
  position: absolute;
  left: 0;
  width: 30px;
  height: 3px;
  background-color: #313131;
}
.mob-nav span:nth-of-type(1) {
  top: 0;
}
.mob-nav span:nth-of-type(2) {
  top: 9px;
}
.mob-nav span:nth-of-type(3) {
  top: 18px;
}
.mob-nav.active span:nth-of-type(1) {
  transform: translateY(8px) rotate(-45deg);
}
.mob-nav.active span:nth-of-type(2) {
  opacity: 0;
}
.mob-nav.active span:nth-of-type(3) {
  transform: translateY(-8px) rotate(45deg);
	width: 30px;
}


#mob-base {
  display: none;
	position: fixed;
	width: 100%;
	overflow-y: auto;
	z-index: 80;
	height: 100vh
}
.mob-wrap {
	margin-top: 52px;
	padding: 20px;
	color: #FFFFFF;
	text-align: left;
	background-color: #272E39;
}
.mob-wrap hr {
	opacity: 0.3;
}
.mob-width {
	width: 100%;
	margin: 0px auto;
}
.mob-menu {
	width: 100%;
  display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-around;
	margin: 20px 0px 20px;
}
.mob-borderbtn {
	width: 100%;
	height: 42px;
	margin: 5px 0;
}
.mob-borderbtn a {
	display:block;
	width: 100%;
  height: 100%;
	color: #FFFFFF;
	font-weight: 800;
	font-size: 16px;
	line-height: 36px;
}
.mob-borderbtn a:hover {
	text-decoration: none;
}
.mob-border {
  position: relative;
  display: block;
  width: 32px;
  height: 1px;
  background-color: #fff;
  overflow: hidden;
  transition: 0.5s;
  top: 0;
  left: 0;
}
.mob-borderbtn:hover .mob-border {
  width: 100%;
}
.mob-tag {
	display: block;
	margin: 20px 0px 20px;
	font-size: 14px;
	font-weight: 800;
	line-height: 36px;
	overflow: hidden;
}
.mob-tag ul {
  display: flex;
	flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
	margin: 10px 0px;
}
.mob-tag ul li {
	display:inline-block;
	margin-right: 10px;
	margin-bottom: 10px;
}
.mob-tag ul li a {
	display:block;
  height: 100%;
  padding: 5px 15px;
	background-color: #FFFFFF;
	color: #2882DF;
	font-size: 12px;
	font-weight: 400;
	line-height: 22px;
	border-radius: 22px;
	transition: 0.4s;
}
.mob-tag ul li a:hover {
	text-decoration: none;
	background-color: #2882DF;
	color: #FFFFFF;
}
.mob-foot {
	display: flex;
	justify-content: center;
	flex-direction: column;
	align-items: center;
	margin: 20px 0px 30px;
	font-size: 12px;
	font-weight: 800;
	line-height: 36px;
}
.mob-foot .mob-sns {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 10px 0px 15px;
}
.mob-foot .mob-sns div {
	margin: 0px 15px;
}



.heroimg{
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	-webkit-box-shadow: inset 0px 1px 2px rgba(0,0,0,0.20);
	box-shadow: inset 0px 1px 2px rgba(0,0,0,0.20);
	width: 100%;
	min-height: 72px;
	margin: 0px auto 10px;
	padding: 10px;
	background-image: url(../imgs/hero_1.jpg);
	background-position: 0% center;
	background-repeat: no-repeat;
	background-size: cover;
}
.heroimg h1{
	position: relative;
	color: #FFFFFF;
	font-weight: 400;
	font-size: 2.2rem;
	line-height: 2.4rem;
	text-align: center;
	width: 100%;
	margin-bottom: 10px;
}
.heroBox{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	padding: 0px;
	overflow: hidden;
}
.heroimg ._h1{
	flex-basis: 15%;
	position: relative;
	max-width: 200px;
	margin: 10px;
}
.heroimg ._h1 img{
	width: 100%;
	display: inline-block;
}
.heroimg ._h2{
	display: flex;
	flex-basis: 70%;
	flex-direction: column;
	justify-content: center;
	position: relative;
	max-width: 580px;
	overflow: hidden;
}
.heroimg ._h2 p{
	display: block;
	width: 100%;
	color: #FFFFFF;
	font-weight: 600;
	font-size: 1.6rem;
	line-height: 2.4rem;
	margin-bottom: 10px;
  text-align: center;
	text-shadow: 0px 2px 4px rgba(0,0,0,0.2);
	overflow: hidden;
}
.heroimg ._h2 p span{
	display: inline-block;
}
.heroimg ._h2 p ._cap{
	color: #fffc9e;
}
.heroimg ._h2 a{
	text-decoration: none;
}
.heroimg ._h2 ._login{
	position: relative;
	color: #FFFFFF;
	font-weight: 400;
	font-size: 1.4rem;
	line-height: 1.4rem;
	text-align: center;
  margin-top: 10px;
	padding: 15px 30px;
  background-color: rgba(255,255,255,0.12);
	border: 1px solid #FFFFFF;
	letter-spacing: 0rem;
	cursor: pointer;
}
.heroimg ._h2 ._login:hover{
	background-color: rgba(255,255,255,0.38);
}
.heroimg ._h2 p._h3{
  text-align: left;
}
.heroimg ._marker{
	display: block;
	color: #fff;
	font-weight: 800;
	font-size: 0.8rem;
	top: 400px;
	text-align: center;
	width: 100%;
	margin-top: 10px;
}
.heroimg ._h2 p._cp{
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 2.0rem;
	margin: 15px auto 0px;
  text-align: center;
}
.heroimg ._h2 p._cp2{
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.8rem;
	margin: 10px auto 20px;
  text-align: center;
}

.heroimg._index {
  width: 100%;
  min-height: 37.5vw;
  margin: 70px auto -62px;
  padding: 20px 10px;
  background-image: url('../imgs/tophero_2024.png') !important;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.heroimg._index .heroBox {
	justify-content: center !important;
}
.heroimg._index h1{
	position: relative;
	color: #FFFFFF;
	font-weight: 700;
	font-size: clamp(1.8rem, 0.043rem + 3.66vw, 3.2rem);
	line-height: 1.3em;
  letter-spacing: 0.01rem;
	text-align: center;
  text-shadow: 1px 8px 5px rgba(0, 0, 0, 0.24);
	width: 100%;
	margin-bottom: 30px;
}
.heroimg._index ._h3{
	position: relative;
	color: #FFFFFF;
	font-weight: 500;
	font-size: clamp(1.6rem, 1.098rem + 1.05vw, 2rem);
	line-height: 1.5em;
	text-align: center;
	width: 100%;
	margin-bottom: 20px;
}

.heroimg2{
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
	position: relative;
	width: 100%;
	min-height: 72px;
	margin: 0px auto 10px;
	padding: 0px;

}
.heroimg2 ._h1{
  flex-basis: 60%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  position: relative;
  min-height: 86px;
  color: #FFFFFF;
  font-weight: 600;
  font-size: 2.0rem;
  line-height: 2.0rem;
  padding: 10px;
  text-shadow: 0px 2px 8px rgba(6,10,17,0.25);
  background-image: url(../imgs/hero_2.jpg);
  background-position: 0% center;
  background-repeat: no-repeat;
  background-size: cover;
  -webkit-box-shadow: inset 0px 0px 0px rgba(0,0,0,0.00);
  box-shadow: inset 0px 0px 0px rgba(0,0,0,0.00);
  overflow: hidden;
  border-top-right-radius: 20px;
}
.heroimg2 ._h1 span{
  display: inline-block;
	font-weight: 400;
	font-size: 2.6rem;
	line-height: 1.0rem;
  margin-right: 5px;
}
.heroimg2 ._h2{
  flex-basis: 40%;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	min-height: 86px;
	padding: 0px;
}
.heroimg2 ._h2 ._mybtn{
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  position: relative;
  min-height: 46px;
  color: #FFFFFF;
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1.5rem;
  padding: 12px 24px;
  background-color: #FA0000;
  border-radius: 6px;
  -webkit-box-shadow: 0px 2px 4px rgba(0,0,0,0.20);
  box-shadow: 0px 2px 4px rgba(0,0,0,0.20);
  overflow: hidden;
  cursor: pointer;
  background-image: -webkit-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
  background-image: -moz-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
  background-image: -o-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
  background-image: linear-gradient(180deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
}
.heroimg2 ._h2 ._mybtn:hover{
  opacity: 0.7;
}
.heroimg2 ._h2 span{
  display: inline-block;
	font-weight: 400;
	font-size: 2.0rem;
	line-height: 1.0rem;
  margin-right: 5px;
}
.heroimg2 ._h2 p{
  color: #fff;
	font-weight: 500;
	font-size: 0.9rem;
	line-height: 1.2rem;
  margin: 5px 10px 0px;
  /* white-space: nowrap; */
}


.recomeBox {
	margin-bottom: 40px;
	display: block;
	margin-left: -20px;
	margin-right: -20px;
	padding-left: 20px;
	padding-right: 20px;
  background-color: rgba(255, 96, 152, 0.2);
	border: 1px solid #ff6098;
	border-radius: 10px;
	padding-bottom: 0px;
	-webkit-box-shadow: 0px 2px 6px rgba(0,0,0,0.10);
	box-shadow: 0px 2px 6px rgba(0,0,0,0.20);
	overflow: hidden;
	margin-top: 15px;
}
.rankBox {
	margin-bottom: 40px;
	display: block;
	margin-left: -20px;
	margin-right: -20px;
	padding-left: 20px;
	padding-right: 20px;
  background-color: rgba(254, 190, 79, 0.2);
	border: 1px solid #febe4f;
	border-radius: 10px;
	padding-bottom: 0px;
	-webkit-box-shadow: 0px 2px 6px rgba(0,0,0,0.10);
	box-shadow: 0px 2px 6px rgba(0,0,0,0.20);
	overflow: hidden;
	margin-top: 15px;
}

/* categBox */
.categBox{
	display: block;
	position: relative;
  width: calc(100% - 20px);
	margin: 5px 10px 50px;
}

.categBox .li_1 {
	display: block;
	position: relative;
  width: 100%;
}
.categBox .li_1 li {
  display: block;
  position: relative;
  width: 100%;
  height: 50px;
  margin-bottom: 10px;
  color: #FFFFFF;
	font-weight: 600;
	font-size: 1.1rem;
	line-height: 1.8rem;
  letter-spacing: 0.1rem;
  opacity: 1;
  overflow: hidden;
  cursor: pointer;
  -webkit-box-shadow: 1px 4px 3px rgba(0,0,0,0.06);
  box-shadow: 1px 4px 3px rgba(0,0,0,0.06);
}
.categBox .li_1 li::before {
	content: '';
	display: block;
	position: absolute;
	width: 88px;
  height: 32px;
	top: 8px;
	right: 12px;
  background-color: #fff;
	border-radius: 16px;
}
.categBox .li_1 li::after {
	content: '＋ 開く';
	display: block;
  position: absolute;
	top: 8px;
	right: 12px;
	width: 88px;
	height: 10px;
  color: #101010;
	font-weight: 600;
	font-size: 0.9rem;
	line-height: 1.8rem;
  letter-spacing: 0.02rem;
  text-align: center;
}
.categBox .li_1 li.acd_op::after {
	content: '× 閉じる';
}
.categBox .li_1 li:hover, .li_1 li.acd a:hover {
	opacity: 0.7;
}
.categBox .li_1 li p {
  display: inline-block;
	padding: 8px 32px 8px 15px;
}




.vlBox{
	display: flex;
	align-items: stretch;
	flex-wrap: wrap;
	margin-left: -4px;
	margin-bottom: 20px;
}
.vlset{
	width: calc( (100% / 1) - 4px );
	margin-left: 4px;
	padding: 5px;
	margin-bottom: 0px;
}
.vlset a{
	color: #313131;
}
.vlset a:hover{
	text-decoration: none;
}

.vlBox .rank{
	display: block;
	position: absolute;
  width: 100px;
	margin-top: -12px;
  margin-left: -12px;
}

.vl{
	height: 100%;
	background-color: #F3FEFF;
	border: 1px solid #8FD4E7;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	padding-left: 10px;
	overflow: hidden;
	cursor: pointer;
}
.vl:hover{
	background-color: #FEFFEE;
	border: 1px solid #00BB9C;
}
.vl img{
	border: 1px solid #9DA3B0;
	float: none;
}
._filter_off {
 background: #000;
}

.vl img._filter_off-img {
 display: block;
 opacity: 0.7;
}


.filter-img {
 display: block;
 opacity: .6;
}

.vl h2{
	padding-top: 6px;
	padding-bottom: 8px;
	font-weight: 600;
	font-size: 1.0rem;
	line-height: 1.1rem;
	margin-bottom: 0px;
}
.vl h2 p{
	padding-top: 5px;
	padding-left: 5px;
	font-weight: 600;
	font-size: 0.86rem;
	line-height: 1.1rem;
	margin-bottom: 0px;
}
.vl p{
	font-weight: 400;
	font-size: 0.82rem;
	line-height: 1.1rem;
	margin-bottom: 8px;
}
.vl p._price{
	font-weight: 400;
	font-size: 0.78rem;
	line-height: 1.0rem;
	margin-left: 8px;
	margin-bottom: 5px;
}
.vl p._price span{
	margin-right: 1.0rem;
}


._enable{
	height: 100%;
	background-color: #F3FEFF;
	border: 1px solid #8FD4E7;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	padding-left: 10px;
	transition: 0.2s;
	overflow: hidden;
	cursor: pointer;
}
._enable:hover{
	color: #fff;
	background-color: #f15a24;
	border: 1px solid #FFFFFF;
}
._enable:hover ._files-play:after{
  background-image: url(../imgs/ico-video_on.svg);
}
._enable img{
	border: 1px solid #BABBBF;
}
._enable h2{
	padding-top: 6px;
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 0px;
}
._enable h3{
	padding-top: 3px;
	font-weight: 400;
	font-size: 0.9rem;
	margin-bottom: 0px;
}
._enable h4{
	padding-top: 6px;
	font-weight: 400;
	font-size: 0.8rem;
	margin-bottom: 0px;
}



._disable{
	background-color: #EEEEEE;
	border: 1px solid #EEEEEE;
}
._disable:hover{
	background-color: #EEEEEE;
	border: 1px solid #EEEEEE;
	cursor: default;
}


._series .vl{
	background-color: #35517B;
	border: 1px solid #35517B;
}
._series .vl:hover{
	background-color: #47628B;
	border: 1px solid #00CFB7;
	cursor: pointer;
}
._series .vl h2,
._series .vl p{
	color: #fff;
}

._capter .vlset{
	width: calc( (100% / 5) - 4px );
}

._files .vlset{
	width: calc( (100% / 5) - 4px );
	margin-left: 4px;
	padding: 5px;
	margin-bottom: 0px;
}
._files .vl h2{
	padding-top: 5px;
	padding-bottom: 0px;
	font-weight: 400;
	font-size: 0.9rem;
	margin-bottom: 0px;
}


._files-play {
  position: relative;
  width: 100%;
  height: auto;
}
._files-play:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  z-index: 3;
  background-image: url(../imgs/ico-video.svg);
  background-repeat: no-repeat;
  background-size: 64px 64px;
  background-position: center center;
  background-origin: border-box;
}



ul.vtag{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	text-align: center;
}
ul.vtag li{
	color: #FFFFFF;
	font-weight: 400;
	font-size: 0.8rem;
	line-height: 0.9rem;
	margin: 3px;
	padding: 3px 6px;
	border-radius: 4px;
}
ul.vspec{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	text-align: center;
}
ul.vspec li{
	color: #FFFFFF;
	font-weight: 400;
	font-size: 0.88rem;
	line-height: 1.0rem;
	margin-left: 4px;
	padding: 4px 8px;
}
ul.vtag li.seisaku{
	color: #FFFFFF;
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.0rem;
	margin: 8px 10px;
	padding: 6px 8px;
	border: 1px solid #FFFFFF;
	border-radius: 0px;
}


.searchBox{
	display: flex;
	justify-content: space-between;
	align-items: center;
	background-color: #EDEDED;
	height: 72px;
	z-index: 9;
	margin-bottom: 10px;
	border-top: 1px solid #999;
	border-bottom: 1px solid #fff;
}
.searchBox ._categ{
	display: flex;
	justify-content: row;
	align-items: center;
	margin-left: 0px;
	margin-top: 0px;
}
.searchBox ._categ ._title{
  color: #101010;
	font-weight: 600;
	font-size: 1.2rem;
	line-height: 1.2rem;
	margin-right: 40px;
}
.searchBox ._categ ._sort{
	font-weight: 400;
	font-size: 1.2rem;
	line-height: 1.2rem;
	margin-right: 15px;
}
.searchBox ._text{
	margin-right: 20px;
	margin-top: 0px;
}
.searchBox ._word {
	width: 180px;
	background-color: #fff;
	margin: 0 auto;
	padding: 6px;
	border: 2px solid #aaa;
	border-radius: 6px;
	outline: 0;
	font-size: 1rem;
}
.searchBox ._word::-ms-clear {
  display: none;
}
.searchBox ._searchBtn {
	background-color: #ccc;
	margin-left: 3px;
	padding: 6px 12px;
	border: 1px solid #999;
	border-radius: 6px;
	outline: 0;
	font-size: 14px;
	cursor: pointer;
}
.searchBox ._searchBtn:hover {
	background-color: #D8F0FE;
	border: 1px solid #7288A8;
}
.searchBox #catkyozaiBtn{
  color: #2882DF;
  cursor: pointer;
}


._ico-h2{
	font-weight: 800;
	font-size: 2.4rem;
	line-height: 2.4rem;
	margin-left: 10px;
	margin-right: 5px;
}
._ico-h3{
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.6rem;
	margin-left: 10px;
	margin-right: 5px;
}


.cp_select {
	overflow: hidden;
}
.cp_select select {
	cursor: pointer;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}
.cp_select select::-ms-expand {
  display: none;
}
.cp_select.cp_sl03 {
	position: relative;
	border-radius: 6px;
	border: 2px solid #aaa;
	background: #ffffff;
}
.cp_select.cp_sl03::before {
	position: absolute;
	top: 1.0em;
	right: 0.8em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #313131;
	pointer-events: none;
}
.cp_select.cp_sl03 select {
	padding: 8px 38px 8px 8px;
	color: #313131;
}




.catchBox{
	width: 100vw;
	background-color: #2882DF;
	position: relative;
	left: 50%;
	right: 50%;
	margin: 20px -50vw 0px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	-webkit-box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
	box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
	background-image: -webkit-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: -moz-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: -o-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: linear-gradient(359deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
}
.catchBox-r{
	order: 2;
	flex-basis: 40%;
	background-image: url(../imgs/foot_c1.jpg);
	background-size: cover;
	height: 360px;
	background-position: 50% 50%;
}
.catchBox-l{
	order: 1;
	flex-basis: 60%;
}
.catchTxt {
	margin-left: auto;
	margin-right: auto;
	max-width: 640px;
}
.catchTxt ._catch {
	font-size: 1.4rem;
	margin: 0px 20px 20px;
	color: #FFFFFF;
}
.catchTxt ._login{
	color: #FFFFFF;
	font-weight: 400;
	font-size: 1.4rem;
	line-height: 1.4rem;
	text-align: center;
	padding: 15px 30px;
	border: 1px solid #FFFFFF;
	margin-left: 20px;
	margin-right: 20px;
}
.catchTxt ._login:hover{
	background-color: rgba(255,255,255,0.36);
	cursor: pointer;
}
.catchTxt a:hover{
	text-decoration: none;
}



.footer {
	background-color: #2C2C30;
	padding-top: 20px;
	padding-bottom: 20px;
	color: #808080;
	font-weight: 400;
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin: 0 -50vw;
	display: flex;
	justify-content: center;
	align-items: stretch;
}
.copyright {
	color: #666;
	width: 100%;
	text-align: center;
	font-family: Verdana, Geneva, sans-serif;
	padding-left: 10px;
	padding-right: 10px;
}
.footer .foot-nav {
	height: 100%;

}
.footer .foot-nav ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 30px;
	padding: 0px;
	text-align: center;
}
.footer .foot-nav ul li{
	margin: 4px;
	padding-top: 4px;
	padding-right: 10px;
	padding-left: 10px;
	padding-bottom: 4px;
	font-size: 0.8rem;
	border-radius: 5px;
	color: #FFFFFF;
	font-weight: 400;
}
.footer .foot-nav ul li a{
	color: #FFFFFF;
	height: auto;
}



/* detail --------------------------------- */
.detailImg{
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #10100D;
}
.detailImg .vMain{
	margin: 10px;
	position: relative;
}
#wrap-video{
	position: relative;
	max-width: 560px;
}
#wrap-video video{
	width: 100%;
}

#video-ctl {
  display: flex;
  flex-direction: row;
	justify-content: flex-start;
	width: 100%;
	height: 20px;
	color: #B5B5B5;
}
#video-ctl ._btn {
	flex-basis: 30px;
	margin: 0px 10px;
	overflow: hidden;
}
#video-ctl ._btn span {
	font-size: 22px;
	line-height: 22px;
	cursor: pointer;
}
#video-ctl ._pause {

}
#video-ctl ._seekbar {
	position: relative;
	flex-basis: 100%;
	margin: 3px;
	background-color: #2D2D2D;
	border: 1px solid #B5B5B5;
	overflow: hidden;
	cursor: pointer;
}
#video-ctl ._seeker {
	display: inline-block;
	width: 80%;
	height: 20px;
	background-color: #67707C;
}



.detailImg .vMain ._sample{
	padding: 10px 30px;
	background-color: #FF071B;
	position: absolute;
	top: 20px;
	left: 20px;
	color: #FFFFFF;
	font-weight: 800;
	font-size: 2.2rem;
	border-radius: 100px;
	opacity: 0.8;
}



.detailTitle{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	color: #ffffff;
	background-color: #2c2c2d;
	padding: 20px;
}
.detailTitle .vInfo{
	margin-left: 10px;
	margin-right: 20px;
}
.detailTitle .vInfo h1{
	font-weight: 800;
	font-size: 1.8rem;
	line-height: 2.4rem;
	margin-bottom: 10px;
}
.detailTitle .vInfo h2{
	font-weight: 800;
	font-size: 1.3rem;
	line-height: 1.8rem;
	margin-left: 2rem;
	margin-bottom: 10px;
}
.detailTitle .vInfo p{
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.6rem;
	margin-top: 10px;
	margin-left: 10px;
}
.detailTitle .vBtn{
	margin-right: 10px;
	margin-left: 20px;
}
.detailTitle .material-icons {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.2rem;
	margin-right: 5px;
	vertical-align: bottom;
}
.detailTitle .vBtn .btn{
	width: 260px;
	font-weight: 600;
	font-size: 1.1rem;
	line-height: 1.5rem;
	padding: 20px 5px;
	text-align: center;
	margin-bottom: 10px;
	background-color: #000000;
	border-radius: 6px;
	cursor: pointer;
}
.detailTitle .vBtn .btn:hover{
	opacity: 0.7;
}
.detailTitle .vBtn ._small{
  display: inline;
	font-weight: 500;
	font-size: 0.9rem;
}
.detailTitle .vBtn ._hyp{
  display: block;
  position: relative;
  width: 100%;
  margin-bottom: 15px;
	font-weight: 400;
	font-size: 0.9rem;
  text-align: right;
}
.detailTitle .vBtn ._hyp a{
  color: #fff;
  margin-right: 15px;
}


.detailTitle .vBtn ._order{background-color: #f15a24;}
.detailTitle .vBtn ._preview{background-color: #0033E8;}
.detailTitle .vBtn ._preview-off{background-color: #0033E8;}
.detailTitle .vBtn ._mylist{background-color: #0071bc;}

.detailTitle .vBtn .vl{
	border-style: none;
}

.detailTitle .vBtn ._off{
	width: 260px;
	font-weight: 800;
	font-size: 1.2rem;
	line-height: 1.2rem;
	padding: 20px;
	text-align: center;
	margin-bottom: 10px;
	background-color: #838383;
	border-radius: 6px;
	opacity: 0.5;
}


._h2 {
	font-weight: 800;
	font-size: 1.3rem;
	line-height: 1.3rem;
	padding: 10px 10px;
}
._h2 .material-icons {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.6rem;
	margin-right: 5px;
	vertical-align: middle;
}
._h3 {
	font-weight: 400;
	font-size: 0.9rem;
	line-height: 1.1rem;
	padding: 5px 10px;
}
._h3 .material-icons {
	font-size: 1.2rem;
	line-height: 1.1rem;
	margin-right: 5px;
	vertical-align: bottom;
}

._heroimg_cap {
	display: block;
	font-size: 1.4rem;
	margin: 0px!important;
	padding: 0px !important;
}

._col-guide {
	background-color: #fff;
	margin: 10px 10px;
}
._col-guide ul {
  display: flex;
  flex-direction: row;
	justify-content: flex-end;
	align-items: flex-end;
}
._col-guide ul li {
	display: inline-block;
	font-weight: 400;
	font-size: 0.8rem;
	line-height: 1.4rem;
	margin-left: 20px;

}
._col-guide ul li span {
	display: inline-block;
	width: 36px;
	height: 20px;
	margin-right: 5px;
	vertical-align: middle;
}


.itemTitle {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	color: #ffffff;
	margin-top: 10px;
	margin-bottom: 5px;
}
.itemTitle ._h2 {
	font-weight: 400;
	font-size: 1.2rem;
	padding: 8px;
}
.itemTitle ._h2 ._sub {
	display: inline-block;
	font-size: 1.0rem;
	margin: 0px 10px;
}
.itemTitle ._h4 {
	display: inline-block;
	font-size: 0.8rem;
}
.itemTitle ._h2 p {
	display: inline;
	font-size: 0.86rem;
}
.itemTitle ._h2 p .material-icons {
	font-size: 1.0rem;
	line-height: 1.0rem;
	margin-right: 3px;
	vertical-align: middle;
}
.itemTitle ._orderBtn {
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.2rem;
	padding: 8px 12px;
	background-color: #FF4500;
	border-radius: 6px;
	display: inline-block;
	margin: 0px 6px;
}
.itemTitle ._orderBtn:hover {
	opacity: 0.7;
	cursor: pointer;
}
.itemTitle ._deleteBtn {
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.2rem;
	padding: 8px 12px;
	background-color: #203B6F;
	border-radius: 6px;
	display: inline-block;
	margin: 0px 6px;
}
.itemTitle ._deleteBtn:hover {
	opacity: 0.7;
	cursor: pointer;
}

._view-free {
	background-color: var(--color-free);
}
._view-able {
	background-color: #2882DF;
}
._view-nobuy {
	background-color: #1DA87F;
}
._view-disable {
	background-color: #848587;
}

._capter {
	background-color: #2c2c2d;
	padding-bottom: 5px;
}
._capter ._h2 {
	font-weight: 400;
	margin: 0px 10px 0px;
	color: #FFFFFF;
}
.vl_capter{
	color: #ffffff;
	height: 100%;
	padding: 10px;
	overflow: hidden;
}

.vl_capter img{
	border: 1px solid #BABBBF;
}
.vl_capter h2{
	padding-top: 10px;
	padding-bottom: 0px;
	font-weight: 400;
	font-size: 0.9rem;
	margin-bottom: 0px;
}
.vl_capter h2 p{
	padding-top: 5px;
	font-weight: 400;
	font-size: 0.8rem;
	margin-bottom: 0px;
}

._series {
	background-color: #35517B;
	padding-top: 5px;
	margin-bottom: 20px;
}
._series ._h2 {
	font-weight: 400;
	font-size: 1.2rem;
	line-height: 1.4rem;
	margin: 0px 10px 0px;
	color: #FFFFFF;
}
.vl_series{
	color: #ffffff;
	height: 100%;
	padding: 10px;
	overflow: hidden;
}
.vl_series:hover{
	background-color: rgba(255,255,255,0.20);
	cursor: pointer;
}
.vl_series img{
	border: 1px solid #BABBBF;
}
.vl_series h2{
	padding-top: 10px;
	padding-bottom: 0px;
	font-weight: 800;
	font-size: 1.0rem;
	line-height: 1.1rem;
	margin-bottom: 0px;
}
.vl_series h2 p{
	padding-top: 5px;
	font-weight: 800;
	font-size: 0.86rem;
	line-height: 1.1rem;
	margin-bottom: 0px;
}
.vl_series p{
	padding-top: 5px;
	font-weight: 400;
	font-size: 0.82rem;
	line-height: 1.1rem;
	margin-bottom: 0px;
}
.vl_series p._price{
	font-weight: 400;
	font-size: 0.78rem;
	margin-left: 8px;
	margin-bottom: 5px;
}


/* supportBox --------------------------------- */
.detailTitle .supportBox{
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 240px;
	margin: 40px 10px 10px;
	padding: 10px;
	background-color: #111;
	border: 1px solid #fff;
}
.detailTitle .supportBox h2{
	position: relative;
	width: 200px;
	padding: 5px 0 2px;
	margin: -20px auto 35px;
	color: #fff;
	font-weight: 400;
	font-size: 1.1rem;
	text-align: center;
	background-color: #FF0000;
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
}
.detailTitle .supportBox h2:after{
	content: "";
	position: absolute;
	width: 0;
	height: 0;
	bottom: -14px;
	left: 0;
	border-style: solid;
	border-color: #FF0000 transparent transparent transparent;
	border-width: 15px 100px 0 100px;
	z-index: 1;
}

.detailTitle .supportBox img{
	width: 16px;
	margin-left: -21px;
	margin-right: 5px;
}
.detailTitle .supportBox a{
	display: block;
	padding-left: 25px;
	color: #fff;
	font-weight: 400;
	font-size: 0.9rem;
	line-height: 1.6em;
	margin-left: 8px;
	margin-bottom: 15px;
}



/* login --------------------------------- */
.loginBox{
	display: flex;
	align-items: center;
	height: calc(100vh - 72px);
	min-height: 500px;
	background-color: #FFFFFF;
	padding: 40px 20px;
	-webkit-box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
	box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
	background-image: -webkit-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: -moz-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: -o-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	background-image: linear-gradient(359deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
}
.loginBox .lform{
	margin-left: auto;
	margin-right: auto;
	max-width: 500px;
	background-color: #FFFFFF;
	width: 100%;
	padding-top: 20px;
	padding-right: 20px;
	padding-bottom: 20px;
	padding-left: 20px;
	text-align: center;
	border-radius: 28px;
	-webkit-box-shadow: 0px 0px 10px 3px rgba(0,0,0,0.12);
	box-shadow: 0px 0px 10px 3px rgba(0,0,0,0.12);
}
.loginBtn{
	width: 260px;
	padding: 20px;
	text-align: center;
	margin-bottom: 20px;
	background-color: #2882DF;
	color: #ffffff;
	font-weight: 800;
	font-size: 1.4rem;
	line-height: 1.4rem;
	border-radius: 50px;
	cursor: pointer;
	margin-left: auto;
	margin-right: auto;
	margin-top: 20px;
  border: 2px solid #FFFFFF;
}
.loginBtn:hover{
	opacity: 0.7;
}
.loginBox form {
  padding: 0 20px;
}
.loginBox .form-item {
	width: 100%;
	margin: 30px 0;
}
.loginBox .form-item input {
	width: 100%;
	height: 50px;
  background: #fafafa;
  border: none;
  border-bottom: 2px solid #e9e9e9;
  color: #666;
  font-size: 1em;
  transition: border-color 0.3s;
}
.loginBox .form-item input:focus {
  border-bottom: 2px solid #c0c0c0;
  outline: none;
}

.loginBox .whatis{
	color: #ffffff;
	font-weight: 800;
	font-size: 1.6rem;
	line-height: 2.4rem;
	margin-left: auto;
	margin-right: auto;
	max-width: 800px;
	width: 100%;
	padding-top: 20px;
	padding-right: 20px;
	padding-bottom: 20px;
	padding-left: 20px;
	text-align: left;
	min-height: 280px;
}





/* library --------------------------------- */
#box1 {
	display: block;
	margin-bottom: 50px;
	overflow: hidden;
}
#box2 {
	display: none;
	position: relative;
	background-color: #1e1e19;
	width: 100%;
	height: 100%;
}
#box2 #mvbox {
	position: relative;
	display: block;
	opacity: 1;
	margin-left: auto;
	margin-right: auto;
	padding-top: 20px;
	padding-bottom: 20px;
	padding-right: 20px;
	padding-left: 20px;
}

#mvTitle {

}
#mvTitle h1 {
	font-weight: 800;
	font-size: 1.4rem;
	line-height: 1.6rem;
	border-left: 12px solid #CA0056;
	padding-left: 10px;
	padding-bottom: 0px;
	padding-top: 0px;
}



/*--------------------------------------------
よくある質問
--------------------------------------------*/

.faqlist {
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 80px;
	width: 90%;
	max-width: 800px;
}
h3.qa_h3 {
	font-weight: 800;
	font-size: 2.0rem;
	line-height: 2.0rem;
	padding: 20px 10px;
	text-align: center;
}
.qa_h3 + dl {
  margin: 0 0 50px;
  border-top: 1px solid #CCC;
}
.qa_h3 + dl dt {
	font-size: 1.2rem;
	line-height: 1.8rem;
  padding: 20px;
  border-left: 1px solid #CCC;
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
  cursor: pointer;
}
.qa_h3 + dl dt:hover {
  background: #F7F5ED;
  color: #009245;
}
.qa_h3 + dl dd {
	margin-bottom: 0px;
	padding: 30px;
	background: #F2F2F2;
	border-left: 1px solid #CCC;
	border-right: 1px solid #CCC;
	border-bottom: 1px solid #CCC;
	display: none;
}
.qa_h3 + dl dd a {
  text-decoration: none;
}
.qa_h3 + dl dd a:hover {
	text-decoration: underline;
}
.qa_h3 + dl dd ol {
  list-style-type: decimal;
  margin: 0 0 0 20px;
}


/*--------------------------------------------
ご利用方法
--------------------------------------------*/

.howtolist {
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 50px;
	width: 90%;
	max-width: 800px;
}
.howtolist h3 {
	font-weight: 800;
	font-size: 2.0rem;
	line-height: 2.0rem;
	padding: 20px 10px;
	text-align: center;
}
.howtolist dl {
	display: inline-block;
	width: 100%;
  margin: 0 0 30px;
  border-top: 1px solid #CCC;
}
.howtolist dl dt {
	color: #009245;
	font-size: 1.2rem;
	line-height: 1.8rem;
  padding: 10px;
  border-left: 1px solid #CCC;
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
}
.howtolist dl dt .material-icons {
	font-size: 2.2rem;
	line-height: 1.0rem;
  margin: 0px 10px;
}
.howtolist dl dd {
	margin-bottom: 0px;
	padding: 15px;
	font-size: 1.0rem;
	line-height: 1.6rem;
	background: #F2F2F2;
	border-left: 1px solid #CCC;
	border-right: 1px solid #CCC;
	border-bottom: 1px solid #CCC;
}
.howtolist dl dd a {
  text-decoration: none;
}
.howtolist dl dd a:hover {
	text-decoration: underline;
}
.howtolist dl dd ol {
  list-style-type: decimal;
  margin: 0 0 0 20px;
}



/*--------------------------------------------
定額見放題
--------------------------------------------*/

.unlimlist {
  display: block;
  position: relative;
	margin: 20px auto 50px;
	width: calc(100% - 40px);
	max-width: 1200px;
  background-color: #000;
}
.unlimlist dl {
	display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
	width: 100%;
  margin: 0 0 30px;
  /* border-top: 1px solid #CCC; */
}
.unlimlist dl dt {
  flex-basis: 50%;
	color: #009245;
	font-size: 1.2rem;
	line-height: 1.8rem;
  padding: 20px;
}
.unlimlist dl dd {
  flex-basis: 50%;
	margin-bottom: 0px;
	padding: 15px;
  color: #fff;
  font-weight: 500;
  font-size: clamp(1.4rem, 0.689rem + 1.48vw, 1.8rem);
	line-height: 1.5em;
  text-align: justify;
}
.unlimlist dl dd p._h2 {
  display: block;
  position: relative;
  margin: 40px 0px 15px;
  padding: 0;
  font-weight: 400;
  font-size: clamp(1.2rem, 0.844rem + 0.74vw, 1.3rem);
	line-height: 1.8rem;
  text-align: left;
}
.unlimlist dl dd p._h3 {
  display: block;
  position: relative;
  margin: 5px 0px 0px;
  padding: 0;
  font-weight: 400;
  font-size: clamp(1rem, 0.644rem + 0.74vw, 1.2rem);
	line-height: 1.5rem;
  text-align: left;
}
.unlimlist dl dd p span {
  display: inline-block;
}


.unlimlist ._faq {
  display: grid;
  justify-items: center;
  align-items: center;
  position: relative;
  width: 100%;
	margin: 100px 0px;
	padding: 100px 0px;
  background-color: #7340BD;
}
.unlimlist ._faq .catchTxt {
  width: 100%;
  max-width: 640px;
}



/*--------------------------------------------
ソートリスト
--------------------------------------------*/

.list-box {
	width: 40%;
}
.list-box ._cap {
	font-size: 1.2rem;
	line-height: 1.2rem;
}
.list-box .material-icons {
	font-size: 2.0rem;
	line-height: 1.4rem;
	margin-right: 3px;
	vertical-align: middle;
}
.row {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 15px;
}
.col {
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
	-ms-flex-positive: 1;
	flex-grow: 1;
	max-width: 100%;
	padding-right: 0;
	margin: 15px 0px;
}
.col2 {
	-ms-flex-preferred-size: 0;
	flex-basis: 0;
	-ms-flex-positive: 1;
	flex-grow: 1;
	width: 100px;
	padding-right: 0;
	margin: 15px;
}

.list-col2 {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 480px;
	padding-left: 0;
	margin-bottom: 0;
}
.list-col2 .material-icons {
	font-size: 6.0rem;
	line-height: 6.4rem;
	margin-right: 3px;
	vertical-align: middle;
	color: #2882DF;
	cursor: pointer;
}
.list-col2 .material-icons:hover {
	opacity: 0.7;
}
.list-col2 p {
	display: inline-block;
	font-size: 0.9rem;
	margin: 10px;
}

.list-enable {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	padding-left: 0;
	margin-bottom: 0;
	height: 480px;
	overflow-y: scroll;
	background-color: #EDEDED;
	border: 1px solid #6D6D6D;
	position: relative;
}
.list-play {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	padding-left: 0;
	margin-bottom: 0;
	height: 480px;
	overflow-y: scroll;
	background-color: #FEFACF;
	border: 1px solid #6D6D6D;
}
.list-group-item {
	position: relative;
	display: block;
	padding: 8px 10px;
	margin: 12px;
	margin-bottom: -1px;
	font-size: 0.92rem;
	background-color: #fff;
	border: 1px solid rgba(0,0,0,.25);
	border-radius: 6px;
	cursor: move;
	-webkit-box-shadow: 0px 1px 1px;
	box-shadow: 0px 1px 1px;
}
.list-group-item:hover {
	background-color: #DCFCFF;
	border: 1px solid rgba(0,0,0,.125);
}

._play_reset{
	display: inline-block;
	padding: 6px 8px;
	text-align: center;
	margin-top: 40px;
	background-color: #2882DF;
	color: #ffffff;
	font-weight: 400;
	font-size: 1.0rem;
	line-height: 1.0rem;
	border-radius: 6px;
	cursor: pointer;
}
._play_reset:hover{
	opacity: 0.7;
}



.list-table {
	width: 100%;
}
.list-table ._cap {
	font-size: 1.2rem;
	line-height: 1.2rem;
}
.list-table .material-icons {
	font-size: 2.0rem;
	line-height: 1.4rem;
	margin-right: 3px;
	vertical-align: middle;
}
.list-table .limit {
	font-size: 1.0rem;
	line-height: 1.0rem;
	margin-left: 10px;
}
.list-history {
	display: block;
	width: 100%;
	min-height: 300px;
	max-height: 500px;
	overflow-y: scroll;
	background-color: #fff;
	border: 1px solid #6D6D6D;
}
.tbl_history {
	padding: 5px 0px;
	width: 100%;
	overflow: hidden;
}
._head {
	position: relative;
	padding: 5px 0px;
	margin-bottom: 0px;
	height: 32px;
	font-weight: 400;
	font-size: 0.9rem;
	line-height: 1.2rem;
	text-align: center;
	background-color: #CDD0D9;
	border-left: 1px solid #6D6D6D;
	border-right: 1px solid #6D6D6D;
	border-top: 1px solid #6D6D6D;
}
._list {
	position: relative;
	padding: 5px 0px;
	font-size: 0.86rem;
	line-height: 1.0rem;
	background-color: #fff;
}
.tbl_history {
	padding: 5px 0px;
	width: 100%;
}
.tbl_history._head td:first-child {
	border-right: 1px solid rgba(0,0,0,.125);
}
.tbl_history._list tr:nth-child(2n+1) {background-color:#EAEEF2;}
.tbl_history td {
	padding: 10px;
}
.tbl_history td:first-child {
	width: 200px;
}

.tbl_history_buy {
	padding: 5px 0px;
	width: 100%;
}
.tbl_history_buy._head td:first-child {
	border-left: 1px solid rgba(0,0,0,.125);
}
.tbl_history_buy._list tr:nth-child(2n+1) {background-color:#EAEEF2;}
.tbl_history_buy td {
	padding: 10px;
	border-left: 1px solid rgba(0,0,0,.125);
}
.tbl_history_buy td:first-child {
	width: 140px;
}
.tbl_history_buy td:nth-child(2) {
	width: 150px;
}





/* ----------------- */
.kyozaiBox{
	display: block;
	position: relative;
	width: 100%;
  background-color: #000;
}
.kyozaiBox .vlset{
  position: relative;
  width: 262px;
  height: 250px;
  margin: 0px 2px;
  overflow: hidden;
}
.kyozaiBox .vlset .vl{
  position: relative;
  width: 100%;
	height: 100%;
  color: #313131;
	font-weight: 400;
	font-size: 0.9rem;
	line-height: 1.2em;
	background-color: #F3FEFF;
	border: 1px solid #8FD4E7;
	padding: 6px;
	cursor: pointer;
}
.kyozaiBox .vlset .vl:hover{
	background-color: #FEFFEE;
	border: 1px solid #00BB9C;
}
.kyozaiBox .vlset .vl._free::before{
  content: 'FREE';
  position: absolute;
  width: 62px;
  height: 32px;
  padding-top: 8px;
  bottom: 0px;
  right: 20px;
	color: #FFFFFF;
	font-weight: 500;
	font-size: 15px;
	line-height: 15px;
	letter-spacing: 0.05em;
  text-align: center;
  background-color: #3fa9f5;
}
.kyozaiBox .vlset .vl form{
  position: relative;
  width: 100%;
	height: 100%;
  margin: 0;
  padding: 0;
}
.kyozaiBox .vlset .vl img{
  width: 100%;
	border: 1px solid #9DA3B0;
}
.kyozaiBox .vlset .vl h2{
	padding: 6px 3px 3px;
  font-weight: 500;
}
.kyozaiBox .vlset .vl ._sm{
	font-size: 0.8rem;
}
.kyozaiBox .vlset .vl ._ss{
	font-size: 0.7rem;
}

.kyozaiBox .vlset .vtag{
	display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-end;
	flex-wrap: nowrap;
	position: absolute;
  bottom: 0px;
}
.kyozaiBox .vlset .vtag li{
	color: #FFFFFF;
	font-weight: 400;
	font-size: 0.8rem;
	line-height: 1em;
	margin: 3px;
	padding: 3px 6px;
	border-radius: 4px;
}
.kyozaiBox .slick-slide {
  width: 262px;
}


/* ----------------- */
.slick-dots {
  text-align:center;
	margin:20px auto 0px;
}
.slick-dots li {
  display:inline-block;
	margin:0 6px;
}
.slick-dots button {
  color: transparent;
  outline: none;
  width: 6px;
  height: 4px;
  display: block;
  border: none;
  border-radius: 2px;
  background:#75777b;
}
.slick-dots .slick-active button{
  background:#ffffff;
}
.slick-next,
.slick-prev {
  display: block;
  position: absolute;
  top: 5px;
  background-repeat: no-repeat;
  background-size: 7px 12px;
  width: 30px;
  height: 250px;
  background-color: rgba(0, 0, 0, 0.2);
  border: none;
  border-radius: 4px;
  z-index: 12;
}
.slick-prev {
  background-image: url('../imgs/yaji_left.svg');
  background-position: 10px center;
}
.slick-next {
  background-image: url('../imgs/yaji_right.svg');
  background-position: 12px center;
}
.slick-next:focus,
.slick-prev:focus {
  outline: none;
  box-shadow: none;
}
.slick-prev:hover,
.slick-next:hover {
  background-color: rgba(0, 0, 0, 0.5);
}
.slick-prev {
  left: 0px; 
}
.slick-next {
  right: 0px; 
}










/* ----------------------------------------------------------------------------------------- */
/* ############################################################################################# */
/* ############################################################################################# */
/* ############################################################################################# */
/* ############################################################################################# */
/* ############################################################################################# */
/* ----------------------------------------------------------------------------------------- */
@media screen and (max-width: 767px) {

	.disp_pc {
		display: none;
	}
	.disp_sp {
		display: block;
	}

	.main {
		padding-top: 52px;
	}

	.bikou_regist {
    display: block;
    background-color:#fff;
    border:1px solid #b33126;
    font-size:0.9rem;
    margin:15px;
    padding:10px;
    vertical-align:middle;
	}

	.header{
		background-color: white;
		position: fixed;
		top: 0px;
		width: 100%;
		height: 52px;
		display: flex;
		justify-content: space-between;
		align-items: center;
		z-index: 99;
		left: 0px;
	}
	.header_sdw{
		-webkit-box-shadow: 0px 1px 2px rgba(32,33,34,0.50);
		box-shadow: 0px 1px 2px rgba(32,33,34,0.50);
	}

	.siteName{
		flex-basis: 120px;
		margin-left: 10px;
	}
	.siteName #siteLogo{
		width: 120px;
		height: auto;
		margin-right: 5px;
	}

	.globalNav{
		margin-right: 10px;
	}
	.list-nav {

	}
	.list-nav ul li{
		font-weight: 400;
		font-size: 0.8rem;
	}
	.list-nav ul li ._login{
		padding: 8px 10px;
		line-height: 0.9rem;
	}
	.list-nav ul li ._regist{
		padding: 8px 10px;
		line-height: 0.9rem;
	}
	.mob-nav {
		margin-left: 10px;
	}

	#mvTitle {
		display: block;
		margin-left: 10px;
		margin-bottom: 0px;
	}
	#mvTitle h1 {
		font-weight: 800;
		font-size: 1.0rem;
		line-height: 1.1rem;
		border-left: 12px solid #FF002D;
		padding-left: 10px;
		padding-bottom: 6px;
		padding-top: 2px;
	}



	.heroimg{
		min-height: 200px;
		margin: 0px auto 10px;
	}
	.heroimg h1{
		position: relative;
		color: #FFFFFF;
		font-weight: 400;
		font-size: 1.8rem;
		line-height: 2.2rem;
		text-align: center;
		width: 100%;
		margin-bottom: 20px;
	}
	.heroBox{
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		padding: 0px;
	}
	.heroimg ._h1{
		display: none;
	}
	.heroimg ._h2{
		width: 100%;
		overflow: hidden;
	}
	.heroimg ._h2 p{
		color: #FFFFFF;
		font-weight: 400;
		font-size: 1.2rem;
		line-height: 1.6rem;
    text-align: left;
		margin-bottom: 15px;
	}
  .heroimg ._h2 p._cp{
    font-size: 1.4rem;
    line-height: 1.6rem;
    margin: 10px auto 0px;
  }
  .heroimg ._h2 p._cp2{
    font-size: 1.2rem;
    line-height: 1.4rem;
    margin: 10px auto 10px;
  }

	.heroimg ._h2 a{
		text-decoration: none;
	}
	.heroimg ._h2 ._login{
		color: #FFFFFF;
		font-weight: 400;
		font-size: 1.2rem;
		line-height: 1.6rem;
		text-align: center;
		padding: 15px 10px;
		border: 1px solid #FFFFFF;
		letter-spacing: 0rem;
		cursor: pointer;
	}
	.heroimg ._h2 ._login:hover{
		background-color: rgba(255,255,255,0.36);
	}

	.heroimg ._marker{
		display: block;
		color: #fff;
		font-weight: 800;
		font-size: 0.8rem;
		top: 400px;
		text-align: center;
		width: 100%;
		margin-top: 10px;
	}


  .heroimg._index {
    margin: 52px auto -42px;
  }
  .heroimg._index h1{
    font-size: clamp(1.4rem, 1.047rem + 1.57vw, 1.8rem);
    /* line-height: clamp(2rem, 1.647rem + 1.57vw, 2.4rem); */
    text-align: justify;
    margin-bottom: 20px;
  }
  .heroimg._index ._h3{
    font-size: clamp(1rem, 0.469rem + 2.36vw, 1.6rem);
    text-align: justify;
    margin-bottom: 10px;
  }


  .heroimg2{
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: stretch;
    position: relative;
    width: 100%;
    min-height: 72px;
    margin: 0px auto 10px;
    padding: 0px;

  }
  .heroimg2 ._h1{
    order: 2;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    min-height: 86px;
    color: #FFFFFF;
    font-weight: 600;
    font-size: 1.8rem;
    line-height: 1.8rem;
    padding: 10px;
    text-shadow: 0px 2px 8px rgba(6,10,17,0.25);
    background-image: url(../imgs/hero_2.jpg);
    background-position: 0% center;
    background-repeat: no-repeat;
    background-size: cover;
    -webkit-box-shadow: inset 0px 0px 0px rgba(0,0,0,0.40);
    box-shadow: inset 0px 0px 0px rgba(0,0,0,0.40);
    overflow: hidden;
    border-top-right-radius: 0px;
  }
  .heroimg2 ._h1 span{
    display: inline-block;
    font-weight: 400;
    font-size: 2.4rem;
    line-height: 1.0rem;
    margin-right: 5px;
  }
  .heroimg2 ._h2{
    order: 1;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-end;
    align-items: center;
    position: relative;
    width: 100%;
    min-height: 86px;
    padding: 10px auto 30px;
    background-color: #2B2145;
    -webkit-box-shadow: inset 0px 1px 2px rgba(0,0,0,0.40);
    box-shadow: inset 0px 1px 2px rgba(0,0,0,0.40);
  }
  .heroimg2 ._h2 ._mybtn{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    min-height: 46px;
    color: #FFFFFF;
    font-weight: 600;
    font-size: 1.1rem;
    line-height: 1.5rem;
    margin-top: 20px;
    padding: 12px 24px;
    background-color: #FA0000;
    border-radius: 6px;
    -webkit-box-shadow: 0px 2px 4px rgba(0,0,0,0.40);
    box-shadow: 0px 2px 4px rgba(0,0,0,0.40);
    overflow: hidden;
    cursor: pointer;
    background-image: -webkit-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
    background-image: -moz-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
    background-image: -o-linear-gradient(270deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
    background-image: linear-gradient(180deg,rgba(255,19,0,1.00) 0%,rgba(198,14,0,1.00) 100%), url(url);
  }
  .heroimg2 ._h2 ._mybtn:hover{
    opacity: 0.7;
  }
  .heroimg2 ._h2 span{
    display: inline-block;
    font-weight: 400;
    font-size: 2.0rem;
    line-height: 1.0rem;
    margin-right: 5px;
  }
  .heroimg2 ._h2 p{
    color: #fff;
    font-weight: 500;
    font-size: 0.9rem;
    line-height: 1.2rem;
    margin: 5px 10px 20px;
    /* white-space: nowrap; */
  }


	.recomeBox {
		margin-bottom: 40px;
		display: block;
		margin-left: -0px;
		margin-right: -0px;
		padding-left: 0px;
		padding-right: 0px;
		border: 1px solid #FF6098;
		border-radius: 0px;
		padding-bottom: 0px;
		-webkit-box-shadow: 0px 0px 6px rgba(0,0,0,0.10);
		box-shadow: 0px 0px 6px rgba(0,0,0,0.20);
		overflow: hidden;
	}

  .vlBox .rank{
    display: block;
    position: absolute;
    width: 18%;
    max-width: 100px;
    margin-top: -6px;
    margin-left: -6px;
  }

	.vl img{
		width: calc( (100% / 2.4) - 20px );
		margin-right: 20px;
		float: left;
	}

	.vl h2{
		padding-top: 0px;
		padding-bottom: 8px;
	}

	ul.vtag li.seisaku{
		margin-left: 0px;
		margin-right: 100%;
		white-space: nowrap;
	}


	.tab-Box{
		display: flex;
		justify-content: center;
		align-items: center;
		height: 72px;
	}
	.tab-Box ._categ{
		display: flex;
		flex-direction: column;
		align-items: center;
		margin-left: 0px;
		margin-top: 0px;
	}
	.tab-Box ._categ ._title{
		font-weight: 400;
		font-size: 0.68rem;
		line-height: 1.0rem;
	}


	.searchBox{
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		background-color: #EDEDED;
		height: auto;
		z-index: 9;
		margin-bottom: 10px;
		border-top: 1px solid #999;
		border-bottom: 1px solid #fff;
		overflow: hidden;
	}
	.searchBox ._categ{
		display: flex;
		justify-content: row;
		align-items: center;
		margin-left: 0px;
		margin-right: 20px;
		margin-top: 10px;
	}
	.searchBox ._categ ._title{
		font-weight: 400;
		font-size: 1.1rem;
		line-height: 1.1rem;
		margin-right: 20px;
	}
	.searchBox ._categ ._sort{
		font-weight: 400;
		font-size: 1.0rem;
		line-height: 1.0rem;
		margin-left: 10px;
		margin-right: 15px;
	}
	.searchBox ._text{
		margin: 10px;
	}
	.searchBox ._word {
		width: 180px;
		padding: 5px 5px 5px 28px;
		font-size: 1rem;
	}

	._ico-h2{
		font-weight: 800;
		font-size: 2.0rem;
		line-height: 2.0rem;
		margin-left: 10px;
		margin-right: 5px;
	}

	.cp_select {
		margin-bottom: 10px;
		overflow: hidden;
	}
	.cp_select.cp_sl03 select {
		padding: 5px 32px 5px 6px;
		color: #313131;
	}


	.catchBox{
		width: 100%;
		background-color: #2882DF;
		position: relative;
		left: 0%;
		right: 0%;
		margin: 0px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		-webkit-box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
		box-shadow: inset 0px 3px 2px rgba(0,0,0,0.12);
		background-image: -webkit-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
		background-image: -moz-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
		background-image: -o-linear-gradient(91deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
		background-image: linear-gradient(359deg,rgba(27,79,172,1.00) 0%,rgba(40,130,223,1.00) 46.95%);
	}
	.catchBox-r{
		order: 1;
		flex-basis: auto;
		width: 100%;
		background-image: url(../imgs/foot_c1.jpg);
		background-size: cover;
		height: 200px;
		background-position: 50% 50%;
	}
	.catchBox-l{
		order: 2;
		width: 100%;
		margin: 40px 20px;
	}
	.catchTxt {
		margin-left: auto;
		margin-right: auto;
		max-width: 600px;
	}
	.catchTxt ._catch {
		font-size: 1.2rem;
		margin: 0px 30px 20px;
		color: #FFFFFF;
	}
	.catchTxt ._login{
		color: #FFFFFF;
		font-weight: 400;
		font-size: 1.2rem;
		line-height: 1.6rem;
		text-align: center;
		padding: 15px 10px;
		border: 1px solid #FFFFFF;
		margin-left: 20px;
		margin-right: 20px;
	}
	.catchTxt ._login:hover{
		background-color: rgba(255,255,255,0.36);
		cursor: pointer;
	}
	.catchTxt a:hover{
		text-decoration: none;
	}





	/* detail --------------------------------- */
	.detailImg{
		display: flex;
		justify-content: center;
		align-items: center;
		background-color: #10100D;
	}
	.detailImg .vMain{
		margin-bottom: 20px;
		margin-top: 20px;
		margin-right: 20px;
		margin-left: 20px;
	}
	.detailImg .vMain ._sample{
		padding: 10px 24px;
		background-color: #FF071B;
		position: absolute;
		top: 15px;
		left: 15px;
		color: #FFFFFF;
		font-weight: 800;
		font-size: 1.8rem;
	}
	.detailTitle{
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		color: #ffffff;
		background-color: #2c2c2d;
		padding-top: 20px;
		padding-right: 20px;
		padding-bottom: 20px;
		padding-left: 20px;
	}
	.detailTitle .vInfo{
		margin-left: 10px;
		margin-right: 20px;
	}
	.detailTitle .vInfo h1{
		font-size: 2.0rem;
		margin-bottom: 10px;
	}
	.detailTitle .vBtn{
	margin-left: auto;
	margin-right: auto;
	margin-top: 10px;
	}
	.detailTitle .vBtn .btn{
		padding-top: 10px;
		padding-right: 10px;
		padding-bottom: 10px;
		padding-left: 10px;
		text-align: center;
		margin-bottom: 10px;
		background-color: #000000;
		font-weight: 600;
		font-size: 1.1rem;
		line-height: 1.5rem;
		border-radius: 5px;
	}

	.detailTitle .vBtn ._order{background-color: #f15a24;}
	.detailTitle .vBtn ._preview{background-color: #0033E8;}
	.detailTitle .vBtn ._preview-off{background-color: #0033E8;}
	.detailTitle .vBtn ._mylist{background-color: #0071bc;}

	.detailTitle .vBtn ._off{
		padding-top: 10px;
		padding-right: 10px;
		padding-bottom: 10px;
		padding-left: 10px;
		text-align: center;
		margin-bottom: 10px;
		background-color: #838383;
		font-weight: 800;
		font-size: 1.4rem;
		line-height: 1.4rem;
		border-radius: 5px;
		opacity: 0.5;
	}


	._h2 {
		font-weight: 800;
		font-size: 1.2rem;
		line-height: 1.4rem;
		padding: 10px 10px;
	}
	._h2 .material-icons {
		font-size: 1.4rem;
		line-height: 1.4rem;
		margin-right: 5px;
	}
	._h3 {
		font-weight: 400;
		font-size: 0.9rem;
		line-height: 1.2rem;
		padding: 5px 10px;
	}
	._h3 .material-icons {
		font-weight: 400;
		font-size: 1.2rem;
		line-height: 1.1rem;
		margin-right: 5px;
		vertical-align: bottom;
	}

	._col-guide {
		background-color: #fff;
		margin: 10px 10px;
	}
	._col-guide ul li {
		display: inline-block;
		font-weight: 400;
		font-size: 0.7rem;
		line-height: 1.2rem;
		margin-left: 20px;

	}
	._col-guide ul li span {
		display: inline-block;
		width: 28px;
		height: 16px;
		margin-right: 3px;
		vertical-align: middle;
	}


	.itemTitle {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		align-items: flex-start;
		color: #ffffff;
		margin-top: 10px;
		margin-bottom: 5px;
	}
	.itemTitle ._h2 {
		font-size: 1.1rem;
		padding: 5px;
	}
	.itemTitle ._h2 ._sub {
		display: inline-block;
		font-size: 0.9rem;
		margin: 0px 6px;
	}
	.itemTitle ._h4 {
		font-size: 0.8rem;
	}
	.itemTitle ._h2 p {
		display: inline;
		font-size: 0.76rem;
		line-height: 0.8rem;
	}
	.itemTitle ._h2 p .material-icons {
		font-size: 0.96rem;
		line-height: 0.96rem;
		margin-right: 3px;
	}
	.itemTitle ._orderBtn {
		font-size: 0.9rem;
		line-height: 1.1rem;
		padding: 6px 10px;
		margin: 0px 4px;
	}
	.itemTitle ._deleteBtn {
		font-size: 0.9rem;
		line-height: 1.1rem;
		padding: 6px 10px;
		margin: 0px 4px;
	}


	._series {
		background-color: #35517B;
		padding-top: 5px;
	}
	._series ._h2 {
	margin-top: 5px;
	margin-left: 10px;
	color: #FFFFFF;
	font-size: 1.2rem;
	line-height: 1.4rem;
	margin-bottom: 0px;
	}

	._capter .vlset{
		width: calc( (100% / 2) - 4px );
	}


	._files .vlset{
		width: calc( (100% / 2) - 4px );
	}
	._files .vl img{
		width: calc( (100% / 1) - 0px );
	}

	._files-play {
		position: relative;
		width: 100%;
		height: auto;
		overflow: hidden;
	}
	._files-play:after {
		background-size: 52px 52px;
	}


	.vl_series{
	color: #ffffff;
	height: 100%;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 0px;
	padding-left: 10px;
	margin-bottom: 0px;
	overflow: hidden;
	}
	.vl_series:hover{
		background-color: #6F6F6F;
		cursor: pointer;
	}
	.vl_series img{
		width: calc( (100% / 2.4) - 20px );
		margin-right: 20px;
		float: left;
	}
	.vl_series h2{
		padding-top: 0px;
		padding-bottom: 0px;
		font-size: 1.1rem;
	}



	/* detail --------------------------------- */
	.loginBtn{
		width: 80%;
		padding-top: 20px;
		padding-right: 20px;
		padding-bottom: 20px;
		padding-left: 20px;
		text-align: center;
		margin-bottom: 20px;
		background-color: #2882DF;
		color: #ffffff;
		font-weight: 800;
		font-size: 1.6rem;
		line-height: 1.6rem;
		border-radius: 50px;
		cursor: pointer;
		margin-left: auto;
		margin-right: auto;
		margin-top: 20px;
	}



/*--------------------------------------------
定額見放題
--------------------------------------------*/

.unlimlist {
  display: block;
  position: relative;
	margin: 20px auto 50px;
	width: calc(100% - 40px);
	max-width: 1200px;
  background-color: #000;
}
.unlimlist dl {
	display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
	width: 100%;
  margin: 0 0 30px;
}
.unlimlist dl dt {
  flex-basis: 50%;
	color: #009245;
	font-size: 1.2rem;
	line-height: 1.8rem;
  padding: 15px;
}
.unlimlist dl dd {
  flex-basis: 50%;
	margin-bottom: 0px;
	padding: 15px;
  color: #fff;
  font-weight: 600;
	font-size: 1.2rem;
	line-height: 2.0rem;
}
.unlimlist ._faq {
  display: grid;
  justify-items: center;
  align-items: center;
  position: relative;
  width: 100%;
	margin: 100px 0px;
	padding: 100px 0px;
  background-color: #7340BD;
}
.unlimlist ._faq .catchTxt {
  width: 100%;
  max-width: 640px;
}


	/*--------------------------------------------
	ソートリスト
	--------------------------------------------*/

	.list-box {
		width: 48%;
		margin: 1%;
	}
	.list-box ._cap {
		font-size: 0.9rem;
		line-height: 1.0rem;
	}
	.list-box .material-icons {
		font-size: 1.6rem;
		line-height: 1.4rem;
		margin-right: 3px;
		vertical-align: middle;
	}
	.row {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		margin: 15px 10px;
	}
	.col {
		-ms-flex-preferred-size: 0;
		flex-basis: 0;
		-ms-flex-positive: 1;
		flex-grow: 1;
		max-width: 100%;
		padding-right: 0;
		margin: 10px 0px;
	}
	.col2 {
		-ms-flex-preferred-size: 0;
		flex-basis: 0;
		-ms-flex-positive: 1;
		flex-grow: 1;
		order: 3;
		width: 100%;
		padding-right: 0;
		margin: 15px;
	}
	.list-col2 {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-direction: column;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		height: 240px;
		padding-left: 0;
		margin-bottom: 0;
	}
	.list-col2 .material-icons {
		font-size: 6.0rem;
		line-height: 6.4rem;
		margin-right: 3px;
		vertical-align: middle;
		color: #2882DF;
		cursor: pointer;
	}
	.list-col2 .material-icons:hover {
		opacity: 0.7;
	}
	.list-col2 p {
		display: inline-block;
		font-size: 0.9rem;
		margin: 0px 0px 10px;
	}

	.list-enable {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-direction: column;
		flex-direction: column;
		padding-left: 0;
		margin-right: 0;
		margin-bottom: 0;
		height: 300px;
		overflow-y: scroll;
		background-color: #EDEDED;
		border: 1px solid #6D6D6D;
	}
	.list-play {
		display: -ms-flexbox;
		display: flex;
		-ms-flex-direction: column;
		flex-direction: column;
		padding-left: 0;
		margin-bottom: 0;
		height: 300px;
		overflow-y: scroll;
		background-color: #FEFACF;
		border: 1px solid #6D6D6D;
	}
	.list-group-item {
		position: relative;
		display: block;
		padding: 4px 6px;
		margin: 10px;
		margin-bottom: -1px;
		font-size: 0.7rem;
		background-color: #fff;
		border: 1px solid rgba(0,0,0,.25);
		border-radius: 6px;
		cursor: move;
		-webkit-box-shadow: 0px 1px 1px;
		box-shadow: 0px 1px 1px;
	}
	.list-group-item:hover {
		background-color: #DCFCFF;
		border: 1px solid rgba(0,0,0,.125);
	}
	._play_reset{
		display: inline-block;
		padding: 6px 8px;
		text-align: center;
		margin-top: 30px;
		background-color: #2882DF;
		color: #ffffff;
		font-weight: 400;
		font-size: 1.0rem;
		line-height: 1.0rem;
		border-radius: 6px;
		cursor: pointer;
	}


	._head {
		font-size: 0.9rem;
		line-height: 1.2rem;
	}
	._list {
		position: relative;
		padding: 5px 0px;
		font-size: 0.8rem;
		line-height: 1.0rem;
		background-color: #fff;
	}
	.tbl_history td {
		padding: 10px 5px;
	}
	.tbl_history td:first-child {
		font-size: 0.7rem;
		width: 100px;
	}

	.tbl_history_buy {
		padding: 5px 0px;
		width: 100%;
	}
	.tbl_history_buy._head td:first-child {
		border-left: 1px solid rgba(0,0,0,.125);
	}
	.tbl_history_buy._list tr:nth-child(2n+1) {background-color:#EAEEF2;}
	.tbl_history_buy td {
		padding: 5px;
		border-left: 1px solid rgba(0,0,0,.125);
	}
	.tbl_history_buy td:first-child {
		width: 75px;
	}
	.tbl_history_buy td:nth-child(2) {
		width: 100px;
	}



}


@media screen and (min-width: 768px) {

/* .wrapper{
  	max-width: 1140px;
  }*/
  .main {
    max-width: 1140px;
  }


	.mob-navbox {
		margin-right: 40px;
	}
	.mob-wrap {
		margin-top: 72px;
	}
	.mob-width {
		width: 708px;
	}
	.mob-menu {
		width: 708px;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 20px 0px 20px;
	}
	.mob-borderbtn {
		width: 334px;
		height: 42px;
		margin: 5px 0;
	}
	.mob-borderbtn a {
		display:block;
		width: 100%;
		height: 100%;
		font-weight: 800;
		font-size: 16px;
		line-height: 36px;
	}
	.mob-borderbtn a:hover {
		text-decoration: none;
	}
	.mob-border {
		position: relative;
		display: block;
		width: 32px;
		height: 1px;
		background-color: #fff;
		overflow: hidden;
		transition: 0.5s;
		top: 0;
		left: 0;
	}
	.mob-borderbtn:hover .mob-border {
		width: 100%;
	}


  .vlset{
  	width: calc( (100% / 3) - 4px );
  }
	._capter .vlset{
		width: calc( (100% / 4) - 4px );
	}
	._files .vlset{
		width: calc( (100% / 4) - 4px );
	}

}


@media screen and (min-width: 1200px) {

/*	.wrapper{
		max-width: 1320px;
  }*/
  .main {
    max-width: 1320px;
  }

  .vlset{
  width: calc( (100% / 4) - 4px );
  }
	._capter .vlset{
		width: calc( (100% / 5) - 4px );
	}
	._files .vlset{
		width: calc( (100% / 5) - 4px );
	}
}



@media screen and (min-width: 1400px) {

/*	.wrapper{
		max-width: 1320px;
  }*/
  .main {
    max-width: 1320px;
  }

  .vlset{
  width: calc( (100% / 4) - 4px );
  }
	._capter .vlset{
		width: calc( (100% / 5) - 4px );
	}
	._files .vlset{
		width: calc( (100% / 5) - 4px );
	}

}
