
* {
  margin: 0;
  padding: 0;
}
body {
  width: 100%;
  margin: 0;
  font: 14px "Noto Sans JP","Hiragino Sans","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","Yu Gothic",YuGothic,"メイリオ",Meiryo,"ＭＳ Ｐゴシック",sans-serif;
  color:#434343;
}


a {
	color:#3d4145;
}

a:hover {
	opacity:0.8;
}



br.pc {
  display:block;
}

br.sp {
  display:none;
}

img.pc {
  display:block;
}

img.sp {
  display:none;
}


@media screen and (max-width: 768px) {

br.pc {
  display:none;
}

br.sp {
  display:block;
}


img.pc {
  display:none;
}

img.sp {
  display:block;
}

}



.main img,
.photo img {
	max-width: 100%;
	height: auto;
}


.main .main_copy span {
	display:none;
}

section {
	display:block;
	width: 90%;
	max-width: 1200px;
	margin: 50px auto;
	background:#fff;
}

section#category01 {
    padding-top: 100px;
    margin-top:-100px;
}

section#category02 {
    padding-top: 100px;
    margin-top:-100px;
}

section#category03 {
    padding-top: 100px;
    margin-top:-100px;
}

section#category04 {
    padding-top: 100px;
    margin-top:-100px;
}

section img {
	display:block;
	width: 80%;
	margin: 50px auto;
}

@media (max-width: 768px){
	section img {
		display:block;
		width: 100%;
		margin: 50px auto;
	}
}


h2 {
	display:block;
	font-size:32px;
	color:#3d4145;
	border:solid 1px #3d4145;
	margin:0 auto 30px;
	padding:15px 0;
	text-align:center;
	font-weight: bold;
}

@media (max-width: 768px){
	h2 {
		display:block;
		font-size:24px;
		color:#3d4145;
		border:solid 1px #3d4145;
		margin:0 auto 30px;
		padding:15px 3px;
		text-align:center;
		font-weight: bold;
	}
}

h3 {
	display:block;
	font-size:26px;
	color:#000;
	margin:0 auto;
	padding:15px 0;
	text-align:left;
	font-weight: bold;
}

@media (max-width: 768px){
	h3 {
		display:block;
		font-size:20px;
		color:#000;
		margin:0 auto;
		padding:15px 0;
		text-align:left;
		font-weight: bold;
	}
}

h3 span{
	font-size:22px;
	color:#fff;
	margin:0 10px 0 0;
	padding:5px 10px;
	text-align:center;
	font-weight: bold;
	background:#3d4145;
}

@media (max-width: 768px){
	h3 span{
		display:block;
		font-size:16px;
		color:#fff;
		margin:0 0 10px 0;
		padding:5px 10px;
		text-align:center;
		font-weight: bold;
		background:#3d4145;
	}
}
p.explain {
		font-size: 18px;
		color: #000;
		line-height: 200%;
		margin:0 0 20px 0;
		padding:0;
}


@media (max-width: 768px){
	p.explain {
			font-size: 16px;
			color: #000;
			line-height: 200%;
	}
}

p.notice {
		font-size: 14px;
		color: #000;
		line-height: 200%;
}


p.lead {
		font-size: 20px;
		color: #000;
		line-height: 200%;
}

@media (max-width: 768px){
	p.lead {
		font-size: 16px;
		font-weight: bold;
		color: #000;
		line-height: 200%;
	}
}


/**********カテゴリー　メニュー****************/

.block-area {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0 0 30px;
	padding: 0;
}
.block-area li {
	flex: 0 1 24%;
	margin: 0 1% 30px 0;
	padding: 0 0 20px 0;
	background: #fff;
	list-style-type:none;
}

.block-area li:last-child {
	margin: 0 0 30px 0;
}



.block-area img {
	width: 100%;
	margin: 0 auto 10px;
	padding: 0;
}


.block-area a:hover {
	opacity:0.7;
}


@media (max-width: 768px){
.block-area {
	display: none;
}
}

/**********カテゴリー　メニュー****************/


/**********カテゴリー　メニュー　スマホ****************/

.block-area-sp {
	display: none;
}





@media (max-width: 768px){
.block-area-sp {
	display: block;
}

.block-area-sp li {
	flex: 0 1 100%;
	margin: 0 0 10px 0;
	padding: 0;
	background: #fff;
	list-style-type:none;
}


.block-area-sp img {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}


.block-area-sp a:hover {
	opacity:0.7;
}

}

/**********カテゴリー　メニュー スマホ****************/


/**********リンク　メニュー****************/

