@charset "UTF-8";

/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
html {
	font-family: sans-serif;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%
}
body {
	margin: 0
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
	display: block
}
audio,
canvas,
progress,
video {
	display: inline-block
}
audio:not([controls]) {
	display: none;
	height: 0
}
progress {
	vertical-align: baseline
}
template,
[hidden] {
	display: none
}
a {
	background-color: transparent;
	-webkit-text-decoration-skip: objects
}
a:active,
a:hover {
	outline-width: 0
}
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted
}
b,
strong {
	font-weight: inherit
}
b,
strong {
	font-weight: bolder
}
dfn {
	font-style: italic
}
h1 {
	font-size: 2em;
	margin: 0.67em 0
}
mark {
	background-color: #ff0;
	color: #000
}
small {
	font-size: 80%
}
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline
}
sub {
	bottom: -0.25em
}
sup {
	top: -0.5em
}
img {
	border-style: none
}
svg:not(:root) {
	overflow: hidden
}
code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
	font-size: 1em
}
figure {
	margin: 1em 40px
}
#trouble figure {
	margin-top: 4rem;
}
#strengthen figure {
	margin-top: 3rem;
}
#efficiency figure {
	margin-top: 3rem;
}
#protection figure {
	margin-top: 3rem;
}
hr {
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
	overflow: visible
}
button,
input,
select,
textarea {
	font: inherit;
	margin: 0
}
optgroup {
	font-weight: bold
}
button,
input {
	overflow: visible
}
button,
select {
	text-transform: none
}
button,
html [type="button"],
[type="reset"],
[type="submit"] {
	appearance: button
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText
}
fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em
}
legend {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal
}
textarea {
	overflow: auto
}
[type="checkbox"],
[type="radio"] {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto
}
[type="search"] {
	appearance: textfield;
	outline-offset: -2px
}
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none
}
::-webkit-input-placeholder {
	color: inherit;
	opacity: 0.54
}
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit
}
html {
	font-size: 13px;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt"
}
body {
	margin: 0;
	color: #000;
	font-family: "Hiragino Kaku Gothic Pro", "Meiryo", "MS Pgothic", knowledge-reg, helvetica, arial, sans-serif;
	line-height: 1.83;
	word-break: normal;
	overflow-wrap: break-word;
	margin: 0
}
body,
button,
input,
select,
optgroup,
textarea {
	color: #000;
	font-family: "Hiragino Kaku Gothic Pro", "Meiryo", "MS Pgothic", knowledge-reg, helvetica, arial, sans-serif;
	font-size: 1rem;
	line-height: 1.5
}
*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}
h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
	letter-spacing: .05em
}
p {
	margin-bottom: 1.5em;
	line-height: normal;
	letter-spacing: .05em
}
dfn,
cite,
em,
i {
	font-style: italic
}
blockquote {
	margin: 0 1.5em;
	letter-spacing: .05em
}
address {
	margin: 0 0 1.5em
}
pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em
}
code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace
}
abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help
}
mark,
ins {
	background: #fff9c0;
	text-decoration: none
}
big {
	font-size: 125%
}
hr {
	border: 0;
	height: 1px;
	margin-bottom: 1.5em
}
ul,
ol {
	margin: 0 0 1.5em 1.5em
}

/*---------- プライバシーポリシーページ start ----------*/
.privacy-policy h3,
.privacy-policy h4,
.privacy-policy h5 {
    font-size: inherit;
    font-weight: bold;
    margin: 0.1rem;
    padding: 0.1rem;
	border-left: none !important;
}
.privacy-policy ol {
    list-style-type: decimal;
    padding-left: 1.2em;
}
.privacy-policy ol li::marker {
    font-weight: bold;
}
.privacy-policy ul {
    list-style-type: disc;
    padding-left: 1.2em;
}
.privacy-policy ol,
.privacy-policy ul {
    padding-left: 1.2em;
    margin-left: 0;
    list-style-position: outside;
}
.privacy-policy ol ol,
.privacy-policy ol ul,
.privacy-policy ul ol,
.privacy-policy ul ul {
    margin-left: 0.7em;
    padding-left: 0.7em;
    margin-top: 0.3em;
    margin-bottom: 0.3em;
}
.privacy-policy li {
    margin-bottom: 0.3em;
}
.privacy-policy ul {
    list-style-type: disc;
}
.privacy-policy ul ul {
    list-style-type: circle;
}
.privacy-policy ul ul ul {
    list-style-type: square;
}
.privacy-policy p {
    margin-top: 0;
    margin-bottom: 0.5em; /* 適度な余白 */
}
.privacy-policy p:first-child {
    margin-top: 0; /* 最初の段落の上の余白を削除 */
}
/*---------- プライバシーポリシーページend ----------*/

ul {
	list-style: disc
}
ol {
	list-style: decimal
}
li>ul,
li>ol {
	margin-bottom: 0;
	margin-left: 1.5em
}
dt {
	font-weight: 700
}
dd {
	margin: 0 0 1.5em 0;
	line-height: 1.89;
	margin-bottom: 1.5em
}
embed,
iframe,
object {
	max-width: 100%
}
img {
	height: auto;
	max-width: 100%;
	vertical-align: top
}
figure {
	margin: 1em 0;
	font-size: 0
}
figcaption {
	font-size: inherit
}
table {
	margin: 0 0 1.5em;
	width: 100%
}
i {
	display: inline-block
}
i img {
	height: auto;
	vertical-align: top;
	width: 100%
}
a {
	color: #005ea4
}
a:hover,
a:focus,
a:active {
	color: inherit
}
a:focus {
	outline: none
}
a:hover,
a:active {
	outline: 0
}
.clearfix,
.cf,
.comment-respond {
	zoom: 1
}
.clearfix:before,
.clearfix:after,
.cf:before,
.comment-respond:before,
.cf:after,
.comment-respond:after {
	display: table;
	content: ""
}
.clearfix:after,
.cf:after,
.comment-respond:after {
	clear: both
}
span.amp {
	font-family: Baskerville, "Goudy Old Style", Palatino, "Book Antiqua", serif !important;
	font-style: italic
}
p {
	word-break: break-word;
	word-wrap: break-word
}
a {
	color: #2980b9
}
a:visited {
	text-decoration: none
}
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5 {
	text-rendering: optimizelegibility;
	font-weight: bold
}
h1 a,
.h1 a,
h2 a,
.h2 a,
h3 a,
.h3 a,
h4 a,
.h4 a,
h5 a,
.h5 a {
	text-decoration: none
}
h1,
.h1 {
	font-size: 2em;
	line-height: 1.333em
}
h2,
.h2 {
	margin: 2em 0 1em;
	font-size: 1.4em;
	line-height: 1.4;
	margin-bottom: 0.375em
}
h3,
.h3 {
	font-size: 135%;
	font-size: 1.35rem;
	border-left: 3px solid #263855;
	line-height: 1.3;
	letter-spacing: 0.95px;
	margin: 0.5em 0 0.7em;
	padding-left: 14px
}
h4,
.h4 {
	font-size: 1.1em;
	font-weight: bold;
	margin: 2em 0 0.7em
}
h5,
.h5 {
	font-size: 1em;
	line-height: 1.5em
}
p {
	margin: 0 0 1.5em
}
table {
	width: 100%;
	border: 2px solid #e6e6e6;
	margin-bottom: 1.5em
}
table caption {
	margin: 0 0 7px;
	font-size: 0.75em;
	color: #9fa6b4;
	text-transform: uppercase;
	letter-spacing: 1px
}
tr {
	border-bottom: 2px solid #e6e6e6
}
td {
	padding: 0.9em 1em;
	border-right: 2px solid #e6e6e6
}
td:last-child {
	border-right: 0
}
th {
	background-color: #f8f9fa;
	border-bottom: 2px solid #e6e6e6;
	border-right: 2px solid #e6e6e6;
	font-weight: normal;
	padding: 0.9em 1em
}
th:last-child {
	border-right: 0
}
blockquote {
	margin: 0 0 1.5em 0.75em;
	padding: 0 0 0 0.75em;
	border-left: 3px solid #2980b9;
	font-style: italic;
	color: #9fa6b4
}
img {
	margin: 0;
	max-width: 100%;
	height: auto
}
.container {
	background-color: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	min-height: 100vh;
	overflow: hidden;
	padding-top: 60px;
	width: 100%
}
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	background-color: #fff;
	-webkit-transition: 0.3s;
	transition: 0.3s
}
button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background-color: #263855;
	color: white
}
button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border: none
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	padding: 3px
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111
}
select {
	border: 1px solid #ccc
}
textarea {
	width: 100%
}
.article-list {
	border-top: 2px solid #e6e6e6
}
.article-list a {
	text-decoration: none
}
.article-date,
.post-date {
	color: #8d8d8d;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0;
	vertical-align: middle
}
.article-label,
.article-label-new {
	font-size: 93%;
	font-size: .93rem;
	background: #263855;
	color: white;
	display: inline-block;
	line-height: 1.1;
	margin-right: 0.5em;
	padding: 3px 1em 2px;
	vertical-align: middle
}
.article-label-new {
	background: #d53654;
	font-family: "Roboto", sans-serif
}
.article-heading {
	font-size: 200%;
	font-size: 2rem;
	color: #000;
	line-height: 1.5;
	margin: 0
}
.article-content {
	color: #bfbfbf
}
.article-item {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background: url(../library/images/icon-arrow-black.svg) right 5px top 18px no-repeat;
	background-size: 5.5px 9px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
	overflow: hidden;
	padding: 13px 20px 13px 5px
}
.article-item .article-date,
.article-item .post-date {
	font-size: 93%;
	font-size: .93rem;
	float: left;
	width: 75px
}
.article-item .article-heading {
	font-size: 93%;
	font-size: .93rem;
	clear: none;
	overflow: hidden
}
.article-item .article-content {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	margin: 0
}
.article-item_link {
	text-decoration: none
}
._pc .article-item_link .article-heading {
	-webkit-transition: color 0.3s;
	transition: color 0.3s
}
._pc .article-item_link:hover .article-heading {
	color: #263855
}
.block-inner {
	padding-left: 15px;
	padding-right: 15px
}
.block-min {
	margin-left: auto;
	margin-right: auto;
	max-width: 1000px
}
.block-border {
	padding: 19px 15px;
	border: solid 2px #eeeeee;
	background-color: #ffffff
}
.breadcrumb {
	font-size: 116%;
	font-size: 1.16rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	line-height: 1.1;
	letter-spacing: 0.38px;
	margin: 17px auto;
	padding: 0 25px;
	width: 1150px
}
.breadcrumb li {
	list-style: none;
	margin: 0 3px;
	vertical-align: top
}
.breadcrumb li+li:before {
	content: '|';
	color: #c8c8c8;
	font-size: 13px;
	font-weight: bold;
	margin-right: 4px;
	vertical-align: top
}
.breadcrumb a {
	color: #c8c8c8;
	text-decoration: none
}
.breadcrumb .icon-home {
	color: #263855;
	font-size: 13px;
	display: inline-block;
	margin-right: 5px;
	margin-top: 1px;
	vertical-align: top
}
.btn,
button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.btn-white,
.wpcf7c-btn-back,
.wpcf7c-btn-confirm,
.formParts-submit {
	font-size: 93%;
	font-size: .93rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: black;
	background-image: url(../library/images/icon-arrow-white.svg);
	background-size: 5.5px 9px;
	background-position: right 16px center;
	background-repeat: no-repeat;
	border-radius: 2.5px;
	border: 3px solid black;
	color: white;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-weight: 600;
	letter-spacing: 0.95px;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	height: 50px;
	line-height: 1.1;
	max-width: 441px;
	padding: 0 16px;
	position: relative;
	text-decoration: none;
	-webkit-transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19);
	transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

.btn:focus,
button:focus,
input:focus[type="button"],
input:focus[type="reset"],
input:focus[type="submit"],
.btn-white:focus,
.wpcf7c-btn-back:focus,
.wpcf7c-btn-confirm:focus,
.formParts-submit:focus {
	color: black;
	background-color: transparent;
	background-image: url(../library/images/icon-arrow-black.svg);
	background-repeat: no-repeat
}

._pc .btn:hover,
._pc button:hover,
._pc input:hover[type="button"],
._pc input:hover[type="reset"],
._pc input:hover[type="submit"],
._pc .btn-white:hover,
._pc .wpcf7c-btn-back:hover,
._pc .wpcf7c-btn-confirm:hover,
._pc .formParts-submit:hover {
	color: black;
	background-color: transparent;
	background-image: url(../library/images/icon-arrow-black.svg);
	background-repeat: no-repeat
}

.btn-white {
	background-color: white;
	background-image: url(../library/images/icon-arrow-black.svg);
	background-repeat: no-repeat;
	border-color: white;
	color: black
}

.btn-white:focus {
	background-image: url(../library/images/icon-arrow-white.svg);
	background-repeat: no-repeat;
	background-color: transparent;
	color: white
}

._pc .btn-white:hover {
	background-image: url(../library/images/icon-arrow-white.svg);
	background-repeat: no-repeat;
	background-color: transparent;
	color: white
}

.btn-tel {
	border: 1px solid #263855;
	color: black;
	display: inline-block;
	height: 47px;
	line-height: 47px;
	padding: 0 50px;
	vertical-align: middle
}

.btn-small {
	font-size: 124%;
	font-size: 1.24rem;
	border: 1px solid #070002;
	color: #000;
	display: inline-block;
	line-height: normal;
	margin: 0 15px 15px 0;
	padding: 10px 50px;
	vertical-align: middle;
	text-align: center;
	text-decoration: none
}

#colorbox,
#cboxOverlay,
#cboxWrapper {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9999;
	overflow: hidden;
	transform: translate3d(0, 0, 0)
}

#cboxWrapper {
	max-width: none
}

#cboxOverlay {
	position: fixed;
	width: 100%;
	height: 100%
}

#cboxMiddleLeft,
#cboxBottomLeft {
	clear: left
}

#cboxContent {
	position: relative
}

#cboxLoadedContent {
	overflow: auto;
	-webkit-overflow-scrolling: touch
}

#cboxTitle {
	margin: 0
}

#cboxLoadingOverlay,
#cboxLoadingGraphic {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

#cboxPrevious,
#cboxNext,
#cboxClose,
#cboxSlideshow {
	cursor: pointer
}

.cboxPhoto {
	float: left;
	margin: auto;
	border: 0;
	display: block;
	max-width: none;
	-ms-interpolation-mode: bicubic
}

.cboxIframe {
	width: 100%;
	height: 100%;
	display: block;
	border: 0;
	padding: 0;
	margin: 0
}

#colorbox,
#cboxContent,
#cboxLoadedContent {
	box-sizing: content-box;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box
}

#cboxOverlay {
	background: #fff;
	opacity: 0.9;
	filter: alpha(opacity=90)
}

#colorbox {
	outline: 0
}

#cboxContent {
	margin-top: 32px;
	overflow: visible;
	background: #000
}

.cboxIframe {
	background: #fff
}

#cboxError {
	padding: 50px;
	border: 1px solid #ccc
}

#cboxLoadedContent {
	background: #000;
	padding: 1px
}

/* #cboxLoadingGraphic {
	background: url(https://hello-prism.com/cms/wp-content/themes/prism.com/library/images/loading.gif) no-repeat center center
} */

#cboxLoadingOverlay {
	background: #000
}

#cboxTitle {
	position: absolute;
	top: -22px;
	left: 0;
	color: #000
}

#cboxCurrent {
	position: absolute;
	top: -22px;
	right: 205px;
	text-indent: -9999px
}

/* #cboxPrevious,
#cboxNext,
#cboxSlideshow,
#cboxClose {
	border: 0;
	padding: 0;
	margin: 0;
	overflow: visible;
	text-indent: -9999px;
	width: 20px;
	height: 20px;
	position: absolute;
	top: -20px;
	background: url(https://hello-prism.com/cms/wp-content/themes/prism.com/library/images/controls.png) no-repeat 0 0
} */

/* #cboxPrevious:active,
#cboxNext:active,
#cboxSlideshow:active,
#cboxClose:active {
	outline: 0
}

#cboxPrevious {
	background-position: 0px 0px;
	right: 44px
}

#cboxPrevious:hover {
	background-position: 0px -25px
} */

#cboxNext {
	background-position: -25px 0px;
	right: 22px
}

#cboxNext:hover {
	background-position: -25px -25px
}

#cboxClose {
	background-position: -50px 0px;
	right: 0
}

#cboxClose:hover {
	background-position: -50px -25px
}

.cboxSlideshow_on #cboxPrevious,
.cboxSlideshow_off #cboxPrevious {
	right: 66px
}

.cboxSlideshow_on #cboxSlideshow {
	background-position: -75px -25px;
	right: 44px
}

.cboxSlideshow_on #cboxSlideshow:hover {
	background-position: -100px -25px
}

.cboxSlideshow_off #cboxSlideshow {
	background-position: -100px 0px;
	right: 44px
}

.cboxSlideshow_off #cboxSlideshow:hover {
	background-position: -75px -25px
}

.gmap {
	margin-top: 5px;
	height: 322px;
	position: relative;
	max-width: 100%;
	width: 100%
}

.gmap iframe,
.gmap object,
.gmap embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.grid,
.grid-col2,
.grid-col3,
.grid-col4 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: 100%
}

.grid:before,
.grid-col2:before,
.grid-col3:before,
.grid-col4:before,
.grid:after,
.grid-col2:after,
.grid-col3:after,
.grid-col4:after {
	content: '';
	display: block;
	height: 1px;
	max-width: calc(50% - 25px);
	-webkit-box-ordinal-group: 2;
	-ms-flex-order: 1;
	order: 1;
	width: 50%
}

.grid-col2>.col,
.grid-col2>img {
	max-width: calc(50% - 25px);
	width: 50%
}

.grid-col3 img {
	margin: 0.5em;
	max-width: calc(32% - 0.5em);
	width: auto
}

.grid-col3:before,
.grid-col3:after {
	max-width: calc(32% - 0.5em)
}

.grid-col4 img {
	margin: 0.5em auto;
	max-width: calc(24% - 0.5em);
	width: auto
}

.grid-col4:before,
.grid-col4:after {
	max-width: calc(24% - 0.5em)
}

.grid-thumbnail {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	width: 100%
}

.grid-thumbnail .col {
	letter-spacing: 1px;
	width: calc(100% - 250px)
}

.grid-thumbnail .thumb {
	width: 198.3px;
	height: 189.9px
}

.grid-thumbnail .thumb img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	width: 100%
}

.heading,
.heading-red {
	font-size: 147%;
	font-size: 1.47rem;
	border-bottom: 2px solid #dbd4cb;
	border-left: none;
	font-weight: 600;
	letter-spacing: 0.5px;
	margin-bottom: 30px;
	margin-top: 0;
	padding-bottom: 10px;
	padding-left: 0
}

.heading-red {
	font-size: 139%;
	font-size: 1.39rem;
	border-bottom: 1px solid #000;
	color: #dc2442;
	margin-bottom: 20px;
	padding-bottom: 15px
}

.heading-band,
.heading-band-serif {
	font-size: 162%;
	font-size: 1.62rem;
	border-left: 3px solid #377fc2;
	line-height: 1.3;
	letter-spacing: 0.95px;
	margin: 1em 0 0.8em;
	padding-left: 14px
}

.heading-band-red {
	font-size: 124%;
	font-size: 1.24rem;
	border-left: 3px solid #dc2442;
	margin: 1.5em 0 0.8em;
	padding-left: 10px
}

