@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   page

--------------------------------------------------------------------------------------------------*/

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
.swiper {
	margin: 0 0 40px;
	padding: 16px 0 40px;
}

.swiper-slide {
  width: 980px;
}

.swiper-slide img {
	width: 100%;
	height: 100%;
	opacity: 0.6;
}

.swiper-slide-active img {
	opacity: 1;
}

.swiper-pagination-bullet {
	width: 16px;
	height: 16px;
	background-color: #CCCCCC;
	opacity: 1;
}

.swiper-pagination-bullet-active {
	background-color: #009E96;
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 5px;
}

.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
	bottom: 0;
	top: unset;
}

#indexNews {
	position: relative;
	margin: 0 0 80px;
}

#indexNews:before {
	position: absolute;
	content: "";
	background-color: #E5F5F4;
	width: 100%;
	height: 100%;
	z-index: -1;
	top: 0;
	right: calc( 50% + 280px );
	border-radius: 0 8px 8px 0;
}

#indexNews .inner {
	display: flex;
	width: 1200px;
	margin: 0 auto;
}

#indexNews .inner .title {
	position: relative;
	width: 400px;
	padding: 50px 0 0;
}

#indexNews .title:before {
	position: absolute;
	background: url(../image/character.png) no-repeat 0 0;
	width: 98px;
	height: 94px;
	top: -22px;
	right: 40px;
	content: "";
}

#indexNews .title h2 {
	margin: 0 0 50px;
	font-size: 40px;
	font-weight: 500;
	color: #009E96;
	line-height: 1.4;
	letter-spacing: 0.02em;
}

#indexNews .title h2 span {
	display: block;
	font-size: 20px;
	font-style: italic;
	color: #111;
}

#indexNews .cont {
	width: 800px;
}

#indexNews .cont ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

#indexNews .cont ul li {
	margin: 0;
	padding: 0;
	line-height: 2.2;
}

#indexNews .cont ul li a {
	display: block;
	padding: 10px 12px;
	text-decoration: none;
	color: #111;
	border-bottom: 1px dotted #CCC;
}

#indexNews .cont ul li a:hover {
	background-color: #E5F5F4;
}

#indexNews .cont ul li a .cat {
	display: inline-block;
	border: 1px solid #CCCCCC;
	width: 100px;
	margin-left: 20px;
	text-align: center;
	background-color: #FFF;
}

#indexNews .cont ul li .info {
	line-height: 1.5;
}

#indexServices {
	position: relative;
	padding: 0 0 80px;
}

#indexServices:before {
	position: absolute;
	content: "";
	bottom: 0;
	left: 0;
	width: 100%;
	height: 75%;
	background-color: #FBFBEC;
	z-index: -1;
}

#indexServices h2 {
	margin: 0 0 50px;
	text-align: center;
	font-size: 40px;
	font-weight: 500;
	color: #009E96;
	line-height: 1.4;
	letter-spacing: 0.02em;
}

#indexServices h2 span {
	display: block;
	font-size: 20px;
	font-style: italic;
	color: #111;
}

#indexServices .main {
	display: flex;
	justify-content: center;
	margin: 0 0 40px;
}

#indexServices .main div {
	width: 300px;
	background-color: #FFF;
	border: 1px solid #BBBBBB;
	padding: 20px 10px 30px;
	position: relative;
}

#indexServices .main div:before {
	position: absolute;
	content: "";
	top: 0;
	left: calc( 50% - 50px );
	width: 100px;
	height: 4px;
	background-color: #009E96;
}

#indexServices .main div:nth-child(2) {
	width: 300px;
	margin: 0 103px;
}

#indexServices .main div h3 {
	margin: 0 0 16px;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
}

#indexServices .main div h3 img {
	display: block;
	margin: 0 auto 10px;
}

#indexServices .main div ul {
	margin: 0 0 0 10px;
	padding: 0;
	list-style: none;
}

#indexServices .main div ul li {
	margin: 0 0 4px;
	padding: 0;
	background: url(../image/arrow-03.png) no-repeat 0 6px;
}

#indexServices .main div ul li a {
	text-decoration: none;
	color: #111;
	padding: 0 24px;
}

#indexServices .main div ul li a.blank {
	background: url(../image/blank.png) no-repeat 100% 60%;
}

#indexServices .main div ul li a:hover {
	text-decoration: underline;
	color: #006699;
}

#indexServices .pickup ul {
	width: 1200px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: center;
}

#indexServices .pickup ul li {
	margin: 0 20px;
	padding: 0;
}

#indexServices .pickup ul li img {
	max-width: 100%;
	height: auto;
}

#indexSns {
	width: 1010px;
	margin: 0 auto;
	padding: 80px 0 100px;
}

#indexSns h2 {
	margin: 0 0 50px;
	text-align: center;
	font-size: 40px;
	font-weight: 500;
	color: #009E96;
	line-height: 1.4;
	letter-spacing: 0.02em;
}

#indexSns h2 span {
	display: block;
	font-size: 20px;
	font-style: italic;
	color: #111;
}

#indexSns ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: center;
}

#indexSns ul li {
	margin: 0 16px;
	padding: 0;
}

#indexHyouka {
	width: 1000px;
	margin: 0 auto 80px;
	border: 1px solid #009E96;
	padding: 30px 30px 20px;
	background-color: #F4FBFB;
}

#indexHyouka dt {
 display: inline-block;
 margin-bottom: 10px;
 font-weight: 500;
 border-bottom: 2px dotted #009E96;
}

#indexHyouka dd p {
 margin: 0 0 10px;
}

#indexServices .indexHfc {
	width: 640px;
	margin: 0 auto 80px;
	background-color: #FFF;
	border: 1px solid #BBBBBB;
	padding: 20px 30px 30px;
	position: relative;
}

#indexServices .indexHfc h3 {
	margin: 0 0 16px;
	font-size: 24px;
	font-weight: 500;
}

#indexServices .indexHfc h3 span {
	background-color: #4c9984;
	color: #FFF;
	padding: 2px 2px;
	display: inline-block;
	font-size: 13px;
	line-height: 1.4;
	margin: 0 0 0 10px;
	vertical-align: 4px;
}

#indexServices .indexHfc ul {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}

#indexServices .indexHfc ul li {
	width: 50%;
	margin: 0;
	padding: 0;
	background: url(../image/arrow-03.png) no-repeat 0 6px;
}

#indexServices .indexHfc ul li a {
	padding: 0 24px;
}

#indexServices .indexHfc ul li a:hover {
	text-decoration: underline;
	color: #006699;
}



/*------------------------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------------------------*/
.companyTb {
	width: 100%;
	margin: 0 0 60px;
}

.companyTb th {
	width: 220px;
	padding: 16px;
	font-weight: 400;
	text-align: left;
	border-bottom: 1px dotted #CCC;
	position: relative;
}

.companyTb th:before {
	position: absolute;
	content: "";
	width: 16px;
	height: 2px;
	top: calc( 50% - 1px );
	right: 16px;
	background-color: #009e96;
}

.companyTb td {
	padding: 16px;
	border-bottom: 1px dotted #CCC;
}

.gmap {
 width: 80%;
	margin: 0 auto 30px;
}
 
.gmap iframe {
 width: 100%;
}

.clauseList {
	margin: 0 20px 40px;
	padding: 0;
	list-style: none;
}

.clauseList li {
	margin: 0 0 16px;
	padding: 0;
}

.clauseList li a {
	display: block;
	padding: 8px;
	box-shadow: 3px 3px 2px #EEE;
	text-decoration: none;
	color: #111;
}

.clauseList li a:hover {
	background-color: #E8F3F4;
}

.psLead {
	font-size: 18px;
	font-weight: 500;
}

.psLead2 {
	font-size: 18px;
	font-weight: 500;
	line-height: 1.4;
}

.psDl dt {
	margin: 0 0 10px;
	font-weight: 500;
	border-bottom: 1px dashed #CCC;
}

.psDl dd {
	margin: 0 12px 30px;
	line-height: 1.4;
}

.psDl dd a {
	background: url(../image/arrow-03.png) no-repeat 0 6px;
	background-size: 14px;
	padding: 0 0 0 18px;
}

.psDl dd ol li {
	margin: 0 0 10px;
}

.psDl dd ol li ul {
	list-style: none;
	margin: 10px 0 16px;
}

.psDl dd ol li ul li {
	background: url(../image/arrow-03.png) no-repeat 0 5px;
	background-size: 14px;
	padding: 0 0 0 18px;
}

.psDl dd ol li ul li a {
	background-image: none;
	padding: 0;
}

ol.cnt {
	margin: 10px 0 30px;
	padding: 0 0 0 32px;
	list-style-type: none;
	text-indent: -1.8em;
}

ol.cnt li {
	margin-left: 1.8em;
	margin-bottom: 6px;
	counter-increment: cnt;
}

ol.cnt li:before {
 display: marker;
 content: "(" counter(cnt) ") ";
}

.chTb {
	margin-bottom:30px;
}

.chTb th {
	background-color: #E8F3F4;
	font-weight: 500;
	padding: 8px 16px;
	border-bottom: 1px solid #CCC;
	border-right: 1px solid #CCC;
}

.chTb td {
	padding: 8px 16px;
	border-bottom: 1px solid #CCC;
	border-right: 1px solid #CCC;
}

.chTb th:last-child,
.chTb td:last-child {
	border-right: none;
}

.chTb td:last-child ul {
	padding-left: 20px;
}

.chTb td:first-child {
	text-align:left;
	width: 260px;
}

.chTb tr:nth-child(2n-1) {
	background-color: #F3F2F1;
}

.chDl {
	margin: 0 0 50px;
	line-height: 1.6;
}

.chDl dt {
	font-weight: 500;
	background: url(../image/arrow-01.png) no-repeat 0 8px;
	background-size: 6px;
	padding-left: 12px;
}

.chDl dd {
 margin-bottom: 12px;
}

a.arw03 {
	background: url(../image/arrow-03.png) no-repeat 0 6px;
	background-size: 14px;
	padding: 0 0 0 18px;
}

.endService {
	text-align: center;
	background-color: #4c9984;
	color: #FFF;
	padding: 8px;
	display: block;
	width: 50%;
	margin: 0 auto 30px;
}


/*------------------------------------------------------------------------------------------------
  gongo_guide
--------------------------------------------------------------------------------------------------*/
.kanyuuTb {
	width: 100%;
	margin: 0 0 40px;
	line-height: 1.4;
}

.kanyuuTb th {
	padding: 16px;
	font-weight: 500;
	border: 1px solid #CCC;
	background-color: #E8F3F4;
}

.kanyuuTb th:nth-child(2),
.kanyuuTb th:nth-child(3) {
	width: 25%;
}

.kanyuuTb td {
	padding: 16px;
	border: 1px solid #CCC;
	text-align: center;
}

.kanyuuTb td:nth-child(1) {
	text-align: left;
}

