@charset "utf-8";

/*
Theme Name: THETA
Author: minoru kubota
Version: 1.11
*/

/*
----------------------------------------
reset
----------------------------------------
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

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

nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote: before, blockquote:after,
q: before, q:after {
	content: '';
	content: none;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor:help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}

input, select {
	vertical-align: middle;
}

input, button, textarea, select {
	font-size: 1.5rem;
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	/*-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;*/
}

input[type="submit"] {
	-webkit-appearance: none;
}

input[type='text'],
input[type='tel'],
input[type='email'],
textarea {
	display: block;
	width: 100%;
	border: solid 1px #ddd;
	padding: 5px;
	box-sizing: border-box;
}

input[type='submit'] {
	background: #c0b283;
    color: #fff;
    padding: 24px 20px;
    border-radius: 5px;
    cursor: pointer;
    transition: all .2s;
    width: 100%;
    max-width: 476px;
    font-size: 1.8rem;
    letter-spacing: 1px;
	border-bottom: 2px solid #a2966f;
	position:relative;
}

input[type='submit']:hover {
	top:2px;
	border-bottom:none;
}

textarea {
	border: solid 1px #ddd;
	padding: 5px;
	box-sizing: border-box;
	width: 100%;
}

input::-webkit-input-placeholder {
	color: #aaa;
	font-weight: normal;
}

#sidebar > .search-form {
	margin: 0 0 30px 0;
	position: relative;
}

.search-form form {
	background: #eee;
	padding: 10px;
	position: relative;
}

.search-form input[type='text'] {
	display: block;
	width: 100%;
	padding: 0 3rem 0 0;
	box-sizing: border-box;
	font-size: 1.8rem;
	line-height: 2rem;
	border: none;
}

.search-form button {
	display: block;
	width: 3rem;
	text-align: center;
	position: absolute;
	right: 10px;
	top: 10px;
}

.search-form button:before {
	font-family: 'FontAwesome';
	content: '\f002';
	font-size: 1.8rem;
	line-height: 2rem;
}

.wpcf7-radio label{
	position:relative;
	padding:0 20px;
}
.wpcf7-radio label:before {
	position: absolute;
	width : 15px;
	height: 15px;
	border: 1px solid #666;
	border-radius : 50%;
	left: 0px;
	top : 0;
	content : '';
	z-index : 3;
}
.wpcf7-radio label:after {
	content: '';
	position : absolute;
	width: 9px;
	height : 9px;
	border-radius: 100%;
	left : 4px;
	top: 4px;
	background-color : #3a4f4d;
	z-index: 1;
}
.wpcf7-radio label input[type="radio"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	position : absolute;
	z-index: 2;
	width: 20px;
	height : 20px;
	left : -23px;
	top: 1px;
	margin : 0px;
	box-shadow : 20px -1px #FFF;
}
.wpcf7-radio label input[type="radio"]:checked {
	box-shadow : none;
}
.wpcf7-radio label input[type="radio"]:focus {
	opacity: 0.2;
	box-shadow : 20px -1px #FFF;
}
.wpcf7-checkbox label{
	position:relative;
	padding:0 20px;
}
.wpcf7-checkbox label:before {
	position: absolute;
	width : 15px;
	height: 15px;
	border: 1px solid #666;
	border-radius : 2px;
	left: 0px;
	top : 0;
	content : '';
	z-index : 3;
}
.wpcf7-checkbox label:after {
	content: '';
	position : absolute;
	width: 9px;
	height : 9px;
	border-radius: 2px;
	left : 4px;
	top: 4px;
	background-color : #3a4f4d;
	z-index: 1;
}
.wpcf7-checkbox label input[type="checkbox"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	position : absolute;
	z-index: 2;
	width: 20px;
	height : 20px;
	left : -23px;
	top: 1px;
	margin : 0px;
	box-shadow : 20px -1px #FFF;
}
.wpcf7-checkbox label input[type="checkbox"]:checked {
	box-shadow : none;
}
.wpcf7-checkbox label input[type="checkbox"]:focus {
	opacity: 0.2;
	box-shadow : 20px -1px #FFF;
}

/*
----------------------------------------
clearfix
----------------------------------------
*/



.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{
clear:both;}

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


/*
----------------------------------------
common
----------------------------------------
*/

.left {
	text-align: left;
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.video {
	max-width: 800px;
	margin: 30px auto;
}

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}


/*
----------------------------------------
default
----------------------------------------
*/

html {
	font-size: 62.5%;
}

body {
	font-size: 1.5rem;
	line-height: 1.7;
	font-family: '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif;
	text-align: center;
	position: relative;
	min-width: 375px;
	-webkit-text-size-adjust: 100%;
}

.fix-body{
overflow:hidden;
}

p{
	line-height: 1.7;
}

a {
	color: #000;
	text-decoration: none;
}

ul, ol {
	list-style: none;
	margin: 0;
}

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

figcaption {
	font-size: 1.2rem;
}

div.wpcf7 .ajax-loader {
	display: none !important;
}

.sp{
	display:none;
}
.pc{
	display:block;
}

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

#wrapper {
	width: 100%;
	margin: 0 auto;
	overflow:hidden;
}

.wrap {
	margin: 0 auto;
	padding: 0 20px;
}

#sp-btn {
	display: none;
}


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

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

#header {
	min-width: 375px;
}

#header h1 {
	background: #eee;
}

#header h1 .wrap {
	font-family: 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
	padding: 2px 20px;
	font-size: 1.2rem;
}

#header .wrap {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	padding-top: 10px;
	padding-bottom: 0px;
	align-items: center;
}

#header .logo {
	margin-right: 20px;
}

#header .identity {
	margin-right: 30px;
	font-size: 3rem;
}

#header .h-txt {
	margin-right: auto;
	text-align: left;
    line-height: 1.5;
	font-size: 1.3rem;
}

#header .bnr {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	line-height: 1.4;
}

#header .bnr figure {
	margin-left: 15px;
}

#header .wrap > div {
	margin-left: 10px;
}

#header .part.flex{
	margin-bottom: 0;
	align-items: center;
	width: 50%;
}
#header .part .box{
	width: 50%;
}
#header .tel p{
	font-family: 'Helvetica Neue','Roboto', sans-serif;
    font-weight: 700;
    font-size: 3.2rem;
	line-height: 1.2;
}
#header .tel p i{
    margin-right: 2px;
    font-size: 2.9rem;
    transform: rotate(10deg);
}
	#header .tel span{
	display: block;
    background: #f1f1f1;
    font-size: 1.3rem;
    line-height: 1.7;
}

#header .btn a{
	width: 100%;
	display: inline-block;
    border:2px solid #183e73;
    background: #183e73;
    color: #fff;
    text-align: center;
    padding: 12px 13px;
    height: 100%;
    font-size: 1.5rem;
	box-sizing: border-box;
	transition: all .4s;
}
#header .btn a i{
	margin-right: 8px;
}
#header .btn a:hover{
    color: #183e73;
    background: #fff;

}

/*
----------------------------------------
g-nav
----------------------------------------
*/

#g-nav {
	background: #fff;
	z-index: 99999;
	padding: 0 10px;
	position: relative;
	width:100%;
	display:table;
	table-layout:fixed;
}

#g-nav.fixed {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: rgba(255,255,255,.9);
}

#g-nav > ul.wrap {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-around;
	padding: 0;
    position: relative;
}

#g-nav > ul > li {
	flex-grow: 1;
	position: relative;
}

#g-nav > ul > li > a {
	display: block;
	padding: 15px 5px;
	color: #000;
	transition: all .2s;
	font-weight: bold;
	font-size:1.6rem;
	transition: all .4s;
}
#g-nav > ul > li > a:hover {
	color: #7f1291;
}
#g-nav > ul > li:before {
	content:"";
	position: absolute;
	top: 21px;
	right: 0;
	border-right: 1px solid #a6a6a6;
	width: 1px;
	height: 1em;
	box-sizing: border-box;
	transform: rotate(25deg);
}
#g-nav > ul > li:last-child:before {
	display:none;
}

#g-nav > ul > li > a:hover {
}

/* sub-menu */

#g-nav li ul {
	min-width: 100%;
	position: absolute;
	top: 90%;
	left: 0;
	background: #f7f7f7;
	visibility: hidden;
	opacity: 0;
	z-index: 999999;
	transition: all .2s;
}

#g-nav li:last-child ul {
	right: 0;
	left: auto;
}

#g-nav li:hover ul {
	top: 100%;
	visibility: visible;
	opacity: 1;
}

#g-nav li ul li {
	border-bottom: solid 1px #ccc;
}

#g-nav li ul a {
	display: block;
	padding: 15px 20px;
	text-align: left;
	white-space: nowrap;
	transition: all .2s;
}

#g-nav li ul a:hover {
	background: #555;
	color: #fff;
}


/*
----------------------------------------
page-ttl
----------------------------------------
*/

