/*
----------------------------------------

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;
}

body {
	line-height: 1;
}

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;
}

a[href='#none'] {
	pointer-events: none !important;
}

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 #ccc;
	margin: 1em 0;
	padding: 0;
}

input, select {
	vertical-align: middle;
}


/*
----------------------------------------

common

----------------------------------------
*/

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

.en-02 {
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
}

.img {
	margin: 0;
	line-height: .5;
}

.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;
}

.sp {
	display: none;
}

.ofi img {
	object-fit: cover;
	font-family: 'object-fit: cover;' /* ie */
}

/* clearfix */

.clearfix:before,
.clearfix:after {
	display: table;
	content: '';
}
.clearfix:after {
	clear: both;
}

/* scrollbar */

/*
::-webkit-scrollbar {
	width: 5px;
	background: transparent;
}

::-webkit-scrollbar-track {
	box-shadow: none;
}

::-webkit-scrollbar-thumb {
	background-color: #ccc;
	box-shadow: none;
}
*/

.topic-path {
	white-space: nowrap;
	overflow: auto;
}

#breadcrumbs {
	font-size: 1.4rem;
	padding: 17px 0;
	margin-bottom: 1.2rem;
}

#breadcrumbs a {
	display: inline-block;
	color: #0083c9;
	position: relative;
	margin-right: 10px;
	padding-right: 15px;
}

#breadcrumbs a::after {
	content: '';
	width: 5px;
	height: 8px;
	background: url( ../img/common/2x/arrow-breadcrumbs.png ) center center / contain no-repeat;
	position: absolute;
	top: calc( 50% - 4px );
	right: 0;
}

#wrapper .slick-slide {
	transition: all .2s;
}

#wrapper .slick-slide img {
	width: 100%;
}

#wrapper .thumb-slide .slick-current img {
	border: solid 1px #0083c9;
}

#wrapper .slick-dots {
	margin: 0;
	bottom: -3rem;
}

#wrapper .slick-dots li {
	padding: 0;
	margin: 0 5px;
	letter-spacing: 0;
}

#wrapper .slick-dots li::before {
	display: none;
}

#wrapper .slick-dots li button:before {
	font-size: 10px;
	color: #ccc;
	opacity: 1;
	transition: all .2s;
}

#wrapper .slick-dots li.slick-active button:before {
	color: #0083c9;
	opacity: 1;
}

#wrapper .slick-prev,
#wrapper .slick-next {
	width: 4rem;
	height: 4rem;
	z-index: 99;
	transition: all .2s;
}

#wrapper .slick-prev {
	left: -4rem;
	background: url( ../img/common/2x/arrow-prev.png ) center center / contain no-repeat;
}

#wrapper .slick-next {
	right: -4rem;
	background: url( ../img/common/2x/arrow-next.png ) center center / contain no-repeat;
}

#wrapper .slick-prev:before,
#wrapper .slick-next:before{
	display: none;
}

.addtoany_list.a2a_kit_size_32 a:not(.addtoany_special_service) > span {
	border-radius: 50%;
	padding: 3px;
	transition: all .2s;
}

.heading-01 {
	font-size: 2.8rem;
	letter-spacing: 2.5px;
	line-height: 1.5;
	padding-left: 4.5rem;
	margin-bottom: 2rem;
	position: relative;
}

.heading-01::before {
	content: '';
	width: 30px;
	height: 1px;
	/* background: #c4ac6d; */
	background: #000;
	position: absolute;
	top: 50%;
	left: 0;
}

/* ttl */

.ttl-01 {
	text-align: center;
	color: #0083c9;
	position: relative;
	padding-top: 8.8rem;
	margin-bottom: 1rem;
	background-image: url( ../img/common/2x/illust-03.png );
	background-position: center top;
	background-size: 64px;
	background-repeat: no-repeat;
}

.ttl-01.icon-02 {
	background-image: url( ../img/common/2x/illust-04.png );
}

.ttl-01.icon-03 {
	background-image: url( ../img/common/2x/illust-02.png );
}

.ttl-01 .jp {
	font-size: 4.2rem;
	line-height: 1.2;
	letter-spacing: 2px;
}

.ttl-01 .en {
	font-size: 1.8rem;
	font-weight: bold;
	text-transform: capitalize;
}

.ttl-01 .num {
	font-size: 5.8rem;
	line-height: 1;
}

.ttl-01 .jp.s {
	font-size: 4rem;
}

.ttl-01 .en-bg {
	font-size: 16rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 3px;
	color: #f5f5f5;
	position: absolute;
	top: 1.5rem;
	right: 0;
	left: 0;
	z-index: -1;
}

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

.ttl-02 .en {
	font-size: 16rem;
	font-weight: bold;
	letter-spacing: 5px;
	line-height: 1;
	color: #f5f5f5;
	margin-bottom: -5.8rem;
}

.ttl-02 .jp {
	font-size: 2.8rem;
	letter-spacing: 2.2px;
	position: relative;
	z-index: 99;
}

.ttl-02 .jp strong {
	font-size: 3.2rem;
	color: #0083c9;
}

.ttl-02 .jp strong span {
	font-weight: normal;
}

.ttl-03 {
	text-align: center;
	line-height: 1.5;
}

.ttl-03 .jp {
	font-size: 2rem;
	font-weight: bold;
	align-items: center;
	justify-content: center;
}

.ttl-03 .jp::before,
.ttl-03 .jp::after {
	content: '';
	width: 4rem;
	height: 2px;
	background: #0083c9;
}

.ttl-03 .jp span {
	padding: 0 2rem;
}

.ttl-03 .en-txt {
	font-size: 7rem;
	font-weight: bold;
	line-height: 1.6;
	color: #0083c9;
}

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

.icon-ttl .icon {
	line-height: .5;
	margin-bottom: 1rem;
}

.icon-ttl .sub {
	font-size: 2rem;
	font-weight: bold;
	color: #0083c9;
	margin-bottom: .5rem;
}

.h-01 {
	text-align: center;
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	width: 100%;
	margin-bottom: 1rem;
}

.h-01::before,
.h-01::after {
	content: '';
	flex: 1;
	height: 2px;
	background: #0083c9;
}

.h-01 .ttl {
	display: inline-block;
	font-size: 3.2rem;
	letter-spacing: 2.4px;
	line-height: 1.5;
	padding: 0 3rem;
}

.h-01 .ttl.s {
	font-size: 2.8rem;
	padding: 0 1.6rem;
}

.h-02 {
	text-align: center;
	position: relative;
	padding-bottom: 1.5rem;
	margin-bottom: 3.5rem;
}

.h-02::after {
	content: '';
	width: 60px;
	height: 4px;
	background: #0083c9;
	position: absolute;
	bottom: 0;
	left: calc( 50% - 30px );
}

.h-02 .ttl {
	font-size: 3.2rem;
	line-height: 1.7;
	letter-spacing: 2px;
}

.h-03 {
	font-size: 2rem;
	line-height: 1.7;
	padding: 1.3rem 2rem 1.3rem 5rem;
	margin-bottom: 1rem;
	position: relative;
	background: #e5f6ff;
}

.h-03::before {
	content: '';
	width: 8px;
	height: 8px;
	border: solid 6px #0083c9;
	border-radius: 50%;
	position: absolute;
	top: calc( 50% - 1rem );
	left: 2rem;
}

.h-04 {
	text-align: center;
	margin-bottom: 2rem;
}

.h-04 .ttl {
	display: inline-block;
	font-size: 2.4rem;
	line-height: 1.6;
	color: #0083c9;
	padding: 0 3.5rem;
	background-image:
		url( ../img/about/2x/h-before.png ),
		url( ../img/about/2x/h-after.png );
	background-position:
		left center,
		right center;
	background-size: 19px;
	background-repeat: no-repeat;
}

/* under-line */