.kanyuuTb tr:nth-child(2n-1) {
	background-color: #F3F2F1;
}

.kanyuuCommon {
	border: 1px solid #CCC;
	margin: 0 0 30px;
	padding: 20px;
}

.kanyuuCommon dt {
	font-weight: 500;
}

.kanyuuCommon dl {
	margin: 0 0 10px;
}

.kanyuuCommon p {
	margin: 0 !important;
	line-height: 1.6;
}


/*------------------------------------------------------------------------------------------------
  hikari
--------------------------------------------------------------------------------------------------*/
.serviceList {
	width: 800px;
	margin: 0 auto 50px;
	padding: 0;
	list-style: none;
}

.serviceList li {
	margin: 0 0 30px;
	padding: 0;
}

.serviceList li img {
	max-width: 100%;
	height: auto;
}

.areaList dt {
	position: relative;
	display: inline-block;
	margin: 0 0 8px;
	font-weight: 500;
	border: 1px solid #CCC;
	padding: 0 20px;
}

.areaList dt:before {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  left: 0;
  top: 0;
  border-style: solid;
  border-color: transparent transparent transparent #009E96;
  border-width: 0 0 10px 20px;
}

.areaList dd {
	margin: 0 0 30px;
	line-height: 1.6;
}


/*------------------------------------------------------------------------------------------------
  hikari-tv
--------------------------------------------------------------------------------------------------*/
.PlanBs {
	width: 800px;
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	margin: 0 auto 20px;
	padding: 30px;
}

#second .PlanBs h3 {
	background-color: #9CBF40;
	color: #FFF;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	border: none;
	line-height: 40px;
	border-radius: 4px;
}

.plans dl {
	display: flex;
	justify-content: center;
	text-align: center;
	align-items: end;
	line-height: 1;
	font-size: 18px;
	margin: 0 0 30px;
}

.plans dl dd {
	font-size: 30px;
	font-weight: 500;
	margin-left: 10px;
}

.plans dl dd span {
	font-size: 18px;
	font-weight: 400;
}

.plans .info {
	background-color: #F3F3F3;
	text-align: center;
	font-size: 18px;
	padding: 16px;
}

.plans .info p {
	margin: 0 0 10px !important;
	line-height: 1.4;
}

.plans .info span {
	font-size: 30px;
	font-weight: 500;
	padding: 0 2px;
}

.plans .info span.p1 {
	color: #9ABF3F;
}

.Plan2 {
	width: 800px;
	margin: 0 auto 60px;
	display: flex;
	justify-content: space-between;
}

.Plan2 .pack,
.Plan2 .bic {
	width: 380px;
}

.Plan2 .pack .lead {
 color: #F05A71;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
}

.Plan2 .bic .lead {
 color: #2480BF;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
}

.waribiki {
	position: relative;
	top: -16px;
	background-color: #FFE761;
	border-radius: 340px / 100px;
	display: block;
	margin: -60px auto 40px;
	width: 400px;
	text-align: center;
	padding: 30px;
	font-size: 18px;
}

.waribiki span {
	font-size: 30px;
	font-weight: bold;
	color: #F00;
}

.waribiki:before {
	position: absolute;
	bottom: -50px;
	left: calc( 50% - 26px);
	background:url(../image/arrow-04.png) no-repeat 0 0;
	width: 52px;
	height: 67px;
	content: "";
	z-index: -1;
}

.waribiki p {
	margin: 0 !important;
	line-height: 1.4;
}

.Plan2 div .box {
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	padding: 30px;
	position: relative;
}

.Plan2 div .box2 {
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	padding: 30px;
	position: relative;
}

.Plan2 div .box:before {
	position: absolute;
	background: url(../image/plus.png) no-repeat 0 0;
	width: 40px;
	height: 40px;
	content: "";
	top: -20px;
	left: calc( 50% - 20px );
}

#second .Plan2 h3 {
	color: #FFF;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	border: none;
	line-height: 40px !important;
	border-radius: 4px;
}

.Plan2 .pack h3 {
	background-color: #F05B71;
}

.Plan2 .bic h3 {
	background-color: #2482C0;
}

.plans .info span.p2 {
	color: #F05B71;
}

.plans .info span.p3 {
	color: #2482C0;
}

.Plan2 div .box2 dl {
	margin: 0;
}

.newstbBox {
	width: 880px;
	margin: 30px auto 30px;
	display: flex;
	flex-wrap: wrap;
}

.newstbBox div {
	width: 400px;
	border: 3px solid #E8F3F4;
	border-radius: 10px;
	margin: 0 20px 30px;
	padding: 20px 16px 16px;
	box-shadow: 3px 3px 6px #EEE;
 background-image: linear-gradient(135deg, #009E96 12px, transparent 0);
	position: relative;
}

.newstbBox div:before {
	position: absolute;
	top: 90px;
	right: 14px;
	width: 150px;
	height: 33px;
	white-space: pre;
	text-align: center;
	background-color: #E8F3F4;
	border: 2px solid #009E96;
	border-radius: 12px;
	padding: 0 0 4px;
}

.newstbBox div:nth-child(1):before {
	content: "標準タイプ";
}

.newstbBox div:nth-child(2):before {
	content: "録画タイプ";
}

.newstbBox div:nth-child(3):before {
	content: "ブルーレイタイプ";
}


.newstbBox div h3 {
	border: none;
	color: #009E96 !important;
	margin: 0 0 4px !important;
	padding: 0 0 8px !important;
	width: auto !important;
	line-height: 1.2;
}

.newstbBox div h3:after {
	display: none;
}

.newstbBox div .modelno {
	font-size: 14px;
}

.newstbBox div .kakaku {
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	padding: 0 0 16px;
	margin-bottom: 16px !important;
	border-bottom: 1px dotted #009E96;
}

.newstbBox div .kakaku span {
	font-size: 14px;
	font-weight: normal;
}

.newstbBox div .kakaku span.zero {
	text-align: left;
	display: block;
	font-size: 15px;
	margin-top: 8px;
}

.newstbBox div .image img {
	display: block;
	margin: 0 auto;
}

.newstbBox div p {
	margin: 0 !important;
	line-height: 1.4;
}

.stbStopTitle {
	font-size: 20px;
	color: #666;
	font-weight: 500;
	text-align: center;
}

.stbStop {
	padding: 0;
	margin: 0 30px 30px;
	list-style: none;
	display: flex;
	justify-content: space-between;
}

.stbStop li {
	width: 48%;
	margin: 0;
	padding: 20px;
	background-color: #F3F3F3;
}

.stbStop li img {
	display: block;
	margin: 0 auto 10px;
}

.hfcbox-01 {
	background-color: #F3F3F3;
	margin: 0 0 80px;
	padding: 20px;
	border-radius: 10px;
}

.hfcbox-01 table {
	width: 100%;
	margin: 0 0 10px;
}

.hfcbox-01 table th {
	width: 200px;
	padding: 10px;
	border-bottom: 2px solid #FFF;
}

.hfcbox-01 table th span {
	display: block;
	border: 1px solid #CCC;
	background-color: #FFF;
	margin-top: 4px;
	font-size: 13px;
}

.hfcbox-01 table tr:nth-child(1) th {
	/*background-color:#CDDF9D;*/
	background-color:#EDB7C5;
}

.hfcbox-01 table tr:nth-child(3) th,
.hfcbox-01 table tr:nth-child(5) th {
}

.hfcbox-01 table tr:nth-child(2) th,
.hfcbox-01 table tr:nth-child(4) th {
	background-color:#ABC4E7;
}

.hfcbox-01 table td {
	padding: 10px;
	border-bottom: 2px solid #FFF;
}

.hfcbox-01 table td.charge {
	width: 150px;
	text-align: right;
	font-size: 24px;
	color: #F00;
	font-weight: bold;
	border-left: 1px dashed #DDD;
}

.hfcbox-01 table td.charge span {
	display: block;
	font-size: 14px;
	color: #000;
	font-weight: normal;
}

.hfcbox-01 p {
	margin: 0 !important;
}

.channelCat01 {
	background-color: #EBF7F8;
	margin: 30px 0 80px;
	padding: 30px 20px 1px;
}

.channelCat02 {
	background-color: #FCEBEF;
	margin: 30px 0 80px;
	padding: 30px 20px 1px;
}

.channelCat03 {
	background-color: #DAEAF5;
	margin: 30px 0 80px;
	padding: 30px 20px 1px;
}

.channelCat04 {
	background-color: #FDEEDD;
	margin: 30px 0 80px;
	padding: 30px 20px 1px;
}

.channelCat01 .ctitle {
	margin: -56px 0 10px !important;
	font-size: 26px;
	font-weight: bold;
	color: #3AA6AB;
}

.channelCat02 .ctitle {
	margin: -56px 0 10px !important;
	font-size: 26px;
	font-weight: bold;
	color: #E96788;
}

.channelCat03 .ctitle {
	margin: -56px 0 10px !important;
	font-size: 26px;
	font-weight: bold;
	color: #3284BA;
}

.channelCat04 .ctitle {
	margin: -56px 0 10px !important;
	font-size: 26px;
	font-weight: bold;
	color: #F18712;
}

.channelCat01 h3,
.channelCat02 h3,
.channelCat03 h3,
.channelCat04 h3 {
	color: #111 !important;
}

.channelAllList {
	display: flex;
	margin: 20px 0 40px;
	padding: 0;
	list-style: none;
	flex-wrap: wrap;
}

.channelAllList li {
	margin: 0 0 16px;
	padding: 0;
	width: 24%;
	display: flex;
	flex-direction: column;
}

.channelAllList li:nth-child(4n-1) {
	margin: 0 1% 16px;
}

.channelAllList li:nth-child(4n-2) {
	margin: 0 0 16px 1%;
}

.channelAllList li.lg {
	width: 49%;
}

.channelAllList li a {
	display: block;
	padding: 16px 10px;
	text-align: center;
	border: 1px solid #CCC;
	border-radius: 10px;
	text-decoration: none;
	font-weight: 500;
	flex-grow: 1;
	box-shadow: 2px 2px 2px #CCC;
	color: #000;
	background-color: #FFF;
	line-height: 1.4;
}

.channelAllList li a .chnum {
	display: block;
	font-weight: normal;
	color: #2D826C;
	margin-bottom: 4px;
}

.channelAllList2 {
	width: 100%;
	background-color: #FFF;
}

.channelAllList2 th {
	background-color: #F18712;
	color: #FFF;
	padding: 8px;
}

.channelAllList2 th:nth-child(1) {
	border-right: 1px solid #FFF;
}

.channelAllList2 td {
	padding: 4px 8px;
	border-bottom: 1px solid #CCC;
	text-align: center;
}

.channelAllList2 td:nth-child(3) {
	text-align: left;
}

.channelAllList2 td:nth-child(4) {
	background-color: #FDFEE7;
}

.channelAllList img {
	max-width: 100%;
	height: auto;
}

.stb-bd {
	background-color: #E1E8F1;
	padding: 20px;
	text-align: center;
}

.stb-hd {
	background-color: #FFEDDF;
	padding: 20px;
	text-align: center;
}

.servicePoint {
	margin: 0 60px 20px;
	padding: 0 0 10px;
	background: url(../image/arrow-05.png) no-repeat center 100%;
	background-size: 40px;
}

.spno {
	background-image: none;
}

.servicePointNum {
	position: relative;
	display: inline-block;
	float: left;
	line-height: 0.8;
	font-weight: bold;
	color: #C75322;
	padding: 14px 0 0 9px;
	margin: 0 30px 16px 0;
	color: #FFF;
	text-align: center;
}

.servicePointNum span {
	font-size: 24px;
	font-style: normal;
}

.servicePointNum:after {
	content: "";
	background-color: #009E96;
	width: 60px;
	height: 60px;
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	border-radius: 100vh;
}

.gsMisTitle {
	float: left;
}

.gsMisTitle h4 {
	position: relative;
	margin: 0;
	padding: 6px 0 0;
	font-size: 22px !important;
	line-height: 47px;
	font-weight: 500;
}

.servicePoint p {
	margin: 0 0 10px !important;
	padding: 0 0 20px;
	border-bottom: 1px dotted #AAA;
}

.nhkkakaku {
 width: 95%;
 margin: 0 auto 10px;
	border-collapse: collapse;
}
.nhkkakaku td {
 border: 1px solid #CCCCCC;
	text-align: center;
}
.nhkkakaku td.bk1 {
 background-color: #FFE8D9;
}
.nhkkakaku td.bk1 {
 text-align: center;
}	

.nhkkakaku td.txRed {
	color: #F00;
}
.nhkkakaku td.txOra {
	color: #F60;
}
.nhkkakaku th {
 border: 1px solid #CCCCCC;
 background-color: #E8F3F4;
}
.nhkannounceBox {
	text-align: center;
}
.nhkannounce {
	margin: 0 0 10px;
	padding: 10px 20px;
	text-align: center;
	display: inline-block;
	background-color: #F90;
	color: #FFF;
	font-size: 18px;
	font-weight: bold;
	border-radius: 6px;
}

.nhkPhone dl {
	margin: 0 0 50px;
	border: 3px solid #009E96;	
	background-color: #E8F3F4;
}

.nhkPhone dl dt {
	background-color: #009E96;
	color: #FFF;
	font-weight: 500;
	padding: 8px;
	font-size: 18px;
}

.nhkPhone dl dd {
	font-size: 30px;
	padding: 10px 10px 10px 50px;
	font-weight: 500;
	background: url(../image/tel_mark.png) no-repeat 10px 23px;
	background-size: 30px;
}

.nhkPhone dl dd span {
	font-size: 18px;
	font-weight: normal;
	margin-left: 10px;
}

.nhkPhone2 {
	display: none;
}

.hikari_charge {
	width: 80%;
	margin: 0 auto;
}

.hikaricharge01 {
	width: 100%;
	margin: 0 auto 60px;
}

.hikaricharge02,
.hikaricharge03,
.hikaricharge04 {
	width: 100%;
	margin: 0 auto 10px;
}

.hikaricharge01 th {
	width: 60%;
	background-color: #FFE1A1;
	padding: 10px;
	border-bottom: 1px solid #CCC;
	letter-spacing: .2em;
	font-size: 20px;
}

.hikaricharge02 th {
	width: 60%;
	background-color: #F9C491;
	padding: 10px;
	border-bottom: 1px solid #CCC;
	letter-spacing: .2em;
	font-size: 20px;
}

.hikaricharge03 th {
	width: 60%;
	background-color: #F6BBC6;
	padding: 10px;
	border-bottom: 1px solid #CCC;
	letter-spacing: .2em;
	font-size: 20px;
}

.hikaricharge04 th {
	width: 60%;
	background-color: #ABC4E7;
	padding: 10px;
	border-bottom: 1px solid #CCC;
	letter-spacing: .2em;
	font-size: 20px;
}

.hikaricharge01 td,
.hikaricharge02 td,
.hikaricharge03 td,
.hikaricharge04 td {
	padding: 10px;
	text-align: right;
	border-bottom: 1px solid #CCC;
	font-size: 24px;
	color: #F00;
	font-weight: bold;
}

.hikaricharge01 td span,
.hikaricharge02 td span,
.hikaricharge03 td span,
.hikaricharge04 td span {
	color: #000;
	font-size: 14px;
	font-weight: normal;
}

.hikari_charge p {
	margin: 0 0 60px;
}

.campaignWrap {
	width: 1000px;
	margin: 0 auto;
}

.campaignWrap .orderBtn {
	width: 800px;
	margin: 0 auto 30px;
	background-color: #FFC;
	padding: 40px 20px;
	border-radius: 6px;
	text-align: center;
	font-size: 20px;
	font-weight: bold;
}

.campaignWrap .orderBtn a {
	display: block;
	width: 400px;
	margin: 10px auto 0;
	text-align: center;
	padding: 16px 20px;
	border-radius: 12px;
	position: relative;
	top: -1px;
	line-height: 1.2;
	overflow:auto;
	color:#ffffff;
	background: #009843;
	text-align:center;
	text-decoration: none;
	-webkit-transition: 0s;
 -moz-transition: 0s;
	-o-transition: 0s;
	box-shadow: inset 0 2px 0 rgba(255,255,255,0.3), inset 0 -2px 0 rgba(84, 48, 80, 0.1), 0 3px #004F23;
	font-weight: normal;
}

.campaignWrap .orderBtn a span {
	font-size: 30px;
	display: block;
	font-weight: bold;
}

.campaignWrap .orderBtn a:hover, .contents .orderBtn a:active {
	box-shadow: none;
	top: 1px;
}

.campaignWrap .lead {
	margin: 20px 0 30px !important;
 text-align: center;
	font-size: 30px;
	font-weight: 500;
	color: #F60;
	line-height: 1.4;
}

.matome {
	text-align: center;
}

.campaignWrap .flow {
	position: relative;
	text-align: center;
	margin: 0 100px 20px;
	font-size: 24px;
	font-weight: bold;
	color: #009843;
}

.campaignWrap .flow:before, .campaignWrap .flow:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 140px;
  height: 2px;
  background-color: #009843;
}