.heading-label-red {
	font-size: 116%;
	font-size: 1.16rem;
	background-color: #eee;
	border-left: 2px solid #dc2442;
	margin: 1.5em 0 0.8em;
	padding: 5px 10px 4px
}

.heading-band-serif {
	font-size: 154%;
	font-size: 1.54rem;
	font-weight: 600;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	letter-spacing: 1.28px;
	margin-bottom: 1.1em
}

.heading-normal {
	font-size: 124%;
	font-size: 1.24rem;
	font-weight: 500;
	border: none;
	letter-spacing: 1.1px;
	margin: 1.6em 0 1em;
	padding: 0
}

.heading-border {
	font-size: 124%;
	font-size: 1.24rem;
	border: solid 1px #000000;
	font-weight: 600;
	letter-spacing: 0.5px;
	margin: 1.5em 0;
	padding: .5em 1em
}

.heading-line {
	font-size: 100%;
	font-size: 1rem;
	border-bottom: 1px solid #000;
	margin-bottom: 0.8em;
	padding-bottom: 0.3em
}

.label,
.label-news {
	font-size: 124%;
	font-size: 1.24rem;
	background: #263855;
	color: white;
	display: inline-block;
	font-weight: 400;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.9px;
	line-height: 1.1;
	padding: 5px 1em;
	text-align: center;
	vertical-align: middle;
	min-width: 116px
}

.label-news {
	background: #d53654;
	min-width: 60px
}

.label-link {
	font-size: 100%;
	font-size: 1rem;
	background-color: #263855;
	color: white;
	display: inline-block;
	line-height: 1.1;
	margin-bottom: 1px;
	padding: 3px 15px 4px;
	vertical-align: middle;
	text-decoration: none
}

.label-link i {
	font-size: 7px;
	line-height: 1.1;
	vertical-align: middle
}

.link,
a.link {
	font-size: 93%;
	font-size: .93rem;
	border-bottom: 2px solid #000;
	color: black;
	font-weight: 600;
	letter-spacing: 0.9px;
	line-height: 1.1;
	position: relative;
	display: block;
	max-width: 100%;
	padding-bottom: 10px;
	padding-right: 10px;
	width: 200px
}

.link:before,
a.link:before {
	position: absolute;
	bottom: -2px;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #263855;
	-webkit-transform: scale(0, 1);
	transform: scale(0, 1);
	-webkit-transform-origin: right top;
	transform-origin: right top;
	-webkit-transition: -webkit-transform .3s;
	transition: -webkit-transform .3s;
	transition: transform .3s;
	transition: transform .3s, -webkit-transform .3s
}

.link:after,
a.link:after {
	background: url(../library/images/icon-arrow-black.svg) left top no-repeat;
	background-size: 100% 100%;
	bottom: 0;
	content: '';
	display: block;
	margin: auto;
	width: 5.5px;
	height: 9px;
	position: absolute;
	right: 3px;
	top: 0
}

._pc .link,
._pc a.link {
	-webkit-transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19);
	transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

._pc .link:hover,
._pc a.link:hover {
	color: #263855
}

._pc .link:hover:before,
._pc a.link:hover:before {
	-webkit-transform-origin: left top;
	transform-origin: left top;
	-webkit-transform: scale(1, 1);
	transform: scale(1, 1)
}

._pc .link:hover:after,
._pc a.link:hover:after {
	background-image: url(../library/images/icon-arrow-blue.svg)
}

.list-style-none {
	margin-left: 0;
	padding-left: 0
}

.list-style-none li {
	list-style: none
}

.list-style-none>dt {
	margin: 0;
	padding: 0
}

.list-indent1 li {
	text-indent: -1em;
	padding-left: 1em
}

.list-indent1-5 li {
	text-indent: -1.5em;
	padding-left: 1.5em
}

.list-faq {
	margin: 0 auto;
	max-width: 1010px;
	padding: 0 15px
}

.heading+.list-faq .list-faq-item,
.heading-red+.list-faq .list-faq-item {
	border-top: none
}

.list-faq-item {
	font-size: 93%;
	font-size: .93rem;
	border-bottom: 1px solid #D3D6DB;
	border-top: 1px solid #D3D6DB;
	line-height: 1.5;
	letter-spacing: 0.3px;
	margin: 0;
	padding: 0 5px
}

.list-faq-item+.list-faq-item {
	margin-top: -1px
}

.list-faq-item_q {
	cursor: pointer;
	padding: 18px 30px 18px 32px;
	position: relative
}

.list-faq-item_q:before {
	content: url(../library/images/q.svg);
	left: 0;
	line-height: 1.1;
	position: absolute;
	-webkit-transform: scale(0.69);
	transform: scale(0.69);
	-webkit-transform-origin: left top;
	transform-origin: left top;
	top: 15px
}

.list-faq-item_q:after {
	content: url(../library/images/icon-plus.svg);
	right: -2px;
	line-height: 1.1;
	position: absolute;
	-webkit-transform: scale(0.69);
	transform: scale(0.69);
	-webkit-transform-origin: center center;
	transform-origin: center center;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	top: 10px
}

.list-faq-item_a {
	display: none;
	margin: 15px 0 0;
	padding: 0 30px 15px 32px;
	position: relative
}

.list-faq-item_a:before {
	content: url(../library/images/a.svg);
	left: 0;
	line-height: 1.1;
	position: absolute;
	-webkit-transform: scale(0.69);
	transform: scale(0.69);
	-webkit-transform-origin: left top;
	transform-origin: left top;
	top: 0
}

.list-faq-item_q._open:after {
	-webkit-transform: scale(0.69) rotate(90deg);
	transform: scale(0.69) rotate(90deg)
}

.list-oneline {
	overflow: hidden;
	margin: 0;
	padding: 0
}

.list-oneline dt {
	float: left;
	padding: 0;
	margin: 0;
	width: 7em
}

.list-oneline dd {
	overflow: hidden;
	padding: 0 0 0 1em;
	text-indent: -1em;
	margin: 0
}

.list-oneline dd:before {
	content: ' ： '
}

.list-inline {
	padding-left: 0;
	margin-left: -5px;
	list-style: none
}

.list-inline>li {
	display: inline-block;
	padding-right: 5px;
	padding-left: 5px
}

.list-item-check {
	list-style: none !important;
	margin-bottom: 1em;
	padding-left: 2em;
	text-indent: -1.2em
}

.list-item-check:before {
	content: url(../library/images/icon-check.svg);
	display: inline-block;
	line-height: 1.1;
	vertical-align: middle;
	margin-right: 7px;
	padding-left: 3px;
	-webkit-transform: scale(0.8);
	transform: scale(0.8)
}

.list-item-dotted {
	list-style: none !important;
	margin-bottom: 1em;
	padding-left: 2em;
	text-indent: -2em
}

.list-item-dotted:before {
	background: #000;
	content: '';
	display: inline-block;
	border-radius: 50%;
	margin-right: 10px;
	width: 8px;
	height: 8px;
	vertical-align: middle
}

.mfp-bg {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1042;
	overflow: hidden;
	position: fixed;
	background: #0b0b0b;
	opacity: 0.8
}

.mfp-wrap {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1043;
	position: fixed;
	outline: none !important;
	backface-visibility: hidden
}

.mfp-container {
	text-align: center;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	padding: 0 8px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.mfp-container:before {
	content: '';
	display: inline-block;
	height: 100%;
	vertical-align: middle
}

.mfp-align-top .mfp-container:before {
	display: none
}

.mfp-content {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	margin: 0 auto;
	text-align: left;
	z-index: 1045
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
	width: 100%;
	cursor: auto
}

.mfp-ajax-cur {
	cursor: progress
}

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
	cursor: -webkit-zoom-out;
	cursor: zoom-out
}

.mfp-zoom {
	cursor: pointer;
	cursor: -webkit-zoom-in;
	cursor: zoom-in
}

.mfp-auto-cursor .mfp-content {
	cursor: auto
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none
}

.mfp-loading.mfp-figure {
	display: none
}

.mfp-hide {
	display: none !important
}

.mfp-preloader {
	color: #CCC;
	position: absolute;
	top: 50%;
	width: auto;
	text-align: center;
	margin-top: -0.8em;
	left: 8px;
	right: 8px;
	z-index: 1044
}

.mfp-preloader a {
	color: #CCC
}

.mfp-preloader a:hover {
	color: #FFF
}

.mfp-s-ready .mfp-preloader {
	display: none
}

.mfp-s-error .mfp-content {
	display: none
}

button.mfp-close,
button.mfp-arrow {
	overflow: visible;
	cursor: pointer;
	background: transparent;
	border: 0;
	appearance: none;
	display: block;
	outline: none;
	padding: 0;
	z-index: 1046;
	-webkit-box-shadow: none;
	box-shadow: none;
	-ms-touch-action: manipulation;
	touch-action: manipulation
}

button::-moz-focus-inner {
	padding: 0;
	border: 0
}

.mfp-close {
	width: 44px;
	height: 44px;
	line-height: 44px;
	position: absolute;
	right: 0;
	top: 0;
	text-decoration: none;
	text-align: center;
	opacity: 0.65;
	padding: 0 0 18px 10px;
	color: #FFF;
	font-style: normal;
	font-size: 28px;
	font-family: Arial, Baskerville, monospace
}

.mfp-close:hover,
.mfp-close:focus {
	opacity: 1
}

.mfp-close:active {
	top: 1px
}

.mfp-close-btn-in .mfp-close {
	color: #333
}

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
	color: #FFF;
	right: -6px;
	text-align: right;
	padding-right: 6px;
	width: 100%
}

.mfp-counter {
	position: absolute;
	top: 0;
	right: 0;
	color: #CCC;
	font-size: 12px;
	line-height: 18px;
	white-space: nowrap
}

.mfp-arrow {
	position: absolute;
	opacity: 0.65;
	margin: 0;
	top: 50%;
	margin-top: -55px;
	padding: 0;
	width: 90px;
	height: 110px;
	-webkit-tap-highlight-color: transparent
}

.mfp-arrow:active {
	margin-top: -54px
}

.mfp-arrow:hover,
.mfp-arrow:focus {
	opacity: 1
}

.mfp-arrow:before,
.mfp-arrow:after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	left: 0;
	top: 0;
	margin-top: 35px;
	margin-left: 35px;
	border: medium inset transparent
}

.mfp-arrow:after {
	border-top-width: 13px;
	border-bottom-width: 13px;
	top: 8px
}

.mfp-arrow:before {
	border-top-width: 21px;
	border-bottom-width: 21px;
	opacity: 0.7
}

.mfp-arrow-left {
	left: 0
}

.mfp-arrow-left:after {
	border-right: 17px solid #FFF;
	margin-left: 31px
}

.mfp-arrow-left:before {
	margin-left: 25px;
	border-right: 27px solid #3F3F3F
}

.mfp-arrow-right {
	right: 0
}

.mfp-arrow-right:after {
	border-left: 17px solid #FFF;
	margin-left: 39px
}

.mfp-arrow-right:before {
	border-left: 27px solid #3F3F3F
}

.mfp-iframe-holder {
	padding-top: 40px;
	padding-bottom: 40px
}

.mfp-iframe-holder .mfp-content {
	line-height: 0;
	width: 100%;
	max-width: 900px
}

.mfp-iframe-holder .mfp-close {
	top: -40px
}

.mfp-iframe-scaler {
	width: 100%;
	height: 0;
	overflow: hidden;
	padding-top: 56.25%
}

.mfp-iframe-scaler iframe {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
	background: #000
}

img.mfp-img {
	width: auto;
	max-width: 100%;
	height: auto;
	display: block;
	line-height: 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 40px 0 40px;
	margin: 0 auto
}

.mfp-figure {
	line-height: 0
}

.mfp-figure:after {
	content: '';
	position: absolute;
	left: 0;
	top: 40px;
	bottom: 40px;
	display: block;
	right: 0;
	width: auto;
	height: auto;
	z-index: -1;
	-webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
	background: #444
}

.mfp-figure small {
	color: #BDBDBD;
	display: block;
	font-size: 12px;
	line-height: 14px
}

.mfp-figure figure {
	margin: 0
}

.mfp-bottom-bar {
	margin-top: -36px;
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	cursor: auto
}

.mfp-title {
	text-align: left;
	line-height: 18px;
	color: #F3F3F3;
	word-wrap: break-word;
	padding-right: 36px
}

.mfp-image-holder .mfp-content {
	max-width: 100%
}

.mfp-gallery .mfp-image-holder .mfp-figure {
	cursor: pointer
}

.wp-video {
	border: 1px solid #999;
	margin: 0 auto
}

.pagenav {
	font-size: 139%;
	font-size: 1.39rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	line-height: 1.1;
	margin: 4em 0 0;
	position: relative;
	text-align: center
}

.pagenav_inner {
	padding: 0
}

.pagenav .pager {
	display: inline-block;
	font-family: "Roboto", sans-serif;
	font-weight: 600;
	margin: 5px;
	color: #8d8d8d;
	padding: 10px 8px;
	position: relative;
	-webkit-transition: 0.2s;
	transition: 0.2s;
	text-decoration: none;
	vertical-align: middle
}

.pagenav .pager:after {
	background-color: #8d8d8d;
	bottom: 0;
	content: '';
	height: 2px;
	display: block;
	left: 0;
	opacity: 0;
	position: absolute;
	-webkit-transform: translateY(5px);
	transform: translateY(5px);
	-webkit-transition: 0.3s;
	transition: 0.3s;
	right: 0;
	width: 100%
}

.pagenav .pager:hover:after {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1
}

.pagenav .pager.current {
	color: #e71c24
}

.pagenav .pager.current:after {
	background-color: #e71c24;
	bottom: 0;
	content: '';
	height: 2px;
	display: block;
	left: 0;
	margin: auto;
	opacity: 1;
	position: absolute;
	-webkit-transform: translateY(0);
	transform: translateY(0);
	right: 0;
	width: 100%
}

.pagenav .prev,
.pagenav .next {
	margin: 0 30px;
	text-decoration: none;
	vertical-align: middle
}

.pagenav .prev:before,
.pagenav .next:before {
	content: url(../library/images/icon-arrow-red.svg);
	display: inline-block
}

.pagenav .prev:before {
	-webkit-transform: scale(-1, 1);
	transform: scale(-1, 1)
}

.category-selecter {
	margin-bottom: 7px;
	position: relative
}

.category-selecter:after {
	content: '';
	bottom: 0;
	border-style: solid;
	border-width: 10px 6px 0 6px;
	border-color: white transparent transparent transparent;
	height: 0;
	line-height: 1.1;
	margin: auto;
	position: absolute;
	top: 0;
	right: 15px;
	width: 0
}

.category-selected {
	font-size: 116%;
	font-size: 1.16rem;
	color: white;
	background: #263855;
	line-height: 1.1;
	padding: 11px 0;
	text-align: center
}

.category-select {
	height: 100%;
	opacity: 0;
	position: absolute;
	top: 0;
	width: 100%
}

.category-select_item {
	text-align: center
}

.category-select_item:checked {
	background: #263855
}

.category_nav {
	display: none
}

@font-face {
	font-family: 'swiper-icons';
	src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
	font-weight: 400;
	font-style: normal
}

:root {
	--swiper-theme-color: #007aff
}

.swiper-container {
	margin-left: auto;
	margin-right: auto;
	position: relative;
	overflow: hidden;
	list-style: none;
	padding: 0;
	z-index: 1
}

.swiper-container-vertical>.swiper-wrapper {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}

.swiper-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-transition-property: -webkit-transform;
	transition-property: -webkit-transform;
	transition-property: transform;
	transition-property: transform, -webkit-transform;
	-webkit-box-sizing: content-box;
	box-sizing: content-box
}

.swiper-container-android .swiper-slide,
.swiper-wrapper {
	-webkit-transform: translate3d(0px, 0, 0);
	transform: translate3d(0px, 0, 0)
}

.swiper-container-multirow>.swiper-wrapper {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}

.swiper-container-multirow-column>.swiper-wrapper {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}

.swiper-container-free-mode>.swiper-wrapper {
	-webkit-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
	margin: 0 auto
}

.swiper-slide {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 100%;
	height: 100%;
	position: relative;
	-webkit-transition-property: -webkit-transform;
	transition-property: -webkit-transform;
	transition-property: transform;
	transition-property: transform, -webkit-transform
}

.swiper-slide-invisible-blank {
	visibility: hidden
}

.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
	height: auto
}

.swiper-container-autoheight .swiper-wrapper {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-transition-property: height, -webkit-transform;
	transition-property: height, -webkit-transform;
	transition-property: transform, height;
	transition-property: transform, height, -webkit-transform
}

.swiper-container-3d {
	-webkit-perspective: 1200px;
	perspective: 1200px
}

.swiper-container-3d .swiper-wrapper,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-cube-shadow {
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d
}

.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 10
}

.swiper-container-3d .swiper-slide-shadow-left {
	background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-container-3d .swiper-slide-shadow-right {
	background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-container-3d .swiper-slide-shadow-top {
	background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-container-3d .swiper-slide-shadow-bottom {
	background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-container-css-mode>.swiper-wrapper {
	overflow: auto;
	scrollbar-width: none;
	-ms-overflow-style: none
}

.swiper-container-css-mode>.swiper-wrapper::-webkit-scrollbar {
	display: none
}

.swiper-container-css-mode>.swiper-wrapper>.swiper-slide {
	scroll-snap-align: start start
}

.swiper-container-horizontal.swiper-container-css-mode>.swiper-wrapper {
	-webkit-scroll-snap-type: x mandatory;
	-ms-scroll-snap-type: x mandatory;
	scroll-snap-type: x mandatory
}

.swiper-container-vertical.swiper-container-css-mode>.swiper-wrapper {
	-webkit-scroll-snap-type: y mandatory;
	-ms-scroll-snap-type: y mandatory;
	scroll-snap-type: y mandatory
}

:root {
	--swiper-navigation-size: 44px
}

.swiper-button-prev,
.swiper-button-next {
	position: absolute;
	top: 50%;
	width: calc(var(--swiper-navigation-size) / 44 * 27);
	height: var(--swiper-navigation-size);
	margin-top: calc(-1 * var(--swiper-navigation-size) / 2);
	z-index: 10;
	cursor: pointer;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
	opacity: 0.35;
	cursor: auto;
	pointer-events: none
}

.swiper-button-prev:after,
.swiper-button-next:after {
	font-family: swiper-icons;
	font-size: var(--swiper-navigation-size);
	text-transform: none !important;
	letter-spacing: 0;
	text-transform: none;
	font-variant: initial;
	line-height: 1
}

.swiper-button-prev,
.swiper-container-rtl .swiper-button-next {
	left: 10px;
	right: auto
}

.swiper-button-prev:after,
.swiper-container-rtl .swiper-button-next:after {
	content: 'prev'
}

.swiper-button-next,
.swiper-container-rtl .swiper-button-prev {
	right: 10px;
	left: auto
}

.swiper-button-next:after,
.swiper-container-rtl .swiper-button-prev:after {
	content: 'next'
}

.swiper-button-prev.swiper-button-white,
.swiper-button-next.swiper-button-white {
	--swiper-navigation-color: #ffffff
}

.swiper-button-prev.swiper-button-black,
.swiper-button-next.swiper-button-black {
	--swiper-navigation-color: #000000
}

.swiper-button-lock {
	display: none
}

.swiper-pagination {
	position: absolute;
	text-align: center;
	-webkit-transition: 300ms opacity;
	transition: 300ms opacity;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
	opacity: 0
}

.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal>.swiper-pagination-bullets {
	bottom: 10px;
	left: 0;
	width: 100%
}

.swiper-pagination-bullets-dynamic {
	overflow: hidden;
	font-size: 0
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transform: scale(0.33);
	transform: scale(0.33);
	position: relative
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
	-webkit-transform: scale(1);
	transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
	-webkit-transform: scale(1);
	transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
	-webkit-transform: scale(0.66);
	transform: scale(0.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
	-webkit-transform: scale(0.33);
	transform: scale(0.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
	-webkit-transform: scale(0.66);
	transform: scale(0.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
	-webkit-transform: scale(0.33);
	transform: scale(0.33)
}

.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	display: inline-block;
	border-radius: 100%;
	background: #000;
	opacity: 0.2
}

button.swiper-pagination-bullet {
	border: none;
	margin: 0;
	padding: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
	cursor: pointer
}

.swiper-pagination-bullet-active {
	opacity: 1;
	background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-container-vertical>.swiper-pagination-bullets {
	right: 10px;
	top: 50%;
	-webkit-transform: translate3d(0px, -50%, 0);
	transform: translate3d(0px, -50%, 0)
}

.swiper-container-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 6px 0;
	display: block
}

.swiper-container-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 8px
}

.swiper-container-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	display: inline-block;
	-webkit-transition: 200ms top, 200ms -webkit-transform;
	transition: 200ms top, 200ms -webkit-transform;
	transition: 200ms transform, 200ms top;
	transition: 200ms transform, 200ms top, 200ms -webkit-transform
}

.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 4px
}

.swiper-container-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	white-space: nowrap
}

.swiper-container-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transition: 200ms left, 200ms -webkit-transform;
	transition: 200ms left, 200ms -webkit-transform;
	transition: 200ms transform, 200ms left;
	transition: 200ms transform, 200ms left, 200ms -webkit-transform
}

.swiper-container-horizontal.swiper-container-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	-webkit-transition: 200ms right, 200ms -webkit-transform;
	transition: 200ms right, 200ms -webkit-transform;
	transition: 200ms transform, 200ms right;
	transition: 200ms transform, 200ms right, 200ms -webkit-transform
}

