/*
Theme Name: nikoniko FX 2020
Author: kobax
Author URI: https://fx.koshiji-renta.jp/
Description: nikoniko FX Theme
Version: 1.0.0
*/

@charset "UTF-8";


@ms-viewport {
	width: device-width;
}

/*
@font-face {
	font-family: '851Gkktt003';
	font-style: normal;
	font-weight: normal;
	src: url('./fonts/851Gkktt_003.ttf') format('truetype'),
	url('./fonts/851Gkktt_003.woff') format('woff'),
	url('./fonts/851Gkktt_003.woff2') format('woff2');
}
*/

body,
li,
input,
select,
textarea,
button,
h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
	-ms-word-wrap: break-word;
	word-wrap: break-word;
	color: #444;
}

body {
	background: #fff;
}

input,
select,
textarea,
button,
.button {
	font-family: 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}


a {
	color: #18488a;
	-webkit-transition: all .5s;
	-moz-transition: all .5s;
	-o-transition: all .5s;
	-ms-transition: all .5s;
	transition: all .5s;
}

a:hover {
	color: #019bd9;
}

a:link,
a:visited {
	color: #18488a;
	-webkit-transition: .3s;
	-moz-transition: .3s;
	-o-transition: .3s;
	-ms-transition: .3s;
	transition: .3s;
}

p {
	font-weight: 300;
	line-height: 2.25;
	margin-bottom: 1.5rem;
}

ul {
	margin-left: 1.5rem;
}

ol {
	margin-left: 1.75rem;
}

address {
	font-style: normal;
	font-size: 0.85rem;
	line-height: 2.6rem;
	padding: 20px 30px;
	color: #333;
}

address p {
	line-height: 1.6rem;
}

hr.dotline {
	border-bottom: dotted 1px #85b0da;
	margin: 60px 0 30px;
	float: left;
	width: 100%;
}

hr.separator {
	border-bottom: solid 1px #85b0da;
}


/* :::::::::::::::::: common :::::::::::::::::: */

header:after,
section:after,
#menu:after,
.clearfix:after {
	display: block;
	clear: both;
	height: 0px;
	line-height: 0px;
	visibility: hidden;
	content: ".";
}

.clear {
	clear: both;
}

.row {
	max-width: 1200px;
}

.rowl {
	max-width: 1400px;
	margin: 0 auto;
}

.rows {
	max-width: 900px;
	margin: 0 auto;
}

.row .row {
	margin-left: 0;
	margin-right: 0;
}

.columns {
	padding-left: 0;
	padding-right: 0;
}

.column:last-child:not(:first-child),
.columns:last-child:not(:first-child) {
	float: left;
}

.columnsRight {
	padding-left: 0;
	padding-right: 0;
	float: right;
}

.columnRight {
	padding-left: 1rem;
	padding-right: 1rem;
	float: right;
}

.columnsOne {
	padding-left: 0;
	padding-right: 1px;
	padding-bottom: 1px;
	float: left;
}

.columnsTable {
	padding-left: 0;
	padding-right: 0;
	display: table-cell;
}

.left {
	float: left;
}

.right {
	float: right;
}

img.auto {
	width: 100%;
}

img.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

img.alignright {
	float: right;
	margin: 0.5rem 0 0.5rem 1rem;
}

img.alignleft {
	float: left;
	margin: 0.5rem 1rem 0.5rem 0;
}

.center {
	text-align: center;
}

.mid {
	vertical-align: middle;
}

table.aligncenter,
div.aligncenter {
	display: table;
	width: auto;
	margin-left: auto;
	margin-right: auto;
}

.attention {
	color: #ff0000;
}

.jtext0 {
	font-family: 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
}

.jtext1 {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
}

.jtext2 {
	font-family: 'Noto Serif JP', '游明朝', 'YuMincho', "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
}

h2.narrow,
h3.narrow,
h4.narrow {
	margin: 0;
}

p.narrow {
	line-height: 1.75rem;
	margin: 0;
}

.topMargin0 {
	padding-top: 0;
	margin-top: 0;
}

.topMargin1 {
	padding-top: 15px;
}

.topMargin2 {
	padding-top: 30px;
}

.topMargin4 {
	padding-top: 60px;
}

.bottomMargin0 {
	padding-bottom: 0;
	margin-bottom: 0;
}

.bottomMargin1 {
	padding-bottom: 15px;
}

