@charset "utf-8";

/**
 *
 *  主な機能 index
 *
 */

/*--------------------------------------------------------------------------
   overwrite  - 共通CSSの上書き -
---------------------------------------------------------------------------*/
.l-section{
	overflow: hidden;
	padding: 70px 0 0 0;
	min-width: 980px;
}
.l-section__head{
	padding-bottom: 50px;
}


@media screen and (max-width: 768px){
	.l-section{
		padding-top: 25px;
		min-width: 0;
	}
	.l-section__head{
		padding-bottom: 15px;
	}
	
}

.g-header__logo.logo-small01{
	width: 215px;
	height: 33px;
}

.g-header__logo.logo-small01 img {
	height: 33px;
}

.g-header__logo.logo-small02{
	width: 278px;
	height: 33px;
	left: 276px;
}

.g-header__logo.logo-small02 img {
	height: 33px;
}

@media screen and (max-width: 1250px){
	.g-header__logo.logo-small01{
		width: 145px;
		height: 22px;
	}
	
	.g-header__logo.logo-small01 img {
		height: 22px;
	}
	
	.g-header__logo.logo-small02{
		width: 188px;
		height: 22px;
		left: 185px;
	}
	
	.g-header__logo.logo-small02 img {
		height: 22px;
	}
}

/* media query -> sp
=================================================================*/
@media screen and (max-width: 768px){
	.g-header__logo.logo-small01{
		width: 106px;
		height: 16px;
	}
	
	.g-header__logo.logo-small01 img {
		height: 16px;
	}
	
	.g-header__logo.logo-small02{
		width: 138px;
		height: 16px;
		left: 130px;
	}
	
	.g-header__logo.logo-small02 img {
		height: 16px;
	}
}


/*--------------------------------------------------------------------------
   - ページ内共通 -
---------------------------------------------------------------------------*/

.txt-strong {
    margin-top: 15px;
    text-align: center;
    color: #0e0d6a;
    font-size: 15px;
    font-weight: 500;
}

.sp-only{display: none;}

.title-dot{
	display: block;
	width: 35px;
	border-top: 3px dotted #0e0d6a;
	margin: 0 auto 20px;
	height: 3px;
}

#function .title-dot{
	border-color: #fff !important;
}


@media screen and (max-width: 768px){
.txt-strong {
    margin-top: 10px;
    font-size: 13px;
}

.title-dot{
	margin: 7px auto 20px;
}
	
.pc-only{display: none;}	
.sp-only{display: inline;}	
	
}



/*--------------------------------------------------------------------------
   MV
---------------------------------------------------------------------------*/

#mv-easy-videophone{
	height: 280px !important;
}

#mv-easy-videophone .m-main-visual__background{
	background-image: url("../images/index/img_mv.jpg") !important;
	background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

#mv-easy-videophone .m-main-visual__body {
    display: flex;
    position: relative;
    top: inherit;
    left: inherit;
    height: 100%;
	text-align: center;
	align-items: center;
	justify-content: center;
	color: #fff !important;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__ttl{
	margin: 0 0 15px;
	font-size: 62px;
	line-height: 1.3;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__ttl span{
	display: block;
	font-size: 29px;
	padding-bottom: 10px;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__txt__stb-2{
	margin-top: 15px;
	font-size: 16px;
	font-weight: normal;
	line-height: 1.4;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__txt__stb-3{
	display: inline-block;
	margin-top: 15px;
	font-size: 20px;
	line-height: 1;
	border: 2px solid #fff;
	padding: 5px 10px;
	font-weight: bold;
}


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

#mv-easy-videophone{
	height: 50vw !important;
}

#mv-easy-videophone .m-main-visual__background{
	background-image: url("../images/index/img_mv_sp.jpg") !important;
	background-repeat: no-repeat;
    background-position: center center;
    background-size: cover !important;
}
	