.swiper-pagination-progressbar {
	background: rgba(0, 0, 0, 0.25);
	position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	background: var(--swiper-pagination-color, var(--swiper-theme-color));
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-webkit-transform: scale(0);
	transform: scale(0);
	-webkit-transform-origin: left top;
	transform-origin: left top
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	-webkit-transform-origin: right top;
	transform-origin: right top
}

.swiper-container-horizontal>.swiper-pagination-progressbar,
.swiper-container-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
	width: 100%;
	height: 4px;
	left: 0;
	top: 0
}

.swiper-container-vertical>.swiper-pagination-progressbar,
.swiper-container-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
	width: 4px;
	height: 100%;
	left: 0;
	top: 0
}

.swiper-pagination-white {
	--swiper-pagination-color: #ffffff
}

.swiper-pagination-black {
	--swiper-pagination-color: #000000
}

.swiper-pagination-lock {
	display: none
}

.swiper-scrollbar {
	border-radius: 10px;
	position: relative;
	touch-action: none;
	background: rgba(0, 0, 0, 0.1)
}

.swiper-container-horizontal>.swiper-scrollbar {
	position: absolute;
	left: 1%;
	bottom: 3px;
	z-index: 50;
	height: 5px;
	width: 98%
}

.swiper-container-vertical>.swiper-scrollbar {
	position: absolute;
	right: 3px;
	top: 1%;
	z-index: 50;
	width: 5px;
	height: 98%
}

.swiper-scrollbar-drag {
	height: 100%;
	width: 100%;
	position: relative;
	background: rgba(0, 0, 0, 0.5);
	border-radius: 10px;
	left: 0;
	top: 0
}

.swiper-scrollbar-cursor-drag {
	cursor: move
}

.swiper-scrollbar-lock {
	display: none
}

.swiper-zoom-container {
	width: 100%;
	height: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	text-align: center
}

.swiper-zoom-container>img,
.swiper-zoom-container>svg,
.swiper-zoom-container>canvas {
	max-width: 100%;
	max-height: 100%;
	-o-object-fit: contain;
	object-fit: contain
}

.swiper-slide-zoomed {
	cursor: move
}

.swiper-lazy-preloader {
	width: 42px;
	height: 42px;
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -21px;
	margin-top: -21px;
	z-index: 10;
	-webkit-transform-origin: 50%;
	transform-origin: 50%;
	-webkit-animation: swiper-preloader-spin 1s infinite linear;
	animation: swiper-preloader-spin 1s infinite linear;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
	border-radius: 50%;
	border-top-color: transparent
}

.swiper-lazy-preloader-white {
	--swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
	--swiper-preloader-color: #000
}

@-webkit-keyframes swiper-preloader-spin {
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg)
	}
}

@keyframes swiper-preloader-spin {
	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg)
	}
}

.swiper-container .swiper-notification {
	position: absolute;
	left: 0;
	top: 0;
	pointer-events: none;
	opacity: 0;
	z-index: -1000
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
	-webkit-transition-timing-function: ease-out;
	transition-timing-function: ease-out
}

.swiper-container-fade .swiper-slide {
	pointer-events: none;
	-webkit-transition-property: opacity;
	transition-property: opacity
}

.swiper-container-fade .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-container-fade .swiper-slide-active,
.swiper-container-fade .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-container-cube {
	overflow: visible
}

.swiper-container-cube .swiper-slide {
	pointer-events: none;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	z-index: 1;
	visibility: hidden;
	-webkit-transform-origin: 0 0;
	transform-origin: 0 0;
	width: 100%;
	height: 100%
}

.swiper-container-cube .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-container-cube.swiper-container-rtl .swiper-slide {
	-webkit-transform-origin: 100% 0;
	transform-origin: 100% 0
}

.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-next,
.swiper-container-cube .swiper-slide-prev,
.swiper-container-cube .swiper-slide-next+.swiper-slide {
	pointer-events: auto;
	visibility: visible
}

.swiper-container-cube .swiper-slide-shadow-top,
.swiper-container-cube .swiper-slide-shadow-bottom,
.swiper-container-cube .swiper-slide-shadow-left,
.swiper-container-cube .swiper-slide-shadow-right {
	z-index: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden
}

.swiper-container-cube .swiper-cube-shadow {
	position: absolute;
	left: 0;
	bottom: 0px;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: 0.6;
	-webkit-filter: blur(50px);
	filter: blur(50px);
	z-index: 0
}

.swiper-container-flip {
	overflow: visible
}

.swiper-container-flip .swiper-slide {
	pointer-events: none;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	z-index: 1
}

.swiper-container-flip .swiper-slide .swiper-slide {
	pointer-events: none
}

.swiper-container-flip .swiper-slide-active,
.swiper-container-flip .swiper-slide-active .swiper-slide-active {
	pointer-events: auto
}

.swiper-container-flip .swiper-slide-shadow-top,
.swiper-container-flip .swiper-slide-shadow-bottom,
.swiper-container-flip .swiper-slide-shadow-left,
.swiper-container-flip .swiper-slide-shadow-right {
	z-index: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden
}

.tab-category,
.tab-category-col3,
.tab-category-main {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 auto;
	max-width: 996px;
	padding: 0
}

.tab-category li,
.tab-category-col3 li,
.tab-category-main li {
	display: inline-block;
	margin: 3px;
	list-style: none;
	max-width: 241px;
	width: 100%
}

.tab-category_item {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #fff;
	border: 1px solid #263855;
	cursor: pointer;
	height: 61px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	line-height: 1.2;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	width: 100%;
	text-decoration: none;
	text-align: center;
	-webkit-transition: 0.2s;
	transition: 0.2s
}

.tab-category_item.is-active {
	background-color: #263855;
	color: #fff;
	cursor: default
}

.tab-category-col3 {
	max-width: 930px
}

.tab-category-col3 li {
	width: 33%
}

.tab-category-main {
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	border-bottom: 2px solid #263855;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	margin-bottom: 2.5em;
	max-width: none;
	padding: 0 40px;
	width: 100%
}

.tab-category-main li {
	max-width: 332px;
	margin-bottom: 0
}

.tab-category-main .tab-category_item {
	border-bottom: none;
	margin-bottom: 0;
	width: 100%
}

.tab-target-wrap {
	position: relative
}

.tab-target {
	height: auto;
	left: 0;
	opacity: 0;
	position: absolute;
	-webkit-transition: 0.2s;
	transition: 0.2s;
	top: 0;
	visibility: hidden;
	width: 100%
}

.tab-target.is-active {
	position: relative;
	opacity: 1;
	visibility: visible
}

.table {
	border: none
}

.table tr {
	border: none;
	border-top: 2px solid #e6e6e6
}

.table th {
	background-color: #fff;
	border: none;
	border-bottom: 2px solid #e6e6e6;
	color: #263855;
	font-weight: normal;
	letter-spacing: 0.9px;
	padding: 23px 0;
	text-align: left;
	vertical-align: top;
	width: 260px
}

.table td {
	background-color: #fff;
	border: none;
	border-bottom: 2px solid #e6e6e6;
	line-height: 1.56;
	letter-spacing: 0.9px;
	vertical-align: top;
	padding: 23px 0
}

.table-dark {
	font-size: 139%;
	font-size: 1.39rem;
	text-align: center
}

.table-dark tr:first-child th {
	background-color: #9c9c9c;
	color: white;
	font-weight: normal;
	min-width: 150px;
	letter-spacing: normal;
	padding: 14px 20px
}

.table-dark th {
	font-weight: normal
}

.table-dark td {
	padding: 14px 20px
}

.type-info {
	font-weight: 400;
	margin-top: 10px
}

.type-info_tel {
	font-size: 155%;
	font-size: 1.55rem;
	color: inherit;
	font-family: "Roboto", sans-serif;
	font-weight: 500
}

.type-info_time {
	font-size: 93%;
	font-size: .93rem;
	font-weight: 600;
	margin-left: 0.5em
}

.type-lead {
	font-size: 131%;
	font-size: 1.31rem;
	font-weight: 600;
	text-align: center
}

.aside-block_inner {
	margin: 0 auto;
	max-width: 1000px;
	padding-bottom: 35px;
	padding-top: 35px
}

.aside-block-title {
	font-size: 139%;
	font-size: 1.39rem;
	border-bottom: 1px solid #000;
	color: #dc2442;
	margin-bottom: 20px;
	padding-bottom: 15px
}

.aside-block-content {
	padding: 0 20px
}

.aside-block-icon {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #fff;
	border-radius: 50%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 auto 25px;
	height: 110px;
	width: 110px
}

.aside-block-icon img {
	height: auto;
	width: 66%
}

.aside-block-list {
	font-weight: 600
}

.aside-block-list dt {
	background: url(../library/images/bg-arrow.svg) left top no-repeat;
	background-size: 100% 100%;
	color: white;
	display: inline-block;
	margin-bottom: 5px;
	padding: 3px 20px 3px 12px
}

.aside-block-list dd {
	margin: 0
}

.aside-contact {
	font-size: 108%;
	font-size: 1.08rem;
	background: url(../library/images/bg-contact-sp.jpg) top left no-repeat;
	background-size: cover;
	color: white;
	line-height: 1.5;
	letter-spacing: 0.35px;
	padding-bottom: 15px;
	padding-top: 15px;
	text-align: center
}

.aside-contact .col {
	margin: 0 auto;
	max-width: 471px;
	padding: 1em 15px
}

.aside-contact .col+.col {
	border-top: 1px solid #fff
}

.aside-section-heading {
	font-size: 154%;
	font-size: 1.54rem;
	border: none;
	line-height: normal;
	letter-spacing: 1.5px;
	margin: 0 0 32px;
	padding: 0;
	text-align: left
}

.aside-section-heading:after {
	content: '';
	display: block;
	margin-top: 10px;
	width: 40px;
	height: 3px;
	background: -webkit-gradient(linear, left top, right top, from(#046fd3), color-stop(#3a3692), to(#f73454));
	background: linear-gradient(90deg, #046fd3, #3a3692, #f73454)
}

#contact .home-section-heading,
#contact .home-section-heading-w {
	text-align: left
}

#contact .home-section-heading:after,
#contact .home-section-heading-w:after {
	margin-left: 0
}

#contact .col+.col {
	padding-top: 2.3em
}

.footer {
	font-size: 93%;
	font-size: .93rem;
	margin-top: auto;
	padding: 40px 0 19px;
	position: relative;
	text-align: center
}

.footer_inner {
	margin: 0 auto;
	max-width: 1150px
}

.footer a {
	color: #000;
	text-decoration: none
}

.footer ul {
	margin-left: 0;
	padding: 0
}

.footer-logo {
	font-size: 0;
	margin: 0 auto;
	width: 189.5px
}

.footer-logo img {
	width: 100%
}

a.footer-btn {
	font-size: 93%;
	font-size: .93rem;
	border: 1px solid black;
	border-radius: 5px;
	display: inline-block;
	font-weight: 600;
	height: 40px;
	line-height: 1.1;
	margin-top: 12px;
	padding-top: 13px;
	width: 190px
}

a.footer-btn:after {
	background-image: url(../library/images/icon-window.svg);
	background-size: 100% 100%;
	background-position: 0;
	content: '';
	margin-left: 3px;
	display: inline-block;
	height: 8px;
	vertical-align: top;
	width: 7px
}

._pc a.footer-btn {
	-webkit-transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19);
	transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19), color 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

._pc a.footer-btn:after {
	-webkit-transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19);
	transition: background 0.2s cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

._pc a.footer-btn:hover {
	background-color: black;
	color: white
}

._pc a.footer-btn:hover:after {
	background-image: url(../library/images/icon-window-white.svg)
}

.footer-credits {
	letter-spacing: normal;
	margin: 0;
	padding: 0
}

.footer-credits_line {
	padding: 0 50px
}

.footer-nav {
	margin: 40px 0 25px
}

.footer-nav li {
	display: inline-block;
	font-weight: 600;
	list-style: none;
	margin: 0 1em
}

.footer-copyright {
	font-size: 77%;
	font-size: .77rem;
	color: rgba(0, 0, 0, 0.6);
	margin: 30px 0 0;
	letter-spacing: 0.25px
}

.header {
	background: #fff;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9999
}

.header:before {
	background-color: #fff;
	content: '';
	display: block;
	left: 0;
	right: 0;
	height: 200vh;
	visibility: hidden;
	opacity: 0;
	position: fixed;
	-webkit-transition: opacity 0.3s, visibility 0.3s, z-index 0.3s;
	transition: opacity 0.3s, visibility 0.3s, z-index 0.3s;
	top: 0;
	width: 100%;
	z-index: -1
}

.header a {
	text-decoration: none
}

.header_inner {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: start;
	height: 60px;
	margin: 0 auto;
	max-width: 1150px;
	padding: 0 13px 0 20px;
	position: relative;
	z-index: 9999
}

.header-logo {
	font-size: 0;
	margin: 0;
	width: 118px;
	z-index: 10000
}

.header-logo img {
	width: 100%
}

.header-description {
	font-size: 93%;
	font-size: .93rem;
	letter-spacing: 0;
	line-height: 1.33;
	margin-left: 13px;
	margin-top: 20px;
	white-space: nowrap
}

.header-sub {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
	text-align: center;
	z-index: 10000
}

.header-info {
	color: #263855;
	font-weight: 600;
	margin-top: 10px
}

.header-info_tel {
	font-size: 177%;
	font-size: 1.77rem;
	color: #263855;
	font-family: "Roboto", sans-serif
}

.header-info_time {
	font-size: 93%;
	font-size: .93rem
}

a.header-btn {
	font-size: 108%;
	font-size: 1.08rem;
	background-color: #263855;
	border-color: #263855;
	margin-top: 50px;
	max-width: 280px;
	height: 60px;
	padding-left: 26px;
	width: 100%
}

a.header-btn:after {
	right: 20px
}

.header-hamburger {
	cursor: pointer;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-left: auto;
	padding: 12px
}

.header-hamburger_line {
	height: 15px;
	position: relative;
	width: 16px
}

.header-hamburger_line:before,
.header-hamburger_line span,
.header-hamburger_line:after {
	background-color: #000;
	bottom: 0;
	content: "";
	display: block;
	height: 2px;
	left: 0;
	margin: auto;
	position: absolute;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	-webkit-transition-delay: 0s;
	transition-delay: 0s;
	top: 0;
	width: 100%
}

.header-hamburger_line:before {
	bottom: calc(100% - 3px);
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
	-webkit-transition: bottom 0.3s, -webkit-transform 0.3s;
	transition: bottom 0.3s, -webkit-transform 0.3s;
	transition: transform 0.3s, bottom 0.3s;
	transition: transform 0.3s, bottom 0.3s, -webkit-transform 0.3s;
	-webkit-transition-delay: 0s, 0.3s;
	transition-delay: 0s, 0.3s;
	-webkit-transform-origin: center center;
	transform-origin: center center
}

.header-hamburger_line:after {
	top: calc(100% - 3px);
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
	-webkit-transform-origin: center center;
	transform-origin: center center;
	-webkit-transition: top 0.3s, -webkit-transform 0.3s;
	transition: top 0.3s, -webkit-transform 0.3s;
	transition: transform 0.3s, top 0.3s;
	transition: transform 0.3s, top 0.3s, -webkit-transform 0.3s;
	-webkit-transition-delay: 0s, 0.3s;
	transition-delay: 0s, 0.3s
}

.header-main {
	margin: 0 auto;
	width: 100%;
	z-index: 9999;
	left: 0;
	height: 0;
	max-width: none;
	opacity: 0;
	overflow: hidden;
	padding: 20px 15px;
	position: fixed;
	top: 60px;
	visibility: hidden;
	-webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, transform 0.3s;
	transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s;
	-webkit-transform: translateY(-0.8em);
	transform: translateY(-0.8em)
}

.header-nav-wrap {
	background: transparent;
	position: relative
}

.header-nav {
	border-top: 1px solid rgba(0, 0, 0, 0.2);
	margin: 0 auto;
	padding: 0
}

.header-nav_item {
	font-size: 116%;
	font-size: 1.16rem;
	font-weight: 600;
	list-style: none;
	margin: 0 auto;
	overflow: hidden
}

.header-nav_ancher {
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
	color: black;
	display: block;
	padding: 15px;
	position: relative;
	-webkit-transition: opacity 0.3s;
	transition: opacity 0.3s
}

._pc .header-nav_ancher:hover {
	opacity: 0.7
}

.header-nav_ancher:after {
	background: url(../library/images/icon-arrow-black.svg) left top no-repeat;
	background-size: 100% 100%;
	bottom: 0;
	content: '';
	height: 9px;
	margin: auto;
	width: 5.5px;
	position: absolute;
	right: 15px;
	top: 0
}

.page-header {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-image: url(../library/images/bg-title.png);
	background-size: cover;
	background-position: top center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	height: 140px;
	overflow: hidden;
	padding: 15px;
	position: relative;
	text-align: center;
	width: 100%
}

.page-heading {
	font-size: 200%;
	font-size: 2rem;
	color: white;
	font-weight: 400;
	line-height: normal;
	letter-spacing: 2px;
	width: 100%;
  padding-left: 35px;
}

.page-link-wrap {
	height: 78px;
	position: relative
}