.under-line {
	background: linear-gradient( transparent 60%, #fef200 60% );
	padding: 1px 0 1px 2px;
}

/* btn */

.btn-01 {
	text-align: center;
}

.btn-01 a {
	display: inline-block;
	width: 360px;
	max-width: 100%;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	color: #0083c9;
	background: #fff url( ../img/common/2x/arrow-01.png ) right 2rem center / 2rem no-repeat;
	padding: 13px 10px;
	border: solid 2px #fff;
	border-radius: 3rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
}

.btn-01.bl a {
	color: #fff;
	background: #0083c9 url( ../img/common/2x/arrow-01-wh.png ) right 2rem center / 2rem no-repeat;
	border: solid 2px #0083c9;
}

.btn-01.ext-link a {
	width: 240px;
	font-size: 1.6rem;
	background: #0083c9 url( ../img/company/2x/icon-ext-link.png ) right 1.5rem center / 1.4rem no-repeat !important;
	padding: 7px 20px 7px 10px;
}

.btn-01.pdf-link a {
	width: 240px;
	font-size: 1.6rem;
	background: #0083c9 url( ../img/common/2x/icon-pdf.png ) right 1.5rem center / 1.4rem no-repeat !important;
	padding: 7px 10px;
}

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

.btn-02 a {
	display: inline-block;
	width: 240px;
	max-width: 100%;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	color: #0083c9;
	background: #fff url( ../img/common/2x/arrow-02.png ) right 1.5rem center / 1.8rem no-repeat;
	border: solid 2px #0083c9;
	padding: 11px 40px 11px 30px;
	border-radius: 2.5rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
}

.btn-03 a {
	display: block;
	width: 100%;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	color: #fff;
	background-color: #0083c9;
	background-image: url( ../img/common/2x/arrow-01-wh.png );
	background-position: right 1.6rem center;
	background-size: 1.8rem;
	background-repeat: no-repeat;
	padding: 8px 10px;
	border-radius: 2rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
}

.btn-03 .gr a {
	background-color: #00b6bf;
}

.mail-btn a {
	display: inline-block;
	width: 360px;
	max-width: 100%;
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 1.8px;
	line-height: 1.5;
	text-align: center;
	color: #222;
	background: #fef200;
	padding: 14.5px 10px 15.5px;
	margin: 1rem auto;
	border-radius: 3rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
}

.mail-btn a::before {
	content: '';
	display: inline-block;
	width: 24px;
	height: 19px;
	background: url( ../img/common/2x/icon-mail-bk.png ) left center / contain no-repeat;
	vertical-align: middle;
	margin-right: 1rem;
	transform: translateY( -2px );
}

/* bnr */

.bg-bnr a {
	width: 100%;
	height: 200px;
	justify-content: center;
	align-items: center;
	background: #000;
	color: #fff;
	border: solid 4px #fff;
	border-radius: 1rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
	overflow: hidden;
	position: relative;
}

.bg-bnr a::after {
	content: '';
	width: 28px;
	height: 28px;
	background: url( ../img/common/2x/arrow-01-wh.png ) center center / contain no-repeat;
	position: absolute;
	right: 2rem;
	top: calc( 50% - 14px );
	z-index: 99;
	transition: all .6s;
}

.bg-bnr a .box {
	line-height: 1.6;
	padding-bottom: 1.2rem;
	text-align: center;
	position: relative;
	z-index: 99;
}

.bg-bnr a .sub {
	display: inline-block;
	padding: 0 2rem;
	margin-top: -1rem;
	font-size: 2.4rem;
	line-height: 1.2;
	position: relative;
}

.bg-bnr a .sub::before,
.bg-bnr a .sub::after {
	content: '';
	height: 3rem;
	position: absolute;
	bottom: 0;
}

.bg-bnr a .sub::before {
	border-left: dotted 3px #fff;
	left: 0;
	transform: rotate( -35deg );
}

.bg-bnr a .sub::after {
	border-right: dotted 3px #fff;
	right: 0;
	transform: rotate( 35deg );
}

.bg-bnr a .sub .num {
	font-size: 3.2rem;
}

.bg-bnr a .ttl {
	font-size: 3.2rem;
	letter-spacing: 2.2px;
}

.bg-bnr.story a .ttl,
.bg-bnr.contact a .ttl {
	font-size: 3.6rem;
}

.bg-bnr a .ttl strong {
	color: #fcf000;
}

.bg-bnr a .txt {
	letter-spacing: 2.2px;
}

.bg-bnr.story a .txt,
.bg-bnr.contact a .txt {
	font-size: 1.8rem;
	letter-spacing: 1.6px;
	margin-top: 1rem;
}

.bg-bnr a .bg-img img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: .5;
	z-index: 1;
	transition: all .6s;
}

/* list */

.list-01 li {
	position: relative;
	padding-left: 1.5rem;
	line-height: 1.7;
}

.list-01 li::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #0083c9;
	position: absolute;
	top: 12px;
	left: 0;
}

.list-01 li + li {
	margin-top: .8rem;
}

.ol-01 {
	counter-reset: ol;
}

.ol-01 li {
	position: relative;
	padding-left: 2.5rem;
	list-style: none;
	line-height: 1.7;
}

.ol-01 li::before {
	content: counters( ol, '.') '. ';
	counter-increment: ol;
	color: #0083c9;
	font-family: 'Roboto', sans-serif;
	font-size:  1.8rem;
	font-weight: 400;
	letter-spacing: 3px;
	position: absolute;
	top: -1px;
	left: 0;
}

.ol-01 li + li {
	margin-top: .8rem;
}

.dl-01 {
	margin-bottom: .5rem;
}

.dl-01 dt {
	font-weight: bold;
	padding-left: 2rem;
	margin-bottom: 0.2rem;
	position: relative;
}

.dl-01 dt::before {
	content: '';
	width: 12px;
	height: 3px;
	background: #0083c9;
	position: absolute;
	top: calc( 50% - 1px );
	left: 0;
}

.dl-01 dd + dt {
	margin-top: 2.5rem;
}

.dl-01 dd {
	line-height: 2;
}

/* table */

.table-01 {
	width: 100%;
	text-align: left;
	line-height: 1.7;
	border-top: solid 1px #dbdbdb;
}

.table-01 th {
	width: 15rem;
	padding: 2.5rem 2rem;
	font-weight: bold;
	border-bottom: solid 1px #0083c9;
	position: relative;
}

.table-01 tr:first-child th::before {
	content: '';
	height: 1px;
	background: #0083c9;
	position: absolute;
	top: -1px;
	right: 0;
	left: 0;
}

.table-01 td {
	width: calc( 100% - 15rem );
	padding: 2.5rem 2rem 2.5rem 8rem;
	border-bottom: solid 1px #dbdbdb;
}

/* layout */

.wrap {
	width: 100%;
	max-width: 1260px;
	padding: 0 30px;
	text-align: left;
	margin: 0 auto;
}

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

.flex.center {
	justify-content: center;
}


/*
----------------------------------------

default

----------------------------------------
*/

html {
	font-size: 62.5%;
}

body {
	font-size: 1.6rem;
	font-family: 'Lato', 'Noto Sans JP', sans-serif;
	font-feature-settings: 'palt';
	letter-spacing: 1px;
	line-height: 2;
	width: 100%;
	text-align: center;
	color: #222;
	box-sizing: border-box;
	position: relative;
	-webkit-text-size-adjust: 100%;
	overflow-scrolling: touch;
}

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

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

ul {
	list-style: none;
}

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

#wrapper {
	position: relative;
}

#header {
	color: #fff;
	background: #ccc;
}

#header .flex {
	height: 380px;
	justify-content: center;
	align-items: center;
	font-size: 8rem;
	padding-bottom: 15px;
}

footer#footer {
	color: #fff;
	background: #ccc;
}