.link-area {
	display: flex;
  justify-content: center;
	flex-wrap: wrap;
	list-style: none;
	margin: 0 0 30px;
	padding: 0;
}
.link-area li {
	flex: 0 1 80%;
	margin: 0 0 10px 0;
	padding: 0 0 0 0;
	background: #fff;
	list-style-type:none;
	font-size:16px;
}

.link-area li:last-child {
	margin: 0 0 0 0;
}



.link-area img {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}


.link-area a:hover {
	opacity:0.7;
}


@media (max-width: 768px){
.link-area {
	display: block;
}
.link-area li {
	flex: 0 1 100%;
	margin: 0;
	padding: 0;
	background: #fff;
	list-style-type:none;
}
}

/**********リンク　メニュー****************/

/*============================
header style
============================*/
#top-head {
  width: 100%;
  height: 80px;
  background: #fff;
  opacity: 1;
  display: flex;
  position: fixed;
  z-index: 999;
  margin-top: -65px;


}
#top-head .inner {
  float: left;
  width: 96%;
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
/*logo style*/
.inner div a {
  color: #20b2aa;
  text-decoration: none;
  font-weight: bold;
}

.inner div a img {
  width: 200px;
  margin: 0 auto;

}

/*nav style*/
#top-head nav ul {
  display: flex;
  list-style-type: none;
}
/*nav link style*/
#top-head nav ul li a {
  text-decoration: none;
  padding: 16px 5px ;
  color: #000;
  margin: 0 30px 0 0px;
  text-align:left;
  display: block;
 font-size:14px;

}
#top-head nav ul li a:hover {
  color: #fff;
  background: #3d4145;
}

#top-head nav ul li a.on {
  border-bottom:solid 2px #3d4145;
}

#nav_toggle {
  display: none;
}
img {
  margin-top: 60px;
  width: 100%;
}

@media screen and (max-width:1366px) {
#top-head nav ul li a {
 font-size:13px;
  margin: 0 8px 0 0px;
}
}

@media screen and (max-width:1200px) {
#top-head nav ul li a {
 font-size:12px;
  margin: 0 5px 0 0px;
}

.inner div a img {
  width: 140px;
  margin: 0 auto;

}
}

@media screen and (max-width:1000px) {
#top-head nav ul li a {
 font-size:11px;
  padding: 16px 2px ;
}

.inner div a img {
  width: 120px;
  margin: 0 auto;

}
}

/*============================
mobile style
============================*/
@media screen and (max-width:768px) {
/*hamburger menu style*/
  #nav_toggle {
    display: block;
    width: 30px;
    height: 30px;
    position: relative;
    top: 4px;
    z-index: 100;
  }
  #nav_toggle div {
    position: relative;
  }
/*hamburger menu close style*/
  #nav_toggle span {
    display: block;
    height: 2px;
    background: #404040;
    position:absolute;
    width: 100%;
    left: 0;
    -webkit-transition: 0.5s ease-in-out;
    -moz-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
  }
  #nav_toggle span:nth-child(1) {
    top:0px;
  }
  #nav_toggle span:nth-child(2) {
    top:10px;
  }
  #nav_toggle span:nth-child(3) {
    top:20px;
  }
/*hamburger menu open style*/
  .open #nav_toggle span:nth-child(1) {
    top: 10px;
    -webkit-transform: rotate(135deg);
    -moz-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  .open #nav_toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #nav_toggle span:nth-child(3) {
    top: 10px;
    -webkit-transform: rotate(-135deg);
    -moz-transform: rotate(-135deg);
    transform: rotate(-135deg);
  }
/*nav style*/
  #top-head nav {
    display: none;
    position: absolute;
    top: 60px;
    left: 0;
    width: 100%;
    height: 1040px;
    background: #fff;
    z-index: 999;
  }
  #top-head nav ul {
    display: block;
    width: 100%;
  }
  #top-head nav ul li {
    text-align: center;
    border-bottom: 1px solid #dcdcdc;
  }

/*nav link style*/
  #top-head nav ul li a {
    display: block;
 font-size:14px;
  margin:0 0 0 10px;

  }
}


a.btn{
  position: relative;
  display: block;
  border-radius: 5px;
  background-color: #3d4145;
  padding: 20px 0;
  margin:40px 0 0 0;
  text-align: center;
  color: white;
  width: 100%;
  font-size: 18px;
  cursor: pointer;
  text-decoration:none;
}