.campaignWrap .flow:before {
  left:0;
}

.campaignWrap .flow:after {
  right: 0;
}

.netPlanLead {
	background-color: #EB668D;
	color: #FFF;
	text-align: center;
	font-size: 18px;
	padding: 6px;
}

.netFee {
	width: 100%;
	line-height: 1.4;
}

.netFee tr {
	display: block;
	margin-bottom: 20px;
	width: 100%;
}

.netFee th {
	width: 200px;
	padding: 10px;
	border-bottom: 1px solid #CCC;
}

.netFee tr:nth-child(1) th {
	background-color: #EDB7C5;
}

.netFee tr:nth-child(2) th {
	background-color: #F8E4E8;
}

.netFee td {
	width: 360px;
	padding: 10px 20px;
	border-bottom: 1px solid #CCC;
}

.netFee td .tsuushin {
	font-weight: 500;
	color: #EB668D;
}

.netFee td.kakaku {
	text-align: right;
	font-size: 30px;
	font-weight: 500;
}

.netFee td.kakaku span {
	font-size: 16px;
}

.rooterRental {
	margin: -30px 0 0;
	font-size: 30px;
	font-weight: 500;
}

.rooterRental span {
	font-size: 16px;
}

.rooterReady {
	border: 2px solid #F60;
	padding: 20px;
}

.etcService {
	width: 100%;
	margin: 0;
	line-height: 1.2;
}

.etcService tbody th {
	width: 200px;
	text-align: left;
	font-weight: normal;
	border: 1px solid #CCC;
	padding: 10px;
	background-color: #F8E4E8;
	white-space: nowrap;
}

.etcService thead th {
	background-color: #EEE;
	border: 1px solid #CCC;
	padding: 10px;
	width: 30%;
}

.etcService td {
	padding: 10px;
	border: 1px solid #CCC;
}

.etcService td.charge {
	text-align: right;
}

.netMailBox {
	margin: 0 0 60px;
	padding: 0;
	list-style: none;
	line-height: 1.4;
}

.netMailBox li {
	margin: 0 0 10px;
	padding: 10px 10px 10px 20px;
	background: url(../image/arrow-03.png) no-repeat 2px 14px;
	background-size: 14px;
	border-bottom: 1px solid #CCC;
}

