@charset 'utf-8';

/*
Theme Name: okimoto-clinic
Author: minoru kubota
Version: 1.0
*/

/*
---------------------------------------
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;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
	margin:0;
	padding:0;
}

body {
	height: 100%;
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
}

input, textarea {
	margin: 0;
	padding: 0;
}

input:focus, textarea:focus {
	outline: 0;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
}

ol, ul {
	list-style: none;
}

table {
	width:100%;
	border-collapse: collapse;
	border-spacing:0;
}

table th {
	font-weight:normal;
}

caption, th {
	text-align: left;
}

a:focus {
	outline:none;
}

p,dd,li,address{
	font-style:normal;
}

body small {
	font-size: 1.1rem;
}

.sp {
	display: none;
}

.inview {
	opacity: 0;
	visibility: hidden;
	transform: translateY( 4rem );
	transition: all .8s;
}

.inview.show {
	opacity: 1;
	visibility: visible;
	transform: none;
}


/*
---------------------------------------
link
---------------------------------------
*/

a {
	color: #535D5C;
	text-decoration: none;
	transition: all .2s;
}

a:hover {
	color: #535D5C;
	text-decoration: none;
}


/*
---------------------------------------
clear
---------------------------------------
*/

.clearfix:after {
	content: '.';
	display: block;
	height: 0;
	font-size: 0;
	clear: both;
	visibility: hidden;
}

.clearfix {
	min-height:1px;
}

* html .clearfix {
	height: 1px;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.clear,
.both,
.clearboth {
	clear: both;
}

*:first-child+html .clearfix { zoom: 1; } /* IE7 */


/*
----------------------------------------
form
----------------------------------------
*/

input[type=text],
input[type=search],
input[type=tel],
input[type=number],
input[type=url],
input[type=email],
input[type=password],
input[type=date],
textarea, select {
	display: inline-block;
	width: 100%;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: 1.8rem;
	border: solid 1px #ccc;
	padding: 10px 15px;
	box-sizing: border-box;
	text-align: left;
}

input[type=email],
input[type=tel],
input.l {
	width: 80%;
	margin: 0;
}

textarea {
	margin: 0 !important;
	width: 100% !important;
	height: 20rem !important;
}


/*
---------------------------------------
table
---------------------------------------
*/

caption {
	caption-side: bottom;
	padding-top: 20px;
}

table {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
	border-spacing: 0;
	border-top: solid 1px #535D5C;
	border-left: solid 1px #535D5C;
}

table th,
table td {
	font-size: 2.8rem;
	line-height: 1.5;
	padding: 2px 10px;
	border-right: solid 1px #535D5C;
	border-bottom: solid 1px #535D5C;
	text-align: center;
	vertical-align: middle;
}

/*
---------------------------------------
h1-h6
---------------------------------------
*/

h1,h2,h3,h4,h5,h6 {
	font-weight: normal;
}

.ttl-01 {
	text-align: center;
	padding-bottom: 2.5rem;
	margin-bottom: 6rem;
	border-bottom: solid 1px #4D4D4D;
}

.ttl-01 .jp {
	font-size: 6.5rem;
	letter-spacing: 14px;
	text-indent: 14px;
	line-height: 1.5;
}

.ttl-01 .en {
	font-size: 2.8rem;
	letter-spacing: 4px;
	color: #33B495;
}

.ttl-02 {
	text-align: center;
}

.ttl-02 h2,
.ttl-02 h3 {
	display: inline-block;
	width: 1180px;
	max-width: 100%;
	font-size: 5rem;
	letter-spacing: 10px;
	line-height: 1.4;
	padding-left: 3rem;
	padding-bottom: 3.5rem;
	margin: 0 auto 1rem;
	border-bottom: solid 1px #33B495;
}


/*
---------------------------------------
btn
---------------------------------------
*/

.btn-01 {
	text-align: center;
	margin: 7rem 0;
}

.btn-01 a {
	display: inline-block;
	margin: 0 auto;
	width: 1040px;
	max-width: 100%;
	font-size: 3.4rem;
	letter-spacing: 7px;
	text-align: center;
	padding: 4rem;
	border: solid 1px transparent;
	background-color: #fff;
	background-image: url( assets/img/common/2x/link-img.png );
	background-position: right 2rem bottom 2rem;
	background-size: 88px;
	background-repeat: no-repeat;
}


/*
---------------------------------------
list
---------------------------------------
*/

.list-circle {
	margin: 10px 0 30px 0;
	font-size: 1.6rem;
}

.list-circle li:before {
	content: '';
	display: inline-block;
	width: .8rem;
	height: .8rem;
	border: solid 2px #ff9800;
	margin-right: 5px;
	border-radius: 50%;
}

.contact-list {
	display: table;
	table-layout: fixed;
	width: 100%;
	height: 140px;
	background: #e6e6e6;
	border-collapse: separate;
	border-spacing: 5px;
	margin:  30px auto;
}

.contact-list li {
	display: table-cell;
	background: #fff;
	vertical-align: middle;
}


/*
---------------------------------------
flex
---------------------------------------
*/

.flex {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
}


/*
---------------------------------------
layout
---------------------------------------
*/

html[lang=ja] {
	margin-top: 0 !important;
}

html{
	font-size: 62.5%;
}

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 300;
	font-size: 2.2rem;
	text-align: center;
	color: #535D5C;
	position: relative;
	-webkit-text-size-adjust: 100%;
}