#page-ttl {
	background: url(img/common/bg-page.png) no-repeat top center;
	background-size:cover;
	padding: 75px 20px;
}

#page-ttl .box {
	display: inline-block;
	background: rgba( 255,255,255,.8 );
	padding: 35px 40px;
	line-height: 1.4;
	min-width: 300px;
	box-sizing: border-box;
}

#page-ttl .box h2 {
	font-size: 3rem;
	font-weight: normal;
}

#page-ttl .box h2.en {
	font-size: 4rem;
}
#page-ttl .box h2.futura {
	font-size: 4rem;
    letter-spacing: 4px;
    font-weight: 700;
	color:#183e73;
}

#page-ttl .box p {
	font-size: 1.5rem;
	letter-spacing: 2px;
}

#page-ttl .box p.en {
	font-size: 2rem;
}


/*
----------------------------------------
topic-path
----------------------------------------
*/

.topic-path {
	padding: 10px 0;
	margin-bottom: 20px;
	background: #fafafa;
}

.topic-path .wrap {
	text-align: left;
}

.topic-path i {
	margin: 0 5px;
}


/*
----------------------------------------
container
----------------------------------------
*/

#container {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-direction: row;
	text-align: left;
	margin-top: 20px;
	padding: 0 0 60px;
	max-width: 1080px;
	justify-content: space-between;
}

#contents {
	width: 75%;
	margin-bottom: 30px;
	padding: 0 !important;
	box-sizing: border-box;
}

#head-contents {
	margin: 20px auto;
	text-align: left;
	max-width: 1080px;
}
#head-contents .wrap{
	padding:0;
}

#head-contents .flex{
	align-items: center;
}
#head-contents .flex > * {
    padding: 0;
    width: 45%;
}
#head-contents .top-txt .flex > *{
	width:100%;
	box-sizing:border-box;
	text-align:center;
	color: #fff;
	background: #183e73;
	padding: 20px 15px;
	font-size: 1.8rem;
}

#head-contents .flex > .heading-01 {
    padding: 0;
    width: 45%;
	padding: 20px;
	font-size: 2.8rem;
	box-sizing:border-box;
	margin:0;
}
#head-contents .flex > p {
    padding: 0;
    width: 50%;
	padding: 10px 0;
	font-size: 1.5rem;
	box-sizing:border-box;
}

#sidebar {

	width: 21%;
	padding: 0 !important;
	box-sizing: border-box;
}


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

.contents section {
	margin-bottom: 65px;
	padding: 20px;
	border: solid 1px #eee;
	padding: 0;
	border: none;
}

.contents > section > figure {
	line-height:1;
	margin: 0 auto 25px auto;
	padding: 0;
	box-sizing: border-box;
}

.contents > section > p {
	margin: 0 auto 25px auto;
}

#contents > p,
#contents > figure {
	margin-bottom: 30px;
}

#contents .bnr {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	margin: 30px 0;
}

#contents .bnr figure {
	text-align: center;
	padding: 0 5px;
}

#contents .post {
	padding: 30px 30px 20px 30px;
	border: solid 1px #ddd;
	margin-bottom: 30px;
}

#contents ul.cat-list {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

#contents ul.cat-list li {
	margin: 0 5px 5px 0;
}

#contents ul.cat-list a {
	display: inline-block;
	padding: 2px 12px;
	background: #999;
	font-size: 1.2rem;
	color: #fff;
	border-radius: 4px;
	transition: all .4s;
}

#contents ul.cat-list a:hover {
	background: #000;
}

.post .post-header {
	border-bottom: solid 1px #ccc;
	padding-bottom: 20px;
	margin-bottom: 30px;
}

#contents .post .post-header h1,
#contents .post .post-header h1 a {
	line-height: 1.4;
	margin-bottom: 5px;
}

.post-contents h1,
.post-contents h2,
.post-contents h3,
.post-contents h4,
.post-contents h5,
.post-contents h6 {
	border-bottom: solid 1px #ccc;
	padding: 0 0 10px 0;
	margin-bottom: 20px;
}

.post .flex {
	margin: 20px 0;
}

.post .flex > .thumb {
	width: 40%;
	padding-right: 30px;
	box-sizing: border-box;
}

.post .flex > .txt {
	width: 100%;
}

.post .flex > .thumb + .txt {
	width: 60%;
}

.post .flex > .txt p {
	margin-bottom: 20px;
}

.post .more {
	text-align: right;
}

.post .more a {
	display: inline-block;
	padding: 2px 25px 2px 10px;
	margin: 10px 0;
	border-bottom: solid 2px #000;
	position: relative;
	transition: all .2s;
}

.post .more a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	top: 2px;
	right: 10px;
	transition: all .2s;
}

.post .more a:hover:after {
	right: 5px;
}

.post-contents p,
.post-contents a {
	font-size: 1.5rem;
}

.post-contents .photo {
	text-align: center;
}

.post-contents img {
	max-width: 100%;
	height: auto;
}

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

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

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

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

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

.post-contents blockquote {
	background: #f3f3f3 url() 20px 20px no-repeat;
	padding: 30px 60px 10px 60px;
	margin-bottom: 30px;
	border-radius: 12px;
}

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

.post-nav {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 60px 0;
}

.post-nav .prev,
.post-nav .next {
	width: 40%;
}

.post-nav a {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	padding: 0 0 0 3rem;
	position: relative;
}

.post-nav .next a {
	flex-direction: row-reverse;
	padding: 0 3rem 0 0;
}

.post-nav a:before {
	font-family: 'FontAwesome';
	position: absolute;
	top: 50%;
	font-size: 3rem;
	transform: translate( 0, -50% );
	transition: all .2s;
}

.post-nav .prev a:before {
	content: '\f104';
	left: 5px;
}

.post-nav .prev a:hover:before {
	left: 0;
}

.post-nav .next a:before {
	content: '\f105';
	right: 5px;
}

.post-nav .next a:hover:before {
	right: 0;
}

.post-nav img {
	width: 30%;
	line-height: 1;
}

.post-nav .prev img {
	margin: 0 15px 0 0;
}

.post-nav .next img {
	margin: 0 0 0 15px;
}

.post-nav .back-link {
	width: 16%;
}

.post-nav .back-link a {
	display: block;
	text-align: center;
	padding: 15px 5px;
	box-sizing: border-box;
	border: solid 1px #ccc;
	border-radius: 5px;
	transition: all .2s;
}

.post-nav .back-link a:hover {
	background: #000;
	color: #fff;
}

.page-nav .wp-pagenavi {
	clear: both;
	text-align: center;
	margin-top: 60px;
}

.page-nav .wp-pagenavi a,
.page-nav .wp-pagenavi span {
	font-size: 1.5rem;
	padding: 10px 15px;
	margin: 3px;
	border-radius: 4px;
	transition: all .4s;
}

.page-nav .wp-pagenavi a:hover,
.page-nav .wp-pagenavi span.current {
	background: #000;
	color: #fff;
}

.addtoany_share_save_container {
	background: #fafafa;
	padding: 20px;
	margin: 40px 0;
}

#contents section.relation-post {
	padding: 0;
}

#contents section.relation-post h2 {
	text-align: center;
	background: #333;
	color: #fff;
	font-size: 1.6rem;
	padding: 5px;
	margin-bottom: 0;
}

#contents section.relation-post .flex {
	padding: 10px;
	margin-bottom: 0;
}

#contents section.relation-post .flex h3 {
	font-size: 1.6rem;
}

#contents section.relation-post ul.cat-list {
	margin-bottom: 5px;
}

#contents section.relation-post ul.cat-list a {
	font-size: 1.1rem;
}

#contents section.relation-post p.user {
	font-size: 1.3rem;
}


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

#sidebar .back-link a {
	display: block;
	padding: 15px;
	font-size: 1.6rem;
	text-align: center;
	border: solid 1px #ccc;
	border-radius: 5px;
	margin-bottom: 30px;
	transition: all .2s;
}

#sidebar .back-link a:hover {
	background: #000;
	color: #fff;
}

#sidebar .back-link a:before {
	font-family: 'FontAwesome';
	content: '\f104';
	margin-right: 1rem;
	position: relative;
	left: 0;
	transition: all .2s;
}

#sidebar .back-link a:hover:before {
	color: #fff;
	left: -5px;
}

#sidebar .bnr {
	margin-bottom: 15px;
}

#sidebar .bnr figure {
	margin-bottom: 10px;
}

#sidebar .bnr figcaption {
	text-align: left;
}

#sidebar > div {
	margin-bottom: 15px;
}

.side-menu h2 {
	font-size: 1.6rem;
	border-top: solid 2px #000;
	border-bottom: solid 2px #000;
	padding: 5px;
	position: relative;
	font-weight:700;
	text-align:center;
	font-family: 'Helvetica Neue','Roboto', sans-serif;
}