a.btn:after{
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  width: 6px;
  height: 6px;
  margin: -4px 0 0 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

a.btn:hover {
	opacity:0.8;
}


@media screen and (max-width: 768px) {
a.btn{
  position: relative;
  display: block;
  border-radius: 5px;
  background-color: #3d4145;
  padding: 10px 0 15px;
  margin:20px auto;
  text-align: center;
  color: white;
  max-width: 360px;
  font-size: 12px;
  cursor: pointer;
  text-decoration:none;
}
}


.page-top {
    position: fixed;
    bottom: 10px;
    right: 10px;
    font-size: 77%;
    z-index:9999;
    opacity: 0.7;
    text-indent:-9999px;
}
.page-top a {
  background: url(/ssp/digik/viera/images/pagetop.png) center/80% no-repeat;
    text-decoration: none;
    color: #fff;
    width: 60px;
    padding: 30px 0;
    text-align: center;
    display: block;
}
.page-top a:hover {
    text-decoration: none;
    opacity: 0.7;
}

@media print, screen and (min-width: 768px) {
.page-top {
    bottom: 20px;
    right: 20px;
}
.page-top a {
  background: url(/ssp/digik/viera/images/pagetop.png) center/80% no-repeat;
    width: 80px;
}
.page-top a:hover {
    text-decoration: none;
    opacity: 0.7;
}
}


footer {
  display: block;
	width: 100%;
	background-color: #000;
	margin: 0 auto;
	padding: 10px 0;
	color:#fff;
	text-align:center;
}

footer img.logo {
	width: auto;
	margin: 30px auto;
	display: block;
}

footer small {
	font-size:12px;
}


.scroll{
overflow: auto;
white-space: nowrap;
  -webkit-overflow-scrolling: touch;
	margin-bottom:30px;
}

.scroll::-webkit-scrollbar{
height: 5px;
}
.scroll::-webkit-scrollbar-track{
background: #F6F6F6;
}
.scroll::-webkit-scrollbar-thumb {
background: #C2C2C2;
}

.scroll table{
	width: 100%;
	margin:0 auto 10px;

}

.scroll .notice{
display: none;
}

@media screen and (max-width: 900px) {
.scroll .notice{
display: block;
width: 100%;
margin:0 auto 5px;
font-size: 12px;
color:#3d4145;
}
}


/*テーブル02*/

table.base02 {
	width: 100%;
	border: #a0a0a0 solid 1px;
	border-collapse:collapse;
	margin: 20px auto 50px;
}

table.base02 th {
	font-size: 16px;
	background: #ddd;
	border: #a0a0a0 solid 1px;
	padding: 15px 0;
	line-height: 180%;
	vertical-align: middle;
}

table.base02 th.w1 {
	width: 22%;
}

table.base02 th.w2 {
	width: 13%;
}

table.base02 th.c1 {
	background: #eeeeee;
	font-weight:normal;
}

@media screen and (max-width: 900px) {

	table.base02 {
	width: 100%;
	border: #a0a0a0 solid 1px;
	border-collapse:collapse;
	margin: 20px auto 20px;
}

	table.base02 th {
		font-size: 14px;
		padding: 10px 5px;
	}
}

table.base02 td {
	font-size: 16px;
	background: #ffffff;
	border: #a0a0a0 solid 1px;
	padding: 16px 0;
	text-align: center;
	line-height: 150%;
	vertical-align: middle;
}



@media screen and (max-width: 900px) {
	table.base02 td {
		font-size: 11px;
		padding: 18px 5px;
	}
}

	table.base02 td span {
	font-size: 28px;
	line-height: 14px;
}
@media screen and (max-width: 900px) {
	table.base02 td span {
		font-size: 20px;
	}
table.base02 th.c1 {
	font-size: 12px;
}

}

  /* 横スクロール時に固定する */

	table.base02 th.c1 {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
}


.video-box {
	margin:0 auto 30px;
	width:800px;
}
.video{
  display:block;
  position:relative;
  width:100%;
  padding-top:56.25%;
	margin:0 auto 30px;
border:solid #ccc 1px;
}
.video iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}


@media screen and (max-width: 768px) {
.video-box {
	margin:0 auto 30px;
	width:96%;
}
}


.stripe2
{
  position: relative;
  background: rgba(255, 255, 255, 1);
  padding: 12px;
  width: 70%;
  height:350px;
	margin:0 auto 30px;
}