.page-link {
	font-size: 93%;
	font-size: .93rem;
	background-color: #eee;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 0;
	font-weight: 600;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	left: 0;
	padding: 13px;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 9998
}

.page-link._fixed {
	position: fixed;
	top: 60px
}

.page-link li {
	font-size: 93%;
	font-size: .93rem;
	display: inline-block;
	margin: 5px 0;
	padding: 0 0 0 10px;
	vertical-align: top;
	min-width: 39%
}

.page-link a {
	color: black;
	text-decoration: none
}

.page-content {
	margin: 0 auto;
	padding: 60px 15px
}

.news-archive {
	margin: 0 auto;
	padding: 0 15px
}

.post-content {
	margin: 0 auto;
	max-width: 930px;
	padding-left: 15px;
	padding-right: 15px
}

.post-header {
	border-bottom: 2px solid #000;
	margin: 0 0 30px;
	padding-bottom: 20px
}

.post-heading {
	font-size: 200%;
	font-size: 2rem;
	margin: 0
}

f .post-detail h2 {
	font-size: 154%;
	font-size: 1.54rem;
	border-left: 4px solid #377fc2;
	margin: 1.5em 0 2em;
	padding: 0.1em 0.8em
}

f .post-detail h3 {
	font-size: 131%;
	font-size: 1.31rem;
	border: 1px solid #000;
	margin: 1.5em 0 2em;
	padding: 10px 14px
}

f .post-detail h4 {
	font-size: 147%;
	font-size: 1.47rem;
	font-weight: 600;
	margin: 1.5em 0 1em
}

f .post-detail ul {
	margin: 0
}

f .post-detail li {
	letter-spacing: .025em
}

f .post-detail blockquote {
	position: relative;
	padding: 20px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	background: #f4f4f4;
	border-radius: 10px;
	margin: 1em 0;
	padding: 20px 20px 10px
}

f .post-detail blockquote p {
	padding: 0;
	margin: 10px 0;
	line-height: 1.7
}

f .post-detail blockquote cite {
	display: block;
	text-align: right;
	color: #888888;
	font-size: 0.9em
}

f .post-detail blockquote li {
	padding-left: 2em;
	text-indent: -1.7em
}

f .post-detail blockquote li:before {
	background: #263855;
	border: none;
	height: 2px;
	margin-top: 0;
	vertical-align: middle;
	width: 10px
}

.gallery-caption {
	color: gray;
	font-size: 0.75em;
	margin: 5px 0;
	text-align: center
}

.wp-caption {
	max-width: 100%;
	margin: 0 0 1.5em;
	padding: 8px;
	border: #eaedf2 2px solid
}

.wp-caption.aligncenter {
	margin: 0 auto 1em
}

.sticky {
	display: block
}

.post {
	margin: 0 0 1.5em
}

.updated:not(.published) {
	display: none
}

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important
}

.p-about .page-content {
	padding-bottom: 60px
}

.about-lead {
	line-height: 1.67;
	margin-bottom: 40px
}

.about-section-heading {
	font-size: 185%;
	font-size: 1.85rem;
	font-weight: 600;
	line-height: 1.53;
	margin-bottom: 30px
}

.about-trouble-list li {
	background-image: url(../library/images/icon-check-red.svg);
	background-size: 15px 11px;
	background-repeat: no-repeat;
	background-position: 0 0.4em;
	margin-bottom: 0.5em;
	padding-left: 20px
}

.about-reason-list {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between
}

.about-reason-list li {
	width: 33%;
	text-align: center
}

.about-reason-list i {
	margin: 0 auto 10px;
	padding: 0 3px
}

.about-reason-list p {
	display: inline-block;
	margin: auto;
	background-image: url(../library/images/about-reason-shadow-l.svg), url(../library/images/about-reason-shadow-r.svg);
	background-repeat: no-repeat;
	background-position: left center, right center;
	background-size: 12px 16px;
	font-size: 3.4vw;
	padding: 0px 4vw;
}

.about-reason-section {
	margin-top: 3em;
}

.about-reason-section figure+div {
	margin: 0 auto;
	width: 98%;
}

.contact-content {
	font-size: 116%;
	font-size: 1.16rem;
}

.contact-info .col {
	padding: 0.5em 1em;
}

.contact-info .col+.col {
	border-top: 1px solid #000;
}

.wpcf7 {
	background-color: #ffffff;
	padding: 30px;
	position: relative;
}

.contact-form {
	letter-spacing: 1.5px;
	margin-top: 30px;
	width: 100%;
}

.contact-form-item {
	padding: 1em 0;
}

.contact-form-item_col1 {
	font-weight: 600;
	margin-bottom: 1em;
	padding-left: 50px;
	position: relative;
}

.contact-form-item .required {
	font-size: 108%;
	font-size: 1.08rem;
	background-color: #dc2442;
	color: white;
	font-weight: normal;
	line-height: 1.1;
	left: 0;
	margin-right: 1em;
	padding: 4px 6px 3px;
	position: absolute;
	top: 0;
}

.contact-form-btn {
	margin-top: 2em;
	/* overflow: hidden; */


	display: flex;
	justify-content: center;
}

.wpcf7c-btn-back,
.wpcf7c-btn-confirm,
.formParts-submit {
	border: none;
	display: block;
	margin: 0 auto;
	cursor: pointer;
	text-align: left;
	width: 100%;
}

.btn.formParts-confirm,
button.formParts-confirm,
input.formParts-confirm[type="button"],
input.formParts-confirm[type="reset"],
input.formParts-confirm[type="submit"],
.formParts-confirm.btn-white,
.formParts-confirm.wpcf7c-btn-back,
.formParts-confirm.wpcf7c-btn-confirm,
.formParts-confirm.formParts-submit {
	border: 2px solid #000;
}

.btn.formParts-confirm:focus,
button.formParts-confirm:focus,
input.formParts-confirm:focus[type="button"],
input.formParts-confirm:focus[type="reset"],
input.formParts-confirm:focus[type="submit"],
.formParts-confirm.btn-white:focus,
.formParts-confirm.wpcf7c-btn-back:focus,
.formParts-confirm.wpcf7c-btn-confirm:focus,
.formParts-confirm.formParts-submit:focus {
	border: 2px solid #000;
	outline: none;
}

.btn.formParts-back,
button.formParts-back,
input.formParts-back[type="button"],
input.formParts-back[type="reset"],
input.formParts-back[type="submit"],
.formParts-back.btn-white,
.formParts-back.wpcf7c-btn-back,
.formParts-back.wpcf7c-btn-confirm,
.formParts-back.formParts-submit {
	background-image: url(../library/images/icon-arrow-gray.svg);
	background-color: #fff;
	border: solid 2px #8d8d8d;
	color: #8d8d8d;
	margin-bottom: 1.5em;
}

.btn.formParts-submit,
input.formParts-submit[type="button"],
input.formParts-submit[type="reset"],
input.formParts-submit[type="submit"],
.formParts-submit {
	background-image: url(../library/images/icon-arrow-white.svg);
	background-color: #377fc2;
	border-color: #377fc2;
	color: white;
	margin-bottom: 1.5em;
}

.btn.formParts-submit:focus,
.formParts-submit:focus {
	color: #377fc2;
}

._pc .btn.formParts-submit:hover,
._pc button.formParts-submit:hover,
._pc input.formParts-submit:hover[type="button"],
._pc input.formParts-submit:hover[type="reset"],
._pc input.formParts-submit:hover[type="submit"],
._pc .formParts-submit.btn-white:hover,
._pc .formParts-submit.wpcf7c-btn-back:hover,
._pc .formParts-submit.wpcf7c-btn-confirm:hover,
._pc .formParts-submit:hover {
  background-image: url(../library/images/icon-arrow-lightblue.svg);
	color: #377fc2;
}

.wpcf7-form input[type='text'],
.wpcf7-form input[type='email'],
.wpcf7-form input[type='tel'],
.wpcf7-form textarea {
	font-size: 108%;
	font-size: 1.08rem;
	font-family: "Hiragino Kaku Gothic Pro", "Meiryo", "MS Pgothic", knowledge-reg, helvetica, arial, sans-serif;
	background-color: #eee;
	border: 1px solid #eee;
	outline: none;
	padding: 1em;
	width: 100%;
}

.wpcf7-form input[type='text']::-webkit-input-placeholder,
.wpcf7-form input[type='email']::-webkit-input-placeholder,
.wpcf7-form input[type='tel']::-webkit-input-placeholder,
.wpcf7-form textarea::-webkit-input-placeholder {
	color: #888888;
}

.wpcf7-form input[type='text']::-moz-placeholder,
.wpcf7-form input[type='email']::-moz-placeholder,
.wpcf7-form input[type='tel']::-moz-placeholder,
.wpcf7-form textarea::-moz-placeholder {
	color: #888888;
}

.wpcf7-form input[type='text']:-ms-input-placeholder,
.wpcf7-form input[type='email']:-ms-input-placeholder,
.wpcf7-form input[type='tel']:-ms-input-placeholder,
.wpcf7-form textarea:-ms-input-placeholder {
	color: #888888;
}

.wpcf7-form input[type='text']::-ms-input-placeholder,
.wpcf7-form input[type='email']::-ms-input-placeholder,
.wpcf7-form input[type='tel']::-ms-input-placeholder,
.wpcf7-form textarea::-ms-input-placeholder {
	color: #888888;
}

.wpcf7-form input[type='text']::placeholder,
.wpcf7-form input[type='email']::placeholder,
.wpcf7-form input[type='tel']::placeholder,
.wpcf7-form textarea::placeholder {
	color: #888888;
}

.wpcf7-form input[type='text']:focus,
.wpcf7-form input[type='email']:focus,
.wpcf7-form input[type='tel']:focus,
.wpcf7-form textarea:focus {
	background-color: white;
	outline: none;
}

.wpcf7-form input[type='text'].wpcf7-form-control:only-child,
.wpcf7-form input[type='email'].wpcf7-form-control:only-child,
.wpcf7-form input[type='tel'].wpcf7-form-control:only-child,
.wpcf7-form textarea.wpcf7-form-control:only-child {
	background-color: #eee;
}

.wpcf7-form input[type='text'].wpcf7-form-control:only-child:focus,
.wpcf7-form input[type='email'].wpcf7-form-control:only-child:focus,
.wpcf7-form input[type='tel'].wpcf7-form-control:only-child:focus,
.wpcf7-form textarea.wpcf7-form-control:only-child:focus {
	background-color: white;
	outline: none;
}

.wpcf7-form input[type='text'].wpcf7-form-control,
.wpcf7-form input[type='email'].wpcf7-form-control,
.wpcf7-form input[type='tel'].wpcf7-form-control,
.wpcf7-form textarea.wpcf7-form-control {
	background-color: #ffccd4;
}

.wpcf7-form input[type='text'].wpcf7c-conf,
.wpcf7-form input[type='email'].wpcf7c-conf,
.wpcf7-form input[type='tel'].wpcf7c-conf,
.wpcf7-form textarea.wpcf7c-conf {
	background-color: white !important;
	border: none;
	outline: none;
}

.wpcf7-form input[type='text'].wpcf7c-conf:-webkit-autofill,
.wpcf7-form input[type='text'].wpcf7c-conf:-webkit-autofill:hover,
.wpcf7-form input[type='text'].wpcf7c-conf:-webkit-autofill:focus,
.wpcf7-form input[type='text'].wpcf7c-conf:-webkit-autofill:active,
.wpcf7-form input[type='email'].wpcf7c-conf:-webkit-autofill,
.wpcf7-form input[type='email'].wpcf7c-conf:-webkit-autofill:hover,
.wpcf7-form input[type='email'].wpcf7c-conf:-webkit-autofill:focus,
.wpcf7-form input[type='email'].wpcf7c-conf:-webkit-autofill:active,
.wpcf7-form input[type='tel'].wpcf7c-conf:-webkit-autofill,
.wpcf7-form input[type='tel'].wpcf7c-conf:-webkit-autofill:hover,
.wpcf7-form input[type='tel'].wpcf7c-conf:-webkit-autofill:focus,
.wpcf7-form input[type='tel'].wpcf7c-conf:-webkit-autofill:active,
.wpcf7-form textarea.wpcf7c-conf:-webkit-autofill,
.wpcf7-form textarea.wpcf7c-conf:-webkit-autofill:hover,
.wpcf7-form textarea.wpcf7c-conf:-webkit-autofill:focus,
.wpcf7-form textarea.wpcf7c-conf:-webkit-autofill:active {
	-webkit-box-shadow: 0 0 0 30px white inset !important;
}

.wpcf7-form input[type='text'].wpcf7c-conf::-webkit-input-placeholder,
.wpcf7-form input[type='email'].wpcf7c-conf::-webkit-input-placeholder,
.wpcf7-form input[type='tel'].wpcf7c-conf::-webkit-input-placeholder,
.wpcf7-form textarea.wpcf7c-conf::-webkit-input-placeholder {
	color: white;
}

.wpcf7-form input[type='text'].wpcf7c-conf::-moz-placeholder,
.wpcf7-form input[type='email'].wpcf7c-conf::-moz-placeholder,
.wpcf7-form input[type='tel'].wpcf7c-conf::-moz-placeholder,
.wpcf7-form textarea.wpcf7c-conf::-moz-placeholder {
	color: white;
}

.wpcf7-form input[type='text'].wpcf7c-conf:-ms-input-placeholder,
.wpcf7-form input[type='email'].wpcf7c-conf:-ms-input-placeholder,
.wpcf7-form input[type='tel'].wpcf7c-conf:-ms-input-placeholder,
.wpcf7-form textarea.wpcf7c-conf:-ms-input-placeholder {
	color: white;
}

.wpcf7-form input[type='text'].wpcf7c-conf::-ms-input-placeholder,
.wpcf7-form input[type='email'].wpcf7c-conf::-ms-input-placeholder,
.wpcf7-form input[type='tel'].wpcf7c-conf::-ms-input-placeholder,
.wpcf7-form textarea.wpcf7c-conf::-ms-input-placeholder {
	color: white;
}

.wpcf7-form input[type='text'].wpcf7c-conf::placeholder,
.wpcf7-form input[type='email'].wpcf7c-conf::placeholder,
.wpcf7-form input[type='tel'].wpcf7c-conf::placeholder,
.wpcf7-form textarea.wpcf7c-conf::placeholder {
	color: white;
}

.formErrorContent {
	font-size: 100%;
	font-size: 1rem;
	background: transparent;
	color: #dc2442;
	font-weight: 600;
	margin: 3px 0 0;
	padding-bottom: 0;
	padding-top: 0;
}

.contact-form-text {
	margin-top: 2em;
	text-align: center;
}

.contact-form-agree {
	font-weight: 600;
	margin-top: 2em;
	padding-bottom: 1.5em;
	position: relative;
	text-align: center;
	vertical-align: top;
}

.contact-form-agree input {
	margin-right: 3px;
	margin-top: 4px;
	vertical-align: text-top;
}

.contact-form-agree+p {
	margin-top: 1em;
	font-weight: 600;
}

.contact-form-agree .formError {
	bottom: -1.8em;
	left: 0 !important;
	margin: auto !important;
	position: absolute !important;
	right: 0 !important;
	top: auto !important;
}

.formParts-checkbox span.partsList-item {
	margin: 0;
}

.formParts-checkbox label {
	display: inline-flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
	padding-left: 2em;
	cursor: pointer;
	position: relative;
}

.formParts-checkbox label:before {
	background-color: #eee;
	content: '';
	display: block;
	height: 22px;
	left: 0;
	position: absolute;
	top: -1px;
	width: 22px;
}

.formParts-checkbox input[type='checkbox'] {
	position: absolute;
	z-index: -1;
	opacity: 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
}

.formParts-checkbox input[type='checkbox']:checked+.partsList-item-label:before,
.formParts-checkbox input[type='checkbox']:checked+.partsList-item-label:after {
	opacity: 1;
}

.formParts-checkbox .formError.inline .formErrorContent {
	margin-top: 5px;
	padding: 0;
}

.formParts-checkbox .wpcf7c-conf-hidden+.partsList-item-label:before,
.formParts-checkbox .wpcf7c-conf-hidden+.partsList-item-label:after {
	opacity: 0.7;
}

.formParts-checkbox .partsList-item-label:before,
.formParts-checkbox .partsList-item-label:after {
	background-color: black;
	content: "";
	display: block;
	opacity: 0;
	position: absolute;}