.side-menu h2 .en {
	font-size: 1.4rem;
	position: absolute;
	right: 0;
	bottom: 5px;
}

.side-menu {
	margin-bottom: 30px;
}

.side-menu .box{
	padding: 15px;
}
/*
.side-menu > ul > li {
	border-bottom: solid 1px #e1e1e1;
}

.side-menu li li {
	border-top: solid 1px #e1e1e1;
}
*/
.side-menu ul li a {
	display: block;
	padding: 18px 20px 18px 20px;
	position: relative;
	transition: all .2s;
	font-weight:bold;
	border-bottom: solid 1px #e1e1e1;
	text-indent: -10px;
}

.side-menu ul.children{
	margin-left:1em;
}

.side-menu ul li a:before{
	content:"";
	/*vertical-align:middle;*/
	margin-right: 7px;
}
.side-menu > ul > li > a:before{
	width:4px;
	height:1.2em;
	display:inline-block;
	background:#183e73;
	vertical-align: text-top;
}

.side-menu ul li a:hover {
	background: #fafafa;
}

.side-menu ul li a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	right: 7px;
	top: 50%;
	transition: all .2s;
	font-weight:normal;
	margin-top: -.5em;
	line-height: 1em;
}

.side-menu ul li a:hover:after {
	right: 10px;
}

.side-menu li li a:before {
	content: '-';
	margin-right: 10px;
}

.side-menu.box-menu {
    background: #f6f6f6;
	padding: 20px;
    border: none;
    padding: 0;
}
.side-menu .tel {
	margin-bottom:10px;
	text-align:center;
}
.side-menu .tel p{
	font-family: 'Helvetica Neue','Roboto', sans-serif;
    font-weight: 700;
    font-size: 2.5rem;
	line-height: 1.2;
}
.side-menu .tel p i{
    margin-right: 2px;
    font-size: 2rem;
    transform: rotate(10deg);
}
.side-menu .tel span{
	display: block;
    font-size: 1.2rem;
    line-height: 1.7;
}
.side-menu .btn a{
	width: 100%;
	display: inline-block;
    background: #183e73;
    border: 2px solid #183e73;
    color: #fff;
    text-align: center;
    padding: 14px 15px;
    height: 100%;
    font-size: 1.3rem;
	box-sizing: border-box;
}
.side-menu p{
	margin:10px 0;
}
.side-menu .btn a i{
	margin-left: 8px;
}
#s-company a{
    color: #183e73;
    background: transparent;
}
#s-company a:hover{
    background: #183e73;
    color: #fff;
}
#s-company h3{
	font-weight:bold;
	color:#183e73;
	font-size:1.6rem;
}
#s-company p{
	font-size:1.2rem;
}

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

.bottom-contents{
	border-top: solid 1px #ccc;
	padding: 30px 20px;
}

footer {
	background: #000 url(img/common/bg-footer.png) no-repeat 0 50%;
	background-size:cover;
}
footer *{
	color:#fff !important;
}

footer .wrap {
	text-align: left;
	padding: 30px 20px;
}

footer .f-02{
	padding: 0 20px;
}

footer .f-01{
	align-items: center;
	justify-content: space-around;
	border-bottom: solid 1px #6d6d6d;
}

footer #bottom-nav {
	flex: 5;
	padding-right: 20px;
	box-sizing: border-box;
}

footer #bottom-nav h2 {
	font-size: 2rem;
	letter-spacing:2px;
	/*padding-bottom: 5px;
	margin-bottom: 10px;*/
}

footer #bottom-nav .flex > ul,
footer #bottom-nav div  > ul.flex,
footer #bottom-nav .menu > ul {
	flex: 1;
}

footer #bottom-nav div  > ul.flex{
	justify-content: left;
	padding: 10px 0;
}
footer #bottom-nav div  > ul.flex li {
	flex-wrap: wrap;
	width: 33.3333%;
	box-sizing: border-box;
}

footer #bottom-nav .flex > ul > li > a,
footer #bottom-nav div  > ul.flex li a,
footer #bottom-nav .menu > ul > li > a {
	padding-left: 1rem;
	position: relative;
}

footer #bottom-nav .flex > ul > li > a:before,
footer #bottom-nav div  > ul.flex li a:before,
footer #bottom-nav .menu > ul > li > a:before {
	content: '-';
    position: absolute;
    top: -5px;
    left: 0;
    color: #a0946d;
}

footer #bottom-nav li li a {
	display: inline-block;
	font-size: 1.2rem;
	margin-left: 1rem;
	text-decoration: underline;
}

footer #bottom-nav .sub-menu {
	margin-bottom: 1.5rem;
}

footer #bottom-nav .sub-menu li {
	display: inline-block;
}

footer .store-info {
	flex: 2;
	padding: 0 20px;
	box-sizing: border-box;
}

footer .store-info p{
	font-size: 1.5rem;
	line-height:1.5;
}

footer .store-info h2 {
	font-size: 1.8rem;
	margin-bottom: 10px;
	padding-left: 10px;
	border-left: solid 4px #000;
}

footer .store-img {
	/*flex: 2;*/
	padding-right:20px;
	text-align: left;
	box-sizing: border-box;
	font-size: 1.5rem;
}

footer .store-img figure{
	margin-bottom:0;
}

footer .store-btn{
	width:25%;
}

footer .store-btn .btn a{
	font-size: 1.5rem;
	line-height:1.5;
    display: block;
    border: 1px solid #fff;
    padding: 15px 20px;
    width: 100%;
    text-align: center;
    box-sizing: border-box;
	max-width: 318px;
	margin: 0 auto;
}

footer .store-btn .btn i{
	margin-left:5px;
}

.copyright {
	color: #fff;
	padding: 10px 20px;
	background: #000;
}

.copyright small {
	font-size: 1.4rem;
}

.copyright a {
	color: #fff;
}

#bottom-fix {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: fixed;
	right: 30px;
	bottom: 30px;
}

#bottom-fix .tel,
#bottom-fix .contact {
	display: none;
}

#bottom-fix .contact a,
#page-top a {
	display: block;
	width: 60px;
	height: 60px;
	line-height: 60px;
	font-size: 3rem;
	background: #000;
	color: #fff;
	text-align: center;
	transition: all .4s;
}

#bottom-fix .contact a {
	font-size: 2rem;
	background: #183e73;
}

#bottom-fix .contact a:hover {
	background: #999;
}

#page-top a:hover {
	background: #555;
}


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

.flex {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: stretch;
	margin: 0 0 30px 0;
}

.flex.nowrap {
	flex-wrap: nowrap;
}

.flex.reverce {
	flex-direction: row-reverse;
}

.flex.item-center {
	align-items: center;
}

.flex figure {
	margin-bottom: 5px;
	text-align: center;
	line-height:1;
}
.flex .box img{
	width: 100%;
	object-fit: contain;
	font-family: 'object-fit: contain; object-position: center top;'
}

.flex > li {
	padding: 5px;
}

/* column */

#contents > section .flex .box.pic,
#contents > section .flex .box.txt {
    margin-top: 25px;
}

.flex .box.pic {
	width: 40%;
	padding: 0 20px 0 0;
	box-sizing: border-box;
	text-align: center;
}

.flex.reverce .box.pic {
	padding: 0 0 0 20px;
}

.flex .box.txt {
	width: 60%;
	box-sizing: border-box;
	padding: 0;
	margin-bottom: 5px;
}

#contents .flex .box.txt h1,
#contents .flex .box.txt h2,
#contents .flex .box.txt h3 {
	font-size: 2rem;
}

/* box */

.flex .box {
	padding: 5px;
	box-sizing: border-box;
	position: relative;
}

.flex .box .num {
	position: absolute;
	left: 5px;
	top: 5px;
	width: 40px;
	height: 40px;
	line-height: 40px;
	background: #000;
	color: #fff;
	text-align: center;
	font-size: 1.8rem;
}

.flex.box-02 .box {
	width: 50%;
}

#contents .flex.box-02 h1,
#contents .flex.box-02 h2,
#contents .flex.box-02 h3 {
	font-size: 2rem;
}

.flex.box-03 .box {
	width: 33.3333%;
}

#contents .flex.box-03 h1,
#contents .flex.box-03 h2,
#contents .flex.box-03 h3,
#contents .flex.box-03 h4 {
	font-size: 1.8rem;
}

.flex.box-04 .box {
	width: 25%;
	font-size: 1.3rem;
}

#contents .flex.box-04 h1,
#contents .flex.box-04 h2,
#contents .flex.box-04 h3,
#contents .flex.box-04 h4,
#contents .flex.box-04 h5 {
	font-size: 1.6rem;
}

.flex.box-05 .box {
	width: 20%;
	font-size: 1.3rem;
}

.flex.box-06 .box {
	width: 16.6666%;
	font-size: 1.3rem;
}


/*
----------------------------------------
font
----------------------------------------
*/

.acf-input {
	font-size: 62.5%;
}

