/* reset*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
a {
	text-decoration: none;
	-webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    -ms-transition: all 0.3s;
    -o-transition: all 0.3s;
    transition: all 0.3s;
	cursor: pointer;
}
a:hover {
	-webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    -ms-transition: all 0.3s;
    -o-transition: all 0.3s;
    transition: all 0.3s;
	opacity: 0.6;
	filter: opacity(60);
}
ol, ul {
list-style: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
img { max-width: 100%;}
strong { font-weight: bold;}

#adLP {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	color: #000;
	background: #FFF;
	font-size: 14px;
	line-height: 22px;
	overflow: hidden;
}
#adLP .w860 {
	width: 860px;
	margin: 0 auto;
}
#adLP .w1320 {
	width: 1320px;
	margin: 0 auto;
}
#adLP p { margin-bottom: 1em;}

#adLP .oubo-btn-wrap {
	text-align: center;
	margin: 50px 0;
}
#adLP .oubo-btn-wrap a {
	display: block;
	width: 390px;
	margin: 0 auto;
	background: url(../images/arrow.png) #c20000 no-repeat right 24px center / 10px auto;
	border-radius: 50px;
	padding: 0.8em 0;
	color: #FFF;
	font-size: 20px;
	position: relative;
}

#adLP h2.gray {
  overflow: hidden;
  text-align: center;
}
#adLP h2.gray span {
  position: relative;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 1em;
  text-align: left;
}
#adLP h2.gray span::before,
#adLP h2.gray span::after {
  position: absolute;
  top: 50%;
  content: '';
  width: 400%;
  height: 2px;
  background-color: #000;
}
#adLP h2.gray span::before {
  right: 100%;
}
#adLP h2.gray span::after {
  left: 100%;
}


#adLP header {
	background: #000;
	padding: 20px 0;
}
#adLP header a {
	color: #FFF;
}
#adLP header ul {
	display: flex;
	align-items: center;
	text-align: right;
}
#adLP header ul li {
	padding: 0 1em;
	border-right: 1px solid #FFF;
}
#adLP header ul li:first-child {
	margin-right: auto;
	padding: 0;
	border: none;
}
#adLP header ul li:last-child {
	padding-right: 0;
	border: none;
}


#adLP .main { padding: 25px; }

#adLP #sec01 {
	background: #f6f6f6;
	padding: 20px 0;
}
#adLP #sec01 h2 {
	position: relative;
	bottom: -30px;
}
#adLP #sec01 .abotbox {
	background: #FFF;
	border: 2px solid #000;
	border-top: none;
	padding:40px 18px 18px;
	font-size: 16px;
	line-height: 1.8;
}
#adLP #sec01 .abotbox p:last-child { margin: 0;}

#adLP #sec02 {
	background: url(../images/sec02-bg.png);
	background-size: cover;
	background-position: center;
	padding: 90px 18px;
	margin-bottom: 60px;
}
#adLP #sec02 .sec02-whitebox {
	background: rgba(255,255,255,0.7);
	padding: 60px;
	text-align: center;
}
#adLP #sec02 .sec02-whitebox h3 { margin-bottom: 24px;}

#adLP #sec03 {
	border-top: 2px solid #000;
	border-bottom: 2px solid #000;
	margin: 60px 0;
	padding: 30px 0
}

#adLP #sec03 h2 {
	text-align: center;
	margin-bottom: 35px;
}
#adLP #sec03 .sample-wrap { background: #f6f6f6; }
#adLP #sec03 .sample-wrap .sample-books { background: #FFF;}
#adLP #sec03 table { width: 100%;}
#adLP #sec03 table,#adLP #sec03 td,#adLP #sec03 th {
    border-collapse: collapse;
    border:2px solid #000;
    }
#adLP #sec03 table td img { display: block; height: 320px; width: auto;}
#adLP #sec03 table .Right td img { margin-left: auto;}


#adLP #sec04 .voice-wrap .voice-box {
	display: flex;
	flex-wrap: wrap;
	padding: 30px 18px;
}
#adLP #sec04 .voice-wrap .voice-box .img-area {
	width: 185px;
	position: relative;
	z-index: 10;
}
#adLP #sec04 .voice-wrap .voice-box .txt-area {
	flex: 1;
	margin-left: -18px;
}
#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	font-weight: bold;
	margin-bottom: 24px;
}
#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi span {
	display: inline-block;
	border-bottom: 2px solid #000;
	padding: 0 12px 10px 30px;
	font-size: 18px;
}
#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi h4 {
	font-size: 20px;
	line-height: 25px;
	margin-left: 30px;
}
#adLP #sec04 .voice-wrap .voice-box .txt-area p { padding-left: 30px;}
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) { background: #f6f6f6;}
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .img-area,
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .txt-area .n-midashi span {
	order: 2;
	margin-left: auto;
}
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .txt-area { margin-right: -18px;}
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .txt-area p { margin: 0 30px 0 0;}
#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .txt-area .n-midashi span {padding: 0 30px 10px 12px;}

#adLP #sec05 {
	background: #f6f6f6;
	padding: 50px 0;
}
#adLP #sec05 h2 {
	position: relative;
	bottom: -20px;
}
#adLP #sec05 .service-wrap {
	padding: 30px 18px 0;
	border: solid #000 2px;
	border-top:none;
}
#adLP #sec05 .service-wrap .service-box {
	background: #FFF;
	padding-right: 30px;
	display: flex;
	margin-bottom: 20px;
}
#adLP #sec05 .service-wrap .service-box .img-area {
	width: 225px;
	overflow: hidden;
}
#adLP #sec05 .service-wrap .service-box.box01 .img-area {
	background: url(../images/service01.jpg) no-repeat;
	background-size: cover;
}
#adLP #sec05 .service-wrap .service-box.box02 .img-area {
	background: url(../images/service02.jpg) no-repeat;
	background-size: cover;
}
#adLP #sec05 .service-wrap .service-box.box03 .img-area {
	background: url(../images/service03.jpg) no-repeat;
	background-size: cover;
}
#adLP #sec05 .service-wrap .service-box .txt-area { flex: 1;}
#adLP #sec05 .service-wrap .service-box .txt-area h3 {
	border-bottom: 2px solid #000;
	font-size: 30px;
	font-weight: bold;
	padding: 30px 30px 10px;
}
#adLP #sec05 .service-wrap .service-box .txt-area h3 span {
	font-size: 16px;
	color: #919191;
	padding-left: 0.5em;
}
#adLP #sec05 .service-wrap .service-box .txt-area .child-txt { padding: 30px; }
#adLP #sec05 .service-wrap .service-box .txt-area .child-txt p {
	font-size: 16px;
	line-height: 1.5;
}
#adLP #sec05 .service-wrap .service-box .txt-area .child-txt p:last-child {margin-bottom: 0;}
#adLP #sec05 .service-wrap .service-box .txt-area .child-txt strong {
	font-size: 20px;
	font-weight: bold;
}

#adLP #sec06 { padding: 50px 0 }
#adLP #sec06 .read { text-align: center; margin: 1em 0;}
#adLP #sec06 .qa-wrap { padding: 32px 18px;}
#adLP #sec06 .qa-wrap:nth-child(odd) { background: #f6f6f6;}
#adLP #sec06 .qa-wrap .qabox {
	display: flex;
	align-items: flex-start;
}
#adLP #sec06 .qa-wrap .qabox i {
	width: 115px;
	margin-right: 1em;
}
#adLP #sec06 .qa-wrap .qabox p {
	flex: 1;
	padding-top: 20px;
}
#adLP #sec06 .qa-wrap .qabox p strong { font-size: 18px; }
#adLP #sec06 .more {
	text-align: right;
	margin: 50px 0;
}
#adLP #sec06 .more a {
	display: inline-block;
	width: 380px;
	color: #FFF;
	text-align: left;
	padding: 0.8em 1em;
	font-size: 18px;
	background: url(../images/arrow.png) #000 no-repeat right 24px center / 10px auto;
}
#adLP #sec07 {
	padding: 30px 0 80px;
	background: url(../images/sec07-bg.jpg);
}
#adLP #sec07 h2 {
	text-align: center;
	margin-bottom: 40px;
}

#adLP #sec08 { padding: 20px 0 50px;}
#adLP #sec08 h2 {
	position: relative;
	bottom: -32px;
}
#adLP #sec08 ul {
	display: flex;
	justify-content: space-between;
	padding:50px 20px 20px;
	border:solid 2px #000;
	border-top:none;
}
#adLP #sec08 ul li {
	width: 24%;
	position: relative;
}
#adLP #sec08 ul li::after {
	content: "";
	width: 22px;
	height: 35px;
	display: block;
	position: absolute;
	right: -11px;
	top:45%;
	background: url(../images/flowarrow.png) no-repeat;
	background-size: contain;
}
#adLP #sec08 ul li:last-child::after {
	background: none;
}

#adLP #sec09 {
	/* background: #000; */
	background: #be0000;
	padding: 30px 0;
	color: #FFF;
	text-align: center;
	font-size: 25px;
}
#adLP #sec09 .oubo-btn-wrap { margin: 1em 0;}