.formParts-checkbox .partsList-item-label:before {
	height: 3px;
	width: 12px;
	top: 9px;
	left: 3px;
	position: absolute;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.formParts-checkbox .partsList-item-label:after {
	height: 3px;
	width: 18px;
	top: 7px;
	left: 9px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.formParts-checkbox .formError.inline .formErrorContent {
	margin-top: 5px;
	padding: 0;
}

.formParts-checkbox .wpcf7c-conf-hidden+.partsList-item-label:before,
.formParts-checkbox .wpcf7c-conf-hidden+.partsList-item-label:after {
	opacity: 0.7;
}

.wpcf7-radio [type="radio"] {
	visibility: hidden;
	opacity: 0;
	width: 0;
	height: 0;
}

.wpcf7-radio span.partsList-item {
	margin: 0 20px 15px 0
}

.wpcf7-radio label {
	cursor: pointer
}

.wpcf7-radio .partsList-item-label {
	position: relative
}

.wpcf7-radio .partsList-item-label:before {
	background-color: #eeeeee;
	border-radius: 13px;
	content: '';
	display: inline-block;
	height: 26px;
	margin-right: 10px;
	margin-top: -2px;
	vertical-align: middle;
	width: 26px
}

.wpcf7-radio .partsList-item-label:after {
	background-color: #000;
	border-radius: 7px;
	content: '';
	display: inline-block;
	height: 14px;
	left: 6px;
	margin-right: 20px;
	opacity: 0;
	position: absolute;
	top: 0;
	vertical-align: middle;
	width: 14px
}

.wpcf7-radio input:checked+.partsList-item-label:after {
	opacity: 1
}

.wpcf7-radio input:checked+[type="hidden"]+.partsList-item-label:after {
	opacity: 0.6
}

.wpcf7-radio [readonly="readonly"]+.partsList-item-label,
.wpcf7-radio [readonly="readonly"]+.wpcf7c-conf-hidden+.partsList-item-label {
	cursor: default
}

.screen-reader-response,
.wpcf7-not-valid-tip,
.wpcf7-validation-errors {
	font-size: 100%;
	font-size: 1rem
}

.wpcf7-not-valid-tip {
	display: none
}

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing,
div.wpcf7-mail-sent-ok {
	border: none
}

.custom-wpcf7c-confirmed .formParts-text,
.custom-wpcf7c-confirmed .formParts-textarea {
	border: none
}

.custom-wpcf7c-confirmed textarea.pp {
	display: none
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
	border: none;
	color: #dc2442;
	font-weight: 600;
	margin-top: 1em;
	text-align: center;
	margin-top: 0
}

div.wpcf7 .ajax-loader {
	clear: both;
	display: block;
	margin: 1em auto 0
}

.undefinedformError {
	display: none !important
}

.wpcf7 form.sent .wpcf7-response-output {
	color: #005a87;
	border: none;
	text-align: center
}

.page-contact .grecaptcha-badge {
	bottom: 14px !important;
	z-index: 9999
}

.p-flow .aside-block-list dd {
	margin: 0
}

.p-flow .aside-block-list ul {
	line-height: 1.6;
	margin: 0;
	padding-left: 1em
}

.label-radius {
	font-size: 93%;
	font-size: .93rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 1px solid #000;
	border-radius: 12px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-weight: 600;
	height: 24px;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	line-height: 1.1;
	width: 80px
}

.label-radius span {
	font-size: 108%;
	font-size: 1.08rem;
	letter-spacing: 0.7px
}

.flow-section_inner {
	margin: 0 auto;
	max-width: 1000px
}

.flow-list-item {
	letter-spacing: 0.8px;
	overflow: hidden;
	padding-bottom: 30px;
	padding-left: 50px;
	padding-top: 10px;
	position: relative
}

.flow-list-item:before {
	background: #000;
	content: '';
	display: block;
	height: 100%;
	left: 20px;
	position: absolute;
	top: 40px;
	width: 2px
}

.flow-list-item:last-child:before {
	display: none
}

.flow-list-num {
	font-size: 147%;
	font-size: 1.47rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #fff;
	border: 2px solid #000;
	border-radius: 50%;
	color: #dc2442;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-family: "Roboto", sans-serif;
	height: 40px;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	left: 0;
	letter-spacing: 0.95px;
	line-height: 1.1;
	padding-left: 2px;
	position: absolute;
	top: 0;
	width: 40px
}

.flow-list-heading {
	font-size: 124%;
	font-size: 1.24rem;
	border: none;
	margin: 0 0 15px 0;
	padding: 0
}

.flow-after-3m {
	background-color: #263855;
	border-radius: 5px;
	margin-bottom: 55px;
	padding: 40px 25px;
	position: relative
}

.flow-after-3m:after {
	content: '';
	display: block;
	border-style: solid;
	border-width: 24px 42.5px 0 42.5px;
	border-color: #263855 transparent transparent transparent;
	bottom: -24px;
	clear: both;
	height: 0;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	width: 0
}

.flow-after-3m-heading {
	margin: 0 auto 28px;
	width: 121px
}

dl.flow-after-3m-item {
	border-radius: 2.5px;
	background-color: #fff;
	overflow: hidden
}

dl.flow-after-3m-item+dl.flow-after-3m-item {
	margin-top: 10px
}

dl.flow-after-3m-item dt {
	font-size: 131%;
	font-size: 1.31rem;
	background-color: #10bdb7;
	color: white;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	min-height: 120px;
	padding: 20px 0;
	text-align: center
}

dl.flow-after-3m-item dt .label-radius {
	border-color: white;
	margin: 0 auto 10px;
	width: 120px
}

dl.flow-after-3m-item dt .label-radius+span {
	margin: auto
}

dl.flow-after-3m-item dd {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: start;
	font-weight: 600;
	line-height: 1.5;
	min-height: 90px;
	padding: 15px
}

dl.flow-after-3m-item dd ul {
	font-size: 108%;
	font-size: 1.08rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}

dl.flow-after-3m-item dd li {
	padding-left: 20px;
	width: 40%
}

.flow-after-end-heading {
	font-size: 116%;
	font-size: 1.16rem;
	border-bottom: 2px solid #e71c24;
	display: inline-block;
	font-weight: 600;
	margin: 0;
	text-align: center
}

.flow-after-end-heading span {
	font-size: 147%;
	font-size: 1.47rem
}

.flow-after-end-content {
	margin-top: 20px
}

.flow-after-end-content > div {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.flow-after-end-content p {
	font-weight: 600;
	margin: 0
}

.flow-after-end-content strong {
	font-size: 185%;
	font-size: 1.85rem;
	display: inline-block;
	padding-top: 0.1em
}

.flow-after-end-content figure {
	margin-right: 15px;
	width: 63px
}

.page-function .page-link li {
	min-width: 26%
}

.function-section {
	padding-top: 10px;
	padding-bottom: 40px;
	position: relative
}

.function-flow-list li {
	max-width: 500px;
	margin: 0 auto 20px
}

.function-featured-block {
	padding-bottom: 30px;
	position: relative;
	width: 100%
}

.function-featured-block>p {
	padding: 0 1em
}

.function-featured-especially {
	padding-top: 50px;
	position: relative
}

.function-featured-especially:before {
	background-color: #eee;
	content: '';
	display: block;
	height: 100%;
	left: -50vw;
	position: absolute;
	top: 0;
	width: 200vw
}

.function-featured-especially figure {
	margin-left: auto;
	margin-right: auto;
	max-width: 520px;
	text-align: center;
	width: 100%
}

.function-featured-especially:after {
	content: '';
	display: block;
	height: 1px;
	width: 520px
}

.function-featured-list li {
	background-image: url(../library/images/icon-check-red.svg);
	background-size: 10px 8px;
	background-repeat: no-repeat;
	background-position: 0 0.4em;
	line-height: 1.5;
	padding-left: 14px;
	width: 50%
}

.function-featured-graph {
	margin: 20px auto;
	width: 77%
}

.function-effect-table-wrap {
	border: 1px solid #dbd4cb;
	border-radius: 5px;
	overflow: hidden
}

.function-effect-table {
	border-collapse: collapse;
	border: none;
	margin: 0
}

.function-effect-table tr {
	border: none
}

.function-effect-table th {
	font-size: 100%;
	font-size: 1rem;
	color: #fff;
	border: none;
	letter-spacing: 2.6px;
	padding: 0.6em
}

.function-effect-table tr>th:nth-of-type(1) {
	background-color: #000;
	width: 42%
}

.function-effect-table tr>th:nth-of-type(2) {
	background-color: #377fc2
}

.function-effect-table tr>th:nth-of-type(3) {
	background-color: #0358a7
}

.function-effect-table td {
	font-size: 93%;
	font-size: .93rem;
	font-weight: 600;
	border: none;
	border-top: 1px solid #dbd4cb;
	padding: 0.5em
}

.function-effect-table td+td {
	border-left: 1px solid #dbd4cb
}

.function-effect-table tr>td:nth-of-type(1) {
	font-weight: 400
}

.function-all-list {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	line-height: 1.4
}

.function-all-list dl,
.function-all-list dt {
	margin-top: 0
}

.function-all-list ul {
	margin: 0
}

.function-all-list li {
	line-height: 1.6
}

.function-all-list li:before {
	content: '・';
	font-weight: 600;
	margin-left: 0.5em;
	margin-right: 0.5em
}

.function-all-list ul.flex-wrap li {
	width: 48%
}

.function-sample-list {
	padding-bottom: 40px;
	position: relative
}

.function-sample-list li {
	border: 1px solid #eee;
	margin: 0 2px
}

.function-sample-list>.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 10px
}

.function-sample-list .swiper-pagination-bullet-active {
	opacity: 1;
	background-color: #000
}

#sample {
	padding-bottom: 0
}

.js-show-popup {
	cursor: pointer
}

._modalOpen {
	margin: auto;
	min-width: auto;
	overflow: hidden !important;
	position: fixed;
	width: 100%
}

._modalOpen::-webkit-scrollbar {
	display: none;
	-webkit-appearance: none
}

.mfp-wrap {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	bottom: 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
	height: 100vh !important;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: auto;
	max-width: 940px;
	right: 0;
	top: 0 !important;
	z-index: 10000
}

.mfp-container:before {
	display: none
}

.mfp-container.mfp-inline-holder {
	padding: 0 6px 50px;
	margin: 0 auto;
	max-height: 95%;
	height: auto;
	overflow: scroll;
	position: relative;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%
}

.mfp-container.mfp-inline-holder::-webkit-scrollbar {
	display: none;
	-webkit-appearance: none
}

.mfp-auto-cursor .mfp-content {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	height: 100%;
	width: 100%
}

_::-webkit-full-page-media,
_:future,
:root .mfp-container.mfp-inline-holder {
	height: auto;
	overflow: visible;
	max-height: calc(100vh - 50px)
}

_::-webkit-full-page-media,
_:future,
:root .mfp-auto-cursor .mfp-content {
	max-height: calc(100vh - 100px);
	overflow: scroll
}

.mfp-zoom-in .mfp-with-anim {
	opacity: 0;
	-webkit-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
	-webkit-transform: scale(0.8);
	transform: scale(0.8)
}

.mfp-zoom-in.mfp-bg {
	height: 100vh !important;
	opacity: 0;
	-webkit-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
	z-index: 10000
}

.mfp-zoom-in.mfp-ready .mfp-with-anim {
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1)
}

.mfp-zoom-in.mfp-ready.mfp-bg {
	opacity: 0.8;
	position: fixed
}

.mfp-zoom-in.mfp-removing .mfp-with-anim {
	-webkit-transform: scale(0.8);
	transform: scale(0.8);
	opacity: 0
}

.mfp-zoom-in.mfp-removing.mfp-bg {
	opacity: 0
}

.modal-window {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	overflow: scroll;
	height: 100%;
	margin: auto;
	width: 100%
}

.modal-window-inner {
	background: #fff;
	padding: 55px 45px
}

.modal-window .text_block {
	margin-top: 10px;
	overflow: hidden
}

.modal-window .text_block .ttl {
	height: 19px;
	opacity: 0.7;
	border: solid 0.5px #000000;
	background-color: #ffffff;
	float: left;
	font-size: 13px;
	font-weight: 500;
	font-style: normal;
	font-stretch: normal;
	line-height: 1.1;
	letter-spacing: normal;
	margin-right: 10px;
	padding: 6px 14px 0
}

.modal-window .text_block .txt {
	font-size: 16px;
	font-weight: 500;
	font-style: normal;
	font-stretch: normal;
	line-height: 1.63;
	letter-spacing: normal;
	overflow: hidden;
	text-align: left;
	color: #000000
}

button.mfp-arrow {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	bottom: 0;
	color: rgba(255, 255, 255, 0.8);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 100%;
	font-size: 16px;
	margin: 0;
	position: absolute;
	width: 40px;
	height: 30px;
	margin: 0 auto;
	top: auto;
	visibility: hidden;
	width: 120px;
	z-index: 9999
}

._modalOpen button.mfp-arrow {
	visibility: visible
}

button.mfp-arrow.mfp-arrow-left {
	left: 50%;
	margin-left: -120px;
	padding-left: 30px
}

button.mfp-arrow.mfp-arrow-right {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	margin-right: -120px;
	padding-right: 30px;
	right: 50%
}

button.mfp-arrow.mfp-arrow-left::before,
button.mfp-arrow.mfp-arrow-right::before,
button.mfp-arrow.mfp-arrow-left::after,
button.mfp-arrow.mfp-arrow-right::after {
	background-color: rgba(255, 255, 255, 0.8);
	bottom: 0;
	border: none;
	content: '';
	margin: auto;
	height: 2px;
	position: absolute;
	top: 0;
	width: 20px;
	-webkit-transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s;
	-webkit-transition: background ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s
}

button.mfp-arrow.mfp-arrow-left::before,
button.mfp-arrow.mfp-arrow-left::after {
	-webkit-transform-origin: left center;
	transform-origin: left center
}

button.mfp-arrow.mfp-arrow-left::before {
	left: 0;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg)
}

button.mfp-arrow.mfp-arrow-left::after {
	left: 0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg)
}

button.mfp-arrow.mfp-arrow-right::before,
button.mfp-arrow.mfp-arrow-right::after {
	left: auto;
	right: 0;
	-webkit-transform-origin: right center;
	transform-origin: right center
}

button.mfp-arrow.mfp-arrow-right::before {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg)
}

button.mfp-arrow.mfp-arrow-right::after {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg)
}

button.mfp-close {
	color: transparent;
	height: 43px;
	margin-bottom: 4px;
	margin-left: auto;
	outline: none;
	position: relative;
	text-indent: -999999px;
	visibility: hidden;
	width: 43px
}

._modalOpen button.mfp-close {
	visibility: visible
}

button.mfp-close:before,
button.mfp-close:after {
	background-color: rgba(255, 255, 255, 0.8);
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 40px;
	height: 2px;
	-webkit-transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s;
	-webkit-transition: background ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s;
	transition: background ease-in-out 0.25s, box-shadow ease-in-out 0.25s, -webkit-box-shadow ease-in-out 0.25s
}

button.mfp-close:before {
	-webkit-transform: rotateZ(-45deg);
	transform: rotateZ(-45deg)
}

button.mfp-close:after {
	-webkit-transform: rotateZ(45deg);
	transform: rotateZ(45deg)
}

button.mfp-arrow.mfp-arrow-left:hover,
button.mfp-arrow.mfp-arrow-right:hover {
	background-image: none;
	color: rgba(255, 255, 255, 0.8);
	text-shadow: 0 0 15px white
}

button.mfp-arrow.mfp-arrow-left:hover::before,
button.mfp-arrow.mfp-arrow-right:hover::before,
button.mfp-arrow.mfp-arrow-left:hover::after,
button.mfp-arrow.mfp-arrow-right:hover::after,
button.mfp-close:hover:before,
button.mfp-close:hover:after {
	background-color: #fff;
	background-image: none;
	-webkit-box-shadow: 0 0 15px white;
	box-shadow: 0 0 15px white
}

button.mfp-close:hover,
button.mfp-close:hover {
	background-image: none
}

.home-section {
	font-size: 108%;
	font-size: 1.08rem;
	line-height: 1.5;
	letter-spacing: 0.35px
}

.home-section_content {
	padding-bottom: 75px;
	padding-top: 70px
}

.home-section a {
	text-decoration: none
}

.home-section figure {
	margin: 0
}

.bg-blue {
	background-color: #263855;
	color: white
}

.bg-gray {
	background-color: #eee
}

.home-section-heading,
.home-section-heading-w {
	font-size: 154%;
	font-size: 1.54rem;
	border: none;
	line-height: normal;
	letter-spacing: 1.5px;
	margin: 0 0 32px;
	padding: 0
}

.home-section-heading:after,
.home-section-heading-w:after {
	content: '';
	display: block;
	margin-top: 10px;
	width: 40px;
	height: 3px;
	background: -webkit-gradient(linear, left top, right top, from(#046fd3), color-stop(#3a3692), to(#f73454));
	background: linear-gradient(90deg, #046fd3, #3a3692, #f73454)
}

.home-section-heading.center,
.center.home-section-heading-w {
	text-align: center
}

.home-section-heading.center:after,
.center.home-section-heading-w:after {
	margin-left: auto;
	margin-right: auto
}

.home-section-heading-w {
	color: white
}

.home-section-heading-w .home-section-heading_en {
	color: white
}

.home-slider {
	opacity: 0;
	position: relative;
	-webkit-transition: opacity 0.6s;
	transition: opacity 0.6s
}

/* IT導入補助金バッジ Start */
#mainSlider {
	position: relative;
}
#mainSlider .it-badge {
	position: absolute;
	top: 30px;
	left: 50px;
	z-index: 10;
	box-shadow: 5px 10px 15px rgba(0, 0, 0, 0.7);
	border-radius: 500%;
}
#mainSlider .it-badge img {
	display: block;
	width: 120px;
	height: auto;
}
.page-header .it-badge {
	position: absolute;
	top: 10px;
	left: 25px;
	z-index: 10;
	box-shadow: 5px 10px 15px rgba(0, 0, 0, 0.7);
	border-radius: 50%;
}
.page-header .it-badge img {
	display: block;
	width: 110px;
	height: auto;
}

/* IT導入補助金バッジ end */

._winShow .home-slider {
	opacity: 1
}

.slider-main {
	overflow-y: visible
}

.slider-main .swiper-wrapper {
	max-height: 640px;
	min-height: 450px;
	height: calc(100vh - 60px);
	overflow: hidden;
	width: 100%
}

.slider-main .swiper-button-prev,
.slider-main .swiper-button-next {
	outline: none;
	height: 71px;
	width: 71px
}

.slider-main .swiper-button-prev:after,
.slider-main .swiper-button-next:after {
	background: url(../library/images/btn-next.svg) left top no-repeat;
	background-size: 100% 100%;
	content: '';
	height: 100%;
	width: 100%
}

.slider-main .swiper-button-prev:after {
	-webkit-transform: scale(-1, 1);
	transform: scale(-1, 1)
}

.slider-main .swiper-pagination {
	text-align: center;
	width: 100%
}

.slider-main .swiper-pagination-bullet {
	height: 12px;
	margin: 0 6px;
	width: 12px
}

.slider-main .swiper-pagination-fraction,
.slider-main .swiper-pagination-custom,
.slider-main .swiper-container-horizontal>.swiper-pagination-bullets {
	bottom: 0
}

.slider-main .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 6px
}

.slider-main .swiper-pagination-bullet-active {
	background-color: #263855
}

.slider-main .swiper-slide {
	text-align: center;
	font-size: 18px;
	background: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.slider-main .slide-bg {
	height: 100%;
	position: relative;
	width: 100%
}

.slider-main .slide-bg img {
	-o-object-fit: cover;
	object-fit: cover;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%
}

.slider-main .swiper-slide-active .slide-bg,
.slider-main .swiper-slide-duplicate-active .slide-bg,
.slider-main .swiper-slide-prev .slide-bg {
	-webkit-animation: zoomUp 10s linear 0s 1 normal both;
	animation: zoomUp 10s linear 0s 1 normal both
}

.slider-main .slide-text {
	height: 100%;
	left: 0;
	margin: auto;
	position: absolute;
	right: 0;
	top: 0;
	width: auto
}

.slider-main .slide-text img {
	height: 100%;
	max-height: 100%;
	max-width: none
}

.slider-thumbnail {
	bottom: 24px;
	left: 0;
	margin: auto;
	overflow: visible;
	position: absolute;
	right: 0;
	width: 1000px
}

.slider-thumbnail .swiper-wrapper .swiper-slide {
	width: 25%;
	height: 100%
}

.slider-thumbnail .swiper-wrapper .swiper-slide.swiper-slide-thumb-active img {
	opacity: 1
}

.slider-thumbnail .slider-thumbnail-item {
	-webkit-box-shadow: 3.8px 4.7px 18px 0 rgba(53, 54, 53, 0.5);
	box-shadow: 3.8px 4.7px 18px 0 rgba(53, 54, 53, 0.5);
	background-color: #fff;
	height: 80px;
	overflow: hidden;
	position: relative;
	width: 240px
}

.slider-thumbnail .slider-thumbnail-item img {
	opacity: .5;
	-webkit-transition: opacity 0.3s;
	transition: opacity 0.3s
}

@-webkit-keyframes zoomUp {
	0% {
		-webkit-transform: scale(1.01);
		transform: scale(1.01)
	}

	100% {
		-webkit-transform: scale(1.15);
		transform: scale(1.15)
	}
}

@keyframes zoomUp {
	0% {
		-webkit-transform: scale(1.01);
		transform: scale(1.01)
	}

	100% {
		-webkit-transform: scale(1.15);
		transform: scale(1.15)
	}
}

.home-contact {
	font-size: 108%;
	font-size: 1.08rem;
	background: url(../library/images/bg-home-contact-sp.jpg) left top no-repeat;
	background-size: cover;
	color: white;
	padding-bottom: 15px;
	padding-top: 15px;
	text-align: center
}

.home-contact .col {
	padding: 1em 15px
}

.home-contact .col+.col {
	border-top: 1px solid #fff
}

.home-lead {
	padding-top: 75px
}

.home-lead strong {
	font-size: 177%;
	font-size: 1.77rem
}

.home-lead figure img {
	width: 100%
}

.home-about {
	padding-bottom: 0
}

.home-about-list .col-2 {
	margin: 0 auto;
	min-height: 215px;
	padding: 25px 15px 30px;
	position: relative;
	width: calc((100% - 30px))
}

.home-about-list figure {
	margin: 0 auto;
	padding-top: 55%;
	position: relative;
	width: calc(100% - 30px)
}

.home-about-list figure img {
	left: 0;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	position: absolute;
	top: 0;
	width: 100%
}

.home-about-list .num {
	height: 146px;
	position: absolute;
	right: 0;
	top: 43px
}

.home-about-list .num img {
	height: 100%;
	width: auto
}

.home-about-list_text1 {
	border: none;
	padding-left: 0
}

li:nth-child(2n) .home-about-list_text1,
li:nth-child(2n) .home-about-list_text2 {
	margin-left: auto
}

.home-service {
	padding-bottom: 75px
}

.home-service strong {
	font-size: 154%;
	font-size: 1.54rem
}

.home-service-list {
	margin: 0;
	padding: 0
}

.home-service-list li {
	background-color: #fff;
	border-radius: 5px;
	list-style: none;
	min-height: 215px;
	margin: 2px;
	padding: 0 0 10px;
	width: calc(50% - 4px)
}

.home-service-list figure {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	height: 76px;
	text-align: center
}

.home-service-list .icon-cloud {
	width: 47.5px;
	height: 47.5px
}

.home-service-list .icon-download {
	width: 43px;
	height: 43.5px
}

.home-service-list .icon-filelink {
	width: 39.5px;
	height: 50.5px
}

.home-service-list .icon-connect {
	width: 38.5px;
	height: 55px
}

.home-service-list .icon-graph {
	width: 43px;
	height: 43px
}

.home-service-list .icon-transfer {
	width: 49px;
	height: 48px
}

.home-service-list .icon-tap {
	width: 39.5px;
	height: 54.5px
}

.home-service-list .icon-percent {
	width: 38px;
	height: 48px
}

.home-service-list .icon-remote {
	width: 53px;
	height: 50px
}

.home-service-list .icon-drug-price {
	width: 46.5px;
	height: 54px
}

.home-service-list .icon-support {
	width: 48px;
	height: 49.5px
}

.home-service-list .icon-handy {
	width: 43.5px;
	height: 54.5px
}

.home-service-list_text1 {
	font-size: 100%;
	font-size: 1rem;
	letter-spacing: 0.33px;
	margin-bottom: 0.2em
}

.home-service-list_text2 {
	font-size: 85%;
	font-size: .85rem;
	padding: 0 10px
}

.home-voice .home-voice-list {
	padding-left: 16px;
	padding-right: 16px;
	position: relative
}

.home-voice-list .swiper-wrapper {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding-bottom: 16px;
	width: 640px
}

.home-voice-item {
	border-radius: 8px;
	border: solid 2px #000000;
	background-color: #ffffff;
	margin: 0;
	opacity: 0.4;
	padding: 20px 25px;
	position: relative;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
	z-index: 1
}

.home-voice-item.swiper-slide-active {
	opacity: 1
}

.home-voice-item:before,
.home-voice-item:after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 8px 0 8px;
	position: absolute;
	right: 16%
}