.btn {
  display: inline-block;
  margin-bottom: 0;
  font-weight: normal;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  border: 1px solid transparent;
  padding: 6px 12px;
  font-size: 14px;
  line-height: 1.42857143;
  border-radius: 4px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.btn:focus,
.btn:active:focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn.active.focus {
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}
.btn:hover,
.btn:focus,
.btn.focus {
  color: #333333;
  text-decoration: none;
}
.btn:active,
.btn.active {
  background-image: none;
  outline: 0;
  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
}
.btn.disabled,
.btn[disabled],
fieldset[disabled] .btn {
  cursor: not-allowed;
  filter: alpha(opacity=65);
  opacity: 0.65;
  -webkit-box-shadow: none;
  box-shadow: none;
}
a.btn.disabled,
fieldset[disabled] a.btn {
  pointer-events: none;
}

.btn-primary {
  color: #ffffff;
  background-color: #337ab7;
  border-color: #2e6da4;
}
.btn-primary:focus,
.btn-primary.focus {
  color: #ffffff;
  background-color: #286090;
  border-color: #122b40;
}
.btn-primary:hover {
  color: #ffffff;
  background-color: #286090;
  border-color: #204d74;
}
.btn-primary:active,
.btn-primary.active,
.open > .dropdown-toggle.btn-primary {
  color: #ffffff;
  background-color: #286090;
  background-image: none;
  border-color: #204d74;
}
.btn-primary:active:hover,
.btn-primary.active:hover,
.open > .dropdown-toggle.btn-primary:hover,
.btn-primary:active:focus,
.btn-primary.active:focus,
.open > .dropdown-toggle.btn-primary:focus,
.btn-primary:active.focus,
.btn-primary.active.focus,
.open > .dropdown-toggle.btn-primary.focus {
  color: #ffffff;
  background-color: #204d74;
  border-color: #122b40;
}
.btn-primary.disabled:hover,
.btn-primary[disabled]:hover,
fieldset[disabled] .btn-primary:hover,
.btn-primary.disabled:focus,
.btn-primary[disabled]:focus,
fieldset[disabled] .btn-primary:focus,
.btn-primary.disabled.focus,
.btn-primary[disabled].focus,
fieldset[disabled] .btn-primary.focus {
  background-color: #337ab7;
  border-color: #2e6da4;
}
.btn-primary .badge {
  color: #337ab7;
  background-color: #ffffff;
}

.callBox {
	margin: 0 20px 30px;
	border: 1px solid #CCC;
	padding: 20px 20px 1px;
}

.callBox .call {
	font-size: 24px;
	font-weight: bold;
	color: #F00;
}

.remotoMember {
	margin: 0 0 60px;
}

.remotoMember li {
	margin: 0 0 16px;
	line-height: 1.6;
}

.securityflow {
	margin: 0 0 20px;
	padding: 0 0 40px;
	background: url(../../hikari/image/arrow-01.png) no-repeat center 100%;
}

.securityflow:nth-of-type(7) {
	padding: 0;
	background-image: none;
}

.securityflow dl {
	border: 1px dashed #F69;
	padding: 10px;
	margin: 0 30px;
	background-color: #FFE;
}

.securityflow dl dt {
	font-weight: bold;
	margin-bottom: 10px;
}

.faq .q {
	position: relative;
	padding: 8px 8px 8px 48px;
	background-color: #E8F3F4;
	font-weight: 500;
	margin: 0 0 8px;
}

.faq .q:before {
	position: absolute;
	content: "";
	background-image: url(../image/q.png);
	width: 32px;
	height: 32px;
	top: 7px;
	left: 8px;
}

.faq .a {
	position: relative;
	margin: 0 0 10px;
	padding: 8px 8px 8px 48px;
}

.faq .a:before {
	position: absolute;
	content: "";
	background-image: url(../image/a.png);
	width: 32px;
	height: 32px;
	top: 7px;
	left: 8px;
}

.faq .a ul {
	margin: -20px 0 30px;
	padding: 0 0 0 24px;
	line-height: 1.3;
}

.faq .a ul li {
	margin: 0 0 16px;
}

.netFeature {
	margin: 0 20px 40px;
	border-radius: 8px;
	padding: 20px 30px;
	border: 2px solid #FC0;
	box-shadow: 3px 3px 3px #EEE;
}

.netFeature h4 {
	margin: 0 0 14px;
	font-size: 20px;
	font-weight: 500;
	color: #009E96;
	padding: 0 0 0 16px;
	background: url(../image/arrow-01.png) no-repeat 0 13px;
	border-bottom: 3px double #CCC;
}

.gongo2 {
	width: 100%;
	margin: 0 0 40px;
}

.gongo2 th {
	padding: 8px;
	border: 1px solid #ccc;
	font-weight: 500;
	background-color:#E8F3F4; 
}

.gongo2 td {
	padding: 8px;
	border: 1px solid #ccc;
}

.userhp {
	width: 100%;
	margin: 0 0 60px;
}

.userhp th {
	padding: 8px;
	border: 1px solid #ccc;
	font-weight: 500;
	text-align: left;
	background-color: #E8F3F4;
}

.userhp td {
	padding: 8px;
	border: 1px solid #ccc;
}

.onuList {
	margin: -20px 0 40px;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
}

.onuList li {
	width: 30%;
	margin: 0 0 30px;
	text-align: center;
}

.onuList li:nth-child(3n-1) {
	margin: 0 5% 30px;
}

.onuList li a {
	display: block;
	padding: 10px;
	border: 1px dotted #CCC;
}

.onuList li img {
	display: block;
	margin: 0 auto 10px;
}

.onuList li a:hover {
	border: 1px dotted #FF6600;
}

.talkPlan {
	margin: 0;
	padding: 0;
	display: flex;
	list-style: none;
}

.talkPlan li {
	width: 46%;
	margin: 0 2%;
	padding: 0;
	text-align: center;
}

.talkPlan li img {
	width: auto;
	border: 1px solid #CCC;
	height: 200px;
}

.talkFeature {
	margin: 0 20px 40px;
	border-radius: 8px;
	padding: 20px 30px 0;
	border: 2px solid #FC0;
	box-shadow: 3px 3px 3px #EEE;
}

.talkFeature h4 {
	margin: 0 0 14px;
	font-size: 20px;
	font-weight: 500;
	color: #009E96;
	padding: 0 0 0 16px;
	background: url(../image/arrow-01.png) no-repeat 0 13px;
	border-bottom: 3px double #CCC;
}

.talkFeature dt {
	display: inline-block;
	padding: 0 8px;
	margin: 0 0 4px;
	font-weight: 500;
	border: 1px solid #CCC;
	background-color: #FFC;
}

.talkFeature dd {
	line-height: 1.6;
}

.talkFeature img {
	max-width: 100%;
	height: auto;
}

.talkList {
	margin: 0 0 60px;
}

.talkList dt {
	padding: 0 0 0 10px;
	font-weight: 500;
	background: url(../image/arrow-01.png) no-repeat 0 9px;
}

.talkList dd {
	margin: 0 0 10px;
}

#second .numberNg {
	position: relative;
}

#second .numberNg:before {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 40px;
	height: 1px;
	background-color: #CCC;
	content: "";
}

#second .numberNg:after {
	position: absolute;
	bottom: 0;
	right: 0;
	height: 40px;
	width: 1px;
	background-color: #CCC;
	content: "";
}

#second .numberNg h4 {
	margin: 0 0 20px;
	padding: 8px;
	position: relative;
	background-color: #E8F3F4;
	font-weight: 500;
}

#second .numberNg h4:before {
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	width: 40px;
	height: 2px;
	background-color: #009E96;
}

#second .numberNg dl {
	margin: 0 20px 50px;
}

#second .numberNg dt {
	font-weight: 500;
}

#second .numberNg dd {
	margin: 0 0 10px;
}

.talkOption {
	padding: 20px;
	background-color: #F3F3F3;
}

.talkOption:nth-child(2n) {
	background-color: #FFF;
}

.talkOption .info {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.talkOption h4 {
	padding: 0 0 0 20px;
	font-size: 18px;
	font-weight: 500;
	background: url(../image/arrow-03.png) no-repeat 0 10px;
	background-size: 14px;
}

.talkOption .info .text {
	width: 55%;
	margin: 0 5% 0 0;
}

.talkOption .info .text p {
	margin: 0 !important;
}

.talkOption .info .fee {
	width: 40%;
	font-weight: 500;
	font-size: 18px;
}

.talkOption .info .fee dl {
	display: flex;
	flex-wrap: wrap;
}

.talkOption .info .fee dl dt {
	width: 100px;
	line-height: 1.6;
}

.talkOption .info .fee dl dd {
	width: calc( 100% - 100px );
	line-height: 1.6;
}

.talkLink {
	margin: 0 20px 40px;
	padding: 10px 0;
	border-bottom: 1px dashed #CCC;
}

.talkLink div.btn4 {
	margin: 0 0 10px;
}

.talkLink p {
	margin: 0 0 10px !important;
}

.talktcharge {
	width: 80%;
	margin: -20px auto 30px;
}

.talktcharge th {
	border: 1px solid #CCC;
	padding: 10px 20px;
	background-color: #D6EAF6;
}

.talktcharge td {
	border: 1px solid #CCC;
	padding: 10px 20px;
	text-align: center;
}


.talkpok {
	width: 100%;
	margin: 0 auto 30px;
}

.talkpok tr:nth-of-type(2n) {
	background-color: #EFEFEF;
}

.talkpok th {
	border: 1px solid #CCC;
	padding: 10px 20px;
	background-color: #D6EAF6;
}

.talkpok td {
	border: 1px solid #CCC;
	padding: 10px 20px;
}

.talkpok td.on {
	text-align: center;
}

.talkpok td:nth-child(1) {
	text-align: center;
}

.talkbefore {
	margin: 0 10px 30px;
	border: 1px solid #CCC;
	padding: 20px;
}

.talkbefore strong {
	color: #F00;
}

.talkbefore img {
	max-width: 100%;
	height: auto;
}

.talkbefore ul {
	margin: 0 0 30px;
	padding: 0;
	list-style: none;
	text-align: center;
}

.talkbefore ul li {
	display: inline-block;
	margin: 0 20px;
	padding: 10px;
	width: 200px;
	border: 1px solid #09C;
}

.talksetoption {
	width: 100%;
	margin: 0 0 30px;
}

.talksetoption thead th {
	border: 1px solid #CCC;
	padding: 10px;
	background-color: #D6EAF6;
	line-height: 1.4;
}

.talksetoption tbody th {
	border: 1px solid #CCC;
	padding: 10px;
	text-align: left;
	font-weight: normal;
	background-color: #EAF4FA;
}

.talksetoption tbody td {
	border: 1px solid #CCC;
	padding: 10px;
	text-align: center;
}

.talkteki {
	margin: 0 30px 30px;
	padding: 20px 20px 1px;
	background-color: #EAF4FA;
}

.htalkfee {
	width: 100%;
	margin: 0 0 10px;
}

.htalkfee th {
	width: 200px;
	padding: 10px;
	border-bottom: 1px solid #CCC;
	background-color: #D6EAF6;
}
	
.htalkfee td {
	padding: 10px;
	border-bottom: 1px solid #CCC;
	text-align: right;
	font-size: 30px;
	font-weight: 500;
}

.htalkfee2 {
	width: 100%;
	margin: 0 0 10px;
}

.htalkfee2 thead th {
	background-color: #8DC6E7;
	padding: 10px;
 border: 1px solid #CCC;
}

.htalkfee2 tbody th {
	padding: 10px;
 border: 1px solid #CCC;
	background-color: #D6EAF6;
	text-align: left;
}

.htalkfee2 tbody th span {
	font-size: 14px;
	color: #F00;
	font-weight: 400;
}

.htalkfee2 tbody td {
	padding: 10px;
 border: 1px solid #CCC;
	white-space: nowrap;
}

.htalkfee2 tbody td div {
	padding: 8px;
	background-color: #E88E9A;
	text-align: center;
	color: #FFF;
	line-height: 1.4;
}

.htalkfee2 tbody td div span {
	font-size: 22px;
	font-weight: bold;
}

span.htalkfeeKome {
	font-size: 14px;
	color: #F00;
}



/*------------------------------------------------------------------------------------------------
  maintenance
--------------------------------------------------------------------------------------------------*/
.kaminariAtten {
	border: 2px solid #F90;
	margin: 0 20px 60px;
	padding: 20px 30px 10px;
	position: relative;
	border-radius: 10px;
}

#second .kaminariAtten h3 {
	color: #ff2300;
	text-align: center;
	border: none;
	font-size: 22px;
}

.kaminariAtten:before {
  content: "";
  position: absolute;
  bottom: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #FFF;
  z-index: 2;
}

.kaminariAtten:after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-top: 14px solid #F90;
  z-index: 1;
}

.kaminariHowto {
	border: 1px dotted #F90;
	margin: 0 0 60px;
	padding: 0;
	background-color: #FFFAE8;
	padding: 20px 40px 10px;
}

.kaminariHowtoTitle {
	display: inline-block;
	padding: 0 10px;
	background-color: #F90;
	color: #FFF;
	margin: 0 !important;
}