#mv-easy-videophone .m-main-visual__body__inner{
	margin-top: -10vw;
    padding: 0 !important;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__ttl{
	margin: 0 0 15px;
	font-size: 7vw;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__ttl span{
	font-size: 4.2vw;
	padding-bottom: 5px;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__txt__stb-2{
	display: block !important;
	margin-top: 7px;
	font-size: 2.4vw;
}

#mv-easy-videophone .m-main-visual__body .m-main-visual__txt__stb-3{
	margin-top: 7px;
	font-size: 2.8vw;
}
	
}

/*--------------------------------------------------------------------------
   news-block
---------------------------------------------------------------------------*/
.news-block{
	display: inline-block;
	width: 980px;
	padding: 40px 0;
	border: 2px solid #dee9ef;
    background: #fff;
}

.news-block + .news-block{
	margin-top: 20px;
	padding: 20px 0;
}

.news-block.emphasis{
	border: 2px solid #00A99D;
}

.news-block + .c-sec-ttl{
	margin-top: 30px;
	padding-bottom: 0;
}

.news-block h3 strong{
	font-size: 20px;
	color: #00A99D;
}

.news-block h3 + p{
	margin-top: 15px;
}

.news-block p + img{
	max-width: 100px;
	margin-top: 10px;
}

.news-block img + p{
	max-width: 750px; 
	margin: -30px auto 0;
	text-align: right; 
}

.news-block p span{
	font-size: 12px;
	line-height: 1.45;
}

.news-block p strong {
	font-weight: 400;
	font-size: 15px;
}

.news-block a{
	display: inline-block;
	margin-top: 5px;
}

.modePC .news-block a:hover{
	text-decoration: underline;
}

@media screen and (max-width: 768px){
	.news-block{
		width: 90%;
        margin: 0 auto 10px;
		padding: 15px 0;
	}

	.news-block + .news-block{
		margin-top: 0;
		padding: 15px 0;
	}
	
	.news-block + .c-sec-ttl{
		margin-top: 10px;
	}

	.news-block h3 strong{
		font-size: 16px;
	}

	.news-block h3+p{
		margin-top: 10px;
	}

	.news-block img + p{
		margin: 10px auto 0;
	}

	.news-block p span{
		font-size: 10px;
	}

	.news-block p strong {
		display: block;
		margin: 0 28px;
		font-size: 12px;
		text-align: left;
	}
	
	.news-block a{
		margin-top: 0;
	}
}

/*--------------------------------------------------------------------------
   Scene
---------------------------------------------------------------------------*/

#Scene{
	padding-top: 40px;
	padding-bottom: 35px;
}

.box-scene{
	width: 476px;
	border: 2px solid #dee9ef;
	background: #fff;
	position: relative;
	text-align: center;
	margin-bottom: 50px;
	min-height: 275px;
}

.box-scene p small{
	font-size: 10px;
}

.scene-01,
.scene-02{
	min-height: 330px;
}

.box-scene-fullw{
	clear: both;
	width: 976px;
	border: 2px solid #dee9ef;
	background: #fff;
	position: relative;
	text-align: center;
	margin-bottom: 50px;
	padding-bottom: 25px;
}

.scene-01, .scene-04{
	float: left;
}

.scene-02, .scene-05{
	float: right;
}

.scene-num{
	display: inline-block;
	width: 94px;
	background: #01534c;
	font-size: 22px;
	height: 38px;
	line-height: 38px;
	position: absolute;
	top: -19px;
	left: 50%;
	margin-left: -47px;
	color: #fff;
}

.img-scene{
	margin: 35px 0 15px;
}

#Scene .l-base{
	padding: 0 20px;
}

#Scene .l-base p{
	margin: 0;
	line-height: 2;
	font-size: 16px;
	font-weight: 700;
}

#Scene .l-base h4{
	margin: 50px 0 0;
	font-size: 24px;
}

#Scene .l-base th,
#Scene .l-base td{
	font-size: 18px;
}

#Scene .l-base td {
	font-weight: 700;
}

