@charset "utf-8";
/* =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
	PT19
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= */
/* =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

	RESET

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	border-width: 0px;
	outline: none;
}

html {
//	-webkit-font-smoothing: antialiased;
//	-moz-osx-font-smoothing: grayscale;

	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
	text-rendering: optimizeLegibility;
	font-feature-settings: "pwid" 1;
}
body {
	font-family: Arial, "Helvetica Neue", "Noto Sans JP", sans-serif;
	color: #333;
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 1.8em;
	font-weight: 400;
	margin-top: 60px;
}
h1 {
	font-size: 200%;
	font-weight: 800;
}
h2 {
	font-size: 150%;
	font-weight: 600;
}
h3 {
	font-size: 140%;
	font-weight: 600;
}
h4 {
	font-size: 120%;
	font-weight: 600;
}

ul,li {
	list-style-type: none;
	list-style-position: outside;
}

table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0px;
}
table th, table td {
	text-align: left;
	vertical-align: top;
	padding: 10px 10px;
}

a:hover {
	opacity: 0.7;
}

main {
	display: block;
	margin: 0 auto;
}

::placeholder{
  color:#bbb;
}
.clearfix:after {
	content: ".";
	display: block;
	height: 0px;
	font-size: 0px;
	clear: both;
	visibility: hidden;
}

.pcdisp {
	display: block;
}
.spdisp {
	display: none;
}

@media screen and ( max-width: 790px ) {
	body {
		font-size: 14px;
		margin-top: 80px;
	}
	.pcdisp {
		display: none;
	}
	.spdisp {
		display: block;
	}
}

/* =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

	COMMON

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= */

/* ---------------------------
	HEADER
--------------------------- */
header {
	width: 100%;
	height: 60px;
	background-color: rgba(248,181,0,0.9);
	box-shadow: 0 1px 2px rgba( 0,0,0, 0.4 );
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
}

header h1 {
	font-size: 0px;
	font-weight: 400;
	padding-top: 0;
	padding-left: 20px;
	transform-origin: top left;
	transform: scale(0.7);
}
header h1 img {
	width: auto;
	height: 30px;

}

header .icon {
	position: absolute;
	top: 20px;
	right: 90px;
	width: auto;
	text-align: right;
	transform-origin: top right;
	transform: scale(0.7);
}
header .icon a {
	display: inline-block;
	width: 75px;
	font-size: 70%;
	text-align: center;
	line-height: 1.5em;
	letter-spacing: -1px;
}
header .icon a img {
	width: auto;
	height: 40px;
}

header #btnMenu {
	width: 40px;
	height: 40px;
	cursor: pointer;
	position: absolute;;
	top: 20px;
	right: 20px;
	z-index: 1100;
	transform-origin: top right;
	transform: scale(0.7);
}
header #btnMenu p {
	margin: 0;
	width: 40px;
	height: 22px;
	border-bottom: 4px solid #000;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1050;
}
header #btnMenu p:before {
	display: block;
	content: '';
	width: 40px;
	height: 0px;
	border-top: 4px solid #000;
	position: absolute;
	top: 0;
	left: 0;
	transition-property: transform width;
	transition-duration: 0.2s;
}

header #btnMenu p:after {
	display: block;
	content: '';
	width: 40px;
	height: 0px;
	border-top: 4px solid #000;
	position: absolute;
	top: 38px;
	left: 0;
	transition-property: transform width;
	transition-duration: 0.2s;
}

header #btnMenu.open p {
	border-width: 0;
}
header #btnMenu.open p:before {
	width: 55px;
	top: 16px;
	left: -8px;
	transform: rotate( -45deg );
}
header #btnMenu.open p:after {
	width: 55px;
	top: 16px;
	left: -8px;
	transform: rotate( 45deg );
}

@media screen and ( max-width: 790px ) {
	header {
		background-color: #f8b500;
		box-shadow: 0 1px 2px rgba( 0,0,0, 0.6 );
		height: 80px;
	}
	header h1 {
		font-size: 10px;
		padding-left: 10px;
		padding-top: 15px;
		transform: scale(1);
	}

	header h1 img {
		height: 20px;
	}


	header .icon {
		top: 28px;
		right: 50px;
		transform: scale(1);
	}

	header .icon a {
		width: 45px;
	}

	header .icon a img {
		height: 30px;
	}

	header #btnMenu {
		transform: scale(1);
	}
	header #btnMenu.open p {
		border-width: 0;
	}

	header #btnMenu.open p:before {
		width: 55px;
		top: 16px;
		left: -8px;
		transform: rotate( -45deg );
	}

	header #btnMenu.open p:after {
		width: 55px;
		top: 16px;
		left: -8px;
		transform: rotate( 45deg );
	}

	header #btnMenu {
		width: 25px;
		height: 25px;
		top: 30px;
		right: 10px;
	
	}
	header #btnMenu p {
		width: 25px;
		height: 13px;
		border-bottom: 2px solid #000;
	}
	header #btnMenu p:before {
		width: 25px;
		border-top: 2px solid #000;
	}
	
	header #btnMenu p:after {
		width: 25px;
		height: 0px;
		border-top: 2px solid #000;
		top: 23px;
	}
	header #btnMenu.open p {
		border-width: 0;
	}
	header #btnMenu.open p:before {
		width: 30px;
		top: 12px;
		left: -1px;
		transform: rotate( -45deg );
	}
	header #btnMenu.open p:after {
		width: 30px;
		top: 12px;
		left: -2px;
		transform: rotate( 45deg );
	}
}

/* ---------------------------
	NAV
--------------------------- */
#nav h3 {
	margin: 0 0 10px 10px;
}
#nav {
	position: fixed;
	top: -100vh;
	left: 0;
	z-index: 995;
	width: 100%;
	padding: 20px;
	background-color: #fff;
	box-shadow: 0 4px 5px rgba( 0,0,0, 0.5 );
	transition-property: top;
	transition-duration: 0.5s;
}
#nav nav>div {
	border-bottom: 1px dotted #888;
	border-right: 1px dotted #888;
	position: relative;
}
#nav nav>div:after {
	display: block;
	content: ">";
	position: absolute;;
	top: 10px;
	right: 10px;
	color: #888;
	transform: scaleY( 1.5 );
}