.bottomMargin2 {
	padding-bottom: 30px;
}

.bottomMargin4 {
	padding-bottom: 60px;
}

.redBoxBorder {
	border: 1px solid #ff0000;
	color: #ff0000;
	padding: 5px 15px;
	display: inline-block;
}

.sp {
	display: none;
}

.pc {
	display: none;
}

#h1 {
	margin: 75px 0 15px;
}

.inline {
	display: inline-block;
}

.left {
	float: left;
}

.right {
	float: left;
}

p.small {
	font-size: 0.875rem;
	line-height: 1.75rem;
}


h1 .private {
	display: block;
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
	font-size: 0.75rem;
	font-weight: bold;
	line-height: 1.25rem;
	color: #fff;
	background: #ff0000;
	padding: 2px 10px;
	border-radius: 4px;
	float: right;
}

a.blueButton {
	font-size: 1.125rem;
	line-height: 1.5;
	color: #fff;
	background: #85b0da;
	display: inline-block;
	padding: 10px 40px 15px;
	margin: 10px 0;
	transition: all .4s;
}

a.blueButton:hover {
	background: #019bd9;
}


.fadein0 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1s ease;
}

.fadein1,.fadein-1 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1.5s ease;
}

.fadein2 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1.5s ease 0.1s;
}

.fadein3 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1.5s ease 0.2s;
}

.fadein4 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1.5s ease 0.3s;
}

.fadein5 {
	opacity: 0;
	transform: translate(0, 150px);
	transition: all 1.5s ease 0.4s;
}

.fadeinf1 {
	opacity: 0;
	transform: translate(0, 50px);
	transition: all 1.5s ease 0.2s;
}
.fadeinf2 {
	opacity: 0;
	transform: translate(0, 50px);
	transition: all 1.5s ease 0.3s;
}
.fadeinf3 {
	opacity: 0;
	transform: translate(0, 50px);
	transition: all 1.5s ease 0.4s;
}

.fadeinr1 {
	opacity: 0;
	transform: translate(150px, 0);
	transition: all 1.5s ease 0.2s;
}
.fadeinr2 {
	opacity: 0;
	transform: translate(150px, 0);
	transition: all 1.5s ease 0.3s;
}

.fadeinl1 {
	opacity: 0;
	transform: translate(-150px, 0);
	transition: all 1.5s ease 0.2s;
}
.fadeinl2 {
	opacity: 0;
	transform: translate(-150px, 0);
	transition: all 1.5s ease 0.3s;
}


.fadein-1.scrollin,
.fadein0.scrollin,
.fadein1.scrollin,
.fadein2.scrollin,
.fadein3.scrollin,
.fadein4.scrollin,
.fadein5.scrollin,
.fadeinf1.scrollin,
.fadeinf2.scrollin,
.fadeinf3.scrollin,
.fadeinr1.scrollin,
.fadeinr2.scrollin,
.fadeinl1.scrollin,
.fadeinl2.scrollin
{
	opacity: 1;
	transform: translate(0, 0);
}

/* :::::::::::::::::: common main :::::::::::::::::: */

#main {
	clear: both;
	overflow: hidden;
	position: relative;
}

#main h1 {
	font-size: 2rem;
	font-weight: 200;
	line-height: 1.75;
	margin: 0 0 30px;
}

#main h2 {
	font-size: 1.75rem;
	font-weight: 200;
	line-height: 1.5;
	margin: 15px 0;
}

/*
#main .page-content h2 {
	font-weight: 200;
	margin: 60px 0 20px 32px;
	text-indent: -32px
}

#main .page-content h2:first-child {
	margin: 20px 0;
}

#main .page-content h2::before {
	content: url('/images/icon-p4-blue.svg');
	display: block;
	float: left;
	margin: 4px 40px 0 0;
}
*/

#main h3 {
	font-size: 1.5rem;
	font-weight: 200;
	line-height: 1.5;
	margin: 30px 0;
}

#main h4 {
	font-size: 1.25rem;
	line-height: 1.5;
	margin: 30px 0;
}

#main h5 {
	font-size: 1.125rem;
	line-height: 1.5;
	margin: 30px 0;
}

#main h6 {
	font-size: 1rem;
	line-height: 1.5;
	margin: 30px 0;
}

#main .content {
	padding: 0 20px 30px;
}

#main .topImage {
	height: 300px;
	overflow: hidden;
	border-top: solid 50px #444;
	margin-top: -50px;
}