.table-wrap {
	margin: 30px 0 0;
	border: 1px solid #1b266f;
	border-radius: 5px;
	overflow: hidden;
}
table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 auto;
	background-color: #fff;
	border-radius: 5px;
}
table th,
table td {
	padding: 20px 10px;
	vertical-align: middle;
	border: 1px solid #d8e4ef;
	font-size: 13px;
	line-height: 1.9;
}
table th {
	font-weight: 200;
	text-align: left;
	background-color: #fafafa;
}
table td.img {
	text-align: center;
	width: 35%;
	max-width: 341px;
}
table td.img img {
	width: auto;
	height: auto;
	max-width: 100%;
}
table thead th {
	text-align: center;
	background-color: #bfeaf8;
}

@media screen and (max-width: 768px){
	
#Scene{
	padding-top: 25px;
	padding-bottom: 0;
}

.box-scene{
	width: 90%;
    margin-bottom: 30px;
    min-height: auto;
    margin: 30px auto 40px;
	padding-bottom: 20px;
}
	
.img-scene img{
	width: 84%;
} 

.box-scene p small{
	font-size: 10px;
}

#Scene .l-base p{
	font-size: 14px;
	font-weight: 400;
}

#Scene .l-base h4{
	margin: 30px 0 0;
	font-size: 20px;
}

#Scene .l-base th,
#Scene .l-base td{
	font-size: 16px;
	font-weight: 400;
}

.scene-01,
.scene-02{
	min-height: auto;
}

.box-scene-fullw{
	width: 90%;
	margin: 0 auto 10px;
	padding-bottom: 20px;
}

.scene-01, .scene-04{
	float: none;
}

.scene-02, .scene-05{
	float: none;
}

.scene-num{
	width: 80px;
	font-size: 14px;
	height: 32px;
	line-height: 32px;
	top: -16px;
	margin-left: -40px;
}

.img-scene{
	margin: 35px 0 15px;
}	

}

/*--------------------------------------------------------------------------
   function
---------------------------------------------------------------------------*/

#function{
	background: url(/catv-service/stb-2/shared/images/common/bg_section01.jpg);
	padding-bottom: 50px;
}

.img-easy{
    text-align: center;
}

.u-font-c-y{color: #e8f7aa;}
#function .txt-strong{color: #fff;}

.contents-function{
	margin: 50px 0 ;
}

.contents-function h3{
	display: block;
	text-align: center;
	font-size: 26px;
	font-weight: bold;
	color: #fff;
	margin-bottom: 30px;
}

.contents-function h4{
	display: block;
	background: #e8f7aa;
	padding: 10px 0;
	text-align: center;
	font-size: 20px;
	color: #0e0d6a;
	font-weight: bold;
	margin-bottom: 15px;
}

.ul-function{
	display: flex;
}

#function01 li{
	width: 314px;
	margin-right: 19px;
	background: #fff;
	text-align: center;
}

#function01 li:last-child{
	margin-right: 0;
}

#function02{
	margin-top: 35px;
}

#function02 li{
	width: 314px;
	text-align: center;
	background: #fff;
}

#function02 li:first-child{
	width: 647px;
	margin-right: 19px;
	background: none;
}

#function02 li:first-child > div{
	display: flex;
}

#function02 li:first-child > div > article{
	background: #fff;
	width: 314px;
	margin-right: 19px;
}

#function02 li:last-child{
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f1fbff !important;
}

#function02 li:last-child h5{
	font-size: 25px;
}

.con-func05{margin-right: 0 !important;}

.img-ul-func{
	background: #f1fbff;
	display: flex;
	align-items: center;
	text-align: center;
	justify-content: center;
	height: 164px;
}

.img-ul-func img{
	height: 100px;
	vertical-align: middle;
}

.txt-ul-func{
	padding: 15px 0;
}

.txt-ul-func h5{
	display: block;
	font-size: 20px;
	color: #0e0d6a;
	font-weight: bold;
	margin-bottom: 8px;
}

.att-function{
	color: #fff;
	text-align: right;
	margin: 10px 0 0;
}


@media screen and (max-width: 768px){
	
#function{
	padding-bottom: 10px;
}
	