#nav nav>div.blank:before {
	display: block;
	content: "";
	position: absolute;;
	top: 14px;
	right: 10px;

	width: 15px;
	height: 12px;
	border: 1px solid #333;
	background-color: #fff;
}

#nav nav>div.blank:after {
	display: block;
	content: "";
	position: absolute;;
	top: 10px;
	right: 14px;

	width: 15px;
	height: 12px;
	border: 1px solid #333;
	background-color: #fff;
}

#nav nav>div a {
	display: block;
	padding: 8px 10px;
	text-decoration: none;
	color: #333;
	font-size: 110%;
	font-weight: 500;
}
#nav nav>div a:hover {
	background-color: #eee;
}
#nav nav>div img {
	width: auto;
	height: 25px;
	margin-right: 20px;
}


@media screen and ( max-width: 790px ) {
	#nav {
		padding: 10px 20px;
	}
	#nav nav>div a {
		padding: 10px 20px;
		font-size: 120%;
	}
}


/* ---------------------------
	クラスリンク
--------------------------- */
.linkClass2 {
	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
	margin-top: 40px;
	max-width: 1200px;
	margin: 40px auto 0;
	width: 80%;
}
.linkClass2 a {
	display: block;;
	width: 31%;
	margin: 0 1%;
	color: #fff;
	text-decoration: none;
	padding: 10px;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
}
.linkClass2 a.e {
	background: url( /img/common/bg_linkClass_e.jpg ) no-repeat;
	background-origin: 50% 50%;
	background-size: cover;
}
.linkClass2 a.j {
	background: url( /img/common/bg_linkClass_j.jpg ) no-repeat;
	background-origin: 50% 50%;
	background-size: cover;
}
.linkClass2 a.h {
	background: url( /img/common/bg_linkClass_h.jpg ) no-repeat;
	background-origin: 50% 50%;
	background-size: cover;
}
.linkClass2 a.k {
	background: url( /img/common/bg_linkClass_k.jpg ) no-repeat;
	background-origin: 50% 50%;
	background-size: cover;
}
.linkClass2 a div {
	border: 1px solid #fff;
	text-align: center;
	position: relative;
	text-shadow: 0 -1px 0 #000;
	padding: 50px 0 40px;
}
.linkClass2 a div:after {
	content: '>';
	color: rgba(255,255,255,0.7 );
	display: block;
	position: absolute;
	right: 10px;
	top: 45%;
	font-weight: 100;
	transform-origin: 50% 50%;
	transform: scaleY( 2 );
}
.linkClass2 a div .p1 {
	font-size: 200%;
	font-weight: 600;
	line-height: 1em;
	margin-bottom: 10px;
}
.linkClass2 a div .p2 {
	font-size: 130%;
	font-weight: 500;
	line-height: 1em;
}
@media screen and ( max-width: 790px ) {
	.linkClass2  {
		width: 95%;
	}
	.linkClass2 a {
		padding: 4px;
	}
	.linkClass2 a div {
		padding: 20px 0 10px;
		text-shadow: 0 0 6px #000;
	}
	.linkClass2 a div:after {
		font-size: 60%;
		right: 5px;
		top: 43%;
	}
	.linkClass2 a div .p1 {
		font-size: 140%;
		font-weight: 800;
		margin-bottom: 5px;
	}
	.linkClass2 a div .p2 {
		font-size: 100%;
	}
}


/* ---------------------------
	問合せ
--------------------------- */
.linkContact2 {
	max-width: none;
	margin: 0 auto;
	background-color: #ffcf4d;
	padding: 150px 0 40px;
	position: relative;
	margin-top: 200px;
}
.linkContact2:before {
	content: '';
	display: block;
	width: 80%;
	height: 92%;
	position: absolute;
	top: 10%;
	left: 10%;
	background-color: #fff;
	z-index: 1;
	border-radius: 10px;
}
.linkContact2>div,
.linkContact2>p,
.linkContact2>a {
	width: 80%;
	max-width: 860px;
	min-width: 790px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 5;
}
.linkContact2 .cont {
	background-color: #00aee8;
	color: #fff;
	padding: 20px;
	margin-bottom: 30px;
}
.linkContact2 .cont .h {
	text-align: center;
	font-size: 150%;
	font-weight: 600;
	position: relative;
	z-index: 10;
	text-shadow: 0px -1px 1px rgba( 0, 0, 0, 0.4 );
	margin-bottom: 10px;
}
.linkContact2 .cont .h:before {
	content: '';
	display: block;
	position: absolute;
	width: 80px;
	height: 80px;
	left: 45%;
	top: -80px;
	background: url( /img/common/icon_cont.png ) no-repeat;
	background-size: 80px 80px;
	opacity: 0.2;
	z-index: 5;
}
.linkContact2 .cont>a {
	display: block;
	float: left;
	width: 48%;
	margin: 1%;
	padding: 20px 20px 15px;
	text-align: center;
	background-color: #fff;
	text-decoration: none;
	color: #333;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
/*
	border: 2px solid #3a00f8;
*/
	border-radius: 10px;
}
.linkContact2 .cont>a .p1 {
	font-size: 180%;
	font-weight: 800;
	line-height: 1em;
	margin-bottom: 8px;
}
.linkContact2 .cont>a.tel .p1 span {
	background: url( /img/common/icon_cont_tel.gif ) no-repeat;
	background-size: 25px 25px;
	background-position: 0px 10px;
	padding-left: 35px;
}
.linkContact2 .cont>a.mail .p1 span {
	background: url( /img/common/icon_cont_mail.gif ) no-repeat;
	background-size: 30px 25px;
	background-position: 0px 10px;
	padding-left: 40px;
	position: relative;
	left: -10px;
}
.linkContact2 .cont>a .p2 {
	font-size: 100%;
	font-weight: 300;
	color: #444;
	letter-spacing: 0;
	line-height: 1em;
}
.linkContact2>p {
	font-size: 90%;
	line-height: 1.5em;
	font-weight: 500;
	margin-bottom: 10px;
}
.linkContact2 .entry {
	display: block;
	background-color: #f83a00;
	color: #fff;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	text-decoration: none;
	padding: 30px 20px 20px 120px;
	position: relative;
	border-radius: 10px;
}
.linkContact2 .entry:after {
	content: '';
	display: block;
	position: absolute;
	width: 50px;
	height: 50px;
	left: 40px;
	top: 50px;
	background: url( /img/common/icon_cont_pen.gif ) no-repeat;
	background-size: 50px 50px;
}
.linkContact2 .entry .p1 {
	font-size: 160%;
	font-weight: 800;
	text-shadow: 0 -1px 0 rgba( 0,0,0,0.1 );
	text-align: center;
	padding-bottom: 20px;
	border-bottom: 1px solid #f2f2f2;
	margin-bottom: 20px;
}
.linkContact2 .entry .p2 {
	font-size: 120%;
	font-weight: 500;
	text-align: center;
}