.hosoku {
	margin: -50px 0 30px !important;
}

.booster {
	margin: 0 10px 60px;
	display: flex;
	justify-content: space-between;
}

.booster div {
	width: 49%;
	text-align: center;
}

.booster div span {
	margin: 0 0 8px;
	display: block;
	background-color: #E8F3F4;
}

.kaminariAtten2 {
	margin: 0 0 60px;
}

.kaminariAtten2 li {
	margin: 0 0 16px;
	line-height: 1.4;
}


/*------------------------------------------------------------------------------------------------
  maintenance
--------------------------------------------------------------------------------------------------*/
.formPaper {
	margin: 0 0 60px;
	padding: 0;
	list-style: none;
	line-height: 1.2;
}

.formPaper li {
	margin: 0 0 20px;
	padding: 8px 8px 12px;
	box-shadow: 3px 3px 2px #EEE;
}

.formPaper li dt {
	margin: 0 0 8px;
}

.formPaper li dt a {
	background: url(../image/arrow-03.png) no-repeat 0 6px;
	background-size: 14px;
	margin-right: 10px;
	margin-bottom: 4px;
	padding: 0 0 0 18px;
}

.formPaper li dt span.tesuu {
	display: block;
	margin-top: 10px;
	margin-left: 18px;
}

.formPaper li dd {
	margin-left: 18px;
}


/*------------------------------------------------------------------------------------------------
  contact
--------------------------------------------------------------------------------------------------*/
.contactTarget {
	margin: 0 0 40px;
}

.contactTarget dt {
	padding: 0 10px;
	background-color: #009E96;
	color: #FFF;
	display: inline-block;
}

.contactTarget dd {
	border: 1px solid #009E96;
}

.contactTarget dd ul {
	margin: 20px 0 0;
	padding: 0 40px;
	list-style: none;
}

.contactTarget dd ul li {
	margin: 0 0 20px;
	padding: 0 0 0 18px;
	background: url(../image/arrow-03.png) no-repeat 0 8px;
	background-size: 14px;
}


/*------------------------------------------------------------------------------------------------
  speaker
--------------------------------------------------------------------------------------------------*/
.speakerWrap {
	width: 1000px;
	margin: 0 auto;
}

.speakerWrap .osusume p {
	font-weight: 500;
	text-align: center;
	font-size: 26px;
	margin-top: 20px;
}

.speakerWrap .osusume p span {
	color: #CF3C24;
}

.speakerWrap .contact {
	margin: 80px 40px 70px;
	padding: 60px 30px 40px;
	position: relative;
	background-color: #F8EDF0;
	border-radius: 20px;
}

.speakerWrap .contact p.tit {
	position: absolute;
	top: -24px;
	font-size: 30px;
	font-weight: 500;
	color: #B23E5A;
	left: 50%;
	transform: translateX(-50%);
 -webkit-transform: translateX(-50%);
 -ms-transform: translateX(-50%);
}

.speakerWrap .contWrap {
	display: flex;
	justify-content: center;
	align-items: center;
}

.speakerWrap .contWrap div {
	width: 44%;
}

.speakerWrap .contWrap div:nth-child(2) {
	margin-left: 20px;
}

.speakerWrap .contWrap div dt {
	font-size: 36px;
	font-weight: 500;
	letter-spacing: 0.02em;
	padding-left: 40px;
	background: url(../../speaker/image/image-04.png) no-repeat 10px 18px;
	background-size: 20px;
}

.speakerWrap .voice {
	background-color: #B8DED6;
	text-align: center;
	padding: 40px 0 10px;
}

.speakerWrap .voice p {
	margin: 0 0 30px;
}


/*------------------------------------------------------------------------------------------------
  wifi
--------------------------------------------------------------------------------------------------*/
.wifiRental {
	width: 1000px;
	margin: 0 auto;
}

.wifiRental .ttl {
	font-weight: bold;
	font-size: 40px;
	color: #3E5BB3;
	text-align: center;
	margin: 0 0 20px;
}

.wifiRental .lead {
	color: #3E5BB3;
	font-weight: bold;
	font-size: 20px;
	text-align: center;
	margin: 0 0 40px;
}

.wifiRental .lead .kome {
	font-size: 14px;
}

.wifiRental .wrap01 {
	display: flex;
	justify-content: center;
	margin: 0 0 60px;
}

.wifiRental .wrap01 .photo {
	margin-right: 40px;
}

.wifiRental .wrap01 .text p {
  position: relative;
  margin: 1.5em 0 1.5em 15px;
  padding: 20px;
  min-width: 120px;
  max-width: 100%;
  font-size: 18px;
  background: #FFF;
  border: solid 3px #3E5BB3;
  box-sizing: border-box;
		font-weight: bold;
		background-color: #E9EDF8;
}

.wifiRental .wrap01 .text p:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -24px;
  margin-top: -12px;
  border: 12px solid transparent;
  border-right: 12px solid #E9EDF8;
  z-index: 2;
}

.wifiRental .wrap01 .text p:after {
  content: "";
  position: absolute;
  top: 50%;
  left: -30px;
  margin-top: -14px;
  border: 14px solid transparent;
  border-right: 14px solid #3E5BB3;
  z-index: 1;
}

.komeText {
	font-size: 14px;
	text-align: center;
}

.wifiRental .wrap02 {
	margin: 60px 0;
}

.wifiRental .wrap03 {
	border: 8px solid #94A6DA;
	padding: 40px 40px 0;
	text-align: center;
}

.wifiRental .wrap03 dl {
	font-size: 24px;
	font-weight: bold;
	margin: 0 0 40px;
}

.wifiRental .wrap03 dt {
	display: inline-block;
	padding: 8px 40px;
	color: #FFF;
	border-radius: 100vh;
	background-color: #3E5BB3;
	margin: 0 0 20px;
}

.wifiRental .wrap03 dd {
	position: relative;
	padding: 8px 0;
  border-bottom: 3px solid #3E5BB3;
		color: #3E5BB3;
		background-color: #E9EDF8;
		border-radius: 20px;
}

.wifiRental .wrap03 dd:before {
  position: absolute;
  bottom: -14px;
  left: calc( 50% - 10px);
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #3E5BB3 transparent transparent transparent;
}

.wifiRental .wrap03 dd:after {
  position: absolute;
  bottom: -10px;
  left: calc( 50% - 10px);
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #E9EDF8 transparent transparent transparent;
}

.wifiRental .wrap03 p {
	margin: 0 0 60px;
	font-size: 18px;
}

.wifiRental .wrap04 {
	margin: 60px 0 0;
}

.wifiRental .wrap04 .price01 {
	border: 4px solid #DDD;
	padding: 20px;
	width: 680px;
	margin: 0 auto;
}

.wifiRental .wrap04 .priceTitle {
	border-bottom: 8px double #94A6DA;
	font-size: 24px;
	font-weight: bold;
	padding: 0 0 6px;
}

.wifiRental .wrap04 .kakaku {
	font-size: 70px;
	font-weight: bold;
	text-align: center;
}

.wifiRental .wrap04 .kakaku span {
	font-size: 30px;
}

.wifiRental .wrap04 .zei {
	text-align: center;
	font-size: 20px;
}

.wifiRental .wrap04 .price02 {
	width: 720px;
	margin: 20px auto 60px;
	display: flex;
	justify-content: space-between;
}

.wifiRental .wrap04 .price02 div {
	border: 4px solid #DDD;
	padding: 20px;
	width: 320px;
	margin: 0 auto;
}

.wifiRental .wrap05 {
	background-color: #E9EDF8;
	padding: 40px 40px 20px;
	margin: 0 0 60px;
}

.wifiRental .wrap05 h3 {
	border-bottom: 8px double #94A6DA;
	font-size: 24px;
	font-weight: 500;
	padding: 0 0 6px;
	width: 100%;
	margin: 0 0 20px;
}

.wifiRental .wrap05 h3:after {
	display: none;
}

.wifiRental .wrap05 .cont {
	display: flex;
	margin: 0 0 40px;
}

.wifiRental .wrap05 .cont .photo {
	margin: 0 40px 0 0;
}

.wifiRental .wrap05 .cont .text {
	background-color: #FFF;
	padding: 20px;
	width: calc( 100% - 340px);
}

.wifiRental .wrap05 .cont .text dt {
	font-weight: bold;
}

.wifiRental .wrap05 .cont .text dd {
	border-bottom: 1px dotted #CCC;
	margin-bottom: 20px;
}


/*------------------------------------------------------------------------------------------------
  faq
--------------------------------------------------------------------------------------------------*/
#internetFaq {
	padding: 0 0 30px;
}

.internetFaqMenu {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: left;
	flex-wrap: wrap;
}

.internetFaqMenu li {
	margin: 0 20px 20px;
	padding: 0;
	font-weight: 500;
}

.internetFaqMenu li a {
	display: block;
	width: 380px;
	padding: 20px 20px 20px 70px;
	border: 3px solid #E8F3F4;
	text-decoration: none;
	color: #333;
	font-size: 16px;
}

.internetFaqMenu li:nth-child(1) a {
	background: url(../../faq/image/faq_icon-01.png) no-repeat 20px center;
	background-size: 40px;
}

.internetFaqMenu li:nth-child(1) a:hover {
	background: url(../../faq/image/faq_icon-01.png) #E8F3F4 no-repeat 20px center;
	background-size: 40px;
	border: 3px solid #009E96;
	opacity: 1;
}

.internetFaqMenu li:nth-child(2) a {
	background: url(../../faq/image/faq_icon-02.png) no-repeat 20px center;
	background-size: 40px;
}

.internetFaqMenu li:nth-child(2) a:hover {
	background: url(../../faq/image/faq_icon-02.png) #E8F3F4 no-repeat 20px center;
	background-size: 40px;
	border: 3px solid #009E96;
	opacity: 1;
}

.internetFaqMenu li:nth-child(3) a {
	background: url(../../faq/image/faq_icon-03.png) no-repeat 20px center;
	background-size: 40px;
}

.internetFaqMenu li:nth-child(3) a:hover {
	background: url(../../faq/image/faq_icon-03.png) #E8F3F4 no-repeat 20px center;
	background-size: 40px;
	border: 3px solid #009E96;
	opacity: 1;
}

.internetFaqMenu li:nth-child(4) a {
	background: url(../../faq/image/faq_icon-04.png) no-repeat 20px center;
	background-size: 40px;
}

.internetFaqMenu li:nth-child(4) a:hover {
	background: url(../../faq/image/faq_icon-04.png) #E8F3F4 no-repeat 20px center;
	background-size: 40px;
	border: 3px solid #009E96;
	opacity: 1;
}

.internetFaqMenu li.noTel {
	display: block;
	width: 340px;
	padding: 20px 20px 20px 70px;
	border: 3px solid #E8F3F4;
	text-decoration: none;
	color: #333;
	font-size: 16px;
	background: url(../../faq/image/faq_icon-05.png) no-repeat 20px center;
	background-size: 40px;
}