.stripe2::after
{
position: absolute;
    top: -10px; bottom: -10px;
    left: -10px; right: -10px;
    background: repeating-linear-gradient(45deg, #ccc, #ccc 5px, white 5px, white 10px);
    background-color: black;
    content: '';
    z-index: -1;
}


h2.check {
  position: relative;
  padding: 10px 0 20px;
  border-bottom: 3px solid #3d4145;
  border-left: none;
  border-top: none;
  border-right: none;
	margin-bottom:15px;


}

h2.check:before {
  position: absolute;
  right: 200px;
  bottom: -21px;
  width: 0;
  height: 0;
  content: '';
  border-width: 21px 21px 0 0;
  border-style: solid;
  border-color: #3d4145 transparent transparent transparent;
}

h2.check:after {
  position: absolute;
  right: 204px;
  bottom: -14px;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 14px 0 0;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

@media screen and (max-width: 768px) {
.stripe2
{
  position: relative;
  background: rgba(255, 255, 255, 1);
  padding: 12px 3%;
  width: 90%;
  height:260px;
	margin:0 auto 30px;
}

h2.check {
  position: relative;
  padding: 10px 0 20px;
  border-bottom: 3px solid #3d4145;
  border-left: none;
  border-top: none;
  border-right: none;
	margin-bottom:30px;


}


h2.check:before {
  position: absolute;
  right: 100px;
  bottom: -21px;
  width: 0;
  height: 0;
  content: '';
  border-width: 21px 21px 0 0;
  border-style: solid;
  border-color: #3d4145 transparent transparent transparent;
}

h2.check:after {
  position: absolute;
  right: 104px;
  bottom: -14px;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 14px 0 0;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

}

/* *******************************/



.contents-area {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0 0 30px;
	padding: 0;
}

/* *******************************/

.contents-grid li {
	flex: 0 1 33.3333%;
}


.contents-area img {
	display:block;
	width: 100%;
	margin: 0 auto 15px;
	padding: 0;
}

/* *******************************/


@media (max-width: 768px){
	.contents-grid li {
		flex: 0 1 100%;
	}


}


.btn-a,
a.btn-a,
button.btn-a {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 0;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

/*背景*/
.btn-wrap {
  margin: 20px auto;
	width:50%;
}

a.btn-c {
  font-size: 18px;

  position: relative;

  padding: 1.5rem 9.5% 1.5rem 9.5%;

  color: #000;
  border: 2px solid #000;
  border-radius: 100vh;
  background: #fff100;
  -webkit-box-shadow: 0 5px 0 #e6d900;
  box-shadow: 0 5px 0 #e6d900;
  margin: 20px auto;
	width:80%;

}

a.btn-c span {
  font-size: 16px;
  line-height: 1.3;

  position: absolute;
  top: -10px;
  left: -20px;

  width: 64px;
  height: 64px;
  padding-top: 15px;

  -webkit-transition: all 0.3s;

  transition: all 0.3s;

  color: #000;
  border: 2px solid #000;
  border-radius: 65%;
  background: #fff;
}

a.btn-c span em {
  font-style: normal;

  color: #d20010;
}

a.btn-c small {
  font-weight: bold;
}

a.btn-c i {
  margin-right: 1rem;
}

a.btn-c:hover {
  -webkit-transform: translate(0, 3px);
  transform: translate(0, 3px);

  color: #000;
  background: #fff21a;
  -webkit-box-shadow: 0 2px 0 #e6d900;
  box-shadow: 0 2px 0 #e6d900;
}

a.btn-c:hover span {
  -webkit-transform: translate(0, -5px);
  transform: translate(0, -5px);
}




@media (max-width: 768px){

.btn-wrap {
  margin: 20px auto;
	width:100%;
}

a.btn-c {
  font-size: 14px;
  padding: 0.6rem 9.5% 0.6rem 9.5%;
margin-top:0px;
}
}

h4 {
  font-size: 30px;
  color:#3d4145;
  position: relative;
  padding: 26px;
margin-top:100px;
  text-align: center;
  border-top: 1px solid #3d4145;
  border-left: 1px solid #3d4145;
  border-right: 1px solid #3d4145;
  background: #f5f5f5;
}

h4:before,
h4:after {
  position: absolute;
  content: '';
}

h4:before {
  top: -50px;
  left: calc(50% - 40px);
  width: 80px;
  height: 80px;
  border: 1px solid #3d4145;
  border-radius: 50%;
  background: #f5f5f5;
}

h4:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #f5f5f5;
}

h4 i {
  font-size: 50px;
  line-height: 60px;
  position: absolute;
  z-index: 1;
  top: -40px;
  left: calc(50% - 40px);
  width: 80px;
  height: 60px;
  text-align: center;
}

h4 span {
  position: relative;
  z-index: 1;
}


.point-box {
  border: 1px solid #3d4145;
  border-top: none;
  padding: 20px 50px 20px;
margin:-20px 0 50px 0;
  background: #f5f5f5;
}


@media (max-width: 768px){

h4 {
  font-size: 20px;
}


h4 i {
  font-size: 40px;
  line-height: 60px;
  position: absolute;
  z-index: 1;
  top: -40px;
  left: calc(50% - 40px);
  width: 80px;
  height: 60px;
  text-align: center;
}

.point-box {
  border: 1px solid #3d4145;
  border-top: none;
  padding: 20px 20px 20px;
margin:-20px 0 50px 0;
}



}