#main .topImage h1 {
	position: absolute;
	width: 100%;
	font-size: 1rem;
	font-weight: normal;
	line-height: 1;
	text-align: center;
	margin: 75px 0 0;
}

#main .topImage h1.title {
	letter-spacing: 0.25rem;
	margin: 92px 0 0;
}

#main .topImage .titleEn {
	display: inline-block;
	font-size: 3.5rem;
	font-weight: 100;
	letter-spacing: 0;
	margin: 0;
}

#main .topImage .titleEn::first-letter {
	font-size: 4rem;
}


#main .topImage .bg img {
	max-width: none;
}

#main .topImage.white h1,
#main .topImage.white .titleEn {
	color: #fff;
	-webkit-text-shadow: 0px 0px 8px rgba(0, 0, 0, 0.75);
	-moz-text-shadow: 0px 0px 8px rgba(0, 0, 0, 0.75);
	text-shadow: 0px 0px 8px rgba(0, 0, 0, 0.75);
}

#main .topImage.black h1,
#main .topImage.black .titleEn {
	color: #000;
	-webkit-text-shadow: 0px 0px 8px rgba(255, 255, 255, 0.75);
	-moz-text-shadow: 0px 0px 8px rgba(255, 255, 255, 0.75);
	text-shadow: 0px 0px 8px rgba(255, 255, 255, 0.75);
}

/* :::::::::::::::::: common table :::::::::::::::::: */

table.detail {
	line-height: 1.75rem;
	width: 100%;
	margin-bottom: 1rem;
}

table.detail th {
	font-size: 0.875rem;
	font-weight: normal;
	background: #fafafa;
	color: #888;
	text-align: left;
	vertical-align: top;
	padding: 5px 15px 5px 10px;
	border: solid 1px #ccc;
	width: 150px;
}

table.detail td {
	font-size: 0.95rem;
	padding: 5px;
	border: solid 1px #ccc;
	vertical-align: top;
}

table.detail tr:first-child th {
	border-top: solid 1px #ccc;
}

table.detail tr:last-child th {
	border-bottom: solid 1px #ccc;
}

table.detail tr:last-child td {
	padding: 5px 5px;
	border-bottom: solid 1px #ccc;
}

table.detail p {
	margin: 0;
	line-height: 1.75rem;
}

table.detail ul li {
	list-style: inherit;
	float: none;
	margin-left: 22px;
}

table.noBorder {
	border: 0;
	margin-bottom: 15px;
}

table.noBorder th {
	font-weight: normal;
	text-align: left;
	vertical-align: top;
	padding: 5px;
	border: 0;
	background: none;
}

table.noBorder td {
	vertical-align: top;
	padding: 5px;
	border: 0;
	color: #000;
}

table.gallery {
	border: 0;
	margin-bottom: 15px;
}

table.gallery td {
	vertical-align: top;
	padding: 5px;
	border: 0;
}

div.gallery {
	margin-bottom: 30px;
}

div.gallery .columnsOne {
	padding-bottom: 15px;
}

div.gallery .g {
	display: inline-block;
	overflow: hidden;
}

/* :::::::::::::::::: breadcrumbs :::::::::::::::::: */

.breadcrumbs {
	display: block;
	overflow: hidden;
	margin: 0 auto;
	padding: 20px;
	list-style: none;
	max-width: 1200px;
}

.breadcrumbs > * {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
	font-size: 0.75rem;
	margin: 0;
	float: left;
}

.breadcrumbs > *:before {
	font-family: 'FontAwesome';
	content: '\f105';
	color: #aaa;
	margin: 0 0.75rem;
	position: relative;
	top: 1px;
}

.breadcrumbs > *:first-child:before {
	content: '';
	margin: 0;
}

.breadcrumbs > *:not(:last-child) {
	color: #aaa;
}

/* :::::::::::::::::: NAVIGATION :::::::::::::::::: */

.single-navi a {
	color: #85b0da;
}

.single-navi .list {
	font-size: 1.125rem;
	font-weight: 500;
	text-align: center;
	margin: 10px 0 0;
}

.single-navi .prev a::before {
	content: '\f0a8';
	font-family: 'FontAwesome';
	font-size: 30px;
	float: left;
	margin: -1px 5px 0 0;
}

.single-navi .prev .navi {
	display: block;
	font-size: 1.125rem;
	font-weight: 500;
	text-align: left;
	padding: 0 0 0 40px;
}