.acf-input h2 {
	font-weight: bold !important;
	color: #444;
	background: #F9F9F9;
	border: solid 1px #E1E1E1;
	margin-bottom: 20px !important;
}

.en {
	font-family: 'Roboto Slab', serif;
}

.helvetica{
	font-family: 'Helvetica','Roboto', sans-serif;
	font-weight:700;
}

.futura{
	font-family: 'Quattrocento Sans', sans-serif;
	font-weight:700;
}

.gothic {
	font-family: 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', '游ゴシック', YuGothic, sans-serif;
}

.mincho {
	font-family: ’ヒラギノ明朝 ProN W3’, ’Hiragino Mincho ProN’, ’游明朝’, YuMincho, ’ＭＳ Ｐ明朝’, ’ＭＳ 明朝’, serif;
}

strong {
	font-weight: normal;
}

.alnR{
	text-align: right;
}

.alnL{
	text-align: left;
}


.alnC{
	text-align: center;
}

p span.alnC,
p span.alnL,
p span.alnR{
	display:block;
}

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

h1.center,
h2.center,
h3.center,
h4.center,
h5.center,
h6.center {
	text-align: center;
}

.contents h1,
.contents h2,
.contents h3,
.contents h4,
.contents h5,
.contents h6 {
	margin-bottom: 15px;
}

.contents h1 {
	font-size: 2.4rem;
}

.contents h2 {
	font-size: 2.2rem;
}

.contents h3 {
	font-size: 2rem;
}

.contents h4,
.contents h5,
.contents h6 {
	font-size: 1.8rem;
}

.contents .heading-01,
.contents .heading-02,
.contents .heading-03,
.contents .heading-04,
.contents .heading-05,
.contents .heading-06 {
	margin-bottom: 25px;
}

/* heading-01 */

.contents .heading-01 {
	color: #fff;
	background: #183e73;
	padding: 10px 15px;
	font-size: 2.8rem;
}

/* heading-02 */


.contents .heading-ttl,
.contents .heading-02 {
	color: #333;
	background: none;
	padding: 0px 15px 18px 15px;
	font-size: 3.5rem;
	text-align: center;
	font-weight: 700;
	position: relative;
	margin-bottom: 45px;
}
.contents .heading-ttl:after,
.contents .heading-02:after{
	content:"";
	display:block;
	width:78px;
	height:3px;
	background:#183e73;
	margin:12px auto 0 auto;
	font-weight: bold;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left:-39px;
	z-index:2;
}

/* heading-03 */

.contents .heading-03 {
	color: #333;
    background: none;
    padding: 0;
    font-size: 2.6rem !important;
    font-weight: bold;
}
.contents .heading-03:after{
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	background: #dcdcdc;
	border-left: 78px solid #183e73;
	margin: 7px auto 0 auto;
	box-sizing: border-box;
}

/* heading-04 */

.contents .heading-04 {
    border-left: solid 3px #183e73;
    padding-left: 10px;
    font-weight: bold;
    line-height: 1.1;
}

/* heading-05 */

.contents .heading-05 {
    font-size: 2.3rem !important;
    font-weight: bold;
	color:#183e73;
}

/* heading-06 */

.contents .heading-06 {
	color: #fff;
	background: #183e73;
	padding: 10px 15px;
	position: relative;
}

/* heading-07 */

.contents .heading-07 {
	color: #fff;
	background: #183e73;
	padding: 10px 15px;
	border-radius: 5px;
	position: relative;
}
.contents .heading-07:after {
	content: '';
	width: 0;
	height: 0;
	border: solid 8px transparent;
	border-top: solid 10px #333;
	position: absolute;
	top: 100%;
	left: 40px;
}

/*
----------------------------------------
bottun
----------------------------------------
*/

.btn-01 a,
.btn-02 a,
.btn-03 a,
.btn-04 a,
.btn-05 a,
.btn-06 a {
	text-decoration: none;
	color: #000;
	margin: 20px 0;
	transition: all .2s;
	width: 90%;
	max-width: 400px;
	box-sizing: border-box;
}

.btn-01.center a,
.btn-02.center a,
.btn-03.center a,
.btn-04.center a,
.btn-05.center a,
.btn-06.center a {
	margin: 20px 5px;
}
/*
.btn-01 a {
	display: inline-block;
	padding: 17px 40px 17px 30px;
	color: #fff;
	background: #183e73;
	border: 2px solid #183e73;
	line-height: 1.5;
	position: relative;
}
*/

.btn-01 a{
	display: inline-block;
	padding: 17px 40px 17px 30px;
	color: #fff;
	background: #183e73;
	border: 2px solid #183e73;
	line-height: 1.5;
	position: relative;
	background:#183e73;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px transparent;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  z-index:2;
}
/* Sweep To Right */
.btn-01 a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.btn-01 a:hover,
.btn-01 a:focus,
.btn-01 a:active{
  color: #183e73;
}
.btn-01 a:hover:before,
.btn-01 a:focus:before,
.btn-01 a:active:before{
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}
.btn-01 a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	top: 17px;
	right: 15px;
	transition: all .2s;
}
/*
.btn-01 a:hover {
	color: #183e73;
	background: #fff;
}

.btn-01 a:hover:after {
	right: 10px;
}
*/
.btn-02 {
	text-align: center;
}
/*
.btn-02 a {
	display: inline-block;
	padding: 17px 40px 17px 30px;
	color: #183e73;
	background: #fff;
	border: 2px solid #183e73;
	line-height: 1.5;
	position: relative;
}
*/
.btn-02 a{
	display: inline-block;
	padding: 17px 40px 17px 30px;
	color: #183e73;
	background: #fff;
	border: 2px solid #183e73;
	line-height: 1.5;
	position: relative;
	background:#fff;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px transparent;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  z-index:2;
}

/* Sweep To Right */
.btn-02 a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #183e73;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.4s;
  transition-duration: 0.4s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.btn-02 a:hover,
.btn-02 a:focus,
.btn-02 a:active{
  color: #fff;
}
.btn-02 a:hover:before,
.btn-02 a:focus:before,
.btn-02 a:active:before{
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

.btn-02 a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	top: 17px;
	right: 15px;
	transition: all .2s;
}
/*
.btn-02 a:hover {
	color: #fff;
	background: #183e73;
}
*/
.btn-03 a {
	padding: 10px 0;
    transition: all .2s;
    color: #183e73;
    font-size: 1.5rem;
    transition: all .4s;
    text-align: left;
    display: block;
    max-width: 100%;
    width: 100%;
    font-weight: bold;
	position: relative;
	padding-left: 30px;
}

.btn-03 a:before {
	content: '';
	width:1.5rem;
	height:2px;
	background: #183e73;
	display:inline-block;
	vertical-align:middle;
	margin-right: 8px;
	font-weight:bold;
	position: absolute;
	top: 50%;
	left: 0;
}
/*
.btn-03 a:hover:before {
	position:relative;
	right:100%;
}
*/
.btn-04 a {
	display: inline-block;
	padding: 2px 25px 2px 10px;
	border-bottom: solid 2px #000;
	position: relative;
	transition: all .2s;
}

.btn-04 a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	top: 2px;
	right: 10px;
	transition: all .2s;
}

.btn-04 a:hover:after {
	right: 5px;
}

.btn-05 a {
	display: inline-block;
	padding: 0 15px 0 20px;
	height: 30px;
	line-height: 30px;
	white-space: nowrap;
	border: solid 2px #ccc;
	border-radius: 16px;
	transition: all .2s;
}

.btn-05 a:after {
	font-family: 'FontAwesome';
	content: '\f061';
	margin-left: 5px;
}

.btn-05 a:hover {
	background: #eee;
}

.btn-06 a {
	display: inline-block;
	padding: 0 15px 0 20px;
	height: 30px;
	line-height: 30px;
	white-space: nowrap;
	border: solid 2px #ccc;
	border-radius: 16px;
	transition: all .2s;
}

.btn-06 a:after {
	font-family: 'FontAwesome';
	content: '\f105';
	margin-left: 5px;
}

.btn-06 a:hover {
	color: #fff;
	background: #000;
}
.pdf {
	margin: 20px 0;
}


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

table caption {
	caption-side: bottom;
	padding-top: 15px;
	font-size: 1.3rem;
}

table.cell-02 th {
	width: 25%;
}

table.cell-02.fixed th,
table.cell-02.fixed td {
	width: 50%;
}

table.cell-03.fixed th,
table.cell-03.fixed td {
	width: 33.3333%;
}

table.cell-04.fixed th,
table.cell-04.fixed td {
	width: 25%;
}

table.cell-05.fixed th,
table.cell-05.fixed td {
	width: 20%;
}

table.cell-06.fixed th,
table.cell-06.fixed td {
	width: 16.6666%;
}

/* table-01 */

.table-01 {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	margin: 30px 0;
}