.faqMokuji {
	margin: 0 20px 60px;
	padding: 0;
	list-style: none;
}

.faqMokuji li {
	margin: 0;
	padding: 0;
}

.faqMokuji li a {
	display: block;
	padding: 10px 8px 10px 24px;
	background: url(../image/arrow-01.png) no-repeat 8px 19px;
	border-bottom: 1px dashed #CCC;
	text-decoration: none;
	color: #111;
	letter-spacing: 0.04em;
}

.faqMokuji li a:hover {
	background: url(../image/arrow-01.png) #E8F3F4 no-repeat 8px 19px;
}

.faq h3 {
	padding: 2px 8px 4px 40px !important;
	color: #111 !important;
	background: url(../image/q.png) #f2f7f2 no-repeat 4px 4px;
}

.faqCat {
	margin: 0 !important;
	padding: 0 8px;
	background-color: #f2f7f2;
	display: inline-block;
	color: #009E96;
}

.faqDetail .qa-a {
	position: relative;
	border: 2px solid #DDD;
	border-radius: 10px;
	margin: 0 10px 30px 0;
	padding: 24px 20px 0 60px;
	box-shadow: 3px 3px 6px #DDD;
	line-height: 1.6;
}

.faqDetail .qa-a::before {
	position: absolute;
	content: "";
	width: 32px;
	height: 32px;
	background: url(../image/a.png) no-repeat 0 0;
	top: 22px;
	left: 20px;
}

.faqDetail .qa-a p {
	margin: 0 0 20px;
}

.faqDetail .qa-a p.lead {
	margin: 0 0 20px;
	font-weight: 500;
	font-size: 17px;
}

.faqDetail .qa-a p span.bg {
	background-color: #F4E3E8;
}

.faqDetail .qa-a dt {
	margin: 0;
	padding: 0;
	color: #009E96;
	font-weight: 500;
}

.faqDetail .qa-a dt.color {
	margin-bottom: 10px;
	padding: 4px;
	background-color: #009E96;
	color: #FFF;
}

.faqDetail .qa-a dd {
	margin: 0 0 30px;
	padding: 0;
}

.faqDetail .qa-a ol {
	margin: 0;
	padding: 10px 0 0 42px;
}

.faqDetail .qa-a ul {
	margin: -10px 0 0;
	padding: 0 0 0 42px;
}

.faqDetail .qa-a ol li,
.faqDetail .qa-a ul li {
	margin: 0 0 6px;
}

.faqDetail .qa-a img {
	border: 1px solid #CCC;
}

.faqDetail .qa-a img.nobdr {
	border: none;
}

.faqDetail .qa-a .tuika1 {
	background-color: #F3F2F1;
	padding: 20px;
}

.faqDetail .qa-0 {
	border: 2px solid #DDD;
	border-radius: 10px;
	margin: 0 10px 30px 0;
	padding: 20px;
	box-shadow: 3px 3px 6px #DDD;
	line-height: 1.6;
}

.faqDetail .qa-tejyun1 {
	border: 2px solid #3C6;
	border-radius: 10px;
	margin: 0 10px 30px 0;
	padding: 20px;
	box-shadow: 3px 3px 6px #DDD;
	line-height: 1.6;
}

.faqDetail .qa-tejyun2 {
	border: 2px solid #00A3D9;
	border-radius: 10px;
	margin: 0 10px 30px 0;
	padding: 20px;
	box-shadow: 3px 3px 6px #DDD;
	line-height: 1.6;
}

.faqDetail .qa-0 p,
.faqDetail .qa-tejyun1 p,
.faqDetail .qa-tejyun2 p {
	margin: 0 0 20px;
}

.faqDetail .qa-0  p.lead {
	font-weight: bold;
	font-size: 18px;
}

.faqDetail .qa-0  p.leadLine {
	border: 1px solid #AAA;
	display: inline-block;
	padding: 4px;
}

.faqDetail .qa-tejyun1 p.lead {
	font-weight: bold;
	font-size: 18px;
	color: #393;
}

.faqDetail .qa-tejyun2 p.lead {
	font-weight: bold;
	font-size: 18px;
	color: #00A3D9;
}

.faqDetail p.mgn20 {
	margin: 0 0 20px;
}

.faqDetail p.mgn40 {
	margin: 0 0 40px;
}

.faqDetail .qa-tejyun1 dl.step {
	margin: 0 0 10px;
	padding: 0 0 4px;
	font-size: 16px;
	border-bottom: 1px dashed #CCC;
}

.faqDetail .qa-tejyun1 dl.step dt {
	background-color: #3C6;
	color: #FFF;
	padding: 1px 4px;
	margin: 0 0 4px;
	display: inline-block;
}

.faqDetail .qa-tejyun2 dl.step {
	margin: 0 0 10px;
	padding: 0 0 4px;
	font-size: 16px;
	border-bottom: 1px dashed #CCC;
}

.faqDetail .qa-tejyun2 dl.step dt {
	background-color: #00A3D9;
	color: #FFF;
	padding: 1px 4px;
	margin: 0 0 4px;
	display: inline-block;
}

.faqDetail .qa-0 dl.step {
	margin: 0 0 10px;
	padding: 0 0 4px;
	font-size: 16px;
	border-bottom: 1px dashed #CCC;
}

.faqDetail .qa-0 dl.step dt {
	background-color: #B33E5C;
	color: #FFF;
	padding: 1px 4px;
	margin: 0 0 4px;
	display: inline-block;
}

.faqDetail .qa-tejyun1 dl.step dd,
.faqDetail .qa-tejyun2 dl.step dd,
.faqDetail .qa-0 dl.step dd {
	font-weight: bold;
}

.faqDetail .qa-tejyun1 p img,
.faqDetail .qa-tejyun2 p img {
	margin: 0 4px;
}


.noanswer {
	margin: 80px 10px 60px 0;
	background-color: #F3F2F1;
	text-align: center;
	padding: 20px 20px 20px;
	border-radius: 8px;
}

.noanswer p {
  position: relative;
  margin: 1.5em 0;
  padding: 10px 16px;
  min-width: 120px;
  max-width: 100%;
  font-size: 18px;
  background: #E8F3F4;
  border-bottom: solid 3px #009E96;
  box-sizing: border-box;
		color: #009E96;
		font-weight: 500;
}

.noanswer p:before {
  content: "";
  position: absolute;
  bottom: -24px;
  left: 50%;
  margin-left: -15px;
  border: 12px solid transparent;
  border-top: 12px solid #E8F3F4;
  z-index: 2;
}

.noanswer p:after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  margin-left: -17px;
  border: 14px solid transparent;
  border-top: 14px solid #009E96;
  z-index: 1;
}

.noanswer a {
	display: block;
	width: 480px;
	text-align: center;
	padding: 16px 20px;
	border-radius: 6px;
	position: relative;
	top: -1px;
	margin: 0 auto;
	overflow:auto;
	color:#333;
	background: #CCC;
	text-align:center;
	text-decoration: none;
	-webkit-transition: 0s;
 -moz-transition: 0s;
	-o-transition: 0s;
	font-size: 18px;
	font-weight: 500;
	box-shadow: inset 0 2px 0 rgba(255,255,255,0.3), inset 0 -2px 0 rgba(84, 48, 80, 0.1), 0 3px #AAA;
}

.noanswer a:hover, .noanswer a:active {
	box-shadow: none;
	top: 1px;
	opacity: 1;
}

.syuttyou {
	border: 2px dashed #009E96;
	padding: 20px;
	margin: 0 10px 0 0;
	background: url(../image/car.png) #FFE no-repeat 16px center;
	background-size: 80px;
}

.syuttyou dl {
	margin-left: 90px;
}

.syuttyou dt {
	margin-bottom: 5px;
	font-weight: 500;
	font-size: 18px;
}

.syuttyou dd p {
	margin-bottom: 0 !important;
}

.firstStep {
	margin: 40px 0;
	background-color: #EBF7F4;
	position: relative;
	padding: 40px 20px 20px;
}

.firstStep .ttl {
	position: absolute;
	top: -10px;
	background-color: #3EB395;
	margin: 0;
	padding: 6px 12px;
	color: #FFF;
	border-radius: 10px;
}

.firstStep p {
	margin: 0 0 20px;
}

.faqinbtn {
	text-align: center;
	margin: 0 0 20px;
}

.faqinbtn a {
	display: block;
	width: 300px;
	text-align: center;
	border: 1px solid #009E96;
	text-decoration: none;
	padding: 8px 0;
	color: #111 !important;
	background: url(../image/arrow-01.png) no-repeat 96% center;
}

.faqinbtn a:hover {
	color: #FFF !important;	
	background: url(../image/arrow-02.png) #009E96 no-repeat 96% center;
}

.spblock {
	margin: 0 0 10px;
}

.spblock th {
	border: 1px solid #AAA;
	background-color: #E8F3F4;
	font-weight: 500;
	text-align: left;
	padding: 10px;
}

.spblock td {
	border: 1px solid #AAA;
	padding: 10px;
}

.faqOnu {
	display: flex;
	justify-content: space-between;
}

.faqOnu .onuImage {
	width: 30%;
}

.faqOnu .onuInfo {
	width: 66%;
}

.faqOnu .onuInfo table {
	width: 100%;
	margin: 0 0 30px;
	font-size: 14px;
}

.faqOnu .onuInfo table th {
	padding: 4px 6px;
	border: 1px solid #AAA;
	font-weight: 500;
	background-color: #E8F3F4;
}

.faqOnu .onuInfo table td {
	padding: 4px 6px;
	text-align: center;
	border: 1px solid #AAA;
}

.faqOnu .onuInfo table td.status {
	text-align: left;
}

.faqOnu .onuInfo table td.midori {
	background-color: #D4E8C6;
}

.onuInfo table td.dai {
	background-color: #FFECB2;
}

.faqOnu .onuInfo table td.aka {
	background-color: #FF7F7F;
}


/*------------------------------------------------------------------------------------------------
  hfc
--------------------------------------------------------------------------------------------------*/
.catvmanual dt {
	margin-bottom: 10px;
	font-weight: 500;
	border-bottom: 1px dotted #CCC;
}

.catvmanual dt::before {
	content:'○';
}

.catvmanual dd {
	margin:0 0 40px 20px;
}

.syoki,
.getsu {
	width: 100%;
	margin: 0 0 30px;
	line-height: 1.4;
}

.syoki th,
.getsu th {
	width: 200px;
	padding: 10px;
	font-weight: 500;
	text-align: left;
	white-space: nowrap;
	border: 1px solid #CCC;
	background-color: #E8F3F4;
}

.syoki td,
.getsu td {
	padding: 10px;
	border: 1px solid #CCC;
}