.home-voice-item:before {
	border-color: #000 transparent transparent transparent;
	bottom: -15px;
	z-index: -1
}

.home-voice-item:after {
	border-color: #fff transparent transparent transparent;
	bottom: -11px
}

.home-voice-item_text {
	font-size: 108%;
	font-size: 1.08rem;
	line-height: 1.5;
	letter-spacing: 0.4px;
	margin-bottom: 19px
}

.home-voice-item_company {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}

.home-voice-item_figure {
	border-radius: 50%;
	overflow: hidden;
	position: relative;
	width: 35px;
	height: 35px
}

.home-voice-item_figure img {
	height: 100%;
	left: 0;
	-o-object-fit: cover;
	object-fit: cover;
	position: absolute;
	top: 0;
	width: 100%
}

.home-voice-item_name {
	font-size: 108%;
	font-size: 1.08rem;
	margin: 0;
	padding-left: 14.5px;
	width: calc(100% - 35px)
}

.home-voice-next,
.home-voice-prev {
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 100% 100%;
	bottom: 0;
	cursor: pointer;
	height: 29px;
	margin: auto;
	position: absolute;
	top: 0;
	width: 17px;
	z-index: 99
}

.home-voice-prev {
	background-image: url(../library/images/btn-prev.svg);
	left: 0
}

.home-voice-next {
	background-image: url(../library/images/btn-next.svg);
	right: 0
}

.home-company-list {
	background-color: #fff;
	font-size: 0;
	margin: 0 auto;
	padding: 15px
}

.home-company-list:after {
	content: '';
	display: inline-block;
	height: 1px;
	width: 33%
}

.home-company-list li {
	list-style: none;
	padding: 10px 0;
	text-align: center;
	width: 33%
}

.home-company-list li img {
	display: inherit;
	margin: auto
}

.home-company-list li:nth-child(1) img {
	width: 100px
}

.home-company-list li:nth-child(2) img {
	width: 44px
}

.home-company-list li:nth-child(3) img {
	width: 100px
}

.home-company-list li:nth-child(4) img {
	width: 78px
}

.home-company-list li:nth-child(5) img {
	width: 44px
}

.home-security {
	background-image: url(../library/images/home-security-bg.svg);
	background-position: right -60px top -5px;
	background-repeat: no-repeat;
	background-size: 80% auto
}

.home-faq .list-faq {
	max-width: 900px
}

.home-price {
	background-image: url(../library/images/home-price-bg.svg);
	background-position: 34px -10px;
	background-repeat: no-repeat;
	background-size: 105% auto
}

.home-news_col {
	margin: 0 25px 25px;
	width: 525px
}

.home-news .list-news {
	max-width: 900px
}

.home-news .article-item {
	background-position: right 5px top 23px;
	min-height: 59px
}

.home-news .article-item_link .article-heading {
	font-size: 124%;
	font-size: 1.24rem
}

.alignleft {
	display: inline;
	float: left;
	margin-right: 1em
}

.alignright {
	display: inline;
	float: right;
	margin-left: 1em
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto
}

[style="text-align: center;"]>* {
	margin-left: auto;
	margin-right: auto
}

/* .bg-cover {
	background: url(https://hello-prism.com/cms/wp-content/themes/prism.com/library/images/bg-cover.png) left top repeat;
	background-size: 6px 6px;
	left: 0;
	position: absolute;
	top: 0;
	height: 100%;
	width: 100%
} */

/* .bg-cover-flow {
	background: url(https://hello-prism.com/cms/wp-content/themes/prism.com/library/images/bg-cover-flow.png) left top repeat;
	background-size: 3px 3px;
	left: 0;
	position: absolute;
	top: 0;
	height: 100%;
	width: 100%
} */

.col-15p {
	width: 13%
}

.col-20p {
	width: 20%
}

.col-25p {
	width: 25%
}

.col-35p {
	width: 35%
}

.col-48p {
	width: 48%
}

.col-50p {
	width: 50%
}

.col-95p {
	width: 95%
}

.col-100p {
	width: 100%
}

.col-5em {
	width: 5em
}

.col-10em {
	width: 10em
}

.color-white {
	color: white
}

.color-blue1 {
	color: #263855
}

.color-red {
	color: #dc2442
}

.display-ib {
	display: inline-block
}

.flex,
.flex-wrap,
.flex-nowrap,
.flex-ai-center,
.flex-ai-c,
.flex-ai-stretch,
.flex-jc-center,
.flex-jc-c,
.flex-jc-between,
.flex-jc-btw,
.flex-jc-start,
.flex-jc-st,
.flex-jc-end,
.flex-jc-around,
.flex-column,
.flex-row {
	display: -ms-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex
}

.flex-wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}

.flex-nowrap {
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap
}

.flex-ai-center,
.flex-ai-c {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.flex-ai-stretch {
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch
}

.flex-jc-center,
.flex-jc-c {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}

.flex-jc-between,
.flex-jc-btw {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between
}

.flex-jc-start,
.flex-jc-st {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start
}

.flex-jc-end {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end
}

.flex-jc-around {
	-ms-flex-pack: distribute;
	justify-content: space-around
}

.flex-column {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column
}

.flex-row {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row
}

.font-right {
	text-align: right
}

.font-left {
	text-align: left
}

.font-center {
	text-align: center
}

.font-normal {
	font-weight: 400
}

.font-bold {
	font-weight: 600
}

.font-l {
	font-size: 124%;
	font-size: 1.24rem
}

.font-m {
	font-size: 116%;
	font-size: 1.16rem
}

.font-n {
	font-size: 100%;
	font-size: 1rem
}

.font-s {
	font-size: 93%;
	font-size: .93rem
}

.font-serif {
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif
}

.font-roboto {
	font-family: "Roboto", sans-serif
}

.hover-zoom-img_img,
.hover-zoom-img img {
	-webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
	-webkit-transform: scale(1.01, 1.01);
	transform: scale(1.01, 1.01)
}

.hover-zoom-img:hover .hover-zoom-img_img,
.hover-zoom-img:hover img {
	opacity: 0.85;
	-webkit-transform: scale(1.06, 1.06);
	transform: scale(1.06, 1.06)
}

.hover-opacity-img img {
	-webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.hover-opacity-img:hover img {
	opacity: 0.8
}

.hover-opacity {
	text-decoration: none;
	-webkit-transition: opacity .5s;
	transition: opacity .5s
}

.hover-opacity:hover {
	opacity: 0.7
}

.hover-blue {
	text-decoration: none;
	-webkit-transition: color .5s;
	transition: color .5s
}

.hover-blue:hover {
	color: #263855
}

[data-inview="cover"] {
	position: relative
}

[data-inview="cover"]:before {
	background: #eff4f7;
	position: absolute;
	z-index: 1;
	content: "";
	display: block;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	-webkit-transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

[data-inview="cover"] [data-inview-child="fadeup"] {
	opacity: 0;
	transition: transform .4s ease 1s, opacity .4s ease 1s, box-shadow .3s ease, -webkit-transform .4s ease 1s;
	-webkit-transform: translateY(15px);
	transform: translateY(15px)
}

[data-inview="cover"]._inview:before {
	-webkit-transition-delay: .5s;
	transition-delay: .5s;
	width: 0
}

[data-inview="cover"]._inview [data-inview-child="fadeup"] {
	opacity: 1;
	-webkit-transform: translateY(0);
	transform: translateY(0)
}

[data-inview="imgfadein"] {
	position: relative
}

[data-inview="imgfadein"] img {
	opacity: 0;
	-webkit-transform: scale(1.1);
	transform: scale(1.1)
}

[data-inview="imgfadein"]._inview img {
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1)
}

[data-inview="fade"] {
	opacity: 0;
	-webkit-transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="fade"]._inview {
	opacity: 1
}

[data-inview="fadeup"] {
	opacity: 0;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
	transition: opacity 0.5s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="fadeup"]._inview {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px)
}

[data-inview="flow"] {
	opacity: 0;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
	-webkit-transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="flow"]._inview {
	opacity: 1;
	-webkit-transform: translateY(0px);
	transform: translateY(0px)
}

[data-inview="faderight"] {
	opacity: 0;
	-webkit-transform: translateX(-50px);
	transform: translateX(-50px);
	-webkit-transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="faderight"]._inview {
	opacity: 1;
	-webkit-transform: translateX(0px);
	transform: translateX(0px)
}

[data-inview="fadeleft"] {
	opacity: 0;
	-webkit-transform: translateX(50px);
	transform: translateX(50px);
	-webkit-transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="fadeleft"]._inview {
	opacity: 1;
	-webkit-transform: translateX(0px);
	transform: translateX(0px)
}

[data-inview="opacity"] {
	opacity: 0;
	transition: transform .4s ease, opacity .4s ease, box-shadow .3s ease, -webkit-transform .4s ease
}

[data-inview="opacity"]._inview {
	opacity: 1
}

[data-inview="clip-path"] {
	-webkit-clip-path: inset(0 100% 0 0);
	clip-path: inset(0 100% 0 0);
	opacity: 0;
	position: relative;
	transition: opacity 0.6s linear, transform 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), clip-path 0.5s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-clip-path 0.5s cubic-bezier(0.39, 0.575, 0.565, 1)
}

[data-inview="clip-path"] [data-inview-child="faderight"] {
	opacity: 0;
	transition: transform .4s ease 1s, opacity .4s ease 1s, box-shadow .3s ease, -webkit-transform .4s ease 1s;
	-webkit-transform: translateX(-30px);
	transform: translateX(-30px)
}

[data-inview="clip-path"]._inview {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
	opacity: 1
}

[data-inview="clip-path"]._inview [data-inview-child="faderight"] {
	opacity: 1;
	-webkit-transform: translateX(0);
	transform: translateX(0)
}

[data-inview="clip-path"]+[data-inview="fadeup"] {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s
}

[data-inview="zoom"] {
	-webkit-filter: blur(8px) brightness(1.5);
	filter: blur(8px) brightness(1.5);
	opacity: 0;
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
	-webkit-transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-filter 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-filter 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), filter 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), filter 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-filter 0.4s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1)
}

[data-inview="zoom"]._inview {
	-webkit-filter: blur(0px) brightness(1);
	filter: blur(0px) brightness(1);
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1)
}

.delay-01s {
	-webkit-transition-delay: 0.1s;
	transition-delay: 0.1s
}

.delay-02s {
	-webkit-transition-delay: 0.2s;
	transition-delay: 0.2s
}

.delay-03s {
	-webkit-transition-delay: 0.3s;
	transition-delay: 0.3s
}

.delay-04s {
	-webkit-transition-delay: 0.4s;
	transition-delay: 0.4s
}

.delay-05s {
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s
}

.is-tel {
	text-decoration: none !important
}

.is-fax {
	pointer-events: none;
	text-decoration: none !important
}

._pc .is-tel {
	pointer-events: none;
	text-decoration: none !important
}

.mg-0 {
	margin: 0
}

.mg-t0 {
	margin-top: 0px
}

.mg-t02em {
	margin-top: 0.2em
}

.mg-t05em {
	margin-top: 0.5em
}

.mg-t1em {
	margin-top: 1em
}

.mg-t1-5em {
	margin-top: 1.5em
}

.mg-t2em {
	margin-top: 2em
}

.mg-t3em {
	margin-top: 3em
}

.mg-t4em {
	margin-top: 4em
}

.mg-t5em {
	margin-top: 5em
}

.mg-b0 {
	margin-bottom: 0px
}

.mg-b05em {
	margin-bottom: 0.5em
}

.mg-b1em {
	margin-bottom: 1em
}

.mg-b2em {
	margin-bottom: 2em
}

.mg-b3em {
	margin-bottom: 3em
}

.mg-b4em {
	margin-bottom: 4em
}

.mg-b5em {
	margin-bottom: 5em
}

.mg-b6em {
	margin-bottom: 6em
}

.mg-center {
	margin-left: auto;
	margin-right: auto
}

.mg-right {
	margin-right: 0;
	margin-left: auto
}

.mg-left {
	margin-right: auto;
	margin-left: 0
}

.shadow {
	background-color: #00243e;
	-webkit-box-shadow: 10.1px 12.4px 28.2px 2.8px rgba(53, 54, 53, 0.4);
	box-shadow: 10.1px 12.4px 28.2px 2.8px rgba(53, 54, 53, 0.4)
}

/*---------- cookie banner start ----------*/
#cookie-consent-banner {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: rgba(38, 56, 85, 0.95);
    color: #fff;
    font-size: 0.95rem;
    text-align: center;
    z-index: 9999;
    padding: 1.5em 1em;
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.2);
}

.cookie-banner-inner {
    max-width: 960px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.cookie-banner-col.text {
    order: 1;
}

.cookie-banner-col.buttons {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1em;
    order: 2;
}

/* テキストの配置 */
.cookie-banner-text {
    margin-bottom: 1em;
    line-height: 1.6;
    text-align: left;
}

/* ボタン全体のレイアウト */
.cookie-button-row {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
}

/* ボタンのデザイン */
.cookie-button-row .btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 44px;  /* ボタンの高さを統一 */
    background-color: #000;
    color: #fff;
    font-weight: bold;
    border-radius: 4px;
    text-decoration: none;
    border: none;
    cursor: pointer;
}

/* クッキー設定ボタンの調整 */
.cookie-banner-btn-settings {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 44px;
    background-color: #000;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
    border-radius: 4px;
    text-align: center;
    padding: 0.6em 1.4em;
}

.cookie-banner-btn-settings:hover {
    text-decoration: underline;
}