.table-01 thead th,
.table-01 thead td {
	color: #fff;
	background: #000;
	text-align: center;
}

.table-01 th {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	background: #f9f9f9;
	font-weight: normal;
	vertical-align: top;
}

.table-01 td {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	vertical-align: top;
}

/* table-02 */

.table-02 {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	margin: 30px 0;
}

.table-02 th {
	padding: 20px 10px;
	border-bottom: solid 1px #ccc;
	font-weight: normal;
}

.table-02 td {
	padding: 20px 10px;
	border-bottom: solid 1px #ccc;
}

/* table-03 */

.table-03 {
	width: 100%;
	text-align: left;
	margin: 30px 0;
}

.table-03 th,
.table-03 td {
	padding: 20px 10px;
	font-size:1.7rem;
	vertical-align: bottom;
}

.table-03 th {
	border-bottom: solid 2px #566f93;
	font-weight: bold;
	text-align: center;
}

.table-03 td {
	border-bottom: solid 1px #d2d2d2;
}


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

input, button, textarea, select {
	/*-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;*/
}


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

.list-block {
	margin: 20px 0;
}

/* arrow */

.li-arrow ul {
	display: inline-block;
	margin: 0 auto;
	font-size: 1.6rem;
	text-align: left;
}

.li-arrow li {
	position: relative;
	padding: 0 2rem;
}

.li-arrow li:before {
	font-family: 'FontAwesome';
	content: '\f105';
	position: absolute;
	left: 0;
	top: 0;
}

/* check */

.li-check ul {
	display: inline-block;
	margin: 0 auto;
	font-size: 1.6rem;
	text-align: left;
}

.li-check li {
	position: relative;
	padding: 0 2rem;
	line-height: 1.4;
	margin-bottom: 10px;
}

.li-check li:before {
	font-family: 'FontAwesome';
	content: '\f046';
	position: absolute;
	left: 0;
	top: 0;
}


/*
----------------------------------------
dl
----------------------------------------
*/

.dl-01 {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 10px 0 0 0;
}

.dl-01 dt {
	width: 20%;
	font-size: 1.1rem;
	line-height: 2rem;
	text-align: center;
	background: #222;
	color: #fff;
	margin-bottom: 10px;
}

.dl-01 dd {
	width: 77%;
	margin-bottom: 10px;
	line-height: 2rem;
}

/*
----------------------------------------
about
----------------------------------------
*/


#about .sec-03 .flex .box .num {
    position: absolute;
    left: 10px;
    top: 10px;
    font-family: 'Helvetica','Roboto', sans-serif;
    font-weight: 700;
	background: none;
	width: auto;
	height: auto;
	line-height: 1;
	font-size:9.2rem;
}
#about .sec-03 .flex .box .num:before {
    content: "0";
    display: inline-block;
}
#about .sec-03 .flex.box-02 .box{
	margin-bottom:2em;
}
#about .sec-03 .flex.box-02 h3 {
	font-size: 2rem;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    color: #fff;
    display: inline;
    vertical-align: middle;
    padding: 10px;
    box-sizing: border-box;
    margin-top: -25px;
}
#about .sec-03 .flex.box-02 .btn-01{
    position: absolute;
    width: 100%;
    right: 0;
    bottom: -1em;;
    margin: 0;
	text-align: right;
	padding: 0 10px;
	box-sizing: border-box;
}
#about .sec-03 .flex.box-02 .btn-01 a{
    margin: 0;
	text-align: center;
}

/*
----------------------------------------
other
----------------------------------------
*/

#other .sec-01 {
    margin-bottom: 100px;
}
#other .sec-01 .flex.box-03 .btn-01{
    position: absolute;
    width: 100%;
    right: 0;
    bottom: -20px;
    margin: 0;
	text-align: right;
	padding: 0 10px;
	box-sizing: border-box;
}
#other .sec-01 .flex.box-03 .btn-01 a {
    margin: 0;
    text-align: left;
    box-sizing: border-box;
    padding: 22px 30px;
	width: 70%;
}
#other .sec-01 .flex.box-03 .btn-01 a:after {
	display:none;
}
#other #other-box {
	margin-top:85px;
}

/*
----------------------------------------
faq
----------------------------------------
*/

#contents #faq-menu {
	background: #fff;
	padding: 0;
	border: none;
}

#faq-menu h2{
	margin-bottom:0;
}
#faq-menu h2 a{
	color:#fff;
}
/*
#faq-menu h2:before {
	font-family: 'FontAwesome';
	content: '\f111';
	margin-right: 1rem;
	font-size: 1.4rem;
	vertical-align: middle;
	color: #ccc;
}
*/
#faq-menu .box{
	padding:0;
	background: #fafafa;
	margin-bottom:20px;
	width: 100%;
	margin: 0 0 25px !important;
}
#faq-menu .box ul{
    padding: 15px;
}
#faq-menu li a {
	display: block;
	padding: 2px 0;
	font-size: 1.6rem;
}
#faq-menu li a{
	font-size: 1.7rem;
	color:#333;
	text-decoration:underline;
}
#faq-menu li a:hover{
	text-decoration:none;
}
#faq-menu li a:before {
	content: 'Q';
	color: #183e73;
	font-size: 2.6rem;
	font-family: 'Arial Black', 'Arial Bold', Gadget, sans-serif;
	display:inline-block;
	vertical-align: baseline;
	margin-right: 10px;
	font-weight:normal;
}

.faq-list dl {
	margin: 20px 0;
	background: #fff;
}

.faq-01 dt {
	font-size: 2rem;
	padding: 25px 0 10px 5rem;
	border-top: solid 1px #ccc;
	position: relative;
}

.faq-01 dt:first-of-type {
	border-top: none;
	padding-top: 0;
}

.faq-01 dt:first-of-type:before {
	top: 2px;
}

.faq-01 dd {
	padding: 0 0 20px 5rem;
	position: relative;
}

.faq-01 dt:before,
.faq-01 dd:before {
	font-size: 1.4rem;
	font-family: 'Roboto Slab', serif;
	text-align: center;
	line-height: 3.4rem;
	display: inline-block;
	width: 3.4rem;
	height: 3.4rem;
	position: absolute;
	left: 0;
}

.faq-01 dt:before {
	content: 'Q';
	color: #fff;
	background: #000;
	top: 27px;
}

.faq-01 dd:before {
	content: 'A';
	background: #ddd;
	top: 2px;
}

.faq-02 dt {
	font-size: 2rem;
	padding: 5px 0 5px 8rem;
	margin-bottom: 15px;
	border-top: solid 1px #555;
	border-bottom: solid 1px #555;
	position: relative;
}

.faq-02 dd {
	padding: 35px 0 40px 0;
	position: relative;
}

.faq-02 dt:before {
	content: 'Q';
	font-family: 'Roboto Slab', serif;
	background: transparent !important;
	text-align: center;
	display: inline-block;
	width: 6rem;
	border-right: solid 1px #555;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate( 0, -50% );
}

.faq-02 dd:before {
	display: inline-block;
	content: 'Answer';
	font-family: 'Roboto Slab', serif;
	font-size: 1.2rem;
	padding: 2px 20px;
	position: absolute;
	top: 0;
	left: 0;
	background: #333;
	color: #fff !important;
}

.faq-03 dt{
	font-size: 1.7rem;
	color:#333;
	font-weight:bold;
}
.faq-03 dt:before {
	content: 'Q';
	color: #183e73;
	font-size: 2.6rem;
	font-family: 'Arial Black', 'Arial Bold', Gadget, sans-serif;
	display:inline-block;
	vertical-align: baseline;
	margin-right: 10px;
	font-weight:normal;
}
.faq-03 dd {
	padding: 10px 0 20px 0;
	position: relative;
	border-bottom: 2px dotted #ccc;
	margin-bottom: 10px;
}

/*
----------------------------------------
flow
----------------------------------------
*/

/* flow-column */

.flow-column .flex {
	padding-top: 60px;
	position: relative;
}

.flow-column .flex:after {
	font-family: 'FontAwesome';
	content: '\f107';
	font-size: 5rem;
	line-height: 1;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate( -50%, 0 );
}

.flow-column .flex:first-of-type {
	padding-top: 10px;
}

.flow-column .flex:first-of-type:after {
	display: none;
}

/* flow */

.flow.flex .box {
	padding: 10px 40px;
	position: relative;
}

.flow.flex .box:before {
	font-family: 'FontAwesome';
	content: '\f105';
	font-size: 4rem;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate( -50%, -50% );
}

.flow.flex .box:first-child:before,
.flow.flex.box-02 .box:nth-child(2n+1):before,
.flow.flex.box-03 .box:nth-child(3n+1):before,
.flow.flex.box-04 .box:nth-child(4n+1):before,
.flow.flex.box-05 .box:nth-child(5n+1):before,
.flow.flex.box-06 .box:nth-child(6n+1):before {
	display: none;
}


/*
----------------------------------------
gallery
----------------------------------------
*/