.hfcTb {
	width: 100%;
	margin: 0 0 30px;
	line-height: 1.4;
}

.hfcTb th {
	width: 200px;
	padding: 10px;
	font-weight: 500;
	text-align: left;
	white-space: nowrap;
	border: 1px solid #CCC;
	background-color: #E8F3F4;
}

.hfcTb td {
	padding: 10px;
	border: 1px solid #CCC;
}

.hfcTb2 {
	width: 100%;
	margin: 0 0 30px;
	line-height: 1.4;
}

.hfcTb2 th {
	padding: 10px;
	font-weight: 500;
	text-align: left;
	white-space: nowrap;
	border: 1px solid #CCC;
	background-color: #E8F3F4;
}

.hfcTb2 td {
	padding: 10px;
	border: 1px solid #CCC;
}

.channelTb {
	width: 100%;
	border: solid 1px #2D826C;
}

.channelTb th {
	background-color:#AAE1D3;
	font-weight: normal;
		border: solid 1px #2D826C;

}
.channelTb th.bb {
	background-color: #5CC7AC;
	font-size: 1.2em;
}
.channelTb th {
	width: 140px;
}
.channelTb .channel02 th  {
	width: 74px;
	height: 35px;
}
	
.channelTb td {
	padding-left: 14px;
}

.channel02 td{
	padding-left: 14px;
  border-right: none;
}

.channel02 tr td.j {
	width: 140px;
	background: #efefef;
	border-left: none;
	padding:0 6px;
	font-size: .9em;
	text-align:center;
}
.channelTb tr td.j {
	width: 120px;
}

.channelTb tr td.m {
	width: 295px;
	border-right: none;
}

.channelTb td {
	border: solid 1px #2D826C;
}

.channel02 {
	width: 100%;
	border: solid 1px #C9788A;
}
.channel02 th.bb {
	background-color: #D799A9;
	font-size: 1.2em;
}

.channel02 th {
	width: 140px;
	background-color: #F4E3E8;
	font-weight: normal;
}
.t_bottom {
	margin-bottom: 40px;
	margin-top:8px;
}
.channel03 {
	border:solid 1px #4b85bf;
}
.channel03 tr td.pr {
	width:200px;
	text-align:center;
	padding:0;
}
.channel04 tr td.pr {
	width:230px;
	text-align:center;
	padding:0;
}	
	
.channel03 th.bb {
	background-color:#64a2e0;
	border-bottom:none;
}
.channel03 tr:nth-child(2) th {
	height:20px;
	font-size:13px;
	background-color:#64a2e0;
}
.channel03 th {
	background-color:#c8edff;
}
.channel04 {
	border:solid 1px #caca3e;
}
.channel04 th.bb {
	background-color:#f7f797;
	border-bottom:none;
}
.channel04 tr:nth-child(2) th {
	height:20px;
	font-size:13px;
	background-color:#f7f797;
}
.channel04 th {
	background-color:#fbfbdd;
}
.channel04 td span {
	font-size:13px;
}
.channel04 tr td.j {
}

.dtvTb {
	margin: 0 auto 30px;
	line-height: 1.4;
}

.dtvTb td {
	padding: 0 20px;
	vertical-align: top;
	width: 50%;
	text-align: center;
}

.dtvTb td img {
	margin: 10px 0;
}

.dtvTb td:nth-child(1) {
	border-right: 1px solid #CCC;
}

.hfcChannelTb {
	margin:20px auto 60px;
}
.hfcChannelTb th {
	padding: 10px;
	box-sizing: border-box;
	background-color: #F4E3E8;
	border: 1px solid #CCC;
	text-align: center;
}
.hfcChannelTb td {
	padding: 10px;
	border: 1px solid #CCC;
}
.hfcChannelTb:nth-of-type(2) th {
	text-align:center;
}
.hfcChannelTb:nth-of-type(2) tr:nth-child(n+4) th{
	background-color:#aae1d3;
}
.hfcChannelTb:nth-of-type(2) td {
	text-align:left;
}
.hfcChannelTb:nth-of-type(3) tr:first-child th:last-child {
	text-align:center;
}
.hfcChannelTb:nth-of-type(3) td {
	text-align: right;
}
.hfcChannelTb tr:nth-child(n+4) th{
	background-color:#aae1d3;
}

.hfcChannelTb2 {
	width: 100%;
	margin: 0 0 10px;
}

.hfcChannelTb2 th {
	background-color: #E8F3F4;
	font-weight: 500;
	text-align: left;
	padding: 8px;
	border: 1px solid #CCC;
}

.hfcChannelTb2 td {
	padding: 8px;
	border: 1px solid #CCC;
	text-align: right;
}


.hfcChannelTb3 {
	width: 100%;
	margin: 0 0 10px;
}

.hfcChannelTb3 th {
	background-color: #E8F3F4;
	font-weight: 500;
	text-align: left;
	padding: 8px;
	border: 1px solid #CCC;
}

.hfcChannelTb3 td {
	padding: 8px;
	border: 1px solid #CCC;
}

.hfcNetTb {
	width: 100%;
	margin: 0 0 10px;
}

.hfcNetTb th {
	width: 25%;
	background-color: #E8F3F4;
	font-weight: 500;
	text-align: left;
	padding: 8px;
	border: 1px solid #CCC;
}

.hfcNetTb td {
	width: 75%;
 padding: 8px;
	border: 1px solid #CCC;
}

.hfcNetTb2 {
	width: 100%;
	margin: 0 0 10px;
	line-height: 1.4;
}

.hfcNetTb2 th {
	background-color: #E8F3F4;
	font-weight: 500;
	text-align: left;
	padding: 8px;
	border: 1px solid #CCC;
}

.hfcNetTb2 td {
 padding: 8px;
	border: 1px solid #CCC;
}

.hfcNetDl {
	margin: 0 0 20px;
}

.hfcNetDl dt {
	margin: 0 0 10px;
	font-weight: 500;
}

.hfcNetDl dd {
	padding: 0 0 20px;
	border-bottom: 1px dashed #CCC;
	display: flex;
}

.hfcNetDl dd div {
	margin-right: 30px;
}

/**/
.index_news ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.index_news ul li {
	margin: 0;
	padding: 0;
	line-height: 2.2;
}

.index_news ul li a {
	display: block;
	padding: 10px 12px;
	text-decoration: none;
	color: #111;
	border-bottom: 1px dotted #CCC;
}

.index_news ul li a:hover {
	background-color: #E5F5F4;
}

.index_news ul li a .cat {
	display: inline-block;
	border: 1px solid #CCCCCC;
	width: 100px;
	margin-left: 20px;
	text-align: center;
	background-color: #FFF;
}

.index_news ul li .info {
	line-height: 1.5;
}


/*shintiku*/
.campaignWrap h3 {
	width: 100%;
	margin: 0 0 20px;
}

.campaignWrap h3:after {
	border-bottom: 2px solid #B33E5C !important;
}

.campaignWrap p {
	margin: 0 0 30px;
}

.campaignWrap .hs {
	color: #F00;
}

.campaignWrap .form table {
	width: 100%;
	margin: 10px 0 30px;
	line-height: 1.4;
}

.campaignWrap .form table th {
	width: 240px;
	padding: 15px;
	border: 1px solid #CCCCCC;
	background-color: #F4E3E8;
	text-align: left;
}

.campaignWrap .form table td {
	padding: 15px;
	border: 1px solid #CCCCCC;
}

.campaignWrap .form table td p {
	margin: 0;
}

.campaignWrap .form table td input {
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.campaignWrap .form table td input.tx1 {
	width: 400px;
}

.campaignWrap .form table td input.tx2 {
	width: 60px;
}

.campaignWrap .form td textarea {
	width: 100%;
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.campaignWrap .form .btn {
	text-align: center;
}

.campaignWrap .form .btn input {
	margin: 0 10px;
	padding: 10px;
}

.campaignWrap .form .privacy {
	border: 3px double #FFCC33;
	margin: 0 30px 30px;
	padding: 20px;
}

.campaignWrap .form .error {
	margin: 3px 0 0;
	background-color: #FEE;
	padding: 5px;
	color: #FF0000;
}

.campaignWrap .box-blue {
 background: linear-gradient(#05FBFF, #1E00FF);
}

.campaignWrap .form .privacy p {
 margin-bottom: 0 !important;
 }

.campaignWrap h3 {
	margin: 0 0 20px;
	padding: 0 0 4px;
	font-size: 20px;
	color: #009E96;
	font-weight: 500;
	border-bottom: 2px solid #CCC;
}

/*hikari*/
.hikariWrap table {
	width: 100%;
	margin: 0 0 30px;
}

.hikariWrap table th {
	width: 220px;
	font-weight: normal;
	text-align: left;
	padding: 13px 5px;
	border-bottom: 1px solid #CCC;
}

.hikariWrap table td {
	position: relative;
	padding: 13px 5px 10px 20px;
	text-align: left;
	border-bottom: 1px solid #CCC;
}

.hikariWrap table td input[type=text]{
	width: 400px;
	padding: 3px;
	margin: 0 5px 3px;
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.hikariWrap table td input.s[type=text]{
	width: 100px;
}

.hikariWrap table td textarea {
	width: 100%;
	padding: 3px;
	font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.hikariWrap table td label {
	margin-right: 30px;
}

.hikariWrap .hs {
	color: #F00;
}

.error-message {
  color: #D50000;
  background-image: url(../image/warning.gif);
  background-repeat: no-repeat;
  text-align: left;
  margin-top: 5px;
  padding-left: 18px;
}

#contact table {
	width: 90%;
	margin:auto;
}
#contact table th {
	padding: 10px;
	box-sizing: border-box;
	background-color: #E8F3F4;
	text-align: left;
}
#contact table td {
	padding: 10px;
}
#contact table dd {
	margin-left:10px;
}
#contact table caption {
	text-align:left;
}
#contact section#ippan table {
	width:700px;
}
#contact #technical table th {
	width:246px;
}
#contact span.red {
	color:red;
}
#contact #contactform table th {
	width:33%;
}
#contact #contactform table .hissu::after {
	content:'※必須';
	color:red;
	font-size:13px;
	font-weight:normal;
	float:right;
}
#contact #contactform table input ,
#contact #contactform table textarea {
	font-size:16px;
	padding:4px;
}
/*#contact #contactform table tr:nth-child(2) td ,
#contact #contactform table tr:nth-child(4) td {
	border-bottom:none;
}*/
#contact #contactform table tr:nth-child(3) td ,
#contact #contactform table tr:nth-child(5) td {
	border-top:none;
}
#contact #contactform .buttons {
	text-align:center;
	margin-top:20px;
}
#contact #contactform .buttons input {
	margin:0 20px;
	border-width:1px;
	padding:4px 10px;
}

.hikariOrder {
margin: 20px 0 0;
text-align: center;
}


@media screen and (max-width: 1199px){

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
.swiper {
	margin: 0 10px;
	padding: 0 0 40px;
}

#indexNews {
	margin: 20px 20px 0;
}