.img-easy{
    padding-left: 15px;
    padding-right: 15px;
	padding-top: 10px;
    /* text-align: center; */
}
	
.img-easy img{
    width: 94%;
    margin-top: 10px;
}

.contents-function{
	margin: 30px auto ;
	width: 90%;
}

.contents-function h3{
	font-size: 20px;
	margin-bottom: 20px;
}

.contents-function h4{
	padding: 7px 0;
	font-size: 16px;
	margin-bottom: 12px;
}

.ul-function{
	display: block;
}

#function01 li{
	width: 100%;
	margin-right: 0;
	margin-bottom: 10px;
}

#function02{
	margin-top: 30px;
}

#function02 li{
	width: 100%;
}

#function02 li:first-child{
	width: 100%;
	margin-right: 0;
	margin-bottom: 10px;
}

#function02 li:first-child > div{
	display: block;
}

#function02 li:first-child > div > article{
	width: 100%;
	margin-right: 0;
	margin-bottom: 10px;
}

#function02 li:last-child{
	padding: 20px 0;
}

.con-func05{margin-right: 0 !important;}

.img-ul-func{
	padding: 12px 0;
}

.img-ul-func img{
	height: 80px;
}

.txt-ul-func{
	padding: 12px 0;
}

.txt-ul-func h5{
	font-size: 18px;
}
}

/*--------------------------------------------------------------------------
   Config
---------------------------------------------------------------------------*/

#Config{
	padding-bottom: 70px;
}

.contents-Config{
	display: flex;
}

.box-Config{
	width: 50%;
	position: relative;
	border: 2px solid #e5eef3;
	text-align: center;
	box-sizing: border-box;
	padding: 50px 0 25px;
}

.box-Config:first-child{
	border-right: none;
}

.num-config{
	display: flex;
	position: absolute;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	text-align: center;
	align-items: center;
	justify-content: center;
	color: #fff;
	background: #01534c;
	font-size: 28px;
	top: -30px;
	left: 50%;
	margin-left: -30px;
}

.img-config{
	height: 144px;
	vertical-align: middle;
}

.box-Config h3{
	display: block;
	font-size: 20px;
	margin: 20px 0;
}

.box-Config h3 span{
	color: #00a99d;
}

@media screen and (max-width: 768px){
	
#Config{
	padding-bottom: 20px;
}

.contents-Config{
	display: block;
	width: 90%;
	margin: 0 auto;
}

.box-Config{
	width: 100%;
	padding: 50px 0 25px;
	margin-bottom: 15px;
	margin-top: 35px;
}

.box-Config:first-child{
	border-right: 2px solid #e5eef3;
}

.num-config{
	width: 50px;
	height: 50px;
	font-size: 20px;
	top: -25px;
	margin-left: -25px;
}

.img-config{
	height: 80px;
}

.box-Config h3{
	font-size: 18px;
	margin: 20px 0;
}	

}

/*--------------------------------------------------------------------------
   App
---------------------------------------------------------------------------*/

#kantantv-Apply{
    padding-bottom: 85px;
    border-top: 4px solid #0e0d6a;
    border-bottom: 4px solid #0e0d6a;
}

#App{
	padding-bottom: 70px;
}

.contents-App h3{
	display: block;
	background: #00a99d;
	color: #fff;
	font-size: 20px;
	padding: 15px 0;
	text-align: center;
}

.contents-App > div{
	text-align: center;
	border: 2px solid #e5eef3;
	border-top: none;
	padding: 30px 0;
	background: #fff;
}

.contents-App article{
	width: 50%;
	border-radius: 4px;
	margin: 0 auto 25px;
	background: #effbfb;
	padding-bottom: 30px;
}

.contents-App article h4{
	display: block;
	background: #00a99d;
	color: #fff;
	font-size: 18px;
	padding: 10px 0;
	border-top-left-radius: 3px;
	border-top-right-radius: 3px;
}

.img-App{
	margin: 30px 0 0;
}