body * {
	box-sizing: border-box;
}

.wrap {
	max-width: 1640px;
	padding: 0 20px;
	margin: 0 auto;
}

#wrapper {
	background: url( assets/img/common/2x/bg-01.png ) right top / 1392px no-repeat;
}

#contents {
	text-align: left;
	line-height: 2;
}

.en {
	font-family: 'Poppins', sans-serif;
	font-weight: 300;
}

strong {
	font-weight: normal;
	color: #33B495;
}


/*
---------------------------------------
header
---------------------------------------
*/

#wrapper > header {
	padding: 6.5rem 0 4.5rem;
}

#wrapper > header .wrap {
	max-width: 1720px
}

#wrapper > header .flex {
	align-items: flex-end;
}

#wrapper > header .logo {
	line-height: .5;
	margin-right: auto;
}

#g-nav {
	padding-right: 1.5rem;
	transform: translateY( 10px );
}

#g-nav li {
	width: 188px;
	max-width: calc( ( 100% - 160px ) / 5 );
	margin-right:  40px;
}

#g-nav li:last-of-type {
	margin-right: 0;
}

#g-nav .jp {
	font-size: 2.4rem;
	letter-spacing: 4px;
}

#g-nav .en {
	border-top: solid 1px #33B495;
	font-size: 1.7rem;
	margin-top: 5px;
	padding-top: 5px;
}

#sp-btn {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	cursor: pointer;
}

#sp-btn > div {
	width: 50px;
	height: 50px;
	background: #33B495;
	position: relative;
}

#sp-btn span {
	display: inline-block;
	box-sizing: border-box;
	transition: all .5s;
}

#sp-btn span {
	position: absolute;
	left: 15px;
	right: 15px;
	height: 2px;
	background: #fff;
}

#sp-btn span:nth-of-type(1) {
	top: 17px;
}

#sp-btn span:nth-of-type(2) {
	top: 24px;
}

#sp-btn span:nth-of-type(3) {
	top: 31px;
}

header.active #sp-btn span:nth-of-type(1) {
	-webkit-transform: translateY(7px) rotate(-45deg);
	transform: translateY(7px) rotate(-45deg);
}
header.active #sp-btn span:nth-of-type(2) {
	opacity: 0;
}
header.active #sp-btn span:nth-of-type(3) {
	-webkit-transform: translateY(-7px) rotate(45deg);
	transform: translateY(-7px) rotate(45deg);
}

.list-01 li {
	font-size: 2.2rem;
	text-indent: -2.2rem;
	letter-spacing: 2px;
	padding-left: 2.2rem;
	margin-top: 2.5px;
}

.list-01 li::before {
	content: '■';
	color: #33B495;
}


/*
---------------------------------------
information
---------------------------------------
*/

#information .page-header {
	background: url( assets/img/page/2x/header-bg.png ) center center / cover no-repeat;
	padding: 8rem 0;
	margin-bottom: 8rem;
}

#information .page-header .wrap {
	text-align: center;
}

#information .page-header .box {
	display: inline-block;
	margin: 0 auto;
	background: #fff;
	padding: 4rem 6rem;
	letter-spacing: 4px;
	line-height: 1.5;
}