.gallery {
	width: 100%;
	max-height: 450px;
	margin: 20px auto;
	overflow: auto;
}

.gallery figure {
	width: 200px;
	padding: 0 5px 2px 5px;
	box-sizing: border-box;
	margin-bottom: 0 !important;
}

.gallery.box-100 figure {
	width: 100px;
}

.gallery.box-150 figure {
	width: 150px;
}

.gallery.box-200 figure {
	width: 200px;
}

.gallery.box-250 figure {
	width: 250px;
}

.gallery.box-300 figure {
	width: 300px;
}


/*
----------------------------------------
map
----------------------------------------
*/

.map  {
	width: 100%;
	height: 400px;
	margin: 40px 0;
	border: solid 1px #ddd;
}


/*
----------------------------------------
slider
----------------------------------------
*/

.slider {
	margin: 40px 0 90px 0;
	text-align: center;
}

.slider .slick-slide img {
	display: inline-block;
}

.slider.thumb-slider {
	margin: 0;
}

.slider.thumb-slider + .thumb {
	margin-bottom: 40px;
}

.slider.thumb-slider + .thumb figure {
	padding: 0 5px;
	box-sizing: border-box;
}

.slider.slick-dotted.slick-slider {
	margin: 0 0 60px 0;
}

.slider .slick-dots {
	bottom: -30px;
}


/*
----------------------------------------
tel-bnr-1
----------------------------------------
*/


#tel-top{
	background:#183e73;
	padding:60px 0;
	position:relative;
}
#tel-top h2{
	text-align:center;
	margin-bottom:30px;
}
.tel-bnr-1 .part.flex{
	width: 95%;
	max-width: 810px;
	margin: 0 auto;
	background: #fff;
	padding: 25px;
	box-sizing: border-box;
	align-items: center;
	border:1px solid #183e73;
}
.tel-bnr-1 .tel{
	width: 40%;
	text-align: center;
}
.tel-bnr-1 .btn{
	width: 35%;
}
.tel-bnr-1 .ttl{
	width: 25%;
	position:relative;
}
.tel-bnr-1 .ttl:before {
	content: "";
    position: absolute;
    top: 0;
    right: 10px;
    border-right: 1px solid #95a6bf;
    width: 1px;
    height: 110%;
    box-sizing: border-box;
    transform: rotate(25deg);
}
.tel-bnr-1 .tel p{
	font-family: 'Helvetica Neue','Roboto', sans-serif;
    font-weight: 700;
    font-size: 3.4rem;
	line-height: 1.2;
}
.tel-bnr-1 .tel p i{
    margin-right: 2px;
    font-size: 2.9rem;
    transform: rotate(10deg);
}
.tel-bnr-1 .tel span{
	display: block;
    background: #f1f1f1;
    font-size: 1.3rem;
    line-height: 1.7;
}
.tel-bnr-1 .btn a{
	width: 100%;
	display: inline-block;
    background: #183e73;
    border: 2px solid #183e73;
    color: #fff;
    text-align: center;
    padding: 14px 15px;
    height: 100%;
    font-size: 1.5rem;
	box-sizing: border-box;
	transition: all .4s;
}

.tel-bnr-1 .btn a:hover{
    background: #fff;
    color: #183e73;
}

.tel-bnr-1 .btn a i{
	margin-right: 8px;
}
.tel-bnr-1 .ttl h3{
	font-size:2.5rem;
	text-align:left;
	line-height:1.5;
	margin-bottom: 0;
}
.tel-bnr-1 .ttl h3 span{
	font-size:1.8rem;
	display:block;
	color:#183e73;
}


/*
----------------------------------------
top
----------------------------------------
*/

#top-main-img {
	background: #eee;
	line-height: 1;
}
#top .slick-dotted.slick-slider {
    margin-bottom: 70px;
}
#top .slick-dots {
    bottom: 25px;
    height: auto;
}
#top .slick-dots li button:before{
	display:none;
}
#top .slick-dots li button{
    width: 80px;
    height: 4px;
    background: #fff;
    padding: 0;
}
#top .slick-dots li.slick-active button{
	background:#d6c695;
}
#top .slick-dots li {
    width: 80px;
    height: 4px;
}
#head-contents-front {
	margin: 20px auto;
	text-align: left;
	max-width: 1080px;
}
#head-contents-front .flex h3{
	position:relative;
    font-size: 3rem;
    font-weight: bold;
    padding-top: 8.4rem;
    margin-bottom: 10px;
}
#head-contents-front .flex h3 span {
    font-size: 13.3rem;
    color: #ededed;
    line-height: 1;
    text-align: center;
    position: absolute;
    top: 0;
    line-height: 1;
	z-index:-1;
}
#head-contents-front #case-1 h3 span,
#head-contents-front #case-3 h3 span {
    right: 0;
}
#head-contents-front #case-2 h3 span {
    left: 0;
}
#head-contents-front .flex h3 span i {
    font-size: 4.7rem;
    display: block;
    margin: 0 auto;
    line-height: 2.7rem;
    font-style: normal;
    text-align: center;
}
#head-contents-front .flex .box.pic {
    width: 60%;
}
#head-contents-front .flex .box.pic img{
	display:block;
}
#head-contents-front .flex .box.pic div{
	position:relative;
}
#head-contents-front .flex .box.pic div:before {
	content:"";
	width:100%;
	height:100%;
	background:#eee;
	position:absolute;
	bottom: -65px;
	z-index: -1;
}
#head-contents-front .flex .box.pic div:after {
	content:"";
	width:100%;
	height:100%;
	position:absolute;
	top: 0;
	z-index: -1;
    background: url(/wp/wp-content/themes/theta/img/top/ttl-fiber.png) no-repeat 10% 0;
}

#head-contents-front #case-1 .box.pic div:before,
#head-contents-front #case-3 .box.pic div:before,
#head-contents-front #case-1 .box.pic div:after,
#head-contents-front #case-3 .box.pic div:after {
	left: -125px;
}
#head-contents-front #case-2 .box.pic div:before,
#head-contents-front #case-2 .box.pic div:after {
	right: -125px;
}
#head-contents-front #case-2 .box.pic div:after {
	background:url(/wp/wp-content/themes/theta/img/top/ttl-fiber.png) no-repeat 90% 0
}
#head-contents-front .flex .box.txt {
    width: 40%;
    position: relative;
    padding-left: 20px;
}
#head-contents-front #case-2 .box.txt {
    padding-left: 0;
    padding-right: 20px;
}
#head-contents-front .flex .box.txt:before {
	content:"";
	width:50px;
	height:50px;
	border-bottom:2px solid #eee;
	position:absolute;
	bottom: -70px;
	z-index: -1;
}
#head-contents-front #case-1 .box.txt:before,
#head-contents-front #case-3 .box.txt:before {
	right: 0;
	border-right:2px solid #eee;
}
#head-contents-front #case-2 .box.txt:before {
	left: 0;
	border-left:2px solid #eee;
}
#head-contents-front .flex .box.txt {
    width: 40%;
    position: relative;
}
#head-contents-front .case-box{
	margin-bottom:140px;
}
.top-box-list {
    position: relative;
    max-width: 810px;
    margin: 0 auto;
}
.top-box-list:before{
	content: "";
	background: #ebebeb;
	width: 3px;
	height: 100%;
	position: absolute;
	top: 150px;
	left: 35px;
	z-index: -1;
}
.top-box-list > section {
    margin-bottom: 80px !important;
}
.top-box-list > section .sec-box{
	position: relative;
	overflow: hidden;
}
.top-box-list > section .sec-box h2{
	position: absolute;
	top: -1px;
	right:0;
	color:#fff;
	text-align: right;
	font-size: 2rem;
	line-height: 1.8;
}
.top-box-list > section .sec-box h2 img{
	display: block;
}
.top-box-list > section .sec-box figure img{
	display: block;
}
.top-box-list > section .btn-01{
	text-align: right;
}
.top-box-list > section .btn-01 a{
	margin:0;
	text-align: center;
	top: -2em;
}
.top-box-list > section .txt-box{
	padding-left: 65px;
}
.top-box-list > section h2 span{
	display: block;
	position:relative;
    top: -7px;
    right: -8px;
	margin-bottom: -10px;
}
#other .ov-box{
	box-sizing: border-box;
	position: relative;
	padding: 20px;
	background: #f4f4f4;
}
#top #other .ov-box{
	padding-top: 95px;
	margin-top: 85px;
	margin-left: auto;
	margin-right: auto;
	max-width: 810px;
}
#other .ov-box h2{
	font-size:1.8rem;
}
#top #other .ov-box h2{
	position: absolute;
	top:-47px;
	left: 0;
}
.top-box-list > section h2 span i,
#other .ov-box h2 span i{
	font-style:normal;
	color:#c0b283;
}
#other .ov-box h2 span{
    font-size: 7.8rem;
	line-height: 1;
	display: inline-block;
	margin-right:10px;
}
.top-box-list > section h2 span,
#top #other .ov-box h2 span{
    font-size: 12.8rem;
	line-height: 1;
}
#other .ov-box h2 img{
	margin-right: 10px;
}
#other .ov-box .flex-top{
	padding:0 10px;
	margin-bottom:45px;
}
#other .ov-box .flex{
	margin-bottom:0;
}
#other .ov-box .flex .box{
	width: 50%;
    margin-top: 0 !important;
}
#other .ov-box .flex .box.pic{
	flex: 1;
	padding-right: 20px;
}
#other .ov-box .flex .box.txt{
	flex: 3;
}
#other .ov-box .fig{
	position:relative;
	overflow:hidden;
}
#other .ov-box .fig h3 i{
	font-style:normal;
	font-size:2rem;
	display:block;
	margin:0 auto;
}
#other .ov-box .fig h3{
    position: absolute;
    color: #fff;
    top: 50%;
    margin-top: -1.25em;
    text-align: center;
    width: 100%;
    height: auto;
	font-size:2.2rem;
	z-index: 1;
}
#top #other .ov-box .fig h3{
	margin-top: -.5em;
}
#other .ov-box .fig a img{
	transition: all .4s;
	display:block;
	margin:0 auto;
}
#other .ov-box .fig a:hover img {
transform: scale(1.2);
}
#advantage-box{
    position: relative;
	padding:0 10px;
}
#advantage-box > *{
    position: relative;
	z-index:1;
}
#advantage-box:before {
    content: "";
    width: 100%;
    height: 50%;
    position: absolute;
    bottom: 0;
    left: 0;
    background: #f4f4f4;
}
#advantage-box h2{
	text-align: center;
	font-size: 1.7rem;
	line-height: 1.2;
	margin: 60px;
}
#advantage-box h2 .helvetica{
    font-size: 6rem;
    display: block;
}
#advantage-box ul li a{
	display:block;
	border:1px solid #f1f1f1;
	background:#fff;
    max-width: 245px;
    margin: 0 auto;
}
#advantage-box ul li h3{
	margin-bottom: 10px;
}
#advantage-box ul li a div{
	padding:24px 10px;
}
#advantage-box ul li figure{
	position: relative;
}
#advantage-box ul li figure:before{
	font-family: FontAwesome;
	content: "\f085";
	width: 46px;
	height: 46px;
	border-radius: 100%;
	background: #183e73;
	border: 2px solid #183e73;
	color: #fff;
	position: absolute;
	bottom: -24px;
	left: 50%;
	margin-left: -24px;
	z-index: 1;
	text-align: center;
	line-height: 48px;
	font-size: 2.2rem;
	transition:all .4s;
}