footer#footer .flex {
	height: 600px;
	justify-content: center;
	align-items: center;
	font-size: 8rem;
}

/*
----------------------------------------

page

----------------------------------------
*/

.page {
	padding-top: 100px;
	background: url( ../img/product/2x/bg-01.png ) right top / 552px no-repeat;
}

.page #main-header {
	background: #fff;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .1 );
}

.page #main-header .logo a {
	border-radius: 0;
}

.page-header {
	padding: 4rem 0 1.5rem;
}

.page-header .ttl-wrap {
	border-left: solid 4px #0083c9;
	padding: .4rem 0 .6rem 2.5rem;
	line-height: 1.3;
}

.page-header .sub {
	font-size: 1.8rem;
	text-transform: uppercase;
	letter-spacing: 1.4px;
	color: #0083c9;
}

.page-header .jp {
	font-size: 4.2rem;
}


/*
----------------------------------------

parts

----------------------------------------
*/

/* type-list */

.type-list li {
	margin: 0 1rem 1rem 0;
}

.type-list li:last-child {
	margin-right: 0;
}

.type-list span {
	display: inline-block;
	text-align: center;
	min-width: 12rem;
	padding: 0 1.5rem;
	font-size: 1.4rem;
	color: #0083c9;
	border: solid 1px #0083c9;
	border-radius: 1.5rem;
}

.type-list span.type-02 {
	color: #00b6bf;
	border: solid 1px #00b6bf;
}

.type-list span.type-03 {
	color: #545ea7;
	border: solid 1px #545ea7;
}

/* bnr-box */

.bnr-box {
	padding: 4rem 0;
	background: #f5f5f5;
}

.bnr-box.bl {
	padding: 3rem 0 4rem;
	background: #0083c9;
}

.bnr-box .bnr {
	width: calc( ( 100% - 3rem ) / 2 );
}

.bnr-box .bnr:nth-child( even ) {
	margin-left: 3rem;
}

.bnr-box .bnr a {
	border: solid 4px #fff;
	border-radius: 1rem;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
	align-items: center;
	height: 150px;
	padding: 0 5rem 0 2.5rem;
	position: relative;
	transition: all .4s;
}

.bnr-box .bnr a::after {
	content: '';
	width: 2.8rem;
	height: 2.8rem;
	background: url( ../img/common/2x/arrow-02.png ) center center / contain no-repeat;
	position: absolute;
	top: calc( 50% - 1rem );
	right: 2rem;
	transition: all .4s;
}

.bnr-box .bnr.arrow-02 a::after {
	background: url( ../img/common/2x/arrow-01-wh.png ) center center / contain no-repeat;
}

.bnr-box .bnr.support a::after {
	background: url( ../img/common/2x/arrow-01-wh.png ) center center / contain no-repeat;
}

.bnr-box .bnr.catalog a {
	background: url( ../img/common/2x/bnr-catalog-bg.png ) center center / cover no-repeat;
}

.bnr-box .bnr.support a {
	background: url( ../img/common/2x/bnr-support-bg.png ) center center / cover no-repeat;
}

.bnr-box .bnr.option a {
	background: url( ../img/product/2x/bnr-option-bg.png ) center center / cover no-repeat;
	color: #fff ;
	text-shadow: 0 2px 2px rgba( 0, 0, 0, .2 );;
}

.bnr-box .bnr.option a h3 {
	font-size: 2.8rem;
	color: #fff;
}

.bnr-box .bnr.option a p {
	letter-spacing: 1.2px;
}

.bnr-box .bnr.support a {
	color: #fff;
}

.bnr-box .bnr .img {
	line-height: .5;
	margin: 0;
	width: 10rem;
}

.bnr-box .bnr.catalog a .img {
	width: 7.5rem;
}

.bnr-box .bnr .txt {
	width: calc( 100% - 10rem );
	padding-left: 2rem;
	font-size: 1.7rem;
}

.bnr-box .bnr.catalog a .txt {
	width: calc( 100% - 7.5rem );
}

.bnr-box .bnr .txt h3 {
	font-size: 2.6rem;
	letter-spacing: 0;
	line-height: 1.5;
	color: #0083c9;
}

.bnr-box .bnr.support .txt h3 {
	font-size: 2.8rem;
	color: #fff;
}

/* search-set */

.search-set {
	padding-top: 8rem;
}

.search-set .sec .ttl {
	position: relative;
}

.search-set .sec .ttl .jp {
	font-size: 2.8rem;
	font-weight: bold;
	letter-spacing: 1.2px;
	padding: 1.8rem 0 1.8rem 7rem;
	background-position: left center;
	background-size: 54px;
	background-repeat: no-repeat;
}

.search-set .sec-01 .ttl .jp {
	background-image: url( ../img/common/2x/icon-search.png );
}

.search-set .sec-02 .ttl .jp {
	background-image: url( ../img/common/2x/icon-series.png );
}

.search-set .sec-03 .ttl .jp {
	background-image: url( ../img/common/2x/icon-water.png );
}

.search-set .sec-04 .ttl .jp {
	background-image: url( ../img/common/2x/icon-usage.png );
}

.swipe {
	display: none;
}

.search-set .sec .ttl .bl {
	color: #0083c9;
}

.search-set .sec .view-more {
	position: absolute;
	right: 0;
	bottom: 0;
}

.search-set .sec .view-more .flex {
	align-items: flex-end;
	position: relative;
}

.search-set .sec .view-more .flex::after {
	content: 'JUST FIT';
	font-size: 12rem;
	font-weight: bold;
	letter-spacing: 4.5px;
	line-height: 1;
	color: #f0f0f0;
	white-space: nowrap;
	position: absolute;
	right: -4.5rem;
	top: -4rem;
	z-index: -1;
}

.search-set .sec .view-more .img {
	line-height: .5;
	margin: 0 8px;
}

.search-set .sec .view-more .btn-02 {
	padding: 2rem 0;
}

.search-set .search-wrap {
	background: #e5f6ff;
	padding: 2rem 3rem;
	margin-bottom: 4rem;
	border-radius: 2rem;
	align-items: center;
}

.search-set .search-wrap .select-wrap {
	width: calc( 100% - 180px );
}

.search-set .search-wrap select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: 1.7rem;
	font-weight: bold;
	letter-spacing: 1px;
	color: #222;
	border: solid 2px #0083c9;
	border-radius: 1rem;
	background: #fff;
	padding: 1.35rem 4rem 1.35rem 2rem;
	width: 100%;
}

.search-set .search-wrap .select {
	width: calc( ( 100% - 60px ) / 3 );
	position: relative;
}

.search-set .search-wrap .select::after {
	content: '';
	width: 3rem;
	position: absolute;
	top: 2px;
	right: 0;
	bottom: 2px;
	border-radius: 0 1rem 1rem 0;
	background: #0083c9 url( ../img/common/2x/arrow-select.png ) center center / 1.2rem no-repeat;
}

.search-set .search-wrap .select + .select {
	margin-left: 3rem;
}

.search-set .search-wrap .select + .select::before {
	content: '';
	width: 15px;
	height: 14px;
	background: url( ../img/common/2x/kakeru.png ) center center / contain no-repeat;
	position: absolute;
	left: -15px;
	top: calc( 50% - 7px );
	transform: translateX( -50% );
}

.search-set .search-wrap .search-btn {
	width: 180px;
	padding-left: 2rem;
}

.search-set .search-wrap button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: inline-block;
	text-shadow: none;
	border: none;
	border-radius: 25px;
	width: 100%;
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
	color: #222;
	background: #fef200;
	padding: 11.5px 10px;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
	transition: all .2s;
	cursor: pointer;
}

.search-set .cont-list {
	margin-top: 1.2rem;
	margin-bottom: -.2rem;
}

.search-set .cont-list .box {
	width: calc( ( 100% - 6px ) / 3 );
	margin-right: 3px;
	 margin-bottom: 2.8rem;
}