@media screen and ( max-width: 1100px ) {
	.linkContact2 {
		width: 100%;
		max-width: 960;
		background-color: #fff;
		padding: 0;
		margin-top: 100px;
		margin-bottom: 80px;
	}
	.linkContact2:before {
		display: none;
	}
}
@media screen and ( max-width: 790px ) {
	.linkContact2 {
		width: 100%;
		max-width: 960;
		background-color: #fff;
		padding: 0;
		margin: 100px auto 60px;
	}
	.linkContact2:before {
		display: none;
	}
	.linkContact2>div,
	.linkContact2>p,
	.linkContact2>a {
		width: 95%;
		max-width: auto;
		min-width: auto;
		
	}
	.linkContact2 .cont {
		padding: 20px 10px;
	}
	.linkContact2 .cont .h {
		font-size: 180%;
		margin-bottom: 10px;
	}
	.linkContact2 .cont .h:before {
		width: 40px;
		height: 40px;
		top: -40px;
		background-size: 40px 40px;
	}
	.linkContact2 .cont>a {
		display: block;
		float: left;
		width: 46%;
		margin: 2%;
		padding: 15px 5px 10px;
		border-radius: 5px;
	}
	.linkContact2 .cont>a .p1 {
		font-size: 4.0vw;
		margin-bottom: 5px;
		letter-spacing: 0;
	}
	.linkContact2 .cont>a.tel .p1 {
		transform-origin: bottom;
		transform: scaleY( 1.2 );
	}
	.linkContact2 .cont>a.tel .p1 span {
		background-size: 10px 10px;
		background-position: 0px 50%;
		padding-left: 15px;
	}
	.linkContact2 .cont>a.mail .p1 span {
		background-size: 15px 10px;
		background-position: 0px 50%;
		padding-left: 20px;
		position: relative;
		left: -2px;
	}
	.linkContact2 .cont>a .p2 {
		font-size: 2.2vw;
	}
	.linkContact2 .entry {
		padding: 20px 5% 15px 50px;
		position: relative;
		border-radius: 5px;
	}
	.linkContact2 .entry:after {
		width: 30px;
		height: 30px;
		left: 10px;
		top: 35px;
		background-size: 30px 30px;
	}
	.linkContact2 .entry .p1 {
		font-size: 140%;
		padding-bottom: 5px;
		margin-bottom: 5px;
	}
	.linkContact2 .entry .p2 
	{
		font-size: 120%;
		font-weight: 500;
		text-align: center;
	}
}

/* ---------------------------
	LINE
--------------------------- */
#line {
	background-color: #ffcf4d;
	padding: 60px 0 50px;
	margin: 0 0 150px;
	text-align: center;
}

#line>div {
	width: 80%;
	max-width: 860px;
	min-width: 790px;
	margin: 0 auto;
}
#line>div .h {
	font-size: 120%;
	font-weight: 600;
	border-bottom: 1px solid #888;
	margin-bottom: 30px;
}
#line>div .contents {
	margin-bottom: 40px;
}
#line>div img {
	width: 150px;
	height: auto;
	filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.5));
}
@media screen and ( max-width: 790px ) {
	#line {
		padding: 30px 0;
		margin: 0 0 60px;
	}
	#line>div {
		width: 90%;
		max-width: autox;
		min-width: auto;
		margin: 0 auto;
	}
}
/* ---------------------------
	/LINE
--------------------------- */


/* ---------------------------
	メニュー
--------------------------- */
#menu {
	width: 80%;
	max-width: 1200px;
	margin: 80px auto 80px;
}
#menu a {
	display: block;
	text-decoration: none;
	color: #333;
	font-size: 120%;
	font-weight: 600;
	border-bottom: 1px solid #bbb;
	padding: 15px 0 10px;
	text-align: center;
	position: relative;
}
#menu a:before {
	content: '>';
	display: block;
	position: absolute;
	color: #888;
	right: 20px;
	top: 10px;
	font-weight: 100;
	font-size: 80%;
	transform: scaleX( 0.7 );
}


@media screen and ( max-width: 790px ) {
	#menu {
		width: 100%;
		margin: 20px auto 40px;
	}
	#contents #menu {
		margin: 20px auto 50px;
	}
}

/* ---------------------------
	tel
--------------------------- */
#tel {
	text-align: center;
	margin-bottom: 60px;
}
#tel a {
	text-decoration: none;
	color: #333;
	font-size: 350%;
	font-weight: 1000;
	position: relative;
}
#tel a:before {
	content: '';
	display: block;
	position: absolute;
	width: 60px;
	height: 60px;
	left: -70px;
	top: 15px;
	background: url( /img/common/icon_tel.gif ) no-repeat;
	background-size: 60px 60px;
}
@media screen and ( max-width: 790px ) {
	#tel {
		margin-bottom: 40px;
	}
	#tel a {
		font-size: 300%;
		left: 15px;
	}
	#tel a:before {
		width: 35px;
		height: 35px;
		left: -40px;
		top: 5px;
		background-size: 35px 35px;
	}
}