#indexNews:before {
	height: 160px;
	right: 50%;
}

#indexNews .inner {
	display: block;
	width: 100%;
}

#indexNews .inner .title {
	padding: 30px 0 0;
	width: 100%;
}

#indexNews .title:before {
	display: none;
}

#indexNews .title h2 {
	margin: 0 0 20px;
	font-size: 24px;
}

#indexNews .title h2 span {
	display: inline-block;
	margin-left: 10px;
	font-size: 18px;
}

#indexNews .cont {
	width: 100%;
	margin: 40px 0 60px;
}

#indexServices {
	background-color: #FBFBEC;
	padding: 40px 0 20px;
}

#indexServices:before {
	display: none;
}

#indexServices h2 {
	font-size: 24px;
}

#indexServices h2 span {
	font-size: 18px;
}

#indexServices .main {
	display: block;
	margin: 0 30px;
}

#indexServices .main div {
	width: 100%;
	margin: 0 0 30px;
}

#indexServices .main div ul {
	display: block;
}

#indexServices .main div ul li {
	width: 100%;
	background-size: 12px;
}

#indexServices .main div ul li a {
	padding: 0 16px;
}

#indexServices .main div:nth-child(2) {
	width: 100%;
	margin: 0 0 30px;
}

#indexServices .pickup ul {
	width: 90%;
	margin: 0 auto;
	display: block;
}

#indexServices .pickup ul li {
	text-align: center;
	margin: 0 0 20px;
}

#indexSns {
	width: 100%;
	padding: 60px 0 60px;
}

#indexSns h2 {
	font-size: 24px;
}

#indexSns h2 span {
	font-size: 18px;
}

#indexHyouka {
	width: 94%;
	margin: 0 auto 60px;
}

#indexServices .indexHfc {
	width: calc( 100% - 60px);
	margin: 0 30px 60px;
	background-color: #FFF;
	border: 1px solid #BBBBBB;
	padding: 20px 10px 30px;
	position: relative;
}

#indexServices .indexHfc h3 {
	text-align: center;
}

#indexServices .indexHfc h3 span {
	display: block;
	margin: 4px 0 0 ;
}

#indexServices .indexHfc ul {
	margin: 0 0 0 10px;
}

#indexServices .indexHfc ul li {
	background-size: 12px;
}

#indexServices .indexHfc ul li a {
	padding: 0 16px;
	text-decoration: none;
	color: #111;
}



/*------------------------------------------------------------------------------------------------
  maintenance
--------------------------------------------------------------------------------------------------*/
.kaminariAtten {
	margin: 0 0 60px;
}

/*------------------------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------------------------*/
.companyTb th {
	display: block;
	width: 100%;
	padding-left: 30px;
	background-color: #F9F9F9;
}

.companyTb th:before {
	right: unset;
	left: 4px;
}

.companyTb td {
	display: block;
	width: 100%;
	padding-left: 30px;
}

.clauseList {
	margin: 0 0 40px;
}

.endService {
	width: 100%;
}

.formPaper li dt a {
	display: block;
	background-size: 10px;
	margin: 0 0 4px;
	background-position: 0 6px;
	padding: 0 0 0 12px;
	font-size: 16px;
}

.formPaper li dd {
	margin-left: 0;
}

.psDl dt {
	padding: 0 0 4px;
}

ol.cnt {
	padding: 0 0 0 20px;
}

.contactTarget dd ul {
	padding: 0 20px;
}

.contactTarget dd ul li {
	background-position: 0 5px;
}

#second .contents .contactWrap2 {
	font-size: 16px;
}

#second .contents .contactWrap2 dl {
	display: block;
}

#second .contents .contactWrap2 dl dt {
	width: 100%;
	margin: 0 0 20px;
}

.chTb td:first-child {
	width: 180px;
}

/*------------------------------------------------------------------------------------------------
  hikari
--------------------------------------------------------------------------------------------------*/
.PlanBs {
	width: 100%;
}

.Plan2 {
	display: block;
	width: 100%;
}

.Plan2 .pack, .Plan2 .bic {
	width: 100%;
	margin: 0 0 30px;
}

.hfcbox-01 {
	background-color: transparent;
}

.hfcbox-01 th {
	display: block;
	width: 100%;
}

.hfcbox-01 td {
	display: block;
	width: 100%;
	background-color: #F3F3F3;
}

.hfcbox-01 table th {
	width: 100%;
}

.hfcbox-01 table td.charge {
	width: 100%;
	margin: 0 0 20px;
}

.newstbBox {
	width: 100%;
}

.newstbBox div {
	width: 100%;
}

.newstbBox div:before {
	height: 28px;
}

.stbStop {
	display: block;
}

.stbStop li {
	width: 100%;
	margin-bottom: 20px;
}

.hikari_charge {
	width: 100%;
}

.hikaricharge01 th,
.hikaricharge02 th,
.hikaricharge03 th,
.hikaricharge04 th {
	width: 60%;
	letter-spacing: 0;
	font-weight: 500;
	font-size: 16px;
}

.hikaricharge01 td span,
.hikaricharge02 td span,
.hikaricharge03 td span,
.hikaricharge04 td span {
 display: block;
}

.servicePoint {
	margin: 0 0 20px;
}

.servicePointNum {
	padding: 15px 0 0 12px;
}

.nhkannounce {
	font-size: 16px;
}

.nhkPhone dl dd span {
	display: block;
	font-size: 16px;
}

.serviceList {
	width: 100%;
}

.netFee th {
	display: block;
	width: 100%;
}

.netFee td {
	display: block;
	width: 100%;
}

.netFeature h4 {
	padding-bottom: 6px;
	line-height: 1.2;
	background-position: 0 7px;
}

.rooterRental {
	font-size: 20px;
}

.talkPlan {
	display: block;
}

.talkPlan li {
	width: 100%;
	margin: 0 0 20px;
}

.talkOption .info {
	display: block;
}

.talkOption .info .text {
	width: 100%;
}

.talkOption .info .fee {
	width: 100%;
	text-align: right;
}

.talktcharge {
	width: 100%;
	margin: 0 0 10px;
}

.talkbefore ul li {
	width: 46%;
	margin: 0 auto;
}


.talkOption .info .fee dl {
	margin: 10px 0 0;
}

.talkOption .info .fee dl dt {
	text-align: left;
}

.talkOption .info .fee dl dd {
	text-align: left;
}

.talkteki {
	margin: 0 0 30px;
}

.campaignWrap {
	width: 96%;
	margin: 0 auto;
}

.campaignWrap .orderBtn {
	width: 100%;
}

.waribiki {
	width: 90%;
}

#second .PlanBs h3,
#second .Plan2 h3 {
font-size: 20px;
}

.newstbBox p.image {
padding-top: 20px;
}

#second .newstbBox div h3 {
font-size: 18px;
}

.channelAllList li,
.channelAllList li.lg {
width: 48%;
margin: 0 1% 16px;
}

.channelAllList li:nth-child(4n-2) {
margin: 0 1% 16px;
}

#contact .hikariWrap table {
width: 100%;
margin: 0 0 30px;
}

.hikariWrap table th {
display:block;
width: 100%;
}

.hikariWrap table td {
display:block;
width: 100%;
}

.hikariWrap table td input[type=text],
.hikariWrap table td textarea {
width: 100%;
font-size: 16px;
}

.htalkfee {
	width: 100%;
	margin: 0 0 10px;
}

.htalkfee th {
	display: block;
	width: 100%;
}
	
.htalkfee td {
	display: block;
	width: 100%;
	font-size: 24px;
}




/*------------------------------------------------------------------------------------------------
  shintiku
--------------------------------------------------------------------------------------------------*/
.campaignWrap .flow:before,
.campaignWrap .flow:after {
	display: none;
}


/*------------------------------------------------------------------------------------------------
  speaker
--------------------------------------------------------------------------------------------------*/
.speakerWrap {
	width: 96%;
	margin: 0 auto;
}

.speakerWrap .osusume p span {
	display: block;
}

.speakerWrap .contact {
	margin: 80px 0 70px;
}

.speakerWrap .contact p.tit {
	width: 100%;
}

.speakerWrap .contWrap {
	display: block;
}

.speakerWrap .contWrap div {
	width: 100%;
}

.speakerWrap .contWrap div dt {
	background: none;
}

.speakerWrap .contWrap div dt img {
	display: inline-block;
	margin-right: 10px;
}

.speakerWrap .contWrap div dd {
	text-align: center;
}

.speakerWrap .contWrap div:nth-child(2) {
	margin-left: 16px;
}

/*------------------------------------------------------------------------------------------------
  wifi
--------------------------------------------------------------------------------------------------*/
.wifiRental {
	width: 96%;
	margin: 0 auto;
}

.wifiRental .wrap01 {
	display: block;
}

.wifiRental .wrap03 dl {
	font-size: 20px;
}

.wrap03 p {
	text-align: left;
}

.wifiRental .wrap04 .price01 {
	width: 100%;
}

.wifiRental .wrap04 .price02 {
	width: 100%;
	display: block;
}

.wifiRental .wrap04 .price02 div {
	width: 100%;
	margin: 0 0 10px;
}

.wifiRental .wrap05 .cont {
	display: block;
}

.wifiRental .wrap05 .cont .text {
	width: 100%;
	margin-top: 20px;
}

.wifiRental .wrap04 .kakaku {
	font-size: 40px;
}


/*------------------------------------------------------------------------------------------------
  hfc
--------------------------------------------------------------------------------------------------*/
.hfcNetDl dd div {
	margin: 0 20px;
}

.hfcNetTb th {
	white-space: nowrap;
}

.channel02 tr td.j {
	width: auto;
}

.channelTb tr td.j {
	width: auto;
}

.channel03 tr td.pr {
	width: auto;
}
.channel04 tr td.pr {
	width: auto;
}

.hfcNetDl dd {
	display: block;
}

.hfcNetDl dd div {
	margin: 0 0 10px;
}

/*------------------------------------------------------------------------------------------------
  support
--------------------------------------------------------------------------------------------------*/
.internetFaqMenu li {
	width: 100%;
	margin: 0 0 10px;
}

.internetFaqMenu li a {
	width: 100%;
}

.internetFaqMenu li.noTel {
	width: 100%;
}

.faq h3 {
	background-size: 20px;
	background-position: 6px 6px;
	font-size: 16px !important;
	padding: 6px 8px 6px 30px !important
}

.faqMokuji {
	margin: 0 0 60px;
}

.faqMokuji li a {
	padding: 14px 8px 13px 24px;
}

.noanswer a {
	width: 100%;
}

.faqOnu {
	display: block;
}

.faqOnu .onuImage {
	width: 100%;
}

.faqOnu .onuInfo {
	width: 100%;
}

.faq .btn2 a {
	margin: 0 0 20px;
}


}