.search-set .cont-list .box:nth-child( 3n ) {
	margin-right: 0;
}

.search-set .cont-list .img {
	line-height: .5;
	margin-bottom: -3.5rem;
	background: #000;
}

.search-set .cont-list .img img {
	transition: all .2s;
}

.search-set .cont-list .txt {
	margin: 0 4.5rem;
	background: #fff;
	text-align: center;
	padding: 1.5rem;
	border-radius: 1rem;
	position: relative;
	z-index: 99;
	font-weight: bold;
	transition: all .2s;
}

.search-set .cont-list .sub {
	color: #0083c9;
	margin-bottom: .5rem;
	transition: all .2s;
}

.search-set .cont-list .ttl {
	display: inline-block;
	font-size: 2.2rem;
	font-weight: bold;
	line-height: 1.5;
	padding-right: 3rem;
	transition: all .2s;
	position: relative;
}

.search-set .cont-list .ttl::after {
	content: '';
	width: 2rem;
	height: 2rem;
	background: url( ../img/common/2x/arrow-02.png ) center center / contain no-repeat;
	position: absolute;
	top: calc( 50% - 1rem );
	right: 0;
	transition: all .2s;
}

.search-set .link-list {
	background: #e5f6ff;
	padding: 3.2rem 3rem 1rem;
	border-radius: 1rem;
	align-items: center;
}	

.search-set .link-list li {
	width: calc( ( 100% - 4rem ) / 3 );
	margin-right: 2rem;
	margin-bottom: 2rem;
}

.search-set .link-list li:nth-child( 3n ) {
	margin-right: 0;
}

.search-set .link-list a {
	display: block;
	background: #fff url( ../img/common/2x/arrow-02.png ) right 1.5rem center / 1.8rem no-repeat;
	padding: 1.2rem 4rem 1.2rem 6rem;
	font-size: 1.8rem;
	font-weight: bold;
	position: relative;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .2 );
	border-radius: 1rem;
}

.search-set .link-list a .img {
	margin: 0;
	width: 30px;
	max-height: 30px;
	text-align: center;
	position: absolute;
	left: 2rem;
	top: 50%;
}

.search-set .link-list a .img img {
	transform: translateY( -50% );
}

/* contact-box */

.contact-box {
	background: #0083c9;
	color: #fff;
}

.contact-box .contact-wrap {
	min-height: 400px;
	padding: 4.5rem 0 5.5rem 29rem;
	background: url( ../img/common/2x/contact-img.png ) left bottom / 269px no-repeat;
}

.contact-box .ttl h2 {
	font-size: 3.6rem;
	line-height: 1.5;
	text-align: center;
	margin-bottom: 1.2rem;
}

.contact-box .flex > dl {
	width: calc( ( 100% - 3rem ) / 2 );
	border: solid 2px rgba( 255, 255, 255, .5 );
	padding: 2.5rem 2rem 1.8rem;
	text-align: center;
	margin-top: 3.5rem;
	border-radius: 1rem;
	position: relative;
}

.contact-box .flex > dl:nth-child( even ) {
	margin-left: 3rem;
}

.contact-box .flex dt {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	transform: translateY( -50% );
}

.contact-box .flex dt span {
	display: inline-block;
	padding: 0 2rem;
	font-size: 1.8rem;
	font-weight: bold;
	background: #0083c9;
}

.contact-box .flex dd a {
	display: block;
}

.contact-box .flex dd a .num {
	display: inline-block;
	font-size: 4.2rem;
	font-weight: bold;
	letter-spacing: 2.2px;
	line-height: 1.2;
	padding-left: 4.6rem;
	color: #fff;
	background: url( ../img/common/2x/icon-tel.png ) left center / 3.6rem no-repeat;
}

.contact-box .flex dd a .note {
	color: #fff;
}

.attention dl {
	border: solid 2px #e5e5e5;
	border-radius: 1rem;
	padding: 2.5rem 3rem 2rem;
	margin: 3rem 0;
	position: relative;
}

.attention dt {
	display: inline-block;
	background: #fff;
	padding: 0 2rem;
	font-size: 1.8rem;
	font-weight: bold;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate( -50%, -50% );
}

.attention dd p {
	width: 100%;
	overflow: hidden;
}

.attention dd li {
	font-size: 1.4rem;
	padding-left: 1.4rem;
	text-indent: -1.4rem;
	line-height: 1.7;
	margin-bottom: .4rem;
}

.page-menu-box {
	width: 100%;
	background: #e5f6ff;
	padding: 2rem 0;
}

.page-menu .flex {
	justify-content: center;
}

.page-menu li {
	width: calc( ( 100% - 8rem ) / 5 );
}

.page-menu li + li {
	margin-left: 2rem;
}

.page-menu li a {
	display: block;
	font-size: 1.8rem;
	font-weight: bold;
	white-space: nowrap;
	background-color: #fff;
	background-image: url( ../img/product/2x/arrow-down-01.png );
	background-position: right 1.5rem center;
	background-size: 18px;
	background-repeat: no-repeat;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .1 );
	padding: 1.2rem 2rem;
	border-radius: 1rem;
}

.case-wrap {
	background: #e6f3f9;
	padding: 6rem 0;
	margin-bottom: 3.5rem;
}

.case-wrap .h-02 {
	margin-bottom: 3rem;
}

.case-wrap .case-slider {
	margin-bottom: 4rem;
}

.case-wrap .case-slider .kitchen {
	margin: 0 2rem;
}

.case-wrap .case-slider a {
	display: block;
	background: #fff;
	box-shadow: 0 2px 4px rgba( 0, 0, 0, .1 );
}

.case-wrap .case-slider a .img {
	line-height: .5;
	background: #000;
}

.case-wrap .case-slider a img {
	width: 100%;
	transition: all .2s;
}

.case-wrap .case-slider .txt-wrap {
	font-size: 1.4rem;
	text-align: left;
	padding: 1.8rem 3rem 2.4rem;
	position: relative;
}

.case-wrap .case-slider .cat {
	position: absolute;
	top: -2.5rem;
	left: 0;
}

.case-wrap .case-slider .cat span {
	display: inline-block;
	font-weight: bold;
	padding: .3rem 1.4rem;
	border-radius: 0 1rem 1rem 0;
	color: #fff;
	background: #0083c9;
}

.case-wrap .case-slider time {
	color: #0083c9;
	font-weight: bold;
}

.case-wrap .case-slider .cat-ttl {
	display: flex;
	align-items: center;
	font-size: 2rem;
	line-height: 1.6;
	margin-bottom: .8rem;
	transition: all .2s;
}

.case-wrap .case-slider .series {
	color: #666;
}

#wrapper .case-wrap .slick-prev {
	left: 13.8vw;
}

#wrapper .case-wrap .slick-next {
	right: 13.8vw;
}

.solution-wrap {
	margin: 5.2rem 0 2rem;
}

.solution-wrap .box {
	width: calc( ( 100% - 4rem ) / 2 );
	border: solid 2px #e5e5e5;
	border-radius: 1rem;
	padding: 1.4rem 1.4rem 1.4rem 3rem;
	position: relative;
	font-size: 1.8rem;
}

.solution-wrap .box:nth-child( even ) {
	margin-left: 4rem;
}

.solution-wrap .box:nth-child( even )::after {
	content: '';
	width: 23px;
	height: 17px;
	background: url( ../img/product_cat/2x/arrow-03.png ) center center / contain no-repeat;
	position: absolute;
	top: 50%;
	left: -2.1rem;
	transform: translate( -50%, -50% );
}

.solution-wrap .box-02 {
	background: #f2fbff;
	border-color: #0083c9;
}

.solution-wrap .ttl {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	text-align: center;
	transform: translateY( -50% );
}