/* PC時のレイアウト */
@media screen and (min-width: 768px) {
    .cookie-banner-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .cookie-banner-col.text {
        width: 60%;
        order: 1;
    }

    .cookie-banner-col.buttons {
        width: 25%;
        flex-direction: column;
        align-items: flex-end;
        gap: 0.5em;
        order: 2;
    }

    .cookie-button-row {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    .cookie-button-row .btn,
    .cookie-banner-btn-settings {
        width: 100%;
    }
}

/*---------- cookie banner end ----------*/

@media print,
screen and (min-width: 768px) {
	body {
		font-size: 124%;
		font-size: 1.24rem
	}

	h3,
	.h3 {
		border-width: 5px;
		font-size: 162%;
		font-size: 1.62rem
	}

	.container {
		min-width: 1280px;
		padding-top: 0
	}

	.article-label,
	.article-label-new {
		font-size: 100%;
		font-size: 1rem
	}

	.article-item {
		background-position: right 40px top 33px;
		background-size: 9px 14px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		min-height: 80px;
		padding: 15px 60px 15px 20px
	}

	.article-item .article-date,
	.article-item .post-date {
		font-size: 124%;
		font-size: 1.24rem;
		float: none;
		width: 145px
	}

	.article-item .article-heading {
		font-size: 139%;
		font-size: 1.39rem
	}

	.block-inner {
		padding-left: 0;
		padding-right: 0
	}

	.block-border {
		border-width: 3px
	}

	.btn,
	button,
	input[type="button"],
	input[type="reset"],
	input[type="submit"],
	.btn-white,
	.wpcf7c-btn-back,
	.wpcf7c-btn-confirm,
	.formParts-submit {
		font-size: 124%;
		font-size: 1.24rem;
		background-position: right 34px center;
		background-size: 9px 14px;
		border-radius: 5px;
		height: 65px;
		padding: 0 34px;
		width: 441px
	}

	.heading,
	.heading-red {
		font-size: 216%;
		font-size: 2.16rem;
		letter-spacing: 0.7px;
		margin-bottom: 50px;
		padding-bottom: 10px
	}

	.heading-red {
		font-size: 216%;
		font-size: 2.16rem;
		border-width: 2px;
		letter-spacing: 0.7px;
		margin-bottom: 30px;
		padding-bottom: 20px
	}

	.heading-band,
	.heading-band-serif {
		border-width: 5px;
		font-size: 216%;
		font-size: 2.16rem
	}

	.heading-band-red {
		font-size: 185%;
		font-size: 1.85rem;
		border-width: 4px
	}

	.heading-label-red {
		font-size: 185%;
		font-size: 1.85rem;
		border-width: 4px;
		padding-left: 19px
	}

	.heading-band-serif {
		font-size: 212%;
		font-size: 2.12rem
	}

	.heading-normal {
		font-size: 170%;
		font-size: 1.7rem
	}

	.heading-border {
		font-size: 154%;
		font-size: 1.54rem
	}

	.heading-line {
		font-size: 154%;
		font-size: 1.54rem
	}

	.link,
	a.link {
		font-size: 124%;
		font-size: 1.24rem;
		letter-spacing: 1.2px;
		padding: 15px 15px 15px 0;
		width: 320px
	}

	.link:after,
	a.link:after {
		width: 9px;
		height: 14px;
		right: 10px
	}

	.list-faq-item {
		font-size: 124%;
		font-size: 1.24rem;
		padding: 0 20px
	}

	.list-faq-item_q {
		padding: 33px 50px 33px 52px
	}

	.list-faq-item_q:before {
		-webkit-transform: scale(1);
		transform: scale(1);
		top: 30px
	}

	.list-faq-item_q:after {
		-webkit-transform: scale(1);
		transform: scale(1);
		top: 30px
	}

	.list-faq-item_a {
		padding: 0 50px 33px 52px
	}

	.list-faq-item_a:before {
		-webkit-transform: scale(1);
		transform: scale(1)
	}

	.list-faq-item_q._open:after {
		-webkit-transform: scale(1) rotate(90deg);
		transform: scale(1) rotate(90deg)
	}

	.list-item-check:before {
		margin-right: 15px;
		padding-left: 5px;
		-webkit-transform: scale(1);
		transform: scale(1)
	}

	.list-item-dotted:before {
		margin-right: 16px;
		width: 10px;
		height: 10px
	}

	.pagenav {
		font-size: 154%;
		font-size: 1.54rem
	}

	.pagenav_inner {
		padding: 0 60px
	}

	.type-info {
		line-height: 1.3;
		margin: 0 15px;
		text-align: right
	}

	.type-info_tel {
		font-size: 185%;
		font-size: 1.85rem
	}

	.type-info_time {
		font-size: 108%;
		font-size: 1.08rem;
		display: block
	}

	.type-lead {
		font-size: 185%;
		font-size: 1.85rem
	}

	.aside-block_inner {
		padding-bottom: 55px;
		padding-top: 55px
	}

	.aside-block .col-1 {
		width: 180px
	}

	.aside-block .col-2 {
		font-size: 139%;
		font-size: 1.39rem;
		padding-left: 30px;
		width: calc(100% - 180px)
	}

	.aside-block-title {
		font-size: 216%;
		font-size: 2.16rem;
		border-width: 2px;
		letter-spacing: 0.7px;
		margin-bottom: 30px;
		padding-bottom: 20px
	}

	.aside-block-icon {
		height: 180px;
		width: 180px
	}

	.aside-block-list {
		margin: 0
	}

	.aside-block-list dt {
		margin-right: 16px;
		padding: 3px 25px 2px 15px
	}

	.aside-contact {
		background: url(../library/images/bg-contact.jpg) center center no-repeat;
		background-size: cover;
		background-attachment: fixed;
		font-size: 154%;
		font-size: 1.54rem;
		line-height: 1.8;
		letter-spacing: 0.25px;
		padding-bottom: 25px;
		padding-top: 30px;
		text-align: left
	}

	.aside-contact_inner {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		margin: 0 auto;
		width: 1100px
	}

	.aside-contact .col {
		margin: 0;
		max-width: none;
		padding: 20px 50px
	}

	.aside-contact .col+.col {
		border-left: 1px solid #fff;
		border-top: none;
		padding: 20px 50px
	}

	.aside-contact p {
		margin-bottom: 1em
	}

	.aside-contact .type-info {
		-webkit-box-align: end;
		-ms-flex-align: end;
		align-items: flex-end;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		font-weight: 600;
		line-height: 1.1;
		margin: 20px 0 0
	}

	.aside-contact .type-info_tel {
		font-size: 293%;
		font-size: 2.93rem;
		letter-spacing: 0.95px
	}

	.aside-contact .type-info_time {
		font-size: 124%;
		font-size: 1.24rem;
		margin-bottom: 5px
	}

	.aside-section-heading {
		font-size: 247%;
		font-size: 2.47rem;
		letter-spacing: 2.4px;
		margin-bottom: 64px
	}

	.aside-section-heading:after {
		margin-top: 15px
	}

	#contact {
		font-size: 124%;
		font-size: 1.24rem;
		padding-bottom: 80px;
		padding-top: 80px
	}

	#contact .type-info {
		display: block;
		margin-top: 1em;
		text-align: left
	}

	#contact .col {
		padding-bottom: 0;
		padding-top: 0
	}

	#contact .col+.col {
		padding-top: 0
	}

	.footer {
		font-size: 108%;
		font-size: 1.08rem
	}

	a.footer-btn {
		font-size: 116%;
		font-size: 1.16rem;
		margin-top: 10px;
		height: 40px
	}

	a.footer-btn:after {
		height: 11px;
		width: 10px
	}

	.footer-credits {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}

	.footer-credits_line+.footer-credits_line {
		border-left: 2px solid black;
		padding: 0 35px
	}

	.footer-nav {
		margin: 0;
		text-align: left;
		width: 550px
	}

	.footer-nav li {
		margin: 0.8em 1em
	}

	.footer-copyright {
		font-size: 108%;
		font-size: 1.08rem;
		margin: 30px 0 0
	}

	.header {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
		height: 80px;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		position: relative
	}

	.header:before {
		display: none
	}

	.header_inner {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		background-color: white;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		height: auto;
		padding: 0 0 0 50px;
		width: 365px
	}

	.header-logo {
		width: 163px
	}

	.header-sub {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		-ms-flex-direction: row;
		flex-direction: row;
		-webkit-box-pack: end;
		-ms-flex-pack: end;
		justify-content: flex-end
	}

	.header-info {
		color: black;
		line-height: 1.3;
		margin: 0 15px;
		text-align: right;
		white-space: nowrap
	}

	.header-info_tel {
		font-size: 185%;
		font-size: 1.85rem;
		color: black
	}

	.header-info_time {
		font-size: 108%;
		font-size: 1.08rem;
		display: block
	}

	a.header-btn {
		background: #263855;
		border-radius: 0;
		border: 3px solid #263855;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		height: 80px;
		margin: 0;
		padding: 0;
		width: 200px
	}

	a.header-btn:after {
		display: none
	}

	a.header-btn:focus {
		background-color: #fff;
		background-image: none;
		color: #263855
	}

	._pc a.header-btn:hover {
		background-color: #fff;
		background-image: none;
		color: #263855
	}

	.header-main {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		height: 100%;
		opacity: 1;
		padding: 0;
		position: relative;
		-webkit-transition: 0s;
		transition: 0s;
		-webkit-transform: none;
		transform: none;
		top: 0;
		visibility: visible;
		width: calc(100% - 365px)
	}

	.header-nav-wrap {
		margin-left: auto
	}

	.header-nav {
		border: none;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		height: auto;
		padding: 0 15px
	}

	.header-nav_item {
		font-size: 124%;
		font-size: 1.24rem;
		white-space: nowrap
	}

	.header-nav_item+.header-nav_item {
		margin-left: 30px
	}

	._pc .header-nav_item {
		-webkit-transition: background 0.3s;
		transition: background 0.3s
	}

	.header-nav_ancher {
		border: none;
		padding: 0
	}

	.header-nav_ancher:after {
		display: none
	}

	.page-header {
		height: 240px;
		padding: 0;
		text-align: left;
	}

	.page-heading {
		font-size: 308%;
		font-size: 3.08rem;
		text-align: left;
		width: 1100px;
	}

	.page-link-wrap {
		height: 80px
	}

	.page-link {
		text-align: center
	}

	.page-link._fixed {
		top: 0
	}

	.page-link li {
		font-size: 108%;
		font-size: 1.08rem;
		margin: 20px 25px;
		padding: 0;
		min-width: auto
	}

	.page-content {
		padding-bottom: 240px;
		padding-top: 120px;
		width: 1130px
	}

	.news-archive {
		padding: 0
	}

	.post-header {
		border-width: 3px;
		margin-bottom: 50px;
		padding-bottom: 40px
	}

	.post-heading {
		font-size: 293%;
		font-size: 2.93rem;
		margin: 0
	}

	f .post-detail h2 {
		font-size: 216%;
		font-size: 2.16rem;
		border-width: 5px
	}

	f .post-detail h3 {
		font-size: 154%;
		font-size: 1.54rem;
		padding: 14px 18px
	}

	f .post-detail h4 {
		font-size: 170%;
		font-size: 1.7rem
	}

	f .post-detail blockquote {
		padding: 40px 40px 30px
	}

	.about-lead {
		margin: 0 auto 75px;
		max-width: 900px
	}

	.about-section-heading {
		font-size: 293%;
		font-size: 2.93rem;
		letter-spacing: 0.95px;
		margin: 0 0 35px
	}

	.about-trouble {
		margin-bottom: 90px
	}

	.about-trouble figure {
		position: absolute;
		right: 0;
		width: 600px
	}

	.about-trouble .col-1 {
		position: relative;
		width: 44%
	}

	.about-trouble .col-2 {
		padding-left: 40px;
		padding-top: 50px;
		width: 56%
	}

	.about-trouble-list li {
		background-size: 18px 14px;
		padding-left: 30px
	}

	.about-reason-list {
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		margin-bottom: 100px
	}

	.about-reason-list li {
		margin: 0 5px;
		width: 304px
	}

	.about-reason-list i {
		margin-bottom: 18px;
		height: 256px;
		width: 250px
	}

	.about-reason-list p {
		font-size: 177%;
		font-size: 1.77rem;
		background-size: 26px 28px;
		padding: 0 36px;
		white-space: nowrap
	}

	.about-reason-section>.flex-tab {
		padding: 0 40px
	}

	.about-reason-section figure {
		width: 480px
	}

	.about-reason-section figure+div {
		padding-left: 30px;
		width: calc(100% - 480px)
	}

	.contact-content {
		font-size: 139%;
		font-size: 1.39rem
	}

	.contact-info {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}

	.contact-info .col+.col {
		border-left: 2px solid #000;
		border-top: none;
		text-align: left
	}

	.contact-info .type-info_tel {
		font-size: 293%;
		font-size: 2.93rem
	}

	.contact-info .type-info_time {
		font-size: 124%;
		font-size: 1.24rem
	}

	.contact-info p {
		margin: 0 15px
	}

	.wpcf7 {
		margin-top: 60px;
		padding: 92px
	}

	.contact-form {
		letter-spacing: 1.86px;
		margin-top: 604px
	}

	.contact-form-item {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex
	}

	.contact-form-item_col1 {
		padding-left: 73px;
		width: 300px
	}

	.contact-form-item_col2 {
		width: calc(100% - 300px)
	}

	.contact-form-item .required {
		font-size: 124%;
		font-size: 1.24rem;
		padding: 6px 11px;
		top: -1px
	}

	.btn.formParts-confirm,
	button.formParts-confirm,
	input.formParts-confirm[type="button"],
	input.formParts-confirm[type="reset"],
	input.formParts-confirm[type="submit"],
	.formParts-confirm.btn-white,
	.formParts-confirm.wpcf7c-btn-back,
	.formParts-confirm.wpcf7c-btn-confirm,
	.formParts-confirm.formParts-submit {
		border-width: 3px
	}

	.btn.formParts-confirm:focus,
	button.formParts-confirm:focus,
	input.formParts-confirm:focus[type="button"],
	input.formParts-confirm:focus[type="reset"],
	input.formParts-confirm:focus[type="submit"],
	.formParts-confirm.btn-white:focus,
	.formParts-confirm.wpcf7c-btn-back:focus,
	.formParts-confirm.wpcf7c-btn-confirm:focus,
	.formParts-confirm.formParts-submit:focus {
		border-width: 3px
	}

	.btn.formParts-back,
	button.formParts-back,
	input.formParts-back[type="button"],
	input.formParts-back[type="reset"],
	input.formParts-back[type="submit"],
	.formParts-back.btn-white,
	.formParts-back.wpcf7c-btn-back,
	.formParts-back.wpcf7c-btn-confirm,
	.formParts-back.formParts-submit {
		float: left
	}

	.btn.formParts-submit,
	input.formParts-submit[type="button"],
	input.formParts-submit[type="reset"],
	input.formParts-submit[type="submit"],
	.formParts-submit {
		float: right
	}

	.wpcf7-form input[type='text'],
	.wpcf7-form input[type='email'],
	.wpcf7-form input[type='tel'],
	.wpcf7-form textarea {
		font-size: 124%;
		font-size: 1.24rem
	}

	.formParts-checkbox label {
		padding-left: 2.5em
	}

	.formParts-checkbox label:before {
		height: 28px;
		width: 28px
	}

	.formParts-checkbox .partsList-item-label:before {
		height: 4px;
		width: 15px;
		top: 12px;
		left: 2px
	}

	.formParts-checkbox .partsList-item-label:after {
		height: 4px;
		width: 21px;
		top: 10px;
		left: 9px
	}

	.wpcf7-radio .partsList-item-label:before {
		border-radius: 16px;
		margin-right: 20px;
		margin-top: -5px;
		height: 32px;
		width: 32px
	}

	.wpcf7-radio .partsList-item-label:after {
		border-radius: 8px;
		left: 8px;
		margin-top: -5px;
		height: 16px;
		top: 6px;
		width: 16px
	}

	.p-flow .page-content {
		padding-bottom: 0
	}

	.p-flow .aside-block-list ul {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		margin-top: 0.2em
	}

	.p-flow .aside-block-list li {
		width: 48%
	}

	.label-radius {
		font-size: 124%;
		font-size: 1.24rem;
		border-radius: 18px;
		border-width: 2px;
		height: 36px;
		width: 100px
	}

	.label-radius span {
		font-size: 154%;
		font-size: 1.54rem
	}

	.flow-section {
		padding-bottom: 80px
	}

	.flow-list-item {
		font-size: 139%;
		font-size: 1.39rem;
		padding-left: 80px;
		padding-bottom: 35px;
		padding-top: 20px
	}

	.flow-list-item:before {
		left: 32px;
		width: 3px
	}

	.flow-list-num {
		font-size: 231%;
		font-size: 2.31rem;
		border-width: 3px;
		height: 64px;
		width: 64px
	}

	.flow-list-heading {
		font-size: 185%;
		font-size: 1.85rem;
		margin: 0 0 25px 0
	}

	.flow-after-3m {
		border-radius: 10px;
		padding: 42px 35px 36px
	}

	.flow-after-3m:after {
		border-width: 43px 70px 0 70px;
		border-color: #263855 transparent transparent transparent;
		bottom: -43px
	}

	.flow-after-3m-heading {
		margin-bottom: 30px;
		width: 181px
	}

	.flow-after-3m-list {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: stretch;
		-ms-flex-align: stretch;
		align-items: stretch
	}

	dl.flow-after-3m-item {
		border-radius: 5px;
		margin: 5px;
		width: 300px
	}

	dl.flow-after-3m-item+dl.flow-after-3m-item {
		margin: 5px
	}

	dl.flow-after-3m-item dt {
		font-size: 200%;
		font-size: 2rem;
		line-height: 1.23;
		min-height: 200px;
		padding: 24px 0 16px
	}

	dl.flow-after-3m-item dt .label-radius {
		font-size: 124%;
		font-size: 1.24rem;
		width: 160px
	}

	dl.flow-after-3m-item dd {
		min-height: 130px
	}

	dl.flow-after-3m-item dd ul {
		font-size: 154%;
		font-size: 1.54rem
	}

	dl.flow-after-3m-item dd li {
		white-space: nowrap;
		padding-left: 0;
		width: 38%
	}

	dl.flow-after-3m-item:nth-child(2) dd li:nth-child(odd) {
		width: 48%
	}

	.flow-after-end-heading {
		font-size: 170%;
		font-size: 1.7rem;
		border-width: 4px
	}

	.flow-after-end-heading span {
		font-size: 231%;
		font-size: 2.31rem
	}

	.flow-after-end-content {
		margin-top: 24px
	}

	.flow-after-end-content p {
		font-size: 154%;
		font-size: 1.54rem
	}

	.flow-after-end-content strong {
		font-size: 293%;
		font-size: 2.93rem
	}

	.flow-after-end-content figure {
		margin-right: 29px;
		width: 102px
	}

	.page-function .page-link li {
		min-width: auto
	}

	.function-section {
		padding-bottom: 60px;
		padding-top: 15px
	}

	.function-flow-list {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}

	.function-flow-list li {
		margin: 20px
	}

	.function-flow-list li:first-child {
		max-width: 700px
	}

	.function-featured-block {
		padding-bottom: 60px
	}

	.function-featured-block:nth-child(even) {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse
	}

	.function-featured-especially {
		padding-bottom: 80px;
		padding-top: 80px
	}

	.function-featured-especially .function-featured-block {
		width: 520px
	}

	.function-featured-especially .function-featured-block:nth-child(odd) {
		margin-right: 60px
	}

	.function-featured-list li {
		background-size: 18px 14px;
		padding-left: 30px
	}

	.function-featured-text {
		margin: 0 15px;
		width: 510px
	}

	.function-featured-graph {
		margin: 0 15px;
		width: 480px
	}

	.function-effect-table-wrap {
		margin: 0 auto 60px;
		width: 1000px
	}

	.function-effect-table th {
		font-size: 139%;
		font-size: 1.39rem;
		padding: 0.8em
	}

	.function-effect-table tr>th:nth-of-type(1) {
		width: 400px
	}

	.function-effect-table td {
		font-size: 124%;
		font-size: 1.24rem;
		padding: 1.2em
	}

	.function-effect-table td+td {
		text-align: center
	}

	.function-all-list li {
		font-size: 139%;
		font-size: 1.39rem
	}

	.function-all-list li:before {
		font-size: 1.5em;
		line-height: 1.1;
		vertical-align: middle
	}

	.function-all-list .col-48p {
		width: calc(25% - 21px)
	}

	.function-all-list .col-100p {
		width: calc(75% - 7px)
	}

	.function-all-list .col-100p ul {
		margin: 0;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		height: 21em;
		width: 745px
	}

	.function-all-list .col-100p ul li {
		width: auto
	}

	.function-sample-list {
		margin: 2em auto 0;
		width: 1000px
	}

	.function-sample-list li {
		margin: 0 6px
	}

	.function-sample-list>.swiper-pagination-bullets .swiper-pagination-bullet {
		margin: 0 14px
	}

	.function-sample-list .swiper-pagination-bullet {
		height: 10px;
		width: 10px
	}

	.home-section {
		font-size: 154%;
		font-size: 1.54rem;
		line-height: 1.8;
		letter-spacing: 0.25px
	}

	.home-section_content {
		margin-left: auto;
		margin-right: auto;
		padding-bottom: 120px;
		padding-top: 110px
	}

	.home-section-heading,
	.home-section-heading-w {
		font-size: 247%;
		font-size: 2.47rem;
		letter-spacing: 2.4px;
		margin-bottom: 64px
	}

	.home-section-heading:after,
	.home-section-heading-w:after {
		margin-top: 15px
	}

	.slider-main .swiper-wrapper {
		height: 640px
	}

	.home-contact {
		background: url(../library/images/bg-home-contact-sp.jpg) center center no-repeat;
		background-size: cover;
		background-attachment: fixed;
		padding-bottom: 25px;
		padding-top: 30px;
		text-align: left
	}

	.home-contact_inner {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		margin: 0 auto;
		width: 1100px
	}

	.home-contact .col {
		padding: 20px 50px
	}

	.home-contact .col+.col {
		border-left: 1px solid #fff;
		border-top: none;
		padding: 20px 50px
	}

	.home-contact p {
		margin-bottom: 1em
	}

	.home-contact .type-info {
		-webkit-box-align: end;
		-ms-flex-align: end;
		align-items: flex-end;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		font-weight: 600;
		line-height: 1.1;
		margin: 20px 0 0
	}

	.home-contact .type-info_tel {
		font-size: 293%;
		font-size: 2.93rem;
		letter-spacing: 0.95px
	}

	.home-contact .type-info_time {
		font-size: 124%;
		font-size: 1.24rem;
		margin-bottom: 5px
	}

	.home-lead {
		font-size: 154%;
		font-size: 1.54rem
	}

	.home-lead p {
		line-height: 1.8;
		letter-spacing: 0.5px;
		margin-left: auto;
		width: 560px
	}

	.home-lead strong {
		font-size: 277%;
		font-size: 2.77rem;
		line-height: 1.5;
		letter-spacing: 0.9px
	}

	.home-lead figure {
		overflow: hidden;
		padding-left: 15px;
		width: 49%
	}

	.home-lead figure img {
		max-width: none;
		width: 736px
	}

	.home-lead-text {
		width: 51%
	}

	.home-about-list li {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		margin: 0 auto;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		padding-right: 60px;
		width: 1160px
	}

	.home-about-list li:nth-child(2n) {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse;
		padding: 0 0 0 30px
	}

	.home-about-list li:nth-child(2n) .home-about-list_text1,
	.home-about-list li:nth-child(2n) .home-about-list_text2 {
		margin-left: 0
	}

	.home-about-list li+li {
		margin-top: 100px
	}

	.home-about-list .col-1 {
		position: relative;
		width: calc(100% - 472px)
	}

	.home-about-list .col-2 {
		margin: 0 0 0 60px;
		padding: 60px 0;
		width: 412px
	}

	.home-about-list li:nth-child(2n) .col-2 {
		margin: 0 104px 0 0;
		padding: 60px 0
	}

	.home-about-list figure {
		bottom: 0;
		margin: auto;
		width: 720px;
		height: 400px;
		padding-top: 0;
		position: absolute;
		right: 0;
		top: 0
	}

	.home-about-list li:nth-child(2n) figure {
		left: 0;
		margin-right: 0;
		right: auto
	}

	.home-about-list .num {
		bottom: -30px;
		height: 218px;
		top: auto
	}

	.home-about-list .num img {
		height: 218px;
		width: auto
	}

	.home-about-list_text1 {
		font-size: 216%;
		font-size: 2.16rem;
		width: 400px
	}

	.home-about-list_text2 {
		font-size: 154%;
		font-size: 1.54rem;
		line-height: 1.5;
		letter-spacing: 0.5px;
		width: 400px
	}

	.home-service {
		padding-top: 120px
	}

	.home-service strong {
		font-size: 247%;
		font-size: 2.47rem
	}

	.home-service-list {
		margin: 0 auto;
		width: 1100px
	}

	.home-service-list li {
		min-height: 200px;
		margin: 5px 0;
		padding: 0;
		width: 360px
	}

	.home-service-list figure {
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		float: left;
		height: 100%;
		width: 95px
	}

	.home-service-list .home-service-list-text {
		overflow: hidden;
		padding: 30px 0
	}

	.home-service-list .icon-cloud {
		width: 64px;
		height: 64px
	}

	.home-service-list .icon-download {
		width: 57px;
		height: 59px
	}

	.home-service-list .icon-filelink {
		width: 56px;
		height: 72px
	}

	.home-service-list .icon-connect {
		width: 54px;
		height: 78px
	}

	.home-service-list .icon-graph {
		width: 57px;
		height: 58px
	}

	.home-service-list .icon-transfer {
		width: 65px;
		height: 64px
	}

	.home-service-list .icon-tap {
		width: 54px;
		height: 75px
	}

	.home-service-list .icon-percent {
		width: 51px;
		height: 66px
	}

	.home-service-list .icon-remote {
		width: 71px;
		height: 67px
	}

	.home-service-list .icon-drug-price {
		width: 62px;
		height: 73px
	}

	.home-service-list .icon-support {
		width: 64px;
		height: 67px
	}

	.home-service-list .icon-handy {
		width: 62px;
		height: 79px
	}

	.home-service-list_text1 {
		font-size: 154%;
		font-size: 1.54rem;
		margin-bottom: 0.5em;
		text-align: left
	}

	.home-service-list_text1.font-s {
		font-size: 139%;
		font-size: 1.39rem
	}

	.home-service-list_text2 {
		font-size: 108%;
		font-size: 1.08rem;
		line-height: 1.43;
		letter-spacing: 0.35px;
		margin-bottom: 0;
		padding: 0;
		width: 235px
	}

	.home-voice-list .swiper-wrapper {
		padding-bottom: 30px
	}

	.home-voice-item {
		border-radius: 16px;
		border-width: 4px;
		padding: 70px 70px 60px
	}

	.home-voice-item:before,
	.home-voice-item:after {
		border-width: 28px 15px 0 15px
	}

	.home-voice-item:before {
		bottom: -28px
	}

	.home-voice-item:after {
		bottom: -20px
	}

	.home-voice-item_text {
		font-size: 139%;
		font-size: 1.39rem;
		letter-spacing: 0.6px
	}

	.home-voice-item_figure {
		width: 50px;
		height: 50px
	}

	.home-voice-item_name {
		font-size: 154%;
		font-size: 1.54rem;
		letter-spacing: 0.5px;
		padding-left: 20px;
		width: calc(100% - 50px)
	}

	.home-voice-next,
	.home-voice-prev {
		left: 50%;
		height: 59px;
		width: 35px
	}

	.home-voice-prev {
		margin-left: -500px
	}

	.home-voice-next {
		margin-left: 500px;
		right: auto
	}

	.home-company-list {
		padding: 20px;
		width: 1000px
	}

	.home-company-list:after {
		display: none
	}

	.home-company-list li {
		padding: 20px 30px;
		width: auto
	}

	.home-company-list li:nth-child(1) img {
		width: 180px
	}

	.home-company-list li:nth-child(2) img {
		width: 73px
	}

	.home-company-list li:nth-child(3) img {
		width: 178px
	}

	.home-company-list li:nth-child(4) img {
		width: 128px
	}

	.home-company-list li:nth-child(5) img {
		width: 73px
	}

	.home-security {
		background-size: 525px auto;
		background-position: right 10% center
	}

	.home-security .home-section_content {
		max-width: 1100px;
		padding-left: 110px;
		padding-right: 110px
	}

	.home-security .col {
		max-width: 490px
	}

	.home-price {
		background-size: 702px auto;
		background-position: left 10% center
	}

	.home-price .home-section_content {
		max-width: 1100px;
		padding-left: 110px;
		padding-right: 110px
	}

	.home-price .col {
		margin-left: 400px;
		max-width: 490px
	}

	.home-news .article-item {
		background-position: right 40px top 23px
	}

	[class*=' flex-tab'] {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex
	}

	[class^='flex-tab'] {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex
	}

	.flex-tab-reverce {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse
	}

	.flex-tab-jc-c {
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}

	.font-l {
		font-size: 185%;
		font-size: 1.85rem
	}

	.font-m {
		font-size: 139%;
		font-size: 1.39rem
	}

	.font-n {
		font-size: 124%;
		font-size: 1.24rem
	}

	.font-s {
		font-size: 124%;
		font-size: 1.24rem
	}

	.font-tab-center {
		text-align: center
	}

	.is-sp {
		display: none !important
	}

	.mg-0 {
		margin: 0
	}

	.mg-t0 {
		margin-top: 0px
	}

	.mg-t02em {
		margin-top: 0.2em
	}

	.mg-t05em {
		margin-top: 0.5em
	}

	.mg-t1em {
		margin-top: 1em
	}

	.mg-t1-5em {
		margin-top: 1.5em
	}

	.mg-t2em {
		margin-top: 2em
	}

	.mg-t3em {
		margin-top: 3em
	}

	.mg-t4em {
		margin-top: 4em
	}

	.mg-t5em {
		margin-top: 5em
	}

	.mg-b0 {
		margin-bottom: 0px
	}

	.mg-b05em {
		margin-bottom: 0.5em
	}

	.mg-b1em {
		margin-bottom: 1em
	}

	.mg-b2em {
		margin-bottom: 2em
	}

	.mg-b3em {
		margin-bottom: 3em
	}

	.mg-b4em {
		margin-bottom: 4em
	}

	.mg-b5em {
		margin-bottom: 5em
	}

	.mg-b6em {
		margin-bottom: 6em
	}

	.mg-center {
		margin-left: auto;
		margin-right: auto
	}

	.mg-right {
		margin-right: 0;
		margin-left: auto
	}

	.mg-left {
		margin-right: auto;
		margin-left: 0
	}

	.mg-tab-t0 {
		margin-top: 0px
	}

	.mg-tab-t1em {
		margin-top: 0.8em
	}

	.mg-tab-t2em {
		margin-top: 1.6em
	}

	.mg-tab-t3em {
		margin-top: 2.4em
	}

	.mg-tab-t4em {
		margin-top: 3.2em
	}

	.mg-tab-t5em {
		margin-top: 1.6em
	}

	.mg-tab-b0 {
		margin-bottom: 0px
	}

	.mg-tab-b05em {
		margin-bottom: 0.4em
	}

	.mg-tab-b1em {
		margin-bottom: 0.8em
	}

	.mg-tab-b2em {
		margin-bottom: 1.6em
	}

	.mg-tab-b3em {
		margin-bottom: 2.4em
	}

	.mg-tab-b4em {
		margin-bottom: 3.2em
	}

	.mg-tab-b5em {
		margin-bottom: 4em
	}

	.mg-tab-b6em {
		margin-bottom: 4.8em
	}

	.mg-tab-center {
		margin-left: auto;
		margin-right: auto
	}

	.mg-tab-center {
		margin-left: auto;
		margin-right: auto
	}

	.mg-tab-center {
		margin-left: auto;
		margin-right: auto
	}

	.shadow {
		-webkit-box-shadow: 20.1px 24.9px 56.4px 5.6px rgba(53, 54, 53, 0.4);
		box-shadow: 20.1px 24.9px 56.4px 5.6px rgba(53, 54, 53, 0.4)
	}
}