#information .page-header .jp {
	font-size: 5rem;
}

#information .page-header .en {
	font-size: 2.8rem;
}


/*
---------------------------------------
main-contents
---------------------------------------
*/

#main-contents {
	width: 70%;
}

.single-column #main-contents {
	width: 100%;
}

#main-contents .cat-list {
	display: inline-block;
	margin-right: 5px;
}

#main-contents .cat-list li {
	display: inline-block;
	margin-right: 5px;
}

#main-contents .cat-list li a {
	display: inline-block;
	padding: 0 10px;
	border: solid 1px #33B495;
	background: #33B495;
	font-size: 1.4rem;
	text-decoration: none;
	color: #fff;
	transition: all .4s;
}

#main-contents .cat-list li a:hover {
	background: #fff;
	color: #33B495;
}

#main-contents .post-header {
	border-bottom: solid 1px #33B495;
	padding-bottom: 20px;
	margin-bottom: 30px;
}

#main-contents .post-header h1 {
	font-size: 3.4rem;
	line-height: 1.4;
	color: #33B495;
	margin-top: 20px;
}

#main-contents .photo {
	text-align: center;
}

#main-contents img {
	max-width: 100%;
	height: auto;
}

.search-ans {
	background: #f3f3f3;
	padding: 10px 20px;
	margin-bottom: 30px;
}

.post a {
	text-decoration: underline;
}

.post .more-link {
	display: block;
	text-align: center;
	width: 16rem;
	margin: 60px 0 0 auto;
	padding: 5px 0;
	background: #f3f3f3;
	border-radius: 4px;
	text-decoration: none;
	position: relative;
	transition: all .4s;
}

.post .more-link:after {
	content: '';
	width: 0;
	height: 0;
	border: solid 4px transparent;
	border-left: solid 4px #333;
	position: absolute;
	right: 1rem;
	top: 50%;
	margin-top: -4px;
	transition: all .4s;
}

.post .more-link:hover {
	background: #000;
	color: #fff;
}

.post-contents .more-link:hover:after {
	border-left: solid 4px #fff;
}

.post-contents p {
	margin-bottom: 40px;
}

.post-contents h2 {
	font-size: 3rem;
	line-height: 1.4;
	padding: 0 0 10px;
	margin-bottom: 20px;
	color: #33B495;
	border-bottom: dashed 1px #33B495;
}

.post-contents h3 {
	font-size: 2.8rem;
	line-height: 1.4;
	color: #33B495;
	margin-bottom: 20px;
	padding-left: 15px;
	border-left: solid 5px #33B495;
}

.post-contents h4 {
	font-size: 2.6rem;
	line-height: 1.4;
	color: #33B495;
	margin-bottom: 20px;
}

.post-contents ul,
.post-contents ol {
	margin-bottom: 40px;
}

.post-contents ul li {
	list-style: disc;
	margin-left: 30px;
}

.post-contents ol li {
	list-style: decimal;
	margin-left: 30px;
}

.post-contents blockquote {
	background: #E8F4EF;
	padding: 30px 40px 10px;
	margin-bottom: 30px;
	border-radius: 12px;
}

.post-contents blockquote p,
.post-contents blockquote ul,
.post-contents blockquote ol {
	margin-bottom: 20px;
}

.post-list .post {
	margin-bottom: 60px;
	align-items: flex-start;
}

.post-list .post > figure {
	width: 40%;
}

.post-list .post > figure a {
	display: block;
	line-height: .5;
	background: #33B495;
	overflow: hidden;
}

.post-list .post > figure img {
	transition: all .6s;
}

.post-list .post > figure a:hover img {
	transform: scale( 1.1 );
	opacity: .8;
}

.post-list .post > figure + .txt {
	width: 60%;
	padding-left: 30px;
}

.post-list .post a {
	text-decoration: none;
}

.post-nav {
	margin-top: 40px;
	padding-top: 40px;
	border-top: dashed 1px #898989;
	justify-content: space-between;
	align-items: center;
}

.post-nav .prev {
	width: 30%;
}

.post-nav .back {
	width: 40%;
	text-align: center;
	margin: 0 auto;
	padding: 0 20px;
}