.solution-wrap .ttl span {
	display: inline-block;
	padding: 0 2.5rem;
	background: #0083c9;
	color: #fff;
	border-radius: 1.9rem;
}

.solution-wrap .box-02 .ttl span {
	background: #fcf000;
	color: #222;
}

.solution-wrap .flex {
	align-items: center;
	flex-wrap: nowrap;
	width: 100%;
	height: 100%;
}

.solution-wrap .flex .txt-wrap {
	padding: 2.7rem 0;
	line-height: 1.5;
}

.solution-wrap .list .list-01 li {
	margin: .1rem 0;
}

.solution-wrap .img {
	margin-left: auto;
	padding-left: 2rem;
}

.solution-wrap .sub-ttl {
	display: inline-block;
	font-size: 2.4rem;
	letter-spacing: 1.8px;
	line-height: 1.5;
	color: #0083c9;
	border-bottom: dotted 2px #0083c9;
	margin: 1rem 0;
}

.solution-wrap .icon {
	margin: 0;
	line-height: .5;
	margin-right: 1rem;
}

.solution-wrap .list-01 li {
	letter-spacing: 0;
	line-height: 1.7;
}

.solution-wrap .read {
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
	padding: 3px;
}

.solution-wrap strong {
	font-size: 2.2rem;
	letter-spacing: 2px;
	color: #0083c9;
}

.point-list {
	margin-top: 1rem;
}

.point-list li + li {
	margin-left: 1.5rem;
}

.point-list .point {
	justify-content: center;
	align-items: center;
	width: 15rem;
	height: 15rem;
	border: solid 1px #0083c9;
	border-radius: 50%;
	text-align: center;
	position: relative;
}

.point-list .point span {
	font-size: 1.8rem;
	line-height: 1.5;
	color: #0083c9;
	font-weight: bold;
}

.img-list {
	padding: 4rem 6rem 0;
	background: #f5f5f5;
	border-radius: 1rem;
}

.img-list .img-wrap {
	width: calc( ( 100% - 12rem ) / 4 );
	margin: 0 4rem 3.4rem 0;
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
}

.img-list .img-wrap:nth-child( 4n ) {
	margin-right: 0;
}

.img-list .img-wrap .img {
	margin-bottom: 1.4rem;
}

.img-list .img-wrap .name {
	line-height: 1.6;
}

/* pagination */

.pagination {
	text-align: center;
	margin: 4rem 0;
}

.pagination > div {
	display: inline-block;
}

.pagination ul {
	justify-content: center;
	position: relative;
	padding: 0 50px;
}

.pagination ul li {
	line-height: .5;
}

.pagination a,
.pagination span {
	display: inline-block;
	min-width: 40px;
	height: 40px;
	line-height: 40px;
	font-size: 2rem;
	font-weight: 500;
	text-align: center;
	margin: 0 5px;
	transition: all .4s;
	background: #fff;
	border: solid 1px #ddd;
}

.pagination span.current {
	background: #0083c9;
	border: solid 1px #0083c9;
	color: #fff;
}

.pagination .prev,
.pagination .next {
	width: 40px;
	text-indent: -9999px;
	overflow: hidden;
	border: none;
	position: absolute;
	top: 0;
}

.pagination .prev {
	background: url( ../img/common/svg/arrow-prev.svg ) center center / 6px no-repeat;
	left: 0;
	border: solid 1px transparent !important;
}

.pagination .next {
	background: url( ../img/common/svg/arrow-next.svg ) center center / 6px no-repeat;
	right: 0;
	border: solid 1px transparent !important;
}

.search-mes {
	text-align: center;
	background: #e5f6ff;
	padding: 2rem 3rem;
	margin-bottom: 4rem;
	border-radius: 2rem;
}

.search-mes .txt {
	display: inline-block;
	border: solid 2px #0083c9;
	border-radius: 1rem;
	background: #fff;
	padding: 1.5rem 3rem;
}

.search-mes .txt .word {
	display: inline-block;
	font-size: 1.7rem;
	font-weight: bold;
	color: #0083c9;
	margin: 0 .5rem;
}

.search-mes .txt .word + .word {
	margin-left: 0;
}

.search-mes .txt .word + .word:before {
	content: '×';
	font-weight: normal;
	color: #222;
	margin-right: .5rem;

}

.search-mes .txt .search-num {
	display: inline-block;
	font-weight: bold;
	color: #0083c9;
}

.search-mes .txt .search-num > span {
	font-size: 2rem;
}

#coming-soon .cont .read {
	text-align: center;
	margin: 4rem 0;
}


/*
----------------------------------------

1400

----------------------------------------
*/

@media screen and ( max-width: 1400px ) {

	#wrapper .slick-prev {
		left: 2rem;
	}

	#wrapper .slick-next {
		right: 2rem;
	}

	.phone-btn a {
		padding: 10px 15px;
	}

	.contact-btn a {
		padding: 8px 15px 8px 35px;
	}

	.search-set .sec .view-more .flex::after {
		right: -2rem;
	}

	.contact-box .ttl h2 {
		font-size: 3.2rem;
	}

	.point-list .point {
		width: 12rem;
		height: 12rem;
	}

	.point-list .point span {
		font-size: 1.6rem;
	}

}


/*
----------------------------------------

1200

----------------------------------------
*/

@media screen and ( max-width: 1200px ) {

	.solution-wrap .sub-ttl {
		font-size: 2rem;
	}

	.case-wrap .case-slider .kitchen {
		margin: 0 1.5rem;
	}

	.search-set .cont-list .txt {
		margin: 0 2rem;
	}

	.contact-box .wrap {
		padding: 0 2rem;
	}

	.contact-box .contact-wrap {
		padding: 3rem 1rem 4rem 22rem;
		background: url( ../img/common/2x/contact-img.png ) left bottom / 210px no-repeat;
		min-height: initial;
	}

	.contact-box .flex dd a .num {
		font-size: 3.2rem;
	}

	.bnr-box .bnr .txt h3 {
		font-size: 2rem !important;
	}

	.page-menu li {
		width: calc( ( 100% - 4rem ) / 5 );
	}

	.page-menu li + li {
		margin-left: 1rem;
	}

	.page-menu li a {
		font-size: 1.6rem;
		padding: 1.2rem 1.5rem;
		text-align: left;
		background-position: right 1rem center;
		background-size: 16px;
	}

	.bnr-box .bnr.catalog a {
		padding: 0 6rem 0 2rem;
	}

	.bnr-box .bnr .img {
		width: 8.5rem;
	}

	.bnr-box .bnr .txt {
		width: calc( 100% - 8.5rem );
	}

	.bnr-box .bnr.catalog a .img {
		width: 6rem;
	}

	.bnr-box .bnr.catalog a .txt {
		width: calc( 100% - 6rem );
	}

	.contact-box .contact-wrap {
		padding: 4.5rem 0 5.5rem 27rem;
	}

	.contact-box .flex > dl {
		width: calc( ( 100% - 2rem ) / 2 );
	}

	.contact-box .flex > dl:nth-child( even ) {
		margin-left: 2rem;
	}

	.img-list {
		padding: 4rem 3rem 0;
	}

	.img-list .img-wrap {
		width: calc( ( 100% - 9rem ) / 4 );
		margin: 0 3rem 3rem 0;
	}

	.search-set .sec .ttl .jp {
		font-size: 2.4rem;
	}

	.search-set .sec .view-more .flex::after {
		font-size: 10rem;
		top: -3rem;
	}

	.search-set .cont-list .txt {
		margin: 0 2rem;
	}

	.search-set .cont-list .ttl {
		font-size: 2rem;
		padding-right: 2.5rem;
	}

	.bnr-box .bnr a {
		padding: 0 1.5rem;
	}

	.bnr-box .bnr a::after {
		right: 1.5rem;
	}

	.bnr-box .bnr .txt {
		font-size: 1.6rem;
		letter-spacing: 0;
	}

	.bnr-box .bnr .txt h3 {
		font-size: 2rem;
	}

	.bnr-box .bnr.support .txt h3 {
		font-size: 2.2rem;
	}

	#wrapper .case-wrap .slick-prev {
		left: 1rem;
	}

	#wrapper .case-wrap .slick-next {
		right: 1rem;
	}

}