@media only screen and (max-width: 767px) {
	.breadcrumb {
		font-size: 93%;
		font-size: .93rem;
		padding: 0 20px
	}
	.breadcrumb li+li:before {
		font-size: 11px
	}
	.breadcrumb .icon-home {
		font-size: 11px
	}
	.btn-small {
		font-size: 100%;
		font-size: 1rem;
		padding: 13px 15px
	}
	.gmap {
		height: 0;
		padding-top: 70%
	}
	.grid-col2>.col,
	.grid-col2>img {
		max-width: none;
		width: 100%
	}
	.grid-col2>.col+.col,
	.grid-col2>img+.col {
		margin-top: 1em
	}
	.grid-col3 img {
		max-width: calc(48% - 0.5em)
	}
	.grid-col3:before,
	.grid-col3:after {
		max-width: 48%
	}
	.grid-col4 img {
		max-width: calc(48% - 0.5em)
	}
	.grid-col4:before,
	.grid-col4:after {
		max-width: calc(48% - 0.5em)
	}
	.label,
	.label-news {
		font-size: 93%;
		font-size: .93rem;
		min-width: 0
	}
	.tab-category,
	.tab-category-col3,
	.tab-category-main {
		width: 100%
	}
	.tab-category:after,
	.tab-category-col3:after,
	.tab-category-main:after {
		content: '';
		display: inline-block;
		max-width: 241px;
		margin: 2px;
		width: calc(50% - 4px)
	}
	.tab-category li,
	.tab-category-col3 li,
	.tab-category-main li {
		margin: 2px;
		width: calc(50% - 4px)
	}
	.tab-category_item {
		height: 40px
	}
	.tab-category-main {
		border-width: 1px;
		margin-bottom: 1.5em;
		padding: 0
	}
	.tab-category-main:after {
		content: none
	}
	.tab-category-main li {
		margin-bottom: 0
	}
	.table tr {
		border-top: 1px solid #e6e6e6
	}
	.table th {
		border-bottom: 1px solid #e6e6e6;
		padding: 1em 0;
		width: 30%
	}
	.table td {
		line-height: normal
	}
	.table-dark {
		font-size: 100%;
		font-size: 1rem;
		border-top: 1px solid #e6e6e6
	}
	.table-dark tr:first-child th {
		min-width: 100px;
		padding: 5px 10px
	}
	.table-dark td {
		line-height: normal;
		padding: 5px 10px
	}
	.table-wrap {
		overflow-x: scroll;
		width: 100%
	}
	.table-wrap table th,
	.table-wrap table td {
		white-space: nowrap
	}
	._navOpen .header:before {
		opacity: 1;
		visibility: visible;
		-webkit-transition: opacity 0.6s, visibility 0.3s, z-index 0.3s;
		transition: opacity 0.6s, visibility 0.3s, z-index 0.3s;
		z-index: 9999;
		width: 100%
	}
	._navOpen .header-hamburger_line:before {
		bottom: 0;
		top: 0;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: bottom 0.3s, -webkit-transform 0.3s;
		transition: bottom 0.3s, -webkit-transform 0.3s;
		transition: transform 0.3s, bottom 0.3s;
		transition: transform 0.3s, bottom 0.3s, -webkit-transform 0.3s;
		-webkit-transition-delay: 0.3s, 0s;
		transition-delay: 0.3s, 0s
	}
	._navOpen .header-hamburger_line span {
		left: 50%;
		-webkit-transition-delay: 0.3s;
		transition-delay: 0.3s;
		width: 0
	}
	._navOpen .header-hamburger_line:after {
		bottom: 0;
		top: 0;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		-webkit-transition: top 0.3s, -webkit-transform 0.3s;
		transition: top 0.3s, -webkit-transform 0.3s;
		transition: transform 0.3s, top 0.3s;
		transition: transform 0.3s, top 0.3s, -webkit-transform 0.3s;
		-webkit-transition-delay: 0.3s, 0s;
		transition-delay: 0.3s, 0s
	}
	._navOpen .header-main {
		height: auto;
		max-height: calc(100vh - 60px);
		overflow: scroll;
		opacity: 1;
		visibility: visible;
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
		-webkit-transition: opacity 0.8s, -webkit-transform 0.5s;
		transition: opacity 0.8s, -webkit-transform 0.5s;
		transition: opacity 0.8s, transform 0.5s;
		transition: opacity 0.8s, transform 0.5s, -webkit-transform 0.5s;
		-webkit-transition-delay: 0.3s;
		transition-delay: 0.3s
	}
	.slider-main .slide-text img {
		max-height: none;
		-o-object-fit: contain;
		object-fit: contain;
		left: 0;
		position: absolute;
		top: 0;
		width: 100%
	}
	[data-inview="faderight"] {
		-webkit-transform: translateY(20px);
		transform: translateY(20px)
	}
	[data-inview="faderight"]._inview {
		-webkit-transform: translateY(0);
		transform: translateY(0)
	}
	[data-inview="fadeleft"] {
		-webkit-transform: translateY(20px);
		transform: translateY(20px)
	}
	[data-inview="fadeleft"]._inview {
		-webkit-transform: translateY(0);
		transform: translateY(0)
	}
	.is-tab {
		display: none !important
	}
	.mg-sp-t0 {
		margin-top: 0px
	}

	.mg-sp-t1em {
		margin-top: 0.8em
	}

	.mg-sp-t2em {
		margin-top: 1.6em
	}

	.mg-sp-t3em {
		margin-top: 2.4em
	}

	.mg-sp-t4em {
		margin-top: 3.2em
	}

	.mg-sp-t5em {
		margin-top: 1.6em
	}

	.mg-sp-b0 {
		margin-bottom: 0px
	}

	.mg-sp-b05em {
		margin-bottom: 0.4em
	}

	.mg-sp-b1em {
		margin-bottom: 0.8em
	}

	.mg-sp-b2em {
		margin-bottom: 1.6em
	}

	.mg-sp-b3em {
		margin-bottom: 2.4em
	}

	.mg-sp-b4em {
		margin-bottom: 3.2em
	}

	.mg-sp-b5em {
		margin-bottom: 4em
	}

	.mg-sp-b6em {
		margin-bottom: 4.8em
	}

	.mg-sp-center {
		margin-left: auto;
		margin-right: auto
	}

	.mg-sp-center {
		margin-left: auto;
		margin-right: auto
	}
}

@media screen and (max-width: 800px) and (orientation: landscape),
screen and (max-height: 300px) {
	.mfp-img-mobile .mfp-image-holder {
		padding-left: 0;
		padding-right: 0
	}

	.mfp-img-mobile img.mfp-img {
		padding: 0
	}

	.mfp-img-mobile .mfp-figure:after {
		top: 0;
		bottom: 0
	}

	.mfp-img-mobile .mfp-figure small {
		display: inline;
		margin-left: 5px
	}

	.mfp-img-mobile .mfp-bottom-bar {
		background: rgba(0, 0, 0, 0.6);
		bottom: 0;
		margin: 0;
		top: auto;
		padding: 3px 5px;
		position: fixed;
		-webkit-box-sizing: border-box;
		box-sizing: border-box
	}

	.mfp-img-mobile .mfp-bottom-bar:empty {
		padding: 0
	}

	.mfp-img-mobile .mfp-counter {
		right: 5px;
		top: 3px
	}

	.mfp-img-mobile .mfp-close {
		top: 0;
		right: 0;
		width: 35px;
		height: 35px;
		line-height: 35px;
		background: rgba(0, 0, 0, 0.6);
		position: fixed;
		text-align: center;
		padding: 0
	}
}

@media all and (max-width: 900px) {
	.mfp-arrow {
		-webkit-transform: scale(0.75);
		transform: scale(0.75)
	}

	.mfp-arrow-left {
		-webkit-transform-origin: 0;
		transform-origin: 0
	}

	.mfp-arrow-right {
		-webkit-transform-origin: 100%;
		transform-origin: 100%
	}

	.mfp-container {
		padding-left: 6px;
		padding-right: 6px
	}
}

@media only screen and (max-width: 1029px) {
	.is-pc {
		display: none !important
	}
}

@media print {
	@page {
		size: A4 landscape;
		margin: 0
	}

	body,
	.container {
		min-width: 287mm
	}

	.grecaptcha-badge,
	.is-sp {
		display: none !important
	}

	[data-inview="cover"] {
		opacity: 1 !important
	}

	[data-inview="cover"]:before {
		display: none !important
	}

	[data-inview="cover"] [data-inview-child="fadeup"] {
		opacity: 1 !important;
		-webkit-transform: translateY(0) !important;
		transform: translateY(0) !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="imgfadein"] {
		opacity: 1 !important
	}

	[data-inview="imgfadein"] img {
		opacity: 1 !important;
		-webkit-transform: scale(1) !important;
		transform: scale(1) !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="fade"] {
		opacity: 1 !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="fadeup"] {
		opacity: 1 !important;
		-webkit-transform: translateY(0px) !important;
		transform: translateY(0px) !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="faderight"] {
		opacity: 1 !important;
		-webkit-transform: translateX(0px) !important;
		transform: translateX(0px) !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="fadeleft"] {
		opacity: 1 !important;
		-webkit-transform: translateX(0px) !important;
		transform: translateX(0px) !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="opacity"] {
		opacity: 1 !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="clip-path"] {
		-webkit-clip-path: inset(0 0 0 0) !important;
		clip-path: inset(0 0 0 0) !important;
		opacity: 1 !important;
		-webkit-transition: none !important;
		transition: none !important
	}

	[data-inview="clip-path"] [data-inview-child="faderight"] {
		opacity: 1 !important;
		-webkit-transform: translateX(0) !important;
		transform: translateX(0) !important;
		-webkit-transition: none !important;
		transition: none !important
	}
}