.post-nav .back a {
	display: inline-block;
	border: solid 1px #33B495;
	padding: 10px 20px;
	transition: all .2s;
}

.post-nav .back a:hover {
	color: #fff;
	background: #33B495;
}

.post-nav .next {
	width: 30%;
	text-align: right;
}

#main-contents .post-list .post h2 {
	line-height: 1.4;
	margin: 5px 0;
}

#main-contents .post-list .post h2 a {
	font-size: 3.4rem;
	color: #33B495;
}

.post-list .more {
	text-align: right;
	margin-top: 5px;
}

#main-contents .post-list .more a {
	display: inline-block;
	border: solid 1px #33B495;
	color: #33B495;
	padding: 0 20px;
	margin-top: 2rem;
	transition: all .2s;
}

#main-contents .post-list .more a:hover {
	background: #33B495;
	color: #fff;
}

.pagination ul {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
}

.pagination li {
	margin: 0 5px;
}

.pagination a,
.pagination span {
	display: inline-block;
	width: 40px;
	height: 40px;
	line-height: 40px;
	text-align: center;
	border: solid 1px #33B495;
	border-radius: 5px;
	color: #33B495;
	transition: all .2s;
}

.pagination a:hover,
.pagination .current {
	background: #33B495;
	color: #fff;
}


/*
---------------------------------------
sidebar
---------------------------------------
*/

#sidebar {
	width: 30%;
	padding-left: 60px;
}

#sidebar .side-wrap {
	position: sticky;
	top: 110px;
}

#sidebar h2 {
	font-size: 2.8rem;
	color: #33B495;
	border-bottom: solid 1px #33B495;
	padding-bottom: 5px;
	margin-bottom: 15px;
}

#sidebar ul {
	margin-bottom: 40px;
}

#sidebar li {
	padding-left: 2.5rem;
	position: relative;
}

#sidebar li::before {
	content: '■';
	color: #33B495;
	position: absolute;
	left: 0;
	top: 0;
}


/*
---------------------------------------
footer
---------------------------------------
*/

footer > .wrap {
	max-width: 1570px;
}

footer .footer-wrap {
	background: #fff;
	align-items: center;
	margin: 11rem 0 18rem;
}

footer .cont {
	width: 585px;
	padding: 7.5rem 4.5rem 0;
}

footer .cont .logo {
	margin-bottom: 8rem;
}

footer .cont .logo img {
	width: 402px;
}

footer .map {
	width: calc( 100% - 585px);
}

footer .map {
	height: 550px;
}

footer .map iframe {
	width: 100%;
	height: 100%;
}

footer .info-list {
	text-align: left;
}

footer .info-list dt {
	width: 13rem;
	margin-bottom: .8rem;
	padding-right: 3rem;
	position: relative;
}

footer .info-list dt::after {
	content: ':';
	position: absolute;
	top: 0;
	right: 2.5rem;
}

footer .info-list dd {
	width: calc( 100% - 13rem );
	margin-bottom: .8rem;
	letter-spacing: 2px;
}

.copyright {
	background: #33B495;
	color: #fff;
	padding: 2rem 0;
}

.copyright .wrap {
	max-width: 1780px;
}

.copyright .flex {
	align-items: flex-end;
}

.copyright .logo {
	padding-right: 4rem;
	margin-right: auto;
}

.copyright .copy {
	font-size: 2.3rem;
	letter-spacing: 1px;
}

#page-top {
	position: fixed;
	right: 20px;
	bottom: 20px;
}

#page-top a {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	background: url( assets/img/common/btn-bg.png ) center center / contain no-repeat;
	color: #fff;
	width: 80px;
	height: 80px;
	padding: 20px;
	transition: all .4s;
}

#page-top a:hover {
}


/*
---------------------------------------
home
---------------------------------------
*/

#home {
	background: url( assets/img/common/2x/bg-03.png ) center bottom / 100% no-repeat;
}

#home .main-img .slider img {
	width: 100%;
}

#home .info-box {
	font-size: 2.8rem;
	align-items: center;
	padding: 8rem 0 0;
}

#home .info-box .logo {
	width: calc( 100% - 820px );
	margin: 0 auto;
	padding-right: 5rem;
	text-align: center;
}