/*
----------------------------------------

1000

----------------------------------------
*/

@media screen and ( max-width: 1000px ) {

	.page {
		padding-top: 64px;
		background: transparent;
	}

	.ttl-01 {
		padding-top: 6.8rem;
		margin: 0 0 1rem;
		background-size: 44px;
	}

	.ttl-01 .jp {
		font-size: 2.8rem;
		line-height: 1.3;
	}

	.ttl-01 .en {
		font-size: 1.2rem;
	}

	.ttl-01 .jp.s {
		font-size: 2.6rem;
	}

	.ttl-01 .en-bg {
		font-size: 8rem;
		top: 2.5rem;
	}

	.ttl-01 .num {
		font-size: 4.2rem;
	}

	.ttl-02 .en {
		font-size: 6rem;
		text-indent: -.6rem;
		margin-bottom: -2.4rem;
		letter-spacing: 2.6px;
	}

	.ttl-02 .jp {
		font-size: 2rem;
		line-height: 1.5;
		letter-spacing: 1px;
	}

	.ttl-02 .jp strong {
		font-size: 2.2rem;
		letter-spacing: 3px;
	}

	.ttl-03 .jp {
		font-size: 1.6rem;
	}

	.ttl-03 .jp::before,
	.ttl-03 .jp::after {
		width: 3rem;
	}

	.ttl-03 .jp span {
		padding: 0 1.5rem;
	}

	.ttl-03 .en-txt {
		font-size: 4rem;
	}

	.h-01 {
		justify-content: center;
		width: initial;
		margin: 0 -2rem 2rem;
		padding: 0 2rem 1rem;
		border-bottom: solid 2px #0083c9;
	}

	.h-01 .ttl {
		font-size: 2.4rem;
		padding: 0;
	}

	.h-01::before,
	.h-01::after {
		display: none;
	}

	.h-01 .ttl.s {
		font-size: 2rem;
		letter-spacing: 1.2px;
		padding: 0;
	}

	.icon-ttl .icon {
		margin-bottom: .5rem;
	}

	.icon-ttl .sub {
		font-size: 1.5rem;
		margin-bottom: .2rem;
	}

	.h-02 {
		padding-bottom: 2rem;
	}

	.h-02 .ttl {
		font-size: 2.4rem;
	}

	.h-03 {
		font-size: 1.7rem;
		padding: .8rem 1rem .8rem 3.8rem;
	}

	.h-03::before {
		border: solid 4px #0083c9;
		top: calc( 50% - .8rem );
		left: 1.2rem;
	}

	.h-04 .ttl {
		background-image:
			url( ../img/sp/1x/h-before-sp.png ),
			url( ../img/sp/1x/h-after-sp.png );
		background-position:
			left bottom 20%,
			right bottom 20%;
		background-size: 22.5px;
		line-height: 1.5;
	}

	.ol-01 li {
		padding-left: 2.2rem;
	}

	.ol-01 li::before {
		font-size: 1.6rem;
		top: -2px;
	}

	.btn-01 a {
		width: 300px;
		font-size: 1.5rem;
		background: #fff url( ../img/common/2x/arrow-01.png ) right 2rem center / 1.6rem no-repeat;
		padding: 12px 0;
	}

	.btn-01.bl a {
		background: #0083c9 url( ../img/common/2x/arrow-01-wh.png ) right 2rem center / 1.6rem no-repeat;
	}

	.btn-01.ext-link a {
		width: 22rem;
		font-size: 1.4rem;
	}

	.btn-02 a {
		width: 300px;
		font-size: 1.5rem;
		letter-spacing: 1px;
		padding: 12px 40px 12px 30px;
	}

	.table-01 th {
		width: 9rem;
		padding: 2rem 1rem;
	}

	.table-01 td {
		width: calc( 100% - 9rem );
		padding: 2rem 0 2rem 1rem;
	}

	.mail-btn a {
		font-size: 1.4rem;
		width: 260px;
		padding: 9.5px 10px 12.5px;
	}

	.mail-btn a::before {
		width: 1.8rem;
		height: 1.4rem;
		transform: translateY( -1px );
	}

	.type-list li {
		margin: 0 .5rem .5rem 0;
	}

	.type-list span {
		font-size: .9rem;
		min-width: 7.5rem; 
		padding: 0 1rem;
	}

	.bg-bnr a {
		height: 110px;
		border: solid 2px #fff;
	}

	.bg-bnr a::after {
		width: 16px;
		height: 16px;
		top: calc( 50% - 8px );
		right: 1rem;
	}

	.bg-bnr a .box {
		padding-bottom: 1rem;
	}

	.bg-bnr a .sub {
		font-size: 1.2rem;
		letter-spacing: .4px;
		padding: .4rem 2.2rem;
	}

	.bg-bnr a .sub::before,
	.bg-bnr a .sub::after {
		height: 1.5rem;
		bottom: 4px;
	}

	.bg-bnr a .sub::before {
		border-left: dotted 1px #fff;
		transform: rotate( -30deg );
		left: 1rem;
	}

	.bg-bnr a .sub::after {
		border-right: dotted 1px #fff;
		transform: rotate( 30deg );
		right: 1rem;
	}

	.bg-bnr a .sub .num {
		font-size: 1.5rem;
	}

	.bg-bnr a .ttl {
		font-size: 1.5rem;
		line-height: 1.3;
		letter-spacing: 1.2px;
	}

	.bg-bnr a .ttl.l {
		font-size: 2rem;
		letter-spacing: 0;
		margin-top: 1rem;
	}

	.bg-bnr a .ttl strong {
		font-size: 1.7rem;
		display: block;
	}

	.bg-bnr a .txt {
		font-size: 1.2rem;
		letter-spacing: .8px;
		margin-top: .5rem;
	}

	.bg-bnr.story a .txt,
	.bg-bnr.contact a .txt {
		font-size: 1.2rem;
		letter-spacing: 0;
	}

	.point-list {
		margin-top: 1.4rem;
	}

	.point-list > .flex {
		justify-content: center;
	}

	.point-list .point {
		width: 10.5rem;
		height: 10.5rem;
		font-size: 1.4rem;
	}

	.point-list li + li {
		margin-left: 1rem;
	}

	.point-list .point span {
		font-size: 1.4rem;
	}

	.search-set .view-more .img {
		display: none;
	}

	.search-set .btn-02 a {
		width: 22rem;
	}

	html #wpadminbar {
		display: none;
	}

	body {
		font-size: 1.4rem;
	}

	.wrap {
		padding: 0 20px;
	}

	#wrapper .slick-prev,
	#wrapper .slick-next {
		width: 50px;
		height: 50px;
	}

	#wrapper .slick-prev {
		left: .8rem;
		background: url( ../img/common/2x/arrow-prev.png ) center center / 30px no-repeat;
	}

	#wrapper .slick-next {
		right: .8rem;
		background: url( ../img/common/2x/arrow-next.png ) center center / 30px no-repeat;
	}

	#wrapper .slick-dots {
		bottom: -32px;
	}

	#header .flex {
		height: 150px;
		font-size: 4rem;
		padding-bottom: 5px;
	}

	.heading-01 {
		font-size: 1.8rem;
		padding-left: 3.5rem;
	}

	.heading-01::before {
		width: 20px;
	}

	.list-01 li {
		letter-spacing: .8px;
		padding-left: 1.2rem;
	}

	.list-01 li::before {
		top: 10px;
	}

	.list-01 li + li {
		margin-top: .4rem;
	}

	.page-header .box {
		height: 160px;
	}

	.page-header .ttl-en {
		font-size: 3.2rem;
	}

	.page-header .ttl-jp {
		font-size: 1.6rem;
	}

	.scroll-wrap {
		margin: 0 -2rem 0;
		padding: 1rem 0;
		overflow-x: scroll;
		overflow-y: hidden;
		position: relative;
	}

	.search-set .cont-list {
		width: 770px;
		padding: 0 2rem;
		margin-top: 0;
		flex-wrap: nowrap;
	}

	.search-set .sec-02 .cont-list {
		width: 1520px;
	}

	@keyframes swipe {
		0% {
			opacity: 0;
		}
		15% {
			opacity: 1;
		}
		35% {
			opacity: 1;
		}
		50% {
			transform: translateX( -30px );
			opacity: 0;
		}
		100% {
			transform: translateX( -30px );
			opacity: 0;
		}
	}

	.swipe-wrap {
		position: relative;
		z-index: 99;
	}

	.swipe {
		display: block;
		position: absolute;
		top: .2rem;
		right: -1rem;
		animation: swipe 3s linear 1s infinite normal;
	}

	.swipe img {
		width: 5.4rem;
	}

	.search-set .cont-list .box {
		width: 230px;
		margin-right: 2rem !important;
		margin-bottom: 0;
	}

	.search-set .cont-list .box:last-child {
		margin-right: 0 !important;
	}

	.search-set .cont-list .img img {
		height: 255px;
	}

	.search-set .cont-list .txt {
		margin: 0 1rem;
		padding: 1.4rem 1rem .2rem;
		letter-spacing: 0;
	}

	.search-set .cont-list .sub {
		font-size: 1.2rem;
		line-height: 1.5;
		letter-spacing: .5px;
	}

	.search-set .cont-list .ttl {
		font-size: 1.4rem;
		letter-spacing: 1.2px;
		padding-right: 2rem;
	}

	.search-set .cont-list .ttl::after {
		width: 1.6rem;
		height: 1.6rem;
		top: calc( 50% - .8rem );
	}

	.search-set .link-list {
		padding: 2rem 2rem .5rem;
		margin-top: 1.5rem;
	}

	.search-set .link-list li {
		width: 100%;
		margin-right: 0;
		margin-bottom: 1.5rem;
	}

	.search-set .link-list a {
		font-size: 1.5rem;
		padding: .9rem 4rem .9rem 5rem;
		background: #fff url( ../img/common/2x/arrow-02.png ) right 1rem center / 1.6rem no-repeat;
	}

	.search-set .link-list a .img {
		width: 24px;
		line-height: .5;
		transform: translateY( -50% );
		left: 1.5rem;
	}

	.search-set .link-list a .img img {
		transform: none;
	}

	.contact-box .contact-wrap {
		padding: 3.5rem 1rem 3.8rem;
		background: none;
	}

	.contact-box .ttl h2 {
		font-size: 2.4rem;
		line-height: 1.2;
	}

	.contact-box .ttl .read {
		display: none;
	}

	.contact-box .flex {
		flex-direction: column;
	}

	.contact-box .flex > dl {
		width: 100%;
		margin-top: 2rem;
		padding: 1.4rem 1rem 1.1rem;
	}

	.contact-box .flex > dl:nth-child( even ) {
		margin-left: 0;
	}

	.contact-box .flex > dl + dl {
		margin-top: 2.4rem;
	}

	.contact-box .flex dt span {
		font-size: 1.6rem;
		letter-spacing: 1.2px;
		padding: 0 .6px;
	}

	.contact-box .flex dd a .num {
		font-size: 3rem;
		padding-left: 3.5rem;
		background: url( ../img/common/2x/icon-tel.png ) left center / 2.4rem no-repeat;
		margin-top: .4rem;
	}

	.contact-box .flex dd a .note {
		font-size: 1.2rem;
	}

	.bnr-box {
		padding: 2rem 0;
	}

	.bnr-box .bnr-set {
		flex-direction: column;
	}

	.bnr-box .bnr {
		width: 100%;
	}

	.bnr-box .bnr:nth-child( even ) {
		margin-left: 0;
	}

	.bnr-box .bnr + .bnr {
		margin-top: 1.5rem;
	}

	.bnr-box .bnr a {
		height: 90px;
		padding: 0 .8rem !important;
		border: solid 2px #fff;
	}

	.bnr-box .bnr a::after {
		width: 16px;
		height: 16px;
		top: calc( 50% - 8px ) !important;
		right: 1rem !important;
	}

	.bnr-box .bnr .img {
		width: 5.2rem;
		text-align: center;
	}

	.bnr-box .bnr.catalog .img {
		padding: 0 .5rem;
	}

	.bnr-box .bnr .txt {
		width: calc( 100% - 5.2rem );
		font-size: 1.15rem;
		line-height: 1.5;
		padding-left: .8rem;
		letter-spacing: 1.2px;
	}

	.bnr-box .bnr .txt h3 {
		font-size: 1.6rem !important;
	}

	.solution-wrap {
		flex-direction: column;
		margin: 2.2rem 0 3rem;
	}

	.solution-wrap .box {
		width: 100%;
		padding: .8rem;
		font-size: 1.4rem;
	}

	.solution-wrap.solution-01 .box {
		padding: 2.2rem 1rem 1.2rem 1.2rem;
	}

	.solution-wrap .box:nth-child( even ) {
		margin: 3.2rem 0 0;
	}

	.solution-wrap.solution-01 .box:nth-child( even ) {
		margin: 4.5rem 0 0;
	}

	.solution-wrap .box:nth-child( even )::after {
		width: 2rem;
		height: 1.6rem;
		top: -1.5rem;
		left: 50%;
		transform: rotate( 90deg ) translate( -50%, 50% );
	}

	.solution-wrap.solution-01 .box:nth-child( even )::after {
		width: 2rem;
		height: 1.6rem;
		top: -3rem;
	}

	.solution-wrap .ttl span {
		font-size: 1.4rem;
		padding: 0 1.8rem;
	}

	.solution-wrap .list-01 li {
		font-size: 1.4rem;
	}

	.solution-wrap .list-01 li::before {
		top: 9px;
	}

	.solution-wrap .img {
		padding-left: 1.5rem;
	}

	.solution-wrap .box-01 .img img {
		width: 10rem;
		padding-bottom: 1.5rem;
	}

	.solution-wrap .sub-ttl {
		font-size: 1.7rem;
		letter-spacing: 1.2px;
		margin-bottom: 2.2rem;
	}

	.solution-wrap.solution-01 .box-02 > .flex {
		display: block;
		position: relative;
	}

	.solution-wrap.solution-01 .box-02 .img {
		position: absolute;
		top: -1.5rem;
		right: .5rem;
		width: 9rem;
		padding: 0;
	}

	.solution-wrap .icon {
		width: 4.8rem;
		margin-right: .5rem;
	}

	.solution-wrap strong {
		font-size: 1.8rem;
		line-height: 1.6;
	}

	.solution-wrap.solution-03 .box-02 .flex {
		flex-direction: column;
	}

	.solution-wrap.solution-03 .flex .txt-wrap {
		text-align: center;
		padding: 0;
		margin-bottom: 1rem;
	}

	.solution-wrap.solution-03 .img {
		padding: .6rem;
		margin: 0 auto;
	}

	.page-menu .flex {
		flex-direction: column;
	}

	.page-menu li {
		width: 100%;
	}

	.page-menu li + li {
		margin: 1.5rem 0 0;
	}

	.attention dl {
		border-radius: 1rem;
		padding: 2.5rem 2rem 1.5rem;
	}

	.attention dt {
		padding: 0 1.5rem;
	}

	.search-mes {
		margin-right: 2rem;
		margin-left: 2rem;
	}

}