.single-navi .prev .smallTitle {
	display: block;
	font-size: 0.75rem;
	line-height: 1.2;
	text-align: left;
	padding: 0 0 0 40px;
}

.single-navi .next a::before {
	content: '\f0a9';
	font-family: 'FontAwesome';
	font-size: 30px;
	float: right;
	margin: -1px 5px 0 0;
}

.single-navi .next .navi {
	display: block;
	font-size: 1.125rem;
	font-weight: 500;
	text-align: right;
	padding: 0 40px 0 0;
}

.single-navi .next .smallTitle {
	display: block;
	font-size: 0.75rem;
	line-height: 1.2;
	text-align: right;
	padding: 0 40px 0 0;
}


.pagination {
	position: relative;
	z-index: 8;
	min-height: 100px;
}

.navigation {
	margin: 15px;
	text-align: center;
}

.navigation ul {
	display: inline-block;
	padding-left: 0;
	margin: 5px;
	border-radius: 3px;
	-webkit-border-radius: 3px;
}

.navigation li {
	font-family: 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
	display: inline;
}

.navigation li span {
	position: relative;
	float: left;
	padding: 6px 12px;
	line-height: 1.5rem;
	text-decoration: none;
	color: #fff;
	border: 1px solid #85b0da;
	margin-left: -1px;
}

.navigation li .current {
	background-color: #85b0da;
}

.navigation li .dots {
	background-color: #ddd;
}

.navigation li a {
	position: relative;
	float: left;
	padding: 6px 12px;
	line-height: 1.5rem;
	text-decoration: none;
	color: #18488a;
	background-color: #fff;
	border: 1px solid #85b0da;
	margin-left: -1px;
}

.navigation li a:hover {
	color: #fff;
	background-color: #85b0da;
}

.navigation li:first-child a,
.navigation li:first-child span {
	margin-left: 0;
	border-bottom-left-radius: 3px;
	border-top-left-radius: 3px;
}

.navigation li:last-child a,
.navigation li:last-child span {
	margin-left: 0;
	border-bottom-right-radius: 3px;
	border-top-right-radius: 3px;
}



/* :::::::::::::::::: header :::::::::::::::::: */

#header {
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 100;
	background: rgba(255, 255, 255, 0.8);
	transition: all 0.8s ease-out;
	padding: 5px 0 0;
}

#header.small {}

#header .logoArea {
	position: relative;
	float: left;
	margin: 0 0 0 5px;
	transition: all 0.8s ease-out;
}

#header.small .logoArea {
	margin-bottom: 5px;
}

#header .logoArea .logo {
	float: left;
}

#header .logoArea .logo img {
	width: 211px;
	transition: all 0.8s ease-out;
}

#header.small .logoArea .logo img {
	width: 150px;
}

#header .logo h1,
#header .logo p {
	line-height: 0;
	margin: 5px 0;
}

#header .logoArea .company {
	float: left;
}

#header .logoArea .company .name {
	line-height: 1;
	margin: 28px 0 0 8px;
	transition: all .4s;
}

#header.small .logoArea .company .name {
	margin: 24px 0 0 8px;
}

#header .logoArea .company .name a {
	color: #444;
}

#header .logoArea .company .name svg {
	fill: #444;
	width: 184px;
	transition: all .4s;
}

#header .logoArea .company .desc {
	font-size: 0.75rem;
	font-weight: 100;
	line-height: 1.5;
	margin: 0 0 0 8px;
	height: 18px;
	overflow: hidden;
	transition: all .4s;
}

#header.small .logoArea .company .desc {
	height: 0;
}

#header .logoArea .catch {
	padding: 15px 0 0;
	clear: both;
}

#header.small .logoArea .catch {
	padding: 0;
}

#header .logoArea .catch p {
	position: absolute;
	font-size: 0.75rem;
	line-height: 1.5;
	text-align: center;
	margin: -15px 0 0;
	overflow: hidden;
	width: 100%;
}

#header .logoArea .catch a {
	display: block;
	text-align: center;
	color: #fff;
	background: rgba(0, 0, 0, 0.5);
	border: solid 1px #fff;
	padding: 5px 7px;
	height: 50px;
	opacity: 1;
	transition: all .4s;
}

#header.small .logoArea .catch a {
	height: 0;
	opacity: 0;
}

#header .menuArea {
	float: left;
	text-align: center;
	width: calc(100% - 566px);
}