/* ---------------------------
	sns
--------------------------- */
#sns {
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
	text-align: right;
	padding-bottom: 60px;
}
#sns img {
	width: 120px;
	height: auto;
}

@media screen and ( max-width: 790px ) {
	#sns img {
		width: 100px;
	}
}

/* ---------------------------
	FOOTER
--------------------------- */
footer {
	background-color: #f8b500;
	padding: 40px 0;
}
footer .school {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
}
footer .school .name {
	font-size: 120%;
	font-weight: 600;
	margin-top: 20px;
}
footer .school .addr a {
	font-weight: 600;
	text-decoration: none;
}
#copy {
	text-align: center;
	padding: 5px 0;
	color: #888;
}

@media screen and ( max-width: 790px ) {
	footer {
		padding: 20px 0;
	}
	footer .school {
		width: 90%;
	}
	footer .school>img {
		width: 50%;
	}
	footer .school .name {
		margin-top: 10px;
	}
	footer .school .addr a {
		font-weight: 600;
		text-decoration: none;
	}
}

/* =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

	TOP

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= */

/* ---------------------------
	重要なお知らせ
--------------------------- */
#top #importantNews {
	border: 4px solid #3a00f8;
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 20px;
	margin-top: 40px;
	margin-bottom: 150px;
	letter-spacing: 0;
}
#top #importantNews h2 {
	color: #3a00f8;
	border-bottom: 1px solid #3a00f8;
	margin-bottom: 20px;
}
@media screen and ( max-width: 790px ) {
	#top #importantNews {
		width: 80%;
		margin-top: 10px;
		margin-bottom: 20px;
	}
}


/* ---------------------------
	特徴
--------------------------- */
#top #feature {
	position: relative;
	margin-top: 200px;
	padding-top: 80px;
	padding-bottom: 20px;
	margin-bottom: 160px;
}
#top #feature:before {
	content: '';
	display: block;
	position: absolute;
	width: 90%;
	height: 100%;
	left: 0;
	top: 0;
	background-color: #f2f2f2;
	z-index: -10;
}
#top #feature:after {
	content: '';
	display: block;
	position: absolute;
	width: 100px;
	height: 100px;
	left: 40px;
	top: -60px;
	background: url( /img/top/icon_feature.gif ) no-repeat;
	background-size: 100px 100px;
}
#top #feature h2 {
	width: 50%;
	border-bottom: 1px solid #888;
	text-align: center;
	margin: 0 auto 100px;
	font-size: 200%;
	padding-bottom: 20px;
}

#top #feature ul {
	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1000px;
	margin: 40px auto 100px;
	padding-bottom: 80px;
}
#top #feature ul:last-child {
	padding-bottom: 0;
	margin-bottom: 80px;
}
#top #feature ul.right {
	flex-direction : row-reverse;
}
#top #feature li.img {
	width: 60%;
	padding: 2%;
}
#top #feature li img {
	width: 100%;
}
#top #feature li.desc {
	width: 40%;
	padding: 2%;
}
#top #feature li.desc h3 {
	margin-bottom: 40px;
}
#top #feature li.desc p {
	margin-bottom: 80px;
	font-weight: 300;
}
#top #feature .desc a {
	display: block;
	text-align: center;
	text-decoration: none;
	color: #fff;
	background-color: #009ed8;
	width: 80%;
	margin: 0 auto;
	padding: 10px 0;
	font-size: 120%;
	font-weight: 500;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	border-radius: 10px;
}

@media screen and ( max-width: 790px ) {
	#top #feature {
		position: relative;
		padding-top: 60px;
		padding-bottom: 0;
		margin-top: 60px;
		margin-bottom: 80px;
	}
	#top #feature:before {
		width: 100%;
	}
	#top #feature:after {
		width: 40px;
		height: 40px;
		left: auto;
		right: 10px;
		top: 10px;
		background-size: 40px 40px;
	}
	#top #feature h2 {
		width: 80%;
		margin: 0 auto 60px;
		font-size: 180%;
		padding-bottom: 10px;
	}
	#top #feature ul {
		display: block;
		margin: 0px auto 0;
		padding-bottom: 60px;
	}
	#top #feature ul:last-child {
		padding-bottom: 40px;
		margin-bottom: 80px;
	}
	#top #feature li.img {
		width: 100%;
		padding: 0 5%;
	}
	#top #feature li img {
		width: 100%;
	}
	#top #feature li.desc {
		width: 100%;
		padding: 2% 5%;
	}
	#top #feature li.desc h3 {
		margin-bottom: 20px;
	}
	#top #feature li.desc p {
		margin-bottom: 40px;
	}
	#top #feature .desc a {
		width: 60%;
		border-radius: 5px;
	}
}


/* ---------------------------
	Youtube動画
--------------------------- */
#top #video {
	position: relative;
	margin-top: 200px;
	padding-top: 80px;
	padding-bottom: 120px;
	margin-bottom: 120px;
}
#top #video:before {
	content: '';
	display: block;
	position: absolute;
	width: 90%;
	height: 100%;
	right: 0;
	top: 0;
	background-color: #f2f2f2;
	z-index: -10;
}
#top #video:after {
	content: '';
	display: block;
	position: absolute;
	width: 100px;
	height: 100px;
	right: 40px;
	top: -60px;
	background: url( /img/top/icon_video.gif ) no-repeat;
	background-size: 100px 100px;
	opacity: 0.3;
}
#top #video h2 {
	width: 50%;
	border-bottom: 1px solid #888;
	text-align: center;
	margin: 0 auto 100px;
	font-size: 200%;
	padding-bottom: 20px;
}