/*
----------------------------------------

768

----------------------------------------
*/

@media screen and ( max-width: 768px ) {

	.pc {
		display: none;
	}

	.sp {
		display: block;
	}

	#breadcrumbs {
		padding: 1.5rem 0;
		margin-bottom: 0;
	}

	#breadcrumbs a {
		margin-right: 1.2rem;
		padding-right: 2rem;		
	}

	.page-header {
		padding: 3rem 0 .5rem;
	}

	.page-header .ttl-wrap {
		padding: 0 0 0 1.5rem;
	}

	.page-header .sub {
		font-size: 1.5rem;
	}

	.page-header .jp {
		font-size: 2.4rem;
	}

	.point-list .flex {
		justify-content: center;
	}

	.img-list {
		padding: 2rem 2rem .5rem;
	}

	.img-list .img-wrap {
		width: calc( ( 100% - 2rem ) / 2 );
		margin: 0 2rem 2rem 0;
		font-size: 1.4rem;
	}

	.img-list .img-wrap:nth-child( 2n ) {
		margin-right: 0;
	}

	.img-list .img-wrap .img {
		margin-bottom: .5rem;
	}

	.search-set .sec .ttl .jp {
		font-size: 1.8rem;
		line-height: 1.5;
		padding: 1rem 0 1rem 5rem;
		background-size: 42px;
	}

	.search-set .sec {
		margin-bottom: 1rem;
	}

	.search-set .sec-01 {
		margin-top: 4rem;
		margin-bottom: 3.8rem;
	}

	.search-set .sec-01 .ttl::before {
		content: 'JUST FIT';
		font-size: 6rem;
		font-weight: bold;
		letter-spacing: 3px;
		line-height: 1;
		color: #f0f0f0;
		white-space: nowrap;
		position: absolute;
		right: -2.5rem;
		top: -3rem;
		z-index: -2;
	}

	.search-set .sec-01 .ttl::after {
		content: '';
		width: 102px;
		height: 80px;
		background: url( ../img/common/2x/search-img-sp.png ) center bottom / contain no-repeat;
		position: absolute;
		right: 2.2rem;
		bottom: 0;
		z-index: -1;
	}

	.search-set .search-wrap {
		flex-direction: column;
		padding: 2.5rem 2rem 2.2rem;
		margin-bottom: 2rem;
		border-radius: 1rem;
	}

	.search-set .search-wrap .select-wrap {
		width: 100%;
	}

	.search-set .search-wrap .select-wrap .flex {
		flex-direction: column;
	}

	.search-set .search-wrap .select {
		width: 100%;
	}

	.search-set .search-wrap .select + .select {
		margin: 3.2rem 0 0;
	}

	.search-set .search-wrap .select + .select::before {
		top: -24px;
		left: calc( 50% - 1.5px );
	}

	.search-set .search-wrap select {
		font-size: 1.5rem;
		padding: 1.5rem 4rem 1.5rem 2rem;
	}

	.search-set .search-wrap .search-btn {
		width: 214px;
		padding: 0;
		margin-top: 1.5rem;
	}

	.search-set .search-wrap button {
		padding: 7.5px 10px;
	}

	.pagination {
		line-height: 1;
		margin: 3rem 0 0;
	}

	.pagination ul {
		padding: 0;
	}

	.pagination a,
	.pagination span {
		min-width: 36px;
		height: 36px;
		line-height: 32px;
		margin: 0 2px;
		font-size: 1.8rem;
	}

	.pagination .prev,
	.pagination .next {
		width: 36px;
		margin: 0;
	}

	.pagination .prev {
		left: -36px;
	}

	.pagination .next {
		right: -36px;
	}

	.search-mes {
		padding: 2rem;
		margin-bottom: 3rem;
	}

	.search-mes .txt {
		padding: 1.5rem 2rem;
	}

	.search-mes .txt .word {
		font-size: 1.6rem;
	}

	.search-mes .txt .search-num > span {
		font-size: 1.8rem;
	}

	#coming-soon .cont .read {
		letter-spacing: .2px;
		margin: 3rem 0;
	}

}