#header .menu {
	margin: 47px 0 0 0;
	transition: all .4s;
}

#header.small .menu {
	margin: 26px 0 0 0;
}

#header .menu ul {
	list-style: none;
	margin: 0;
}

#header .menu li {
	margin: 0 3px;
	display: inline-block;
}

#header .menu li a {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 0.875rem;
	line-height: 2;
	padding: 0 20px 3px;
	display: inline-block;
	border-radius: 20px;
}

#header .menu li a.yellow {
	background: #f5d547;
}

#header .menu li a:hover {
	color: #fff;
	background: #85b0da;
}

#header .menu li a.yellow:hover {
	color: #18488a;
	background: #f5d547;
}

#header .menu li a.on {
	color: #fff;
	background: #85b0da;
}

#header .menuButton {
	display: block;
	position: fixed;
	z-index: 100;
	margin: 20px 0 0 0;
	right: 12px;
	top: 0;
}

.menu-trigger,
.menu-trigger span.menu-bar {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}

.menu-trigger {
	position: relative;
	width: 32px;
	height: 28px;
}

.menu-trigger:hover {
	opacity: 1;
}

.menu-trigger span.menu-bar {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background: #000;
}

.menu-trigger span:nth-of-type(1) {
	top: 0;
}

.menu-trigger span:nth-of-type(2) {
	top: 9px;
}

.menu-trigger span:nth-of-type(3) {
	top: 18px;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(6px) rotate(-45deg);
	transform: translateY(6px) rotate(-45deg);
}

.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}

.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-12px) rotate(45deg);
	transform: translateY(-12px) rotate(45deg);
}

#header .searchArea {
	float: right;
	margin: 7px 5px 5px 0;
}

#header .searchArea .tel {
	font-family: 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 1.125rem;
	font-weight: bold;
	text-decoration: none;
	margin-right: 8px;
	transition: all 0.8s ease-out;
}

#header.small .searchArea .tel {
	font-size: 1rem;
}

#header .searchArea .tel svg {
	vertical-align: bottom;
	margin: 0 -4px 4px 0;
}

#header.small .searchArea .tel svg {
	transform: scale(0.75);
	margin: 0 -4px 0 0;
}

#header .searchArea .link {
	float: left;
}

#header .searchArea .link a {
	font-size: 1rem;
	font-weight: 500;
	text-align: center;
	color: #fff;
	background: #85b0da;
	width: 150px;
	display: inline-block;
	padding: 5px 0 8px;
	transition: all .4s;
}

#header.small .searchArea .link a {
	font-size: 0.875rem;
	width: 135px;
	padding: 4px 0 6px;
}

/* :::::::::::::::::: front :::::::::::::::::: */

#topImage {
	text-align: center;
	z-index: 1;
	position: relative;
}


/* :::::::::::::::::: contact :::::::::::::::::: */

#contactArea {
	color: #18488a;
	background: #cce5ee;
	padding: 20px 10px;
	clear: both;
}

#contactArea p {
	line-height: 1.5;
	margin-bottom: 5px;
}

#contactArea .telArea {
	text-align: center;
}

#contactArea .telArea .tels {
	display: inline-block;
	text-align: left;
	width: calc(100% - 10px);
}

#contactArea .telArea .lineH {
	float: right;
	position: relative;
	margin: 12px -6px 0 0;
}

#contactArea .telArea .desc {
	font-size: 1.125rem;
	margin-left: 60px;
}

#contactArea .telArea .tel {
	font-family: 'Century Gothic', 'Noto Sans Japanese', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 2.75rem;
	font-weight: 300;
	letter-spacing: 0.1rem;
	margin: 5px 0;
}

#contactArea .telArea .tel img {
	width: 46px;

}

#contactArea .telArea .telTime {
	font-size: 0.875rem;
	margin-left: 60px;
}
#contactArea .telArea .comment {
	font-size: 0.875rem;
	margin-left: 60px;
}
#contactArea .mailArea {
	text-align: center;
}
#contactArea .mailArea .desc {
	font-size: 1.125rem;
}
#contactArea .mailArea .desc p {
	margin: 0;
}

#contactArea .mailArea .orangeButton {
	padding: 8px 60px 10px;
	margin: 12px 0;
}

/* :::::::::::::::::: footer :::::::::::::::::: */

#footer {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
}

#footer .leftArea {
	margin-bottom: 60px;
}