#top #video ul {
	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1000px;
	margin: 40px auto 100px;
	padding-bottom: 20px;
}
#top #video ul li {
	width: 46%;
	height: 25vw;
	margin: 0 2%;
}
#top #video ul li iframe {
	width: 100%;
	height: 20vw;
}
#top #video>a {
	display: block;
	background-color: #ff0000;
	color: #fff;
	text-decoration: none;
	width: 50%;
	height: 70px;
	min-width: 450px;
	text-align: center;
	font-size: 110%;
	font-weight: 600;
	line-height: 70px;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	margin: 0 auto;
	position: relative;
	border-radius: 10px;
}
#top #video>a:after {
	content: '';
	display: block;
	position: absolute;
	width: 40px;
	height: 30px;
	left: 40px;
	top: 20px;
	background: url( /img/top/icon_youtube.gif ) no-repeat;
	background-size: 40px 30px;
}


@media screen and ( max-width: 790px ) {
	#top #video {
		position: relative;
		margin-top: 80px;
		padding-top: 60px;
		padding-bottom: 40px;
		margin-bottom: 40px;
	}
	#top #video:before {
		width: 100%;
	}
	#top #video:after {
		width: 40px;
		height: 40px;
		left: auto;
		right: 10px;
		top: 10px;
		background-size: 40px 40px;
	}
	#top #video h2 {
		width: 80%;
		margin: 0 auto 60px;
		font-size: 180%;
		padding-bottom: 10px;
	}
	#top #video ul {
		width: 90%;
		display: block;
		margin: 0 auto;
		padding: 0 5% 20px;
	}
	#top #video ul li {
		width: 100%;
		height: auto;
		margin-bottom: 40px;
	}
	#top #video ul li iframe {
		width: 100%;
		height: 47vw;
	}
	#top #video>a {
		width: 90%;
		height: 55px;
		font-size: 100%;
		line-height: 55px;
		border-radius: 5px;
		min-width: 0;
	}
	#top #video>a:after {
		width: 25px;
		height: 20px;
		left: 20px;
		top: 17px;
		background-size: 25px 20px;
	}
}


/* =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

	PARTS

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= */
#contents>h2 {
	height: 100px;
}
#contents>p {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 140px;
}
#contents section {
	padding: 40px 0;
	margin-bottom: 100px;
}
#contents section h2 {
	text-align: center;
	font-size: 180%;
	font-weight: 700;
	border-bottom: 1px solid #bbb;
	width: 800px;
	margin: 0 auto 140px;
	padding-bottom: 20px;
}
@media screen and ( max-width: 790px ) {
	#contents section {
		margin-bottom: 60px;
	}
	#contents section h2 {
		border-bottom: 1px solid #bbb;
		width: 75%;
		margin: 0 auto 80px;
		padding-bottom: 10px;
	}
	#contents>h2 {
		height: 40px;
	}
}

/* ---------------------------
	pt01
	プライバシー、特商
--------------------------- */
#contents .pt01 {
	max-width: 1200px;
	margin: 0 auto;
}


@media screen and ( max-width: 790px ) {
	#contents .pt01 {
		max-width: 90%;
		margin: 0 auto;
	}
}


/* ---------------------------
	pt02
	下層MV
--------------------------- */
.pt02 {
	width: 100%;
	height: 200px !important;
	line-height: 200px;
	text-align: center;
	font-weight: 800;
	color: #fff;
	font-size: 250%;
	font-weight: 1000;
	text-shadow: 0 -1px 1px rgba( 0,0,0,0.4 );
	margin-bottom: 80px;
}
.pt02.e {
	background: url( /img/class/e_mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.j {
	background: url( /img/class/j_mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.h {
	background: url( /img/class/h_mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.k {
	background: url( /img/class/k_mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.faq {
	background: url( /img/faq/mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.voice {
	background: url( /img/voice/mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
.pt02.teachers {
	background: url( /img/teachers/mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
	margin-bottom: 0 !important;
}
.pt02.about {
	background: url( /img/about/mv.jpg ) no-repeat;
	background-size: cover;
	background-position: 50% 50%;
}
@media screen and ( max-width: 790px ) {
	.pt02 {
		height: 100px !important;
		line-height: 100px;
		font-size: 180%;
		margin-bottom: 40px;
		letter-spacing: 0;
	}
}


/* ---------------------------
	pt03
	ローカルナビ
--------------------------- */
.pt03 {
	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
	width: 80%;
	max-width: 800px;
	margin: 0 auto 120px;
}
.pt03 a {
	display: block;
	background-color: #009ed8;
	width: 48%;
	margin: 2px;
	color: #fff;
	font-size: 100%;
	font-weight: 600;
	text-decoration: none;
	text-align: center;
	padding: 10px 0;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	position: relative;
	text-shadow: 0 -1px 1px #66b;

}
.pt03 a:before {
	content: '>';
	display: block;
	position: absolute;
	font-weight: 100;
	top: 10px;
	right: 20px;
	transform: rotate( 90deg ) scaleY( 2 );
	transform-origin: 50% 50%;
	opacity: 0.8;
}


@media screen and ( max-width: 790px ) {
	.pt03 {
		width: 95%;
		margin: 0 auto 80px;
	}
}


/* ---------------------------
	pt17
	授業ヘッダ
--------------------------- */
#contents .pt17 {
	width: 90%;
	max-width: 900px;
	margin: 0 auto;
}
#contents .pt17 h3 {
	text-align: center;
	margin-bottom: 20px;
}
#contents .pt17 p {
	margin-bottom: 40px;
}

/* ---------------------------
	pt16
	授業の特徴
--------------------------- */
#contents section.pt16 {
	width: 90%;
	max-width: 800px;
	margin: 0 auto;
}
#contents section.pt16>h3 {
	margin-bottom: 40px;
}
#contents section.pt16>p {
	width: 95%;
	margin: 0 auto 20px;
}
#contents section.pt16>img {
	display: block;
	width: 95%;
	margin: 0 auto 100px;
	border: 1px solid #bbb;
}

#contents section.pt16 a {
	display: block;
	text-align: center;
	text-decoration: none;
	color: #fff;
	background-color: #009ed8;
	width: 80%;
	margin: 0 auto;
	padding: 10px 0;
	font-size: 120%;
	font-weight: 500;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	border-radius: 10px;
}

@media screen and ( max-width: 790px ) {
	#contents section.pt16 a {
		width: 60%;
		border-radius: 5px;
	}
}

/* ---------------------------
	pt18
	eduKarteの特徴
--------------------------- */
#contents section.pt18 {
	background-color: #f2f2f2;
}
#contents section.pt18>h3 {
	width: 90%;
	max-width: 800px;
	margin: 0 auto;
	margin-bottom: 40px;
}
#contents section.pt18>h4 {
	font-size: 100%;
	text-decoration: underline;
	width: 85%;
	max-width: 750px;
	margin: 0 auto 10px;
}
#contents section.pt18>p {
	width: 85%;
	max-width: 750px;
	margin: 0 auto 40px;
}
#contents section.pt18>p>img  {
	width: 100%;
}