.img-App img{
	vertical-align: middle;
	margin: 0 10px;
}

.contents-App > div > a{
	width: 370px !important;
	margin: 25px auto 0;
}

#kantantv-Apply .l-base > article{
    width: 480px;
    margin: 0 auto;
}

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

#kantantv-Apply{
    padding-bottom: 35px;
    padding-left:15px;
    padding-right: 15px;
}
	
#App{
	padding-bottom: 35px;
}
	
.contents-App{
    width: 90%;
    margin: 15px auto 0;
}

#App .txt-strong{
    margin-bottom: 15px !important;
}

.contents-App h3{
	font-size: 15px;
	padding: 10px 0;
}

.contents-App > div{
	padding: 20px 0;
}

.contents-App article{
	width: 80%;
	padding-bottom: 20px;
}

.contents-App article h4{
	font-size: 15px;
	padding: 8px 0;
}

.img-App{
	margin: 20px 0 0;
	text-align: center;
}

.img-App img{
	vertical-align: middle;
	margin: 10px auto;
	display: block;
	max-width: 100%;
}

.contents-App > div > a{
	width: 80% !important;
	margin: 25px auto 0;
}	

#kantantv-Apply .l-base > article{
    width: 100%;
}
    
    #kantantv-Apply .apply__item{
        min-height: 154px;
    }

}

/*--------------------------------------------------------------------------
   Information
---------------------------------------------------------------------------*/
#Information {
	padding: 50px 20px;
}

#Information p + h4 {
	margin: 30px 0 0;
}

#Information p{
	line-height: 2;
}

#Information h4 + p {
	margin: 10px 0 0;
}

@media screen and (max-width: 768px){
	#Information p + h4 {
		margin: 10px 0 0;
	}
	
	#Information h4 + p {
		margin: 5px 0 0;
	}
}


/*--------------------------------------------------------------------------
   apply
---------------------------------------------------------------------------*/
.apply{
	padding: 75px 0 110px;
}

/* apply__area
-----------------------------------------------------------------*/
.apply__area + .apply__area{
	margin-top: 60px;
}
.apply__ttl{
	margin-bottom: 40px;
}
.apply__list{
	display: flex;
    justify-content: center;
	overflow: hidden;
	margin: -10px;
}
.apply__item{
	float: left;
	width: 230px;
	margin: 10px;
}
.apply__item:nth-child(4n+1) {
	clear: left;
}
.apply__item a{
	display: block;
}
.apply__item .logo{
	display: table;
	box-sizing: border-box;
	position: relative;
	width: 100%;
	height: 145px;
	border: 2px solid #edeeef;
	background: #fff;
	-webkit-transition: border .3s cubic-bezier(0.165, 0.84, 0.44, 1);
					transition: border .3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.modePC .apply__item a:hover .logo{
	border-color: #00aae2;
}
.apply__item .logo:before{
	content: '';
	position: absolute;
	bottom: 0;
	right: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 6px 6px;
	border-color: transparent transparent #151f63 transparent;
}
.apply__item .logo img{
	width: 100%;
	height: auto;
}
.apply__item .name{
	margin-top: 8px;
	color: #9189c2;
	text-decoration: underline;
}
.apply__item .name span{
	display: inline-block;
}
.modePC .apply__item a:hover .name span{
	text-decoration: underline;
}

/* media query -> sp
=================================================================*/
@media screen and (max-width: 768px){
	.apply{
		padding: 35px 15px 45px;
	}

	/* apply__area
	-----------------------------------------------------------------*/
	.apply__area + .apply__area{
		margin-top: 35px;
	}
	.apply__ttl{
		margin-bottom: 20px;
	}
	.apply__list{
		margin: -2% -1%;
	}
	.apply__item{
		width: 48%;
		margin: 2% 1%;
	}
	.apply__item .logo{
		height: 100px;
		border-width: 1px;
	}
	.apply__item .logo:before{
		border-width: 0 0 4px 4px;
	}
	.apply__item .logo span img{
		max-width: 90px;
	}
}