#footer .rightArea {
	margin-bottom: 30px;
}

#footer .logoArea {
	margin: 60px 10px 30px;
}

#footer .catch p {
	font-size: 0.875rem;
	line-height: 1.5;
	margin-bottom: 5px;
}

#footer .leftArea .logo {
	float: left;
	margin: 50px 25px;
}

#footer .leftArea .company {
	float: left;
	margin: 50px 10px 0;
}

#footer .leftArea .company .name {
	line-height: 1.5;
	margin: 0 0 2px;
}

#footer .leftArea .company .desc {
	font-size: 1rem;
	font-weight: 200;
	line-height: 1.5;
	color: #000;
	margin-bottom: 1rem;
}

#footer .leftArea .company .address {
	font-size: 0.875rem;
	line-height: 1.5;
	margin-bottom: 0.5rem;
}

#footer .leftArea .company .address a {
	font-size: 0.75rem;
	color: #85b0da;
	border: solid 1px #85b0da;
	padding: 5px 10px;
	margin: 0 0 0 10px;
	display: inline-block;
}

#footer .leftArea .company .address a::before {
	content: url('/images/icon-3k.svg');
	margin: 0 5px 0 0;
}

#footer .leftArea .company .tel {
	font-size: 0.875rem;
	line-height: 1.5;
	margin-bottom: 0.25rem;
}

#footer .leftArea .company .fax {
	font-size: 0.875rem;
	line-height: 1.5;
	margin: 0;
}

#footer .rightArea li {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 0.875rem;
	font-weight: bold;
	color: #18488a;
}

#footer .rightArea a {
	color: #18488a;
}

#footer .rightArea .column {
	margin-top: 40px;
	width: auto;
}

#footer .rightArea .column > ul {
	list-style: none;
	margin: 0;
}

#footer .rightArea .column > ul > li {
	margin-bottom: 20px;
}

#footer .rightArea .column > ul > li::before {
	content: url(/images/icon-arrow.svg);
	display: inline-block;
	margin: 0 10px 0 0;
}

#footer .rightArea .column > ul > li > ul {
	list-style: none;
	margin: 0 0 0 15px;
}

#footer .rightArea .column > ul > li > ul > li {
	margin: 10px 0;
}

#footer .rightArea .column > ul > li > ul > li::before {
	content: '－';
	display: inline-block;
	margin: 0 5px 0 0;
}

.copyright {
	font-size: 0.75rem;
	font-weight: 100;
	letter-spacing: 0.05rem;
	text-align: center;
	color: #fff;
	background: #18488a;
	padding: 5px 0 8px;
}

.copyright p {
	margin: 0;
}

/* :::::::::::::::::: pagetop :::::::::::::::::: */

.page-top {
	display: none;
}

.page-top a {
	display: inline-block;
	position: fixed;
	bottom: 50px;
	right: 5%;
	background: #18488a;
	border-radius: 50px;
	width: 45px;
	height: 45px;
	z-index: 10;
}

.page-top a:hover {
	background: #019bd9;
}

.page-top a:before {
	content: "";
	position: absolute;
	left: 16px;
	top: 19px;
	width: 12px;
	height: 12px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(315deg);
	transform: rotate(315deg);
}

input[type=text],
input[type=tel],
input[type=email] {
	font-family: 'Century Gothic', 'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', sans-serif;
}

input[type=tel] {
	max-width: 300px;
}

input[type=email] {
	max-width: 500px;
}

input[type=radio] {
	width: 22px;
	height: 22px;
	vertical-align: -4px;
	margin: 8px 4px 8px 0;
}

.wpcf7-list-item-label {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 1.125rem;
	color: #333;
	margin-right: 8px;
}

#main div.wpcf7 .ajax-loader {
	display: block;
	margin: 20px auto;
	background-image: url('/images/icon-loader.gif');
	width: 28px;
	height: 28px;
}

input.wpcf7-submit {
	font-family: 'Noto Sans Japanese', 'Century Gothic', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	color: #fff;
	background-color: #85b0da;
	border: 0;
	border-color: #85b0da;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	display: block;
	margin: 0 auto;
	padding: 10px 12px;
	font-size: 1.25rem;
	line-height: 2.4rem;
	letter-spacing: 0.25rem;
	text-align: center;
	min-width: 150px;
	-webkit-transition: all 0.25s ease-out;
	-moz-transition: all 0.25s ease-out;
	-o-transition: all 0.25s ease-out;
	-ms-transition: all 0.25s ease-out;
	transition: all 0.25s ease-out;
}