#contents section.pt18>img {
	display: block;
	width: 85%;
	max-width: 750px;
	margin: 0 auto 100px;
	border: 1px solid #bbb;
}


/* ---------------------------
	pt04
	授業の特徴
	eduKarteの流れ
--------------------------- */
#contents #flowKarte.pt04 {
	background-color: #f2f2f2;
}

.pt04 ul {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 120px;
	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;

}
.pt04 ul.right{
	flex-direction : row-reverse;
}
.pt04 ul li {
	padding: 0 2%;
}
.pt04 ul li.img {
	width: 55%;
}
.pt04 ul li.img img {
	width: 100%;
}
.pt04 ul li.desc {
	width: 45%;
	font-weight: 300;
}
.pt04 ul li.desc h3 {
	font-size: 120%;
	margin-bottom: 20px;
}
@media screen and ( max-width: 790px ) {
	.pt04 ul {
		margin: 0 auto 80px;
	}
	.pt04 ul li.img {
		width: 100%;
		margin-bottom: 10px;
	}
	.pt04 ul li.desc {
		width: 100%;
	}
}


/* ---------------------------
	pt05
	授業の流れ
--------------------------- */
.pt05 {
	background-color: #f2f2f2;
}
.pt05>h2 {
	margin-bottom: 40px !important;
}
.pt05>p {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto 40px;
}
.pt05 div.flow {
	background-color: #fff;
	border: 1px solid #bbb;
	width: 80%;
	max-width: 1000px;
	margin: 0 auto 100px;;
	padding: 20px 40px 0;
	position: relative;
}
.pt05 div.flow.arrow:after {
	content: '';
	display: block;
	width: 40%;
	height: 50px;
	position: absolute;
	bottom: -70px;
	left: 40%;
	background: url( /img/class/icon_arrow.gif ) no-repeat;
	background-size: 40% 50px;
	opacity: 0.4;
}
.pt05 div.flow h4 {
	text-align: center;
	font-size: 150%;
	margin-bottom: 40px;
}
.pt05 div.flow>p {
	margin-bottom: 40px;
	font-weight: 300;
}
.pt05 div.flow>img {
	width: 100%;
	border: 1px solid #bbb;
	margin: 0 auto 80px;
}

@media screen and ( max-width: 790px ) {
	.pt05 div.flow {
		width: 95%;
		margin: 0 auto 60px;;
		padding: 10px 10px;
	}
	.pt05 div.flow.arrow:after {
		width: 60%;
		height: 30px;
		bottom: -50px;
		left: 30%;
		background-size: 60% 30px;
	}
}

/* ---------------------------
	pt06
	進学実績
--------------------------- */
.pt06>div {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 120px;

	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
	
}
.pt06>div p {
	width: 40%;
	margin: 0 5%;
	border-bottom: 1px solid #bbb;
	font-size: 120%;
	padding: 10px 10px 5px;
}


@media screen and ( max-width: 790px ) {
	.pt06>div {
		width: 95%;
		margin: 0 auto;
	}
	.pt06>div p {
		width: 46%;
		margin: 0 1%;
		font-size: 100%;
		padding: 5px;
	}
}
/* ---------------------------
	pt07
	授業料
--------------------------- */
.pt07 {
	background-color: #f2f2f2;
}
.pt07>h2 {
	margin-bottom: 80px !important;
}
.pt07 .wrap {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 20px;
	display: flex;
	justify-content: center;
	align-items: top;
	flex-wrap: wrap;
}
.pt07 .wrap>div {
	width: 48%;
	margin: 0 1%;
	border-top: 1px solid  #bbb;
	border-bottom: 1px solid  #bbb;
	padding: 20px;
}
.pt07 h3 {
	font-size: 120%;
	margin-bottom: 20px;
}
.pt07 table th {
	font-size: 100%;
	font-weight: 400;
	padding-left: 10px;
	width: 280px;
}
.pt07 table td {
	font-size: 120%;
	font-weight: 700;
}
.pt07 p.note {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 120px;
	padding: 0 40px;

	font-size: 90%;
	font-weight: 200;
	line-height: 1.3em;
}

@media screen and ( max-width: 790px ) {
	.pt07 .wrap {
		width: 90%;
		margin: 0 auto 20px;
		display: block;
	}
	.pt07 .wrap>div {
		width: 100%;
		margin: 0;
		padding: 10px;
	}
	.pt07 h3 {
		margin-bottom: 10px;
	}
	.pt07 table td,
	.pt07 table th {
		padding: 5px;
	}
	.pt07 table th {
		width: 60%;
	}
	.pt07 p.note {
		margin: 0 auto 40px;
		padding: 0;
		font-size: 80%;
	}
}