#adLP #sec10 {
	padding: 25px 0;
	text-align: center;
}

#adLP footer {
	background: #f6f6f6;
	padding: 25px 0;
	text-align: center;
}

@media only screen and (max-width: 736px) {
	#adLP .main { padding: 10px;}
	#adLP .w1320 img { height: 45vmin;}
	#adLP .w860 {
		width: auto;
		padding: 0 1em;
	}
	#adLP .oubo-btn-wrap a { width: 100%;}
	#adLP header ul {
		flex-wrap: wrap;
		text-align: center;
		justify-content: center;
	}
	#adLP header ul li,#adLP header ul li:last-child {
		width: 50%;
		box-sizing: border-box;
		padding: 15px;
		text-align: center;
		border: 1px solid #FFF;
		margin-top: -1px;
	}
	#adLP header ul li:first-child {
		width: 100%;
		margin: 0 auto 10px;
	}

	#adLP #sec01 h2 { bottom: -5.5vmin;}
	#adLP #sec02 { padding: 20px 0; }
	#adLP #sec02 .sec02-whitebox { padding:30px 20px;}

	#adLP #sec03 { background: #f6f6f6;}
	#adLP #sec03 h2 {
		padding: 0 20px;
		margin-bottom: 20px;
	}
	#adLP #sec03 table td { padding-right: 15px;}
	#adLP #sec03 table .Right td { padding: 0 0 0 15px;}
	#adLP #sec03 table td img {
		width: 100%;
		height: auto;
	}

	#adLP #sec04 .w860 { padding: 0;}
	#adLP #sec04 .w860 .oubo-btn-wrap { padding: 0 20px;}
	#adLP #sec04 .voice-wrap .voice-box {display: block;}
	#adLP #sec04 .voice-wrap .voice-box .img-area {
		width: 100%;
		text-align: center;
		margin-bottom: 15px;
	}
	#adLP #sec04 .voice-wrap .voice-box .txt-area { margin: 0;}
	#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi { text-align: center;}
	#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi h4 {
		margin: 0;
		width: 100%;
	}
	#adLP #sec04 .voice-wrap .voice-box .txt-area .n-midashi span,
	#adLP #sec04 .voice-wrap .voice-box:nth-child(even) .txt-area .n-midashi span{
		padding: 10px;
		margin: 0 auto 10px;
		order: 0;
	}
	#adLP #sec04 .voice-wrap .voice-box .txt-area p { padding: 0;}


	#adLP #sec05 { padding-bottom: 10px;}
	#adLP #sec05 h2 { bottom: -2.8vmin;}
	#adLP h2.gray span { margin: 0 0.8em;}
	#adLP #sec05 .service-wrap { padding: 0;}
	#adLP #sec05 .service-wrap .service-box { padding: 0;}
	#adLP #sec05 .service-wrap .service-box .img-area { display: none;}

	#adLP #sec06 { padding: 20px 0 0;}
	#adLP #sec06 .qa-wrap .qabox i { width: 20vmin;}
	#adLP #sec06 .more a {
		width: auto;
		padding-right: 50px;
	}
	#adLP #sec07 { padding: 30px 0;}

	#adLP #sec08 h2 { bottom: -5vmin;}
	#adLP #sec08 ul { flex-wrap: wrap;}
	#adLP #sec08 ul li { width: 48%;}

	#adLP #sec09 { font-size: 20px;}
}