#home .info-box .logo .txt {
	width: 584px;
	max-width: 100%;
	letter-spacing: 3px;
	margin: 5px auto 0;
	padding-top: 5px;
	border-top: solid 1px#4FC092;
}

#home .info-box .cont {
	width: 820px;
	padding: 5px 15px 0 0;
}

#home .info-box table .maru {
	color: #4FC092;
}

#home .info-box .tel-wrap p {
	margin: 2rem 0;
}

#home .info-box .web-yoyaku {
	margin: 9rem 0 6rem;
}

#home .info-box .web-yoyaku a {
	width: 100%;
	justify-content: center;
	align-items: center;
	padding: 5.4rem 4rem 7.2rem 2rem;
	border: solid 1px #33B495;
	background: url( assets/img/common/2x/yoyaku-bg.png ) left 2rem top 2rem / 33px no-repeat;
}

#home .info-box .web-yoyaku .txt {
	font-size: 5.7rem;
	letter-spacing: 12.5px;
}

#home .info-box .web-yoyaku figure {
	line-height: .5;
	margin-left: 4rem;
}

#home .news-box {
	padding: 8rem 0 4rem;
}

#home .news-list {
	margin-bottom: 60px;
}

#home .news {
	width: calc( ( 100% - 176px ) / 3 );
	margin: 0 88px 40px 0;
}

#home .news:nth-child( 3n ),
#home .news:last-child {
	margin: 0 0 40px 0;
}

#home .news a {
	display: block;
}

#home .news figure {
	overflow: hidden;
	background: #33B495;
	line-height: .5;
	margin-bottom: 2rem;
}

#home .news img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all .6s;
}

#home .news a:hover img {
	transform: scale( 1.1 );
	opacity: .8;
}

#home .news a {
	font-size: 2.1rem;
	line-height: 1.5;
}

#home .news h3 {
	font-size: 2.7rem;
	letter-spacing: 3px;
}

#home .news .time {
	margin: 2rem 0;
	letter-spacing: 4px;
}

#home .news .desc {
	letter-spacing: 1.8px;
}

#home .news .more {
	margin-top: 5px;
}

#home .about-box {
	position: relative;
	padding: 6rem 0;
}

#home .about-box::after {
	content: '';
	width: 100%;
	height: 79.0104166666667vw;
	background: url( assets/img/common/2x/bg-02.png ) center center / 100% no-repeat;
	position: absolute;
	top: -18vw;
	right: 0;
	left: 0;
	z-index: -1;
}

#home .about-box .ttl-01 {
	border: none;
	margin-bottom: 7.5rem;
}

.illust-wrap {
	position: relative;
}

.illust-wrap .illust {
	position: absolute;
}

.illust-wrap .illust-01 {
	top: -340px;
	right: 8vw;
}

.illust-wrap .illust-02 {
	bottom: -110px;
	left: 9vw;
}

#home .about-box .about-img {
	margin-bottom: 13.5rem;
}

#home .about-box .about-img img {
	width: 100%;
}

#home .about-box .cont {
	margin: 6rem 0;
	padding: 0 4rem;
}

#home .about-box .txt {
	width: calc( 100% - 520px);
	text-align: center;
}

#home .about-box .txt p {
	letter-spacing: 5px;
	line-height: 2.5;
}

#home .about-box .txt .name {
	font-size: 3.3rem;
	letter-spacing: 5px;
	margin-top: 2.5rem;
}

#home .medical-box {
	background: #E8F4EF;
	padding: 7rem 0;
}

.illust-03 {
	top: -180px;
	right: 8vw;
}

#home .medical-box .ttl-01 {
	border: none;
}

.medical-list {
	max-width: 1430px;
	margin: 0 auto;
}

.medical-list li {
	width: 33.3333%;
	margin-bottom: 5rem;
}

.medical-list li > span {
	display: block;
	font-size: 3.4rem;
	text-align: center;
	letter-spacing: 7px;
	padding: 2.5rem 2rem;
	border-left: solid 1px #9E9E9F;
}

.medical-list li:nth-child( 3n ) span,
.medical-list li:last-child span {
	border-right: solid 1px #9E9E9F;
}

#home .feature-box {
	padding:10rem 0;
}

.illust-04 {
	top: -160px;
	left: 10vw;
}