/* ---------------------------
	pt08
	FAQ
--------------------------- */
.pt08 {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
}
.pt08 h2 {
	border-width: 0 !important;
	border-bottom: 1px solid #bbb;
	padding-bottom: 80px;
	margin-bottom: 40px !important;
}
.pt08 .q {
	font-size: 120%;
	font-weight: 800;
	color: #0000ff;
	margin-right: 10px;
}
.pt08 .a {
	font-size: 120%;
	font-weight: 800;
	color: #ff0000;
	margin-right: 10px;
}
.pt08 h3 {
	margin-bottom: 20px;
}
.pt08 p {
	margin-bottom: 40px;
	padding-bottom: 20px;
	border-bottom: 1px solid #bbb;
}

@media screen and ( max-width: 790px ) {
	.pt08 {
		width: 95%;
	}
	.pt08 h2 {
		padding-bottom: 40px !important;
		margin-bottom: 20px !important;
	}
	.pt08 p {
		margin-bottom: 20px;
		padding-bottom: 20px;
	}

}


/* ---------------------------
	pt09
	生徒の声
--------------------------- */
.pt09>h2 {
	margin-bottom: 40px !important;
}
.pt09>p {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
	margin-bottom: 80px;
}
.pt09>ul {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;

	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
}
.pt09>ul li {
	width: 46%;
	margin: 2%;

	border: 1px solid #f5b300;
	border-radius: 20px;
	padding: 40px;
}
.pt09>ul li h3{
	font-size: 120%;
	border-bottom: 1px solid #bbb;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.pt09>ul li .p1 {
	margin-bottom: 20px;
	font-weight: 800;
}
.pt09>ul li .p1 span {
	color: #fff;
	padding: 4px 8px;
	margin-right: 5px;
	font-size: 90%;
	font-weight: 500;
}
.pt09>ul li .p1 span.h {
	background-color: #8888ff;
}
.pt09>ul li .p1 span.j {
	background-color: #44aa44;
}
.pt09>ul li .p1 span.e {
	background-color: #ff8800;
}

@media screen and ( max-width: 790px ) {
	.pt09>p {
		width: 90%;
		margin-bottom: 40px;
	}
	.pt09>ul {
		width: 90%;
		display: block;
	}
	.pt09>ul li {
		width: 100%;
		margin: 0 0 40px;
		border-radius: 10px;
		padding: 20px;
	}
}

/* ---------------------------
	pt19
	生徒の声 アンケート
--------------------------- */
.pt19>h2 {
	margin-bottom: 40px !important;
}

.pt19>p {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
	margin-bottom: 80px;
}

.pt19>div {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 80px;
	border: 1px solid #bbb;
	padding: 40px 40px 30px;
	border-radius: 10px;
	background-color: #f8f8f8;
}

.pt19>div h3 {
	margin-bottom: 40px;
}

.pt19>div ul {
}

.pt19>div ul li {
	list-style: disc outside;
	margin-bottom: 20px;
	margin-left: 20px;
	border-bottom: 1px dotted #bbb;
}

@media screen and ( max-width: 790px ) {
	.pt19>div {
		padding: 20px 20px 10px;
	}
	.pt19>div ul li {
		margin-left: 10px;
	}
}

/* ---------------------------
	pt10
	講師紹介
--------------------------- */
.pt10>h2 {
	margin-bottom: 40px !important;
}
.pt10>p {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
	margin-bottom: 80px;
}
.pt10>ul {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;

	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
}
.pt10>ul li {
	width: 29%;
	margin: 2%;

	background-color: #f8f8f8;
	border: 1px solid #bbb;
	padding: 20px;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
}
.pt10>ul li>a {
	text-decoration: none;
	color: #333;
	display: block;
	width: 100%;
	height: 100%;
}
.pt10>ul li h3{
	font-size: 120%;
	margin-bottom: 20px;
}
.pt10>ul li h3 span {
	font-size: 80%;
	margin-left: 10px;
}
.pt10>ul li img {
	width: 100%;
}
.pt10>ul li p {
	margin-bottom :10px;
	border-bottom: 1px dotted #bbb;
}
.pt10>ul li p span {
	font-weight: 700;
	margin-right: 10px;
}

@media screen and ( max-width: 790px ) {
	.pt10>p {
		width: 90%;
		margin-bottom: 40px;
	}
	.pt10>ul {
		width: 95%;
	}
	.pt10>ul li {
		width: 48%;
		margin: 0 1% 40px;
		padding: 10px;
	}
}


/* ---------------------------
	pt11
	講師紹介 詳細
--------------------------- */
.pt11 {
	padding-top: 200px !important;
	background-color: #f2f2f2;
}
.pt11>h2 {
	width: 30%;
	max-width: 800px;
	margin: 0 auto 100px !important;
	padding-bottom: 20px;
	border-width: 0 !important;
	border-bottom: 1px solid #bbb !important;
}
.pt11>h2 span {
	font-size: 80%;
	margin-left: 10px;
}
.pt11>ul {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;

	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
}
.pt11>ul li.img {
	width: 40%;
}
.pt11>ul li.img div {
	padding: 10px;
	border: 1px solid #bbb;
	background-color: #fff;
}
.pt11>ul li img {
	width: 100%;
}
.pt11>ul li.desc {
	width: 60%;
	padding-left: 40px;
}
.pt11>ul li.desc p {
	border-bottom: 1px dotted #bbb;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.pt11>ul li.desc p span {
	font-weight: 700;
	margin-right: 20px;
}
.pt11>a {
	display: block;
	text-align: center;
	text-decoration: none;
	color: #fff;
	background-color: #009ed8;
	width: 40%;
	margin: 80px auto 100px;
	padding: 10px 0;
	font-size: 120%;
	font-weight: 500;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	border-radius: 10px;
}


@media screen and ( max-width: 790px ) {
	.pt11 {
		padding-top: 100px !important;
	}
	.pt11>h2 {
		width: 80%;
		max-width: 800px;
		margin: 0 auto 40px !important;
		padding-bottom: 10px;
	}
	.pt11>ul {
		width: 90%;
		display: block;
	}
	.pt11>ul li.img {
		width: 100%;
		margin-bottom: 20px;
	}
	.pt11>ul li.desc {
		width: 100%;
		padding-left: 0;
	}
	.pt11>ul li.desc p {
		padding-bottom: 5px;
		margin-bottom: 10px;
	}
	.pt11>ul li.desc p span {
		font-weight: 700;
		margin-right: 20px;
	}
	.pt11>a {
		width: 50%;
		margin: 40px auto 40px;
		border-radius: 5px;
	}
}