#advantage-box ul li.num-01 figure:before{
	transform: rotate(45deg);
	content:"\f085";
}
#advantage-box ul li.num-02 figure:before{
	content:"\f073";
}
#advantage-box ul li.num-03 figure:before{
	content:"\f0f6";
}
#advantage-box ul li.num-01 a:hover figure:before{
	transform: rotate(720deg);
	transform: scale(1.2);
}
#advantage-box ul li.num-02 a:hover figure:before{
	transform: scale(1.2);
}
#advantage-box ul li.num-03 a:hover figure:before{
	line-height: 38px;
	transform: scale(1.2);
}
#advantage-box ul li a:hover figure:before{
	background:#fff;
	color: #183e73;
}
#faq-box {
	position: relative;
}
#faq-box .faq-list{
	width:100%;
}
#faq-box .faq-list dt{
	font-size: 1.7rem;
}
#faq-box .alnR i{
	margin-left:.5em;
}
#faq-box .alnR a{
	color: #989898;
}
#faq-box .alnR a:hover{
	text-decoration: underline;
}
#faq-box .flex{
	position: relative;
	box-sizing: border-box;
	padding-left: 12.2rem;
}
#faq-box .flex .ttl{
	position: absolute;
	top: 0;
	left: 0;
	width: 12.2rem;
	height: 100%;
	display: table;
}
#faq-box .flex .ttl span{
	font-size: 10.2rem;
	position: absolute;
	top: 0;
	left: 0;
	line-height: 1;
	vertical-align: text-bottom;
	display: block;
	color: #ededed;
	width: 8.2rem;
	height: auto;
	overflow: visible;
	z-index: -1;
}
#faq-box .flex .ttl h2{
	width: 100%;
	height: 100%;
	display: table-cell;
	vertical-align: top;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	-ms-text-combine-horizontal: digits 3;
	text-combine-upright: digits 3;
	line-height: 8.2rem;
	letter-spacing: 2px;
}
#top #faq-box dl{
	margin-top:0;
}
/*
----------------------------------------
voice
----------------------------------------
*/

#voice .user,
#voice .star {
	display: inline-block;
	margin-bottom: 10px;
}

#voice .user {
	font-size: 1.6rem;
	margin-right: 1rem;
}

#voice .star {
	font-size: 2rem;
	color: #ccc;
	letter-spacing: 3px;
}

#voice .star span {
	color: #D5B376;
}

#voice dl.cat-list {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	margin-bottom: 10px;
	padding: 10px;
	background: #fafafa;
	border-radius: 5px;
}

#voice dl.cat-list dt {
	background: #000;
	color: #fff;
	font-size: 1.2rem;
	padding: 1px 20px;
	margin-right: 10px;
}

#voice dl.cat-list a {
	display: inline-block;
	font-size: 1.4rem;
	margin-right: 10px;
	text-decoration: underline;
}

#voice .faq-list {
	margin: 20px 0 40px 0;
	padding: 20px 20px 0 20px;
	background: #fafafa;
	border-radius: 5px;
}

#voice .comment h2:before {
	font-family: 'FontAwesome';
	content: '\f026';
	margin-right: 1rem;
}

/* archive */

#voice #contents h1 {
	margin-bottom: 10px;
}

#voice .post-archive ul.cat-list {
	margin-bottom: 5px;
}

#voice .post-archive .user {
	font-size: 1.4rem;
}

#voice .post-archive .star {
	font-size: 1.8rem;
}

#voice .post-archive p {
	margin-bottom: 0;
}


/*
----------------------------------------
case
----------------------------------------
*/

#case #page-ttl {
    background: url(/wp/wp-content/uploads/2017/10/ttl-case.png) no-repeat top center;
}
#case .case-box {
	margin-bottom: 60px;
}

#case .case-box h2 {
	font-size: 2.8rem;
	margin: 30px 0;
}

#case.single .main-img {
    text-align: center;
    margin-bottom: 20px;
}

#case.single .main-img img{
    max-width: 80%;
}

#case.single .main-txt {
	margin-bottom: 40px;
}

#case .staff-box {
	background: #fff;
	padding: 20px 20px 5px 20px;
	border-radius: 10px;
	margin-top: 60px;
}
/*
#case .staff-box h2 {
	text-align: center;
	border-bottom: solid 1px #999;
	padding-bottom: 15px;
}
*/
#case .staff-box .pic {
	width: 30%;
	padding: 0;
}

#case .staff-box .txt {
	width: calc( 70% - 25px );
	padding: 10px;
	box-sizing: border-box;
	border-radius: 10px;
	background: #fff;
	position: relative;
}

#case .staff-box h3 {
    font-size: 2.3rem;
    font-weight: bold;
}
#case .staff-box .txt::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	left: -15px;
	top: 50%;
	border-right: 15px solid #fff;
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
	transform: translateY( -50% );
}

#case .staff-box .txt h3 {
	margin-bottom: 10px;
}

#case .staff-box .txt p {
	margin-bottom: 0;
}

#contents ul.cat-list .num-1 a{
	background:#1d1d1d;
}
#contents ul.cat-list .num-2 a{
	background:#595757;
}
#contents ul.cat-list .num-3 a{
	background:#919191;
}
#contents ul.cat-list .num-4 a{
	background:#cacaca;
}
/*
#contents ul.cat-list .num-1 a{
	background:#877d5d;
}
#contents ul.cat-list .num-2 a{
	background:#988d68;
}
#contents ul.cat-list .num-3 a{
	background:#c0b283;
}
#contents ul.cat-list .num-4 a{
	background:#e3d39e;
}
*/


/*
----------------------------------------
contact
----------------------------------------
*/