input.wpcf7-submit:hover,
input.wpcf7-submit:focus,
input.wpcf7-submit:active,
input.wpcf7-submit.active {
	color: #fff;
	background-color: #019bd9;
	border-color: #019bd9;

}

#main div.wpcf7-response-output {
	font-family: 'Century Gothic', 'Noto Sans Japanese', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 1.125rem;
	text-align: center;
	border: none;
}

#main span.wpcf7-not-valid-tip {
	font-family: 'Century Gothic', 'Noto Sans Japanese', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 0.875rem;
	font-weight: bold;
	padding: 5px;
	color: #cc0000;
	border: solid 2px #cc0000;
	display: inline-block;
}

#main span.wpcf7-not-valid-tip::before {
	content: '↑';
	font-family: 'Noto Sans Japanese', 'Meiryo', 'Hiragino Kaku Gothic Pro', sans-serif;
	font-size: 1rem;
	font-weight: bold;
	display: inline-block;
	margin: -3px 0 0 0;
}

div.wpcf7-mail-sent-ok {
	color: #fff;
	background: #398f14;
	border: none;
}

div.wpcf7-mail-sent-ng,
div.wpcf7-aborted {
	color: #fff;
	background: #ff0000;
	border: none;
}

div.wpcf7-spam-blocked {
	color: #000;
	background: #ffa500;
	border: none;
}

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
	color: #000;
	background: #f7d800;
	border: none;
}


/* :::::::::::::::::: smartphone :::::::::::::::::: */

/* 640px smartphone*/

@media only screen and (max-width: 40em) {
	#header {
		padding: 0;
	}
	#header .menu {
		margin: 55px 0 0;
	}
	#header .menuArea {
		position: fixed;
		display: block;
		opacity: 1;
		height: 0;
		top: 0;
		width: 100%;
		background: rgba(255, 255, 255, 0.95);
		transition: all .4s;
		overflow: hidden;
	}
	#header .menuArea .menu li {
		display: block;
	}
	#header .menuArea .menu li a {
		font-size: 1rem;
		line-height: 60px;
		width: 100%;
		border-radius: 30px;
		margin: 0 0 3px;
	}
	#header .logoArea {
		padding: 0 5px;
		margin: 0;
	}
	#header .logoArea .logo img {
		width: 120px;
	}
	#header.small .logoArea .logo img {
		width: 100px;
	}
	#header .logoArea .company {
		width: calc(100% - 165px);
	}
	#header.small .logoArea .company {
		width: calc(100% - 155px);
	}
	#header .logoArea .company .name {
		margin: 0 0 0 5px;
	}
	#header.small .logoArea .company .name {
		margin: 5px 0 0 8px;
	}
	#header .logoArea .company .name svg {
		width: 100%;
		margin: 5px 0 0;
	}
	#header.small .logoArea .company .name svg {}
	#header .logoArea .company .desc {
		margin: 0 0 0 5px;
	}
	#header .logoArea .catch {
		padding: 0;
	}
	#header.small .logoArea .catch {
		height: 0;
	}
	#header .logoArea .catch p {
		position: relative;
		margin: 0;
	}
	#header .logoArea .catch a {
		line-height: 1.75;
		padding: 2px 5px 0;
	}
	#header.small .logoArea .catch a {
		font-size: 0.825rem;
	}
	#header .logoArea .catch .headCatch br{
		display: none;
	}
	
	#header .descArea {
		margin: 0 10px;
	}
	#header.small .descArea {
		display: none;
	}
	#header .descArea .desc {
		font-size: 0.875rem;
	}
	#header.small .searchArea {
		display: none;
	}
	#header .searchArea {
		float: right;
		margin: 7px 5px 5px;
	}
	#header .searchArea .tel {
		font-size: 1.25rem;
		display: inline-block;
		margin: 0 8px;
	}
	#header .searchArea .link {
		display: inline-block;
		float: right;
	}
	#header .searchArea .link a {
		font-size: 1rem;
		padding: 5px 15px;
		width: auto;
	}
	#header .searchArea .search {
		display: none;
	}
	#main {
		margin-top: 130px;
	}
	#main .topImage {
		border-top: none;
		margin-top: 18px;
		height: 250px;
	}
	#main h2 {
		font-size: 1.5rem;
		margin: 0 15px 0 0;
	}
	#main h3 {
		font-size: 1.375rem;
	}
	#main .page-content h2 {
		margin: 30px 0 20px 32px;
	}
	#main .page-content h2::before {
		height: 40px;
	}
	#main table.detail th {
		width: 110px;
	}
	#contactArea .telArea {
		border-right: none;
	}
	#contactArea .telArea .desc {
		font-size: 1rem;
    	text-align: center;
		margin-left: auto;
	}
	#contactArea .telArea .tel {
		font-size: 2rem;
	}
	#contactArea .telArea .tel svg {
		margin: 6px 6px 0 0;
	}
	#contactArea .telArea .telTime {
		margin-left: auto;
		text-align: center;
	}
	#contactArea .telArea .comment {
		margin-left: auto;
	}
	#contactArea .telArea .comment br {
		display: none;
	}
	
	#contactArea .mailArea .desc {
		font-size: 1rem;
		text-align: center;
	}
	#contactArea .telArea .lineH {
		float: none;
	}
	#contactArea .telArea .lineH img {
		transform: rotate(90deg);
		margin: -40px 0;
	}
	#footer .logoArea {
		margin: 30px 10px 10px;
	}
	#footer .leftArea .name {
		margin: 15px 0 5px;
	}
	#footer .leftArea .logo{
		width: 20%;
		margin: 10px 5px 15px;
	}
	#footer .leftArea .company{
		width: calc(80% - 20px);
		margin: 25px 5px 30px;
	}
	#footer .leftArea .company .desc{
		font-size: 0.875rem;
		margin-bottom: 0.25rem;
	}
	#footer .leftArea .company .address a{
		margin: 0;
	}
	#footer .leftArea,
	#footer .rightArea {
		margin-bottom: 0;
	}
	#footer .rightArea .column{
		margin-top: 10px;
		width: 100%;
	}
	#footer .rightArea .column:nth-of-type(3){
		width: calc(100% - 80px);
	}
	#footer .rightArea .column:nth-of-type(3) li{
		float: left;
		margin: 0 25px 25px 0;
	}
	#footer .company .name svg {
		width: 100%;
	}
	.page-top a {
		bottom: 80px;
	}
}