#home .feature-box .ttl-01 {
	border: none;
	margin-bottom: 4rem;
}

#home .feature-box .btn-01 a {
	background-color: #E8F4EF;
}

#home .feature-box .feature-img {
	margin-top: 18rem;
}

#home .feature-box .feature-img img {
	width: 100%;
}


/*
---------------------------------------
information
---------------------------------------
*/

#about .main-img {
	background: url( assets/img/page/2x/header-bg.png ) center top / 100% no-repeat;
	text-align: right;
	padding-top: 4rem;
}

.illust-05 {
	bottom: 80px;
	left: 10.5vw;
}

#about .main-img .img {
	margin-right: 1.5rem;
}

#about .doctor-box {
	padding: 0 0 27rem;
	margin-top: -3rem;
}

.illust-06 {
	top: 110px;
	right: 13vw;
}

#about .doctor-box .doctor-info {
	align-items: flex-end;
	width: 1180px;
	max-width: 100%;
	margin: 11rem auto 7rem;
}

#about .doctor-box .doctor-info .img {
	width: 620px;
}

#about .doctor-box .doctor-info .txt {
	width: calc( 100% - 620px );
	padding-left: 7.5rem;
}

#about .doctor-box .doctor-info h3 {
	font-size: 2.7rem;
	margin-bottom: 5px;
	letter-spacing: 3px;
}

#about .doctor-box .doctor-info h3 .name {
	font-size: 4.7rem;
}

#about .doctor-box .doctor-prof {
	width: 1180px;
	max-width: 100%;
	margin: 0 auto;
	padding-top: 7rem;
	border-top: dashed 1px #4D4D4D;
	align-items: center;
}

#about .doctor-box .doctor-prof .name-wrap {
	width: 620px;
	border: solid 1px #33B495;
	padding: 6.5rem 2rem;
	font-size: 2.7rem;
	text-align: center;
	letter-spacing: 4px;
}

#about .doctor-box .doctor-prof .name-wrap .name {
	font-size: 4.7rem;
}

#about .doctor-box .doctor-prof .txt {
	width: calc( 100% - 620px );
	padding-left: 7.5rem;
}

#about .feature-list .flex {
	width: 1180px;
	max-width: 100%;
	margin: 0 auto;
}

#about .feature-list li {
	width: 50%;
	text-align: center;
	margin-top: 7rem;
}

#about .feature-list li .num {
	font-size: 3.8rem;
}

#about .medical-box {
	position: relative;
	padding-top: 17rem;
}

#about .medical-box::after {
	content: '';
	width: 100%;
	height: 79.0104166666667vw;
	background: url( assets/img/common/2x/bg-02.png ) center center / 100% no-repeat;
	position: absolute;
	top: -16vw;
	right: 0;
	left: 0;
	z-index: -1;
}

.cont-list {
	max-width: 1060px;
	margin: 5.5rem auto;
}

.cont-list dt {
	font-size: 3.1rem;
	padding-left: 3.1rem;
	text-indent: -3.1rem;
	margin-bottom: 2rem;
	letter-spacing: 7px;
}

.cont-list dt::before {
	content: '■';
	color: #33B495;
}

.cont-list dd {
	margin-bottom: 3.4rem;
	letter-spacing: 2.4px;
	line-height: 2.15;
}

.illust-07 {
	right: 18vw;
	bottom: -175px;
}

#about .feature-box {
	margin: 18rem 0 22rem;
	padding: 20rem 0 8rem;
	background: url( assets/img/common/2x/bg-04.png ) center bottom / auto 100% no-repeat;
}

#about .feature-box .cont-list dd {
	margin-bottom: 7.5rem;
}

.illust-08 {
	top: -200px;
	left: 16vw;
}

.illust-09 {
	right: 9vw;
	bottom: -80px;
}


/*
----------------------------------------
767
----------------------------------------
*/

@media screen and ( min-width: 767px ) {

	#g-nav a:hover {
		color: #33B495;
	}

	#wrapper > header .logo a:hover {
		opacity: .7;
	}

	.btn-01 a:hover {
		border: solid 1px #33B495;
	}

	#home .info-box .web-yoyaku a:hover {
		background: #E8F4EF url( assets/img/common/2x/yoyaku-bg.png ) left 2rem top 2rem / 33px no-repeat;
	}

}