.wpcf7-form > br{
	display:none;
}
#contact #contents p {
	margin: 10px 0;
}
#tel .tel-bnr-1{
	margin:45px auto;
}
#tel .tel-bnr-1 .btn{
	display:none;
}
#tel .tel-bnr-1 .ttl {
    width: 27%;
}
#tel .tel-bnr-1 .tel {
    width: 73%;
}
#tel .tel-bnr-1 .tel > *{
	vertical-align:middle;
	display:inline-block;
}
#tel .tel-bnr-1 .tel span {
    display: inline-block;
    /*background: #f1f1f1; */
	background:#fff;
    font-size: 1.3rem;
    line-height: 1.7;
    padding: 1px 15px;
}
/*
#contact #contents h2 {
	border-bottom: solid 1px #ccc;
	padding: 0 0 10px 0;
	margin: 40px 0 20px 0;
}

#contact #contents h2:before {
	font-family: 'FontAwesome';
	content: '\f111';
	margin-right: 1rem;
	font-size: 1.4rem;
	vertical-align: middle;
	color: #ccc;
}
#contact #contents .tel {
	font-size: 4.5rem;
	vertical-align: middle;
	display: inline-block;
}
#contact #tel .tel-bnr-1 .part.flex{
	padding: 20px 25px;
}

#contact #contents .tel:before {
	font-family: 'FontAwesome';
	content: '\f095';
	font-size: 1.6rem;
	background: #000;
	color: #fff;
	display: inline-block;
	width: 2.5rem;
	height: 2.5rem;
	line-height: 2.5rem;
	text-align: center;
	margin-right: 1rem;
	transform: translate( 0, -30% );
}*/

#contact #contents .date {
	display: inline-block;
	margin-left: 10px;
	border-bottom: solid 1px #000;
	transform: translate( 0, -5px );
}

#contact #contents .submit {
	text-align: center;
	height: 70px;
	margin-top: 45px;
}

#contact .form-table {
	width: 100%;
	text-align: left;
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	margin: 30px 0;
}

#contact .form-table thead th,
#contact .form-table thead td {
	color: #fff;
	background: #000;
	text-align: center;
}

#contact .form-table th {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	background: #f6f6f6;
	font-weight: normal;
	vertical-align: top;
	width: 28%;
}

#contact .form-table td {
	padding: 15px;
	border-bottom: solid 1px #ccc;
	border-right: solid 1px #ccc;
	vertical-align: top;
}
#contact .txt-box-01 {
	margin-bottom:25px;
}
#contact .txt-box-02 {
    border: 1px solid #ccc;
    padding: 20px;
    margin: 45px auto;
    max-height: 250px;
    overflow: auto;
    background: #f6f6f6;
}
#contact .txt-box-02 dl dd{
	padding:0 0 1em 1em;
}
#contact table th .imp {
    background: #c00;
    color: #fff;
    display: inline-block;
    padding: 0 8px;
    font-size: 1.2rem;
    margin-left: 5px;
    vertical-align: middle;
}

select.wpcf7-select{
    width: auto !important;
    max-width: inherit !important;
    font-size: 1.4rem;
    padding: 10px;
    box-sizing: content-box;
    border: 1px solid rgb(204, 204, 204);
    border-radius: 5px;
    background: #fff;
    box-shadow: none;
	min-width: 180px;
}
input.wpcf7-text, textarea.wpcf7-textarea {
    vertical-align: middle;
    font-size: 1.6rem;
    padding: 10px;
    width: 100% !important;
    max-width: 450px !important;
    box-sizing: border-box;
    border: 1px solid #ccc;
    outline: none;
    background: #fff;
}

.contents .heading-ttl{
	font-size:3rem;
}
.contents .heading-ttl:after{
	height:3px;
}
.contents .heading-ttl:before{
	content:"";
	display:block;
	width:100%;
	height:3px;
	background:#dcdcdc;
	margin:12px auto 0 auto;
	font-weight: bold;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index:1;
}
.mt0{
	margin-top:0 !important;
}
.list-2 li {
    width: 50%;
    float: left;
    line-height: 1;
    box-sizing: border-box;
    padding: 10px;
}
.list-3 li {
    width: 33.3333%;
    float: left;
    line-height: 1;
    box-sizing: border-box;
    padding: 10px;
}

/*
----------------------------------------
melit
----------------------------------------
*/

#melit .melit-list,
#melit .demelit-list{
	background:#f6f6f6;
	padding:20px 40px;
}

#melit .melit-list li,
#melit .demelit-list li{
	font-size:2.3rem;
	position:relative;
	padding-left:72px;
    min-height: 52px;
    margin: 20px 0;
    line-height: 1.5;
}
#melit .melit-list li i,
#melit .demelit-list li i{
	margin-right:20px;
	font-size:6rem;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -35px;
}
#melit .melit-list li i{
	color:#c0b283;
}
#melit .demelit-list li i{
	color:#183e73;
}
#melit .melit-list li a{
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: underline;
}
#melit .melit-list li a:hover{
    text-decoration: none;
}
#melit #contents > section .flex .box.pic{
	width:60%;
	margin-top:0;
}
#melit #contents > section .flex .box.txt {
	width:40%;
	margin-top:0;
}
#melit-list,
#melit-list .heading-06{
	margin-bottom:0;
}
#melit-list .heading-06{
	background: #c0b283;
	font-size: 3.2rem;
	padding: 15px;
	line-height:1.5;
}
#melit-list .heading-06:before{
content:"";
position:absolute;
bottom:-16px;
left:50%;
margin-left:-11.5px;
z-index:1;
width: 0;
height: 0;
border-style: solid;
border-width: 18px 11.5px 0 11.5px;
border-color: #c0b283 transparent transparent transparent;
}
#melit-list .heading-06 i{
	font-size: 5.2rem;
	vertical-align: middle;
	right: 7px;
	position: relative;
}

#melit-1 .heading-03:after,
#melit-2 .heading-03:after,
#melit-3 .heading-03:after,
#melit-4 .heading-03:after{
    border-left: 78px solid #c0b283;
}
#melit-1 .heading-03 i,
#melit-2 .heading-03 i,
#melit-3 .heading-03 i,
#melit-4 .heading-03 i{
    color: #c0b283;
	font-style:normal;
	vertical-align:baseline;
	font-size:2.8rem;
	margin-right:5px;
	display:inline-block;
}
#melit-1,
#melit-2,
#melit-3,
#melit-4{
	margin-bottom:0;
    padding: 20px 20px 20px;
    background: #fff;
    border-left: 5px solid #f6f6f6;
    border-right: 5px solid #f6f6f6;
}
#melit-1 .flex,
#melit-2 .flex,
#melit-3 .flex,
#melit-4 .flex{
	margin:30px 0 0 0;
}
#melit-4{
    border-bottom: 5px solid #f6f6f6;
	margin-bottom:65px;
}
#melit .list-2 li{
	padding:5px;
}
/*
----------------------------------------
advantage
----------------------------------------
*/

.contents > #advantage-01 > figure{
	margin-top:0;
}
#advantage-01,
#advantage-02,
#advantage-03{
	margin-bottom:45px;
	border-bottom:5px solid #f6f6f6;
}
#advantage-01 .flex,
#advantage-02 .flex,
#advantage-03 .flex{
	align-items: center;
	margin: 30px auto;
}

#advantage-01 .box-02 .ttl,
#advantage-02 .box-02 .ttl,
#advantage-03 .box-02 .ttl{
	width:25%;
	text-align:center;
}
#advantage-01 .box-02 .ttl h3,
#advantage-02 .box-02 .ttl h3,
#advantage-03 .box-02 .ttl h3{
	line-height: 1;
	display: inline-block;
	vertical-align: middle;
	margin-bottom: 0;
	top: 1.2rem;
	position: relative;
}
#advantage-01 .box-02 .cont,
#advantage-02 .box-02 .cont,
#advantage-03 .box-02 .cont{
	width:75%;
	padding: 10px 0 10px 30px;
	box-sizing:border-box;
}

#advantage-01 .box-02 .cont .heading-05,
#advantage-02 .box-02 .cont .heading-05,
#advantage-03 .box-02 .cont .heading-05{
    font-size: 3rem !important;
	line-height: 1.2;
	margin-bottom: 10px;
}

#advantage-01 .center span,
#advantage-01 .center i,
#advantage-02 .center span,
#advantage-02 .center i,
#advantage-03 .center span,
#advantage-03 .center i{
    font-style: normal;
    display: block;
    line-height: 1;
	font-family: 'Helvetica','Roboto', sans-serif;
	font-weight:700;
}

#advantage-01 .center span,
#advantage-02 .center span,
#advantage-03 .center span{
    font-size: 2.4rem;
}
#advantage-01 .center i,
#advantage-02 .center i,
#advantage-03 .center i{
    font-size: 14.8rem;
	letter-spacing: -2px;
}

#advantage .sec-04 .btn-01.center a {
    width: 48%;
    margin: 45px 1%;
}
#advantage .sec-04 .btn-01 a:last-child{
	color: #183e73;
	background: #fff;
}
#advantage .sec-04 .btn-01 a:last-child:before {
  background: #183e73;
	color:#fff;
}

#advantage .sec-04 .btn-01 a:last-child:hover,
#advantage .sec-04 .btn-01 a:last-child:focus,
#advantage .sec-04 .btn-01 a:last-child:active{
  color: #fff;
}

span.wpcf7-list-item{
display:block !important;
}