/*
----------------------------------------

hover

----------------------------------------
*/

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

	.btn-01 a:hover {
		color: #fff;
		background: #0083c9 url( ../img/common/2x/arrow-01-wh.png ) right 1.5rem center / 2rem no-repeat;
		border: solid 2px #fff;
		box-shadow: 0 2px 8px rgba( 0, 0, 0, .2 );
	}

	.btn-01.bl a:hover {
		color: #0083c9;
		background: #fff url( ../img/common/2x/arrow-01.png ) right 1.5rem center / 2rem no-repeat;
		border: solid 2px #0083c9;
	}

	.btn-01.ext-link a:hover {
		background: #fff url( ../img/company/2x/icon-ext-link-bl.png ) right 1.5rem center / 1.4rem no-repeat !important;
	}

	.btn-01.pdf-link a:hover {
		background: #fff url( ../img/common/2x/icon-pdf-bl.png ) right 1.5rem center / 1.4rem no-repeat !important;
	}

	.btn-02 a:hover {
		color: #fff;
		background: #0083c9 url( ../img/common/2x/arrow-02-wh.png ) right 1rem center / 1.8rem no-repeat;
		box-shadow: 0 2px 8px rgba( 0, 0, 0, .2 );
	}

	.btn-03 a:hover {
		background-color: #008bd6;
		background-position: right 1.1rem center;
	}

	.btn-03 .gr a:hover {
		background-color: #00c2cc;
	}

	#wrapper .slick-prev:hover,
	#wrapper .slick-next:hover {
		transform: translate( 0, -50% ) scale( 1.1 );
	}

	#wrapper .slick-dots li:hover button:before {
		color: #0083c9;
	}

	.search-set .search-wrap button:hover {
		background: #0083c9;
		color: #fff;
	}

	.cont-list a:hover .txt {
		background: #0083c9;
	}

	.cont-list a:hover .sub,
	.cont-list a:hover .ttl {
		color: #fff;
	}

	.cont-list a:hover .img img {
		opacity: .8;
	}

	.cont-list a:hover .ttl::after {
		background: url( ../img/common/2x/arrow-02-wh.png ) center center / contain no-repeat;
		right: -.5rem;
	}

	.link-list a:hover {
		color: #0083c9;
		background: #fff url( ../img/common/2x/arrow-02.png ) right 1rem center / 1.8rem no-repeat;
	}

	.bg-bnr a:hover .bg-img img {
		transform: scale( 1.1 );
		opacity: .6;
	}

	.bg-bnr a:hover::after {
		right: 1.5rem;
	}

	.mail-btn a:hover {
		transform: translateY( -5px );
		box-shadow: 0 7px 8px rgba( 0, 0, 0, .1 );
	}

	.mail-btn a:active {
		transform: none;
		box-shadow: 0 0 0 rgba( 0, 0, 0, .2 );
	}

	.bnr-box .bnr a:hover {
		border-color: #fef200;
	}

	.bnr-box .bnr a:hover::after {
		right: 1.5rem;
	}

	.page-menu li a:hover {
		background-color: #0083c9;
		background-image: url( ../img/product/2x/arrow-down-01-wh.png );
		color: #fff;
	}

	.pagination a:hover {
		color: #fff;
		background: #0083c9;
		border: solid 1px #0083c9;
	}

	.pagination .prev:hover {
		background: url( ../img/common/svg/arrow-prev.svg ) left 10px center / 6px no-repeat;
	}

	.pagination .next:hover {
		background: url( ../img/common/svg/arrow-next.svg ) right 10px center / 6px no-repeat;
	}

	.case-wrap .case-slider a:hover img {
		opacity: .8;
	}

	.case-wrap .case-slider a:hover .cat-ttl {
		color: #0083c9;
	}

}