/* CTA
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.section .section-inner {
    max-width: 1000px;
    margin: 0 auto;
}
.flex {
    display: flex;
    justify-content: space-between;
}
.section-cta {
    background-color: #be0000;
    padding: 30px 15px;
}

.cta-buttons .button {
    width: 32%;
    height: 142px;
    background-color: #fff;
    border-radius: 15px;
    padding: 7px;
    box-sizing: border-box;
    transition: .2s;
}

.cta-buttons .button:hover {
    opacity: .8;
}

.cta-buttons .button a {
    display: block;
    border: 3px solid #be0000;
    height: 100%;
    box-sizing: border-box;
    border-radius: 10px;
    position: relative;
}

.cta-buttons .button a::after {
    content: '';
    width: 35px;
    height: 35px;
    background-image: url(../img/icon_arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

.cta-buttons .button a img {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.cta-buttons .button a img:hover {
    opacity: inherit;
}

.cta-buttons .button_order a img {
    max-width: 170px;
    left: 35px;
}

.cta-buttons .button_inquiry a img {
    max-width: 210px;
    left: 19px;
}

.cta-buttons .button_apply a img {
    max-width: 176px;
    left: 35px;
}
.cta-buttons .button a::after {
    content: '';
    width: 35px;
    height: 35px;
    background-image: url(../images/icon_arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.mb-2 {
	margin-bottom: 2em;
}
.cta-buttons .button {
	margin-bottom: 0;
}
@media only screen and (max-width: 720px){
.section-cta {
    padding: 25px;
	}
	.cta-buttons.flex {
    flex-direction: column;
	}
	.cta-buttons .button {
    width: 100%;
    height: 85px;
    border-radius: 10px;
    padding: 4px;
    margin-bottom: 13px;
	}
	.cta-buttons .button a {
    border: 2px solid #be0000;
    border-radius: 6px;
	}
	.cta-buttons .button a img {
    height: 24px;
    width: auto;
	}
	.cta-buttons .button a::after {
    width: 21px;
    height: 21px;
    right: 20px;
	}
	.cta-buttons .button:nth-child(3) {
	margin-bottom: 0!important;
	}
}
#adLP.w1000 {
	width: 1000px;
}