/* 640px PC*/

@media only screen and (min-width: 40em) {
	.sp-br br {
		display: none;
	}
	#header .menuButton {
		display: none;
	}
}

/* 640-1000px */

@media only screen and ( max-width: 62.5em) and (min-width: 40em) {
	#header .logoArea {
		width: 405px;
	}
	#header .row {
		height: 96px;
	}
	#header .menuButton {
		display: block;
	}
	#header .menuArea {
		position: fixed;
		display: block;
		opacity: 1;
		height: 0;
		top: 0;
		width: 100%;
		background: rgba(255, 255, 255, 0.95);
		transition: all .4s;
		overflow: hidden;
	}
	#header .menuArea .menu li {
		display: block;
	}
	#header .menuArea .menu li a {
		font-size: 1rem;
		line-height: 56px;
		width: 100%;
	}
	#header .descArea {
		margin: 5px 0 0 10px;
		width: calc(100% - 605px);
		max-height: 90px;
		overflow: hidden;
	}
	#header.small .descArea {
		margin: 5px 0 0 10px;
		width: calc(100% - 535px);
	}
	#header .searchArea .tel {
		font-size: 1.25rem
	}
	#header .searchArea .link a {
		font-size: 1rem;
		padding: 5px 15px;
	}
	#header .searchform input.searchField {
		font-size: 0.875rem;
		padding: 6px 15px;
	}
	#header .menu li a {
		padding: 0 20px;
	}


}

@media only screen and ( max-width: 750px) and (min-width: 640px) {
	#header .descArea {
		display: none;
	}
}

/* 1000-1200px */

@media only screen and ( max-width: 75em) and (min-width: 62.5em) {
	#header .descArea {
		margin: 28px 0 0 30px;
	}
	#header .menu li a {
		padding: 0 5px 3px;
	}
}

/* 1200-1600px */

@media only screen and ( max-width: 100em) and (min-width: 75em) {}

/* 1600px over */

@media only screen and ( min-width: 100em) {}

/* 640-800px */

@media only screen and ( max-width: 50em) and (min-width: 40em) {}

/* 0-480px */

@media only screen and (max-width: 30em) {}