/* ---------------------------
	pt12
	代表ご挨拶
--------------------------- */
.pt12 {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 100px 0 !important;
}
.pt12 p>img {
	width: 400px;
	float: left;
	margin: 0 40px 0 0;
}


@media screen and ( max-width: 790px ) {
	.pt12 {
		padding: 40px 0 !important;
	}
	.pt12 p>img {
		display: block;
		width: 90%;
		float: none;
		margin: 0 auto 40px;
	}
}
/* ---------------------------
	pt13
	運営方針
--------------------------- */
.pt13 {
	background-color: #f2f2f2;
	padding: 100px 0 !important;
}
.pt13>ul {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;

	display: flex;
	justify-content: flex-start;
	align-items: top;
	flex-wrap: wrap;
}
.pt13>ul li.desc {
	width: 40%;
	padding-right: 50px;
}
.pt13>ul li.img {
	width: 60%;
}
.pt13>ul li.img img {
	width: 100%;
}

@media screen and ( max-width: 790px ) {
	.pt13 {
		padding: 40px 0 !important;
	}
	.pt13>ul {
		width: 80%;
		display: block;
	}
	.pt13>ul li.desc {
		width: 100%;
		padding-right: 0;
		margin-bottom: 40px;
	}
	.pt13>ul li.img {
		width: 60%;
		margin: 0 auto;
	}
}


/* ---------------------------
	pt14
	アクセス
--------------------------- */
.pt14 {
	text-align: center;
	padding: 100px 0 0 !important;
}
.pt14>h3 {
	margin-bottom: 10px;
}
.pt14>p {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto 20px;
}
.pt14 iframe {
	width: 100%;
	height: 450px;
}
@media screen and ( max-width: 790px ) {
	.pt14 {
		padding: 40px 0 !important;
	}
	.pt14 iframe {
		height: 300px;
	}
}

/* ---------------------------
	pt15
	フォーム
--------------------------- */
.pt15 {
	width: 80%;
	max-width: 1000px;
	margin: 0 auto;
}
.pt15 h2 {
	margin-bottom: 80px !important;
	line-height: 1.5em;
}
.pt15>p {
	margin-bottom: 40px !important;
}
.pt15>p.thanks {
	text-align: center;
	margin-bottom: 100px !important;
}
.pt15 table {
	margin-bottom: 80px;
}
.pt15 table th,
.pt15 table td {
	border-bottom: 1px solid #bbb;
	padding: 40px 10px 10px;
}
.pt15 table th span {
	color: #0000ff;
	font-size: 80%;
	margin-left: 10px;
}
.pt15 table th {
	width: 40%;
}
.pt15 table td {
	width: 60%;
}
.pt15 .err{
	color: #ff0000;
	font-weight: 600;
}
.pt15 input[type="text"], 
.pt15 input[type="date"], 
.pt15 input[type="number"], 
.pt15 input[type="tel"], 
.pt15 input[type="email"], 
.pt15 textarea, select {
	width: 100%;
	padding: 10px 10px;
	background-color: #f2f2f2;
}
.pt15 textarea {
	height: 100px;
}
.pt15 input:placeholder {
	color: 888;
}
.pt15 .note {
	font-size: 90%;
	font-weight: 300;
	line-height: 1.2em;
	margin-bottom: 20px;
}
.pt15 label {
	cursor: pointer;
	line-height: 2em;
}
.pt15 label input[type="checkbox"] {
	border: 1px solid #888;
	transform: scale( 1.5 );
	margin-right: 20px;
}
.pt15 button,
.pt15>form>div a {
	display: block;
	width: 50%;
	margin: 0 auto;
	padding: 20px;
	text-align: center;
	cursor: pointer;
	color: #fff;
	background-color: #8888ff;
	font-size: 120%;
	font-weight: 800;
	box-shadow: 2px 2px 4px rgba( 0, 0, 0, 0.3 );
	text-decoration: none;
	border-radius: 10px;
}
.pt15 button:hover {
	opacity: 0.8;
}
.pt15>form>div {
	text-align: center;
}
.pt15>form>div a {
	display: inline;
	margin: 0 20px;
}
.pt15>form>div a.submit {
	display: inline;
	margin: 0 20px;
	padding: 20px 80px;
}
.pt15>form>div a.back {
	display: inline;
	margin: 0 20px;
	padding: 20px 30px;
	background-color: #bbb;
}

@media screen and ( max-width: 790px ) {
	.pt15 {
		width: 90%;
	}
	.pt15 table {
		margin-bottom: 40px;
	}
	.pt15 table th,
	.pt15 table td {
		display: block;
		width: 100% !important;
		border-width: 0;
		padding: 10px;
	}
	.pt15 table th {
		border-bottom: 1px solid #bbb;
		margin-bottom: 20px;
		font-size: 130%;
	}
	.pt15 table td {
		margin-bottom: 40px;
	}
	.pt15 label {
		line-height: 3em;
	}
	.pt15 input[type="text"], 
	.pt15 input[type="date"], 
	.pt15 input[type="number"], 
	.pt15 input[type="tel"], 
	.pt15 input[type="email"], 
	.pt15 textarea, select {
		font-size: 16px;
	}
	.pt15 button,
	.pt15>form>div a {
		border-radius: 5px;
	}
	.pt15>form>div a {
		display: inline;
		margin: 0 5px !important;
		border-radius: 5px;
	}
	.pt15>form>div a.submit {
		display: inline;
		padding: 20px 30px;
	}
	.pt15>form>div a.back {
		display: inline;
		padding: 20px 10px;
		background-color: #bbb;
	}
}

