@charset "UTF-8";
.wrapper {
	position: relative;
	width: 100%;
	max-width: 960px;
	margin: 0 auto; }
	@media screen and (max-width: 1200px) {
		.wrapper {
			width: 100%;
			max-width: 920px; } }
	@media screen and (max-width: 960px) {
		.wrapper {
			width: 95%; } }
	@media screen and (max-width: 768px) {
		.wrapper {
			width: 90%; } }

.col1 {
	margin-bottom: 20px;
	width: calc(100% / 1 - calc(20px * calc(1 - 1) / 1)); }
	.col1:nth-child(1) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col1 {
			width: 100%;
			margin-right: 0; } }
	.col1 img {
		width: 100%; }

.col2 {
	margin-bottom: 20px;
	width: calc(100% / 2 - calc(20px * calc(2 - 1) / 2)); }
	.col2:nth-child(2) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col2 {
			width: 100%;
			margin-right: 0; } }
	.col2 img {
		width: 100%; }

.col3 {
	margin-bottom: 20px;
	width: calc(100% / 3 - calc(20px * calc(3 - 1) / 3)); }
	.col3:nth-child(3) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col3 {
			width: 100%;
			margin-right: 0; } }
	.col3 img {
		width: 100%; }

.col4 {
	margin-bottom: 20px;
	width: calc(100% / 4 - calc(20px * calc(4 - 1) / 4)); }
	.col4:nth-child(4) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col4 {
			width: 100%;
			margin-right: 0; } }
	.col4 img {
		width: 100%; }

.col5 {
	margin-bottom: 20px;
	width: calc(100% / 5 - calc(20px * calc(5 - 1) / 5)); }
	.col5:nth-child(5) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col5 {
			width: 100%;
			margin-right: 0; } }
	.col5 img {
		width: 100%; }

.col6 {
	margin-bottom: 20px;
	width: calc(100% / 6 - calc(20px * calc(6 - 1) / 6)); }
	.col6:nth-child(6) {
		margin-right: 0; }
	@media screen and (max-width: 768px) {
		.col6 {
			width: 100%;
			margin-right: 0; } }
	.col6 img {
		width: 100%; }

@keyframes humb {
	100% {
		background: rgba(0, 0, 0, 0); } }
@keyframes scaleOut {
	100% {
		transform: scale(0);
		opacity: 0; } }
@keyframes pageTransition {
	100% {
		transform: translateX(0); } }
@keyframes pageFadeout {
	100% {
		opacity: 0; } }
@keyframes scaleIn {
	0% {
		transform: scale(0); }
	100% {
		transform: scale(1);
		opacity: 1; } }
@keyframes fadeIn {
	0% {
		opacity: 0; }
	100% {
		opacity: 1; } }
@keyframes slideIn {
	0% {
		transform: translate(0, 100%); }
	100% {
		transform: translate(0, 0); } }
@keyframes slideOut {
	0% {
		transform: translate(0, 0); }
	2% {
		transform: translate(1%, 1%); }
	10% {
		transform: translate(1%, 1%); }
	50% {
		transform: translate(50%, 50%); }
	100% {
		transform: translate(100%, 70%);
		opacity: 0; } }
@keyframes curtainEffect {
	0% {
		transform-origin: left center;
		transform: scaleX(0); }
	49.999% {
		transform-origin: left center;
		transform: scaleX(1); }
	50% {
		transform-origin: right center;
		transform: scaleX(1); }
	100% {
		transform-origin: right center;
		transform: scaleX(0); } }
@keyframes loading {
	0% {
		left: -10%; }
	50% {
		width: 120%; }
	99.9999999% {
		width: 0%;
		left: 110%;
		opacity: 1; }
	100% {
		opacity: 0;
		visibility: hidden; } }
.fx {
	opacity: 0;
	visibility: hidden;
	backface-visibility: hidden; }
	.fx .fxBox {
		opacity: 0;
		-webkit-transform: translate(0, 90px);
		transform: translate(0, 90px);
		backface-visibility: hidden;
		will-change: transform; }
	.fx .cols {
		-webkit-transform: translate(0, 0);
		transform: translate(0, 0); }
		.fx .cols .fxInr {
			opacity: 0;
			-webkit-transform: translate(0, 90px);
			transform: translate(0, 90px);
			backface-visibility: hidden;
			will-change: transform; }
	.fx .left {
		-webkit-transform: translate(50px, 0);
		transform: translate(50px, 0);
		backface-visibility: hidden;
		opacity: 0;
		will-change: transform; }
	.fx.on {
		opacity: 1;
		-webkit-transition: ease 2s 0s;
		transition: ease 2s 0s;
		visibility: visible;
		backface-visibility: visible; }
		.fx.on .left {
			backface-visibility: hidden;
			opacity: 0;
			will-change: transform;
			-webkit-transform: translate(0, 0);
			transform: translate(0, 0);
			-webkit-transition: ease 1s 0s;
			transition: ease 1s 0s; }
		.fx.on .fxBox {
			opacity: 1;
			-webkit-transform: translate(0, 0);
			transform: translate(0, 0);
			backface-visibility: hidden;
			opacity: 0;
			will-change: transform; }
		.fx.on .cols .fxInr {
			opacity: 1;
			backface-visibility: hidden;
			will-change: transform;
			-webkit-transform: translate(0, 0);
			transform: translate(0, 0);
			-webkit-transition: ease 2s 0.6s;
			transition: ease 2s 0.6s; }
			.fx.on .cols .fxInr:nth-child(1) {
				-webkit-transition: ease-out 0.6s 0.1s;
				transition: ease-out 0.6s 0.1s; }
			.fx.on .cols .fxInr:nth-child(2) {
				-webkit-transition: ease-out 0.6s 0.3s;
				transition: ease-out 0.6s 0.3s; }
			.fx.on .cols .fxInr:nth-child(3) {
				-webkit-transition: ease-out 0.6s 0.5s;
				transition: ease-out 0.6s 0.5s; }
			.fx.on .cols .fxInr:nth-child(4) {
				-webkit-transition: ease-out 0.6s 0.7s;
				transition: ease-out 0.6s 0.7s; }
			.fx.on .cols .fxInr:nth-child(5) {
				-webkit-transition: ease-out 0.6s 0.9s;
				transition: ease-out 0.6s 0.9s; }
			.fx.on .cols .fxInr:nth-child(6) {
				-webkit-transition: ease-out 0.6s 1.1s;
				transition: ease-out 0.6s 1.1s; }
			.fx.on .cols .fxInr:nth-child(7) {
				-webkit-transition: ease-out 0.6s 1.3s;
				transition: ease-out 0.6s 1.3s; }
			.fx.on .cols .fxInr:nth-child(8) {
				-webkit-transition: ease-out 0.6s 1.5s;
				transition: ease-out 0.6s 1.5s; }
			.fx.on .cols .fxInr:nth-child(9) {
				-webkit-transition: ease-out 0.6s 1.7s;
				transition: ease-out 0.6s 1.7s; }
			.fx.on .cols .fxInr:nth-child(10) {
				-webkit-transition: ease-out 0.6s 1.9s;
				transition: ease-out 0.6s 1.9s; }
			.fx.on .cols .fxInr:nth-child(11) {
				-webkit-transition: ease-out 0.6s 2.1s;
				transition: ease-out 0.6s 2.1s; }
			.fx.on .cols .fxInr:nth-child(12) {
				-webkit-transition: ease-out 0.6s 2.3s;
				transition: ease-out 0.6s 2.3s; }
			.fx.on .cols .fxInr:nth-child(13) {
				-webkit-transition: ease-out 0.6s 2.5s;
				transition: ease-out 0.6s 2.5s; }
			.fx.on .cols .fxInr:nth-child(14) {
				-webkit-transition: ease-out 0.6s 2.7s;
				transition: ease-out 0.6s 2.7s; }
			.fx.on .cols .fxInr:nth-child(15) {
				-webkit-transition: ease-out 0.6s 2.9s;
				transition: ease-out 0.6s 2.9s; }
			.fx.on .cols .fxInr:nth-child(16) {
				-webkit-transition: ease-out 0.6s 3.1s;
				transition: ease-out 0.6s 3.1s; }
			.fx.on .cols .fxInr:nth-child(17) {
				-webkit-transition: ease-out 0.6s 3.3s;
				transition: ease-out 0.6s 3.3s; }
			.fx.on .cols .fxInr:nth-child(18) {
				-webkit-transition: ease-out 0.6s 3.5s;
				transition: ease-out 0.6s 3.5s; }
			.fx.on .cols .fxInr:nth-child(19) {
				-webkit-transition: ease-out 0.6s 3.7s;
				transition: ease-out 0.6s 3.7s; }
			.fx.on .cols .fxInr:nth-child(20) {
				-webkit-transition: ease-out 0.6s 3.9s;
				transition: ease-out 0.6s 3.9s; }
			.fx.on .cols .fxInr:nth-child(21) {
				-webkit-transition: ease-out 0.6s 4.1s;
				transition: ease-out 0.6s 4.1s; }
			.fx.on .cols .fxInr:nth-child(22) {
				-webkit-transition: ease-out 0.6s 4.3s;
				transition: ease-out 0.6s 4.3s; }
			.fx.on .cols .fxInr:nth-child(23) {
				-webkit-transition: ease-out 0.6s 4.5s;
				transition: ease-out 0.6s 4.5s; }
			.fx.on .cols .fxInr:nth-child(24) {
				-webkit-transition: ease-out 0.6s 4.7s;
				transition: ease-out 0.6s 4.7s; }
			.fx.on .cols .fxInr:nth-child(25) {
				-webkit-transition: ease-out 0.6s 4.9s;
				transition: ease-out 0.6s 4.9s; }
			.fx.on .cols .fxInr:nth-child(26) {
				-webkit-transition: ease-out 0.6s 5.1s;
				transition: ease-out 0.6s 5.1s; }
			.fx.on .cols .fxInr:nth-child(27) {
				-webkit-transition: ease-out 0.6s 5.3s;
				transition: ease-out 0.6s 5.3s; }
			.fx.on .cols .fxInr:nth-child(28) {
				-webkit-transition: ease-out 0.6s 5.5s;
				transition: ease-out 0.6s 5.5s; }
			.fx.on .cols .fxInr:nth-child(29) {
				-webkit-transition: ease-out 0.6s 5.7s;
				transition: ease-out 0.6s 5.7s; }
			.fx.on .cols .fxInr:nth-child(30) {
				-webkit-transition: ease-out 0.6s 5.9s;
				transition: ease-out 0.6s 5.9s; }

/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
	box-sizing: border-box;
	border-style: solid;
	border-width: 0; }

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
	line-height: 1.15;
	/* 1 */
	-webkit-text-size-adjust: 100%;
	/* 2 */
	-webkit-tap-highlight-color: transparent;
	/* 3*/ }

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block; }

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
	margin: 0; }

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	font-weight: inherit;
	margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt {
	font-weight: bold; }

dd {
	margin-left: 0; }

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	/* 1 */
	height: 0;
	/* 1 */
	overflow: visible;
	/* 2 */
	border-top-width: 1px;
	margin: 0;
	clear: both;
	color: inherit; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	/* 1 */
	font-size: inherit;
	/* 2 */ }

address {
	font-style: inherit; }

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
	text-decoration: none;
	color: inherit; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	text-decoration: underline dotted;
	/* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	/* 1 */
	font-size: inherit;
	/* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline; }

sub {
	bottom: -0.25em; }

sup {
	top: -0.5em; }

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
	vertical-align: bottom; }

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none;
	/* 1 */
	appearance: none;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	background: transparent;
	padding: 0;
	margin: 0;
	border-radius: 0;
	text-align: inherit;
	text-transform: inherit;
	/* 2 */ }

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type="checkbox"] {
	-webkit-appearance: checkbox;
	appearance: checkbox; }

[type="radio"] {
	-webkit-appearance: radio;
	appearance: radio; }

/**
 * Correct cursors for clickable elements.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	cursor: pointer; }

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
	cursor: default; }

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
	outline: auto; }

select:disabled {
	opacity: inherit; }

/**
 * Remove padding
 */
option {
	padding: 0; }

/**
 * Reset to invisible
 */
fieldset {
	margin: 0;
	padding: 0;
	min-width: 0; }

legend {
	padding: 0; }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto; }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto; }

/**
 * 1. Correct the outline style in Safari.
 */
[type="search"] {
	outline-offset: -2px;
	/* 1 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	/* 1 */
	font: inherit;
	/* 2 */ }

/**
 * Clickable labels
 */
label[for] {
	cursor: pointer; }

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item; }

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
	outline: auto; }

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
	border-color: inherit;
	/* 1 */ }

caption {
	text-align: left; }

td,
th {
	vertical-align: top;
	padding: 0; }

th {
	text-align: left;
	font-weight: bold; }

html {
	scroll-behavior: smooth; }
	html body.login-password-protected {
		grid-template-columns: inherit;
	}
	html body {
		box-sizing: border-box;
		position: relative;
		font-family: "Alata", "Noto Sans JP", serif;
		font-size: 16px;
		display: grid;
		grid-template-columns: 240px 1fr;
		background-color: #f7f6e9;
		color: #312a2a; }
		html body header {
			grid-column: 1 / 2;
			width: 240px; }
			@media screen and (max-width: 768px) {
				html body header {
					grid-column: 1 / 3;
					width: 100% !important;
					transition: all .2s;
				}
				html body.nav-fix header {
					background: linear-gradient( #fff, rgba( 255, 255, 255, .85 ) 8%, rgba( 255, 255, 255, 0 ) 16% ); }
				}
		html body main {
			grid-column: 2 / 2; }
			@media screen and (max-width: 1200px) {
				html body main {
					grid-column: 1 / 3; }
				html body header {
					grid-column: 1 / 2;
					width: 240px;
					pointer-events: none; }
				html body #navInput:checked ~ header {
					pointer-events: auto;
				}

			}
		html body footer {
			grid-column: 2 / 2; }
			@media screen and (max-width: 1200px) {
				html body footer {
					grid-column: 1 / 3; } }

a:hover {
	opacity: 0.8; }

.btnArea {
	text-align: center;
	width: 100%; }
	.btnArea a {
		position: relative;
		display: block;
		width: 38.5%;
		margin: 0 auto;
		background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
		border-radius: 30px;
		padding: 19px;
		font-size: 1.25rem;
		font-weight: 500;
		color: white;
		text-align: center;
		letter-spacing: .7px; }
	.btnArea a:hover {
		opacity: 1;
		box-shadow: 0 5px 10px rgba( 0, 0, 0, .2 );
	}
		@media screen and (max-width: 768px) {
			.btnArea a {
				width: 100%;
				border-radius: 50px; } }
		.btnArea a::after {
			content: url("../images/common/arrow_white.png");
			position: absolute;
			right: 30px;
			top: 50%;
			-webkit-transform: translateY(-50%);
			transform: translateY(-50%);
			line-height: .5;
			transition: all .2s; }
		.btnArea a:hover::after {
			right: 25px;
		}

.ttlWrap {
	text-align: center;
	position: relative;
	margin-bottom: 20px; }
	.ttlWrap .ttl_en {
		display: block;
		font-size: 20px;
		color: #22ac38;
		margin-bottom: 8px;
		letter-spacing: 2.2px; }
		@media screen and (max-width: 768px) {
			.ttlWrap .ttl_en {
				font-size: 1rem;
				letter-spacing: 1px;
			}
		}
	.ttlWrap h1, .ttlWrap h2 {
		color: #312a2a !important;
		font-size: 2.625rem;
		font-weight: bold;
		line-height: 1.5; }
		@media screen and (max-width: 768px) {
			.ttlWrap h1, .ttlWrap h2 {
				font-size: 1.75rem; } }
	.ttlWrap.green .ttl_en {
		color: #22ac38; }
	.ttlWrap.green h1:first-letter, .ttlWrap.green h2:first-letter {
		color: #22ac38; }
	.ttlWrap.orange .ttl_en {
		color: #fa931e; }
	.ttlWrap.orange h1:first-letter, .ttlWrap.orange h2:first-letter {
		color: #fa931e; }
	.ttlWrap.mei {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column; }
		.ttlWrap.mei::before {
			content: "";
			background: url("../images/common/logo_illust.svg");
			width: 77px;
			height: 95px;
			margin-bottom: 14px;
			background-size: contain; }
			@media screen and (max-width: 768px) {
				.ttlWrap.mei::before {
					width: 53px;
					height: 66px;
					margin-bottom: 2px;
				}
			}
	.ttlWrap.column {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column; }
		.ttlWrap.column::before {
			background: url("../images/home/column.png");
			content: "";
			width: 167px;
			height: 79px;
			background-size: contain; }
			@media screen and (max-width: 768px) {
				.ttlWrap.column::before {
					width: 111px;
					height: 52px; } }
	.ttlWrap.uline::after {
		display: block;
		width: 100%;
		height: 15px;
		content: "";
		background-image: url(../images/common/hr_line.gif);
		background-repeat: repeat-x;
		margin-top: 20px; }
	.ttlWrap.ulineDot::after {
		display: block;
		width: 100%;
		height: 3px;
		content: "";
		background-image: url(../images/common/hr_dot.gif);
		background-repeat: repeat-x;
		margin-top: 40px; }

.red {
	color: #ec4326; }

.orange {
	color: #fa931e; }

.green {
	color: #22ac38; }

.blue-green {
	color: #22a791; }

#blogList {
	margin-bottom: 35px; }
	#blogList a {
		border-radius: 10px;
		width: 300px;
		margin: 10px 15px;
		box-shadow: 0px 0px s15px -5px #312a2a; }
	#blogList a:hover {
		opacity: 1;
		box-shadow: 0 0 10px rgba( 0, 0, 0, .2 );
	}
		#blogList a .blogThmb {
			position: relative;
		}
		#blogList a .blogThmb img {
			width: 100%;
			height: 225px;
			object-fit: cover;
			border-radius: 10px 10px 0 0; }
		#blogList a .blogThmb .shadow {
			position: absolute;
			height: 20px;
			right: 0;
			bottom: 0;
			left: 0;
			background: linear-gradient( rgba( 0, 0, 0, 0 ), rgba( 0, 0, 0, .05 ) );
		}
		#blogList a .blogInfo {
			background-color: white;
			border-radius: 0 0 10px 10px;
			padding: 37px 30px 32px;
			position: relative; }
			.catName {
				box-sizing: border-box;
				position: absolute;
				top: -11px;
				left: 0;
				display: flex;
				justify-content: center;
				align-items: center;
				font-size: 0.875rem;
				padding: 10px 15px 10px 19px;
				height: 32px;
				color: white;
				background: #22ac38; }
				.catName > span {
					position: relative;
					z-index: 3;
					font-weight: 500; }
				.catName::before {
					content: '';
					position: absolute;
					top: 0;
					right: 0;
					bottom: 0;
					left: 0;
					z-index: 2;
					background: #22ac38; }
				.catName::after {
					display: block;
					content: '';
					position: absolute;
					top: 0;
					right: -10.8px;
					border-top: 16px solid #22ac38;
					border-bottom: 16px solid #22ac38;
					border-right: 10.8px solid transparent;
					border-left: 10.8px solid transparent; }
				.catName.a::before {
					background: #22ac38; }
					.catName.a::after {
						border-top: 16px solid #22ac38;
						border-bottom: 16px solid #22ac38;
						border-right: 10.8px solid transparent;
						border-left: 10.8px solid transparent; }
				.catName.b::before {
					background: #299fdb; }
					.catName.b::after {
						border-top: 16px solid #299fdb;
						border-bottom: 16px solid #299fdb;
						border-right: 10.8px solid transparent;
						border-left: 10.8px solid transparent; }
				.catName.c::before {
					background: #ec4326; }
					.catName.c::after {
						border-top: 16px solid #ec4326;
						border-bottom: 16px solid #ec4326;
						border-right: 10.8px solid transparent;
						border-left: 10.8px solid transparent; }
				.catName.d::before {
					background: #fa931e; }
					.catName.d::after {
						border-top: 16px solid #fa931e;
						border-bottom: 16px solid #fa931e;
						border-right: 10.8px solid transparent;
						border-left: 10.8px solid transparent; }
				.catName.mei::before {
					background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%); }
					.catName.mei::after {
						border-top: 16px solid #299fdb;
						border-bottom: 16px solid #299fdb;
						border-right: 10.8px solid transparent;
						border-left: 10.8px solid transparent;
						z-index: 1; }
				.catName .shadow {
					content: '';
					height: 1px;
					position: absolute;
					right: -9px;
					bottom: 0;
					left: 0;
					box-shadow: 0 1px 2px rgba( 0, 0, 0, .5 ); }
			#blogList a .blogInfo .date {
				color: #999999;
				display: block;
				margin-bottom: 10px; }
			#blogList a .blogInfo .title {
				font-size: 1.125rem;
				font-weight: bold;
				line-height: 1.7;
				-js-display: flex;
				 display: -ms-flex;
				 display: -webkit-flex;
				 display: flex;
				 align-items: center; }

/* Scss Document */
article #keyVisual {
	width: 100%;
	position: relative;
	margin-bottom: 30px; }
	article #keyVisual #kv {
		width: 100%;
		height: 306px;
		background-position: bottom center;
		background-repeat: no-repeat;
		background-size: cover;
		display: flex;
		justify-content: center;
		align-items: center; }
		@media screen and (max-width: 768px) {
			article #keyVisual #kv {
				height: 260px; } }
		article #keyVisual #kv .ttlWrapTop {
			text-align: center;
			position: relative;
			margin-bottom: 20px; }
			article #keyVisual #kv .ttlWrapTop .ttl_en {
				display: block;
				font-size: 1.5rem;
				color: white;
				margin-bottom: 5px;
				letter-spacing: 0.1rem; }
			article #keyVisual #kv .ttlWrapTop h1,
			article #keyVisual #kv .ttlWrapTop .h1 {
				color: white;
				font-size: 3rem;
				font-weight: bold;
				line-height: 1.5;
				letter-spacing: 0.3rem; }
		article #keyVisual #kv::before, article #keyVisual #kv::after {
			content: "";
			background-repeat: no-repeat;
			background-position: center center;
			background-size: contain;
			position: absolute;
			z-index: -1;
			bottom: -130px; }
		article #keyVisual #kv::after {
			bottom: -138px;
		}
			@media screen and (max-width: 768px) {
				article #keyVisual #kv::before, article #keyVisual #kv::after {
					bottom: -50px; } }
		article #keyVisual #kv::before {
			background-image: url("../images/pages/kv_l.png");
			width: 456px;
			height: 380px;
			left: 10px; }
			@media screen and (max-width: 768px) {
				article #keyVisual #kv::before {
					width: 137px;
					height: 114px;
					left: 10px; } }
		article #keyVisual #kv::after {
			background-image: url("../images/pages/kv_r.png");
			width: 426px;
			height: 481px;
			right: 0; }
			@media screen and (max-width: 768px) {
				article #keyVisual #kv::after {
					width: 128px;
					height: 149px;
					right: 0; } }
	article #keyVisual #bredCrumb {
		padding-top: 22px; }
		/*
		article #keyVisual #bredCrumb ul {
			display: flex;
			justify-content: flex-start;
			align-items: center; }
			article #keyVisual #bredCrumb ul li {
				font-size: 0.95rem;
				white-space: nowrap; }
				article #keyVisual #bredCrumb ul li a {
					text-decoration: underline;
					color: #22ac38; }
				article #keyVisual #bredCrumb ul li::after {
					content: ">";
					margin: 0 10px; }
				article #keyVisual #bredCrumb ul li:last-child {
					overflow: hidden;
					text-overflow: ellipsis;
				}
				article #keyVisual #bredCrumb ul li:last-child::after {
					content: none; }
		*/
article #contents {
	margin-bottom: 120px; }
article#company #keyVisual #kv {
	background-image: url("../images/company/kv.png"); }
	@media screen and (max-width: 768px) {
		article#company #keyVisual #kv {
			background-image: url("../images/company/kv_sp.png?ud=202002"); } }
article#company .wrapper__company {
	padding-top: 30px;
}
article#company #massageArea {
	box-sizing: border-box;
	display: flex;
	/*padding: 65px 70px 85px;*/
	padding: 50px 70px 60px;
	background-color: white;
	border-radius: 10px;
	position: relative;
	margin-top: 80px;
	margin-bottom: 170px; }
	@media screen and (max-width: 768px) {
		article#company .wrapper__company {
			padding-top: 0;
		}
		article#company #massageArea {
			flex-direction: column;
			padding: 20px;
			margin-bottom: 50px; } }
	article#company #massageArea .thmb {
		position: absolute;
		top: -50px;
		left: -115px; }
		article#company #massageArea .thmb img {
			width: 100%; }
		@media screen and (max-width: 768px) {
			article#company #massageArea .thmb {
				position: relative;
				top: auto;
				left: auto;
				margin-bottom: 20px; } }
	article#company #massageArea .txt {
		padding: 0 0 0 265px; }
		@media screen and (max-width: 768px) {
			article#company #massageArea .txt {
				padding: 0 0 0 0; } }
		article#company #massageArea .txt h3 {
			font-size: 2rem;
			font-weight: bold;
			line-height: 1.5;
			margin-bottom: 20px; }
			@media screen and (max-width: 768px) {
				article#company #massageArea .txt h3 {
					font-size: 1.25rem; } }
		article#company #massageArea .txt p {
			font-size: 1rem;
			line-height: 2.5;
			letter-spacing: 0.015rem;
			text-align: justify; }
		article#company #massageArea .txt .name {
			width: 100%;
			display: block;
			text-align: right;
			margin-top: 35px;
			padding-right: 5px; }
	article#company #massageArea::after {
		content: "MESSAGE";
		position: absolute;
		font-size: 6.25rem;
		font-weight: 400;
		color: #22ac38;
		left: -46px;
		bottom: -40px;
		letter-spacing: 4.2px; }
		@media screen and (max-width: 768px) {
			article#company #massageArea::after {
				font-size: 12vw;
				left: 50%;
				bottom: auto;
				top: -30px;
				-webkit-transform: translateX(-50%);
				transform: translateX(-50%); } }
article#company #companyInfo {
	margin-bottom: 50px;
	width: 100%;
	background-image: url(../images/common/hr_dot.gif);
	background-repeat: repeat-x;
	background-position: center top;
	margin-top: 40px; }
	article#company #companyInfo table {
		border-collapse: collapse;
		width: 100%; }
		article#company #companyInfo table tr {
			border-bottom: 1px dotted #312a2a; }
			@media screen and (max-width: 768px) {
				article#company #companyInfo table tr {
					display: block;
					text-align: left;
					padding: 20px 0 0 0; } }
			article#company #companyInfo table tr th, article#company #companyInfo table tr td {
				padding: 33px 0 33px 40px;
				line-height: 2.2;
				letter-spacing: 0.1rem; }
				@media screen and (max-width: 768px) {
					article#company #companyInfo table tr th, article#company #companyInfo table tr td {
						display: block;
						width: 100%;
						text-align: left;
						padding: 0 0 10px 0; } }
			article#company #companyInfo table tr th {
				width: 195px; }
			article#company #companyInfo table tr td {
				position: relative;
				padding-left: 0; }
				article#company #companyInfo table tr td a.btn {
					position: relative;
					display: block;
					width: 100%;
					margin: 0 auto;
					padding: 5px 10px;
					background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
					border-radius: 50px;
					font-size: 0.875rem;
					color: white;
					text-align: center;
					letter-spacing: 0.05rem; }
					article#company #companyInfo table tr td a.btn::before {
						content: url("../images/common/blank.png");
						display: inline-block;
						margin-right: 10px; }
				article#company #companyInfo table tr td.flex {
					display: flex;
					flex-wrap: wrap; }
					@media screen and (max-width: 768px) {
						article#company #companyInfo table tr td.flex {
							flex-direction: column; } }
					article#company #companyInfo table tr td.flex .colsLeft {
						width: 60%; }
						@media screen and (max-width: 768px) {
							article#company #companyInfo table tr td.flex .colsLeft {
								width: 100%; } }
					article#company #companyInfo table tr td.flex .colsRight {
						width: 28%; }
						@media screen and (max-width: 768px) {
							article#company #companyInfo table tr td.flex .colsRight {
								width: 100%; } }
					article#company #companyInfo table tr td.flex .tbInr {
						width: 50%;
						margin-bottom: 30px; }
						@media screen and (max-width: 768px) {
							article#company #companyInfo table tr td.flex .tbInr {
								width: 100%; } }
						article#company #companyInfo table tr td.flex .tbInr span {
							font-weight: bold; }
						article#company #companyInfo table tr td.flex .tbInr ul {
							padding: 0 0 0 20px; }
							article#company #companyInfo table tr td.flex .tbInr ul li {
								list-style: disc;
								margin-bottom: 5px; }
article#about #greenAdventure {
	margin-bottom: 92px;
	padding-top: 2px; }
article#about #sdgsList {
	background-color: white;
	padding: 20px 0; }
	article#about #sdgsList ul {
		width: 100%;
		max-width: 1190px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between; }
		article#about #sdgsList ul li {
			width: 123px; }
			article#about #sdgsList ul li img {
				width: 100%; }

.bnrArea a {
	display: block; }
	.bnrArea a img {
		width: 100%; }

#feature {
	position: relative; }
	@media screen and (max-width: 479px) {
		#feature {
			min-height: 80vh; } }
	#feature #keyVisual h1 {
		position: absolute;
		top: 30.6%;
		right: 0;
		left: 0;
		text-align: center; }
		#feature #keyVisual h1 img {
			width: 53.8vw; }
			@media screen and (max-width: 768px) {
				#feature #keyVisual h1 img {
					width: 90vw; } }
	#feature #keyVisual #imgArea img {
		width: 100%; }
		#feature #keyVisual #imgArea img.pc {
			display: block; }
			@media screen and (max-width: 479px) {
				#feature #keyVisual #imgArea img.pc {
					display: none; } }
		#feature #keyVisual #imgArea img.sp {
			display: none; }
			@media screen and (max-width: 479px) {
				#feature #keyVisual #imgArea img.sp {
					display: block; } }
	#feature #headLine {
		position: absolute;
		right: 0;
		bottom: 20%;
		display: flex;
		width: 60.5%; }
		@media screen and (max-width: 479px) {
			#feature #headLine {
				height: auto;
				width: 90%;
				bottom: 15%; } }
		#feature #headLine h1 {
			padding: 20px 0 20px 10px;
			font-size: 1.1rem;
			color: white;
			background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
			font-weight: normal;
			border-radius: 30px 0 0 30px;
			letter-spacing: 0.1rem;
			display: flex;
			justify-content: center;
			align-items: center;
			width: 17%; }
			@media screen and (max-width: 768px) {
				#feature #headLine h1 {
					border-radius: 50px 0 0 50px;
					width: 23%; } }
		#feature #headLine .info-slide {
			width: 83%;
			display: flex;
			opacity: 0;
			background: #fff;
		}
		#feature #headLine .info-slide.slick-slider {
			display: block;
			opacity: 1;
		}
		#feature #headLine a {
			background-color: white;
			padding: 20px 40px 20px 25px;
			position: relative;
			display: flex;
			flex-direction: row;
			flex-wrap: nowrap;
			align-items: center;
		}
		#feature #headLine a:hover {
			opacity: 1;
		}
		#feature #headLine a .title {
			overflow: hidden;
			white-space: nowrap;
			text-overflow: ellipsis;
			border-top: solid 1px transparent;
			border-bottom: solid 1px transparent;
			transition: all .2s;
		}
		#feature #headLine a:hover .title {
			color: #22ac38;
			border-bottom: solid 1px #22ac38;
		}
			@media screen and (max-width: 768px) {
				#feature #headLine .info-slide {
					width: 77%;
				}
				#feature #headLine a {
					flex-wrap: wrap } }
			#feature #headLine a::after {
				display: block;
				width: 11px;
				height: 18px;
				content: '';
				background: url( ../images/common/arrow.png ) center center / contain no-repeat;
				position: absolute;
				right: 22px;
				top: 50%;
				display: block;
				-webkit-transform: translateY(-50%);
				transform: translateY(-50%);
				transition: all .2s; }
			#feature #headLine a:hover::after {
				right: 17px;
			}
			#feature #headLine a .date {
				font-size: 0.95rem;
				color: #22ac38;
				margin-right: 40px; }
				@media screen and (max-width: 479px) {
					#feature #headLine a .date {
						font-size: 0.875rem;
						padding-right: 0;
						margin-bottom: 5px; } }
			@media screen and (max-width: 768px) {
				#feature #headLine a .title {
					font-size: 0.875rem;
					padding-right: 0;
					letter-spacing: 1px; } }

#memoryArea {
	margin-top: -115px;
	margin-bottom: 90px; }
	@media screen and (max-width: 479px) {
		#memoryArea {
			margin-top: 0; } }
	#memoryArea .ttlWrap .ttl_en {
		color: #22ac38; }
	#memoryArea .ttlWrap h1:first-letter {
		color: #22ac38; }

#memoryArea.wrapper {
	max-width: 990px;
}

#aboutArea {
	position: relative; }
	#aboutArea .abThmb {
		position: absolute;
		top: -20px;
		right: 0; }
		@media screen and (max-width: 768px) {
			#aboutArea .abThmb {
				position: relative;
				padding-left: 5%; } }
		#aboutArea .abThmb img {
			width: 41vw;
			max-width: 800px;
			right: 0; }
			@media screen and (max-width: 768px) {
				#aboutArea .abThmb img {
					width: 100%;
					max-width: none; } }
	#aboutArea .abInr {
		padding-top: 80px;
		width: 50%;
		margin-bottom: 300px; }
		@media screen and (max-width: 768px) {
			#aboutArea .abInr {
				width: 100%;
				margin-bottom: 100px; } }
		#aboutArea .abInr .ttlWrap {
			text-align: left; }
			@media screen and (max-width: 768px) {
				#aboutArea .abInr .ttlWrap {
					text-align: center; } }
			#aboutArea .abInr .ttlWrap .ttl_en {
				color: #fa931e; }
			#aboutArea .abInr .ttlWrap h1 {
				letter-spacing: -0.15rem; }
				#aboutArea .abInr .ttlWrap h1:first-letter {
					color: #fa931e; }
		#aboutArea .abInr p {
			line-height: 2.4;
			margin-bottom: 40px;
			letter-spacing: 0.1rem; }
			@media screen and (max-width: 768px) {
				#aboutArea .abInr p {
					font-size: 0.875rem;
					line-height: 2; } }
		#aboutArea .abInr .btnArea {
			text-align: left; }
			@media screen and (max-width: 768px) {
				#aboutArea .abInr .btnArea {
					text-align: center; } }
			#aboutArea .abInr .btnArea a {
				width: 78%;
				font-weight: normal;
				margin: 0; }
				@media screen and (max-width: 768px) {
					#aboutArea .abInr .btnArea a {
						width: 90%;
						margin: 0 auto; } }
		#aboutArea .abInr::after {
			content: "";
			background: url("../images/home/about_bg.png");
			background-size: contain;
			width: 541px;
			height: 382px;
			position: absolute;
			left: -320px;
			bottom: -200px;
			z-index: -1; }
			@media screen and (max-width: 768px) {
				#aboutArea .abInr::after {
					width: 270px;
					height: 191px;
					left: -90px;
					bottom: -50px; } }

#profArea {
	padding-top: 25px;
	margin-bottom: 50px; }
	#profArea .ttlWrap {
		width: 100%;
		margin-bottom: 50px; }
		#profArea .ttlWrap h1 {
			font-size: 2.25rem; }
			@media screen and (max-width: 768px) {
				#profArea .ttlWrap h1 {
					font-size: 1.5rem; } }
			#profArea .ttlWrap h1:first-letter {
				color: #febb3f; }
	#profArea #relationMapArea {
		margin: 0 auto;
		max-width: 900px; }
		@media screen and (max-width: 768px) {
			#profArea #relationMapArea {
				width: 605px;
				text-align: center;
				padding-bottom: 20px; } }
		#profArea #relationMapArea img {
			width: 100%; }

#youtubeArea {
	width: 100%;
	position: relative;
	padding-bottom: 200px; }
	@media screen and (max-width: 768px) {
		#youtubeArea {
			padding-bottom: 100px; } }
	#youtubeArea .ttlWrap {
		width: 100%;
		margin-bottom: 60px; }
		#youtubeArea .ttlWrap h1 {
			display: inline;
			font-size: 2.25rem;
			vertical-align: text-bottom; }
			#youtubeArea .ttlWrap h1 img {
				width: 201px;
				height: 45px; }
			@media screen and (max-width: 768px) {
				#youtubeArea .ttlWrap h1 {
					font-size: 1.5rem; }
					#youtubeArea .ttlWrap h1 img {
						width: 135px;
						height: 30px; } }
			#youtubeArea .ttlWrap h1 span {
				margin-left: 10px; }
	@media screen and (max-width: 768px) {
		#youtubeArea #pWrap {
			width: 90%;
			margin: 0 auto; } }
	#youtubeArea #pWrap #ytPlayer {
		width: calc( 50% + 10px );
		position: absolute;
		padding-bottom: 25%;
		/* 56.25% / width */
		padding-top: 30px;
		height: 0;
		overflow: hidden;
		margin-bottom: 2rem;
		border-radius: 10px; }
		@media screen and (max-width: 768px) {
			#youtubeArea #pWrap #ytPlayer {
				width: 100%;
				max-width: none;
				position: relative;
				padding-bottom: 56.25%; } }
		#youtubeArea #pWrap #ytPlayer iframe {
			position: absolute;
			top: 0;
			left: 0;
			width: 100%;
			height: 100%; }
	#youtubeArea #ytInr {
		position: relative;
		padding-top: 46px;
		z-index: -1; }
	#youtubeArea #pWrap + #ytInr {
		padding-left: 558px;
	}
		@media screen and (max-width: 1200px) {
			#youtubeArea #pWrap + #ytInr {
				padding-left: 50%; } }
		@media screen and (max-width: 768px) {
			#youtubeArea #pWrap + #ytInr {
				padding-left: 0; } }
		#youtubeArea #ytInr h2 {
			font-size: 1.75rem;
			font-weight: bold;
			margin-bottom: 16px;
			line-height: 1.7; }
			@media screen and (max-width: 768px) {
				#youtubeArea #ytInr h2 {
					text-align: center;
					font-size: 1.25rem; } }
		#youtubeArea #ytInr p {
			line-height: 2.4;
			letter-spacing: 1.6px;
			text-align: justify; }
		#youtubeArea #ytInr::before {
			content: url("../images/home/yt_bg.png");
			position: absolute;
			display: block;
			top: 22%;
			left: 21%;
			z-index: -1; }
			@media screen and (max-width: 768px) {
				#youtubeArea #ytInr::before {
					top: -90%;
					left: auto;
					right: -10px; } }

#contactArea {
	background-image: url("../images/home/contact_bg.png");
	background-size: contain;
	background-position: center top;
	background-repeat: no-repeat;
	text-align: center;
	position: relative;
	margin: 0 auto 100px auto;
	box-sizing: border-box; }
	@media screen and (max-width: 960px) {
		#contactArea {
			background-image: url("../images/home/contact_bg.png");
			background-size: cover;
			background-position: center top;
			margin: 0 auto 200px auto; } }
	@media screen and (max-width: 768px) {
		#contactArea {
			min-height: 700px; } }
	#contactArea .cWrapper {
		max-width: 1041px;
		min-height: 626px;
		margin: 0 auto; }
		@media screen and (max-width: 1200px) {
			#contactArea .cWrapper {
				max-width: 960px; } }
		@media screen and (max-width: 960px) {
			#contactArea .cWrapper {
				width: 90%; } }
	#contactArea .ttlWrap {
		width: 100%; }
		#contactArea .ttlWrap h1 {
			font-size: 2.25rem;
			color: white !important; }
			@media screen and (max-width: 768px) {
				#contactArea .ttlWrap h1 {
					font-size: 1.75rem; } }
			@media screen and (max-width: 768px) {
				#contactArea .ttlWrap h1 .sp {
					display: none; } }
	#contactArea #contactWrap {
		margin: 0 auto;
		text-align: center;
		width: 65%;
		position: relative; }
		#contactArea #contactWrap::before {
			content: "";
			background-image: url("../images/home/contact_bg_side.png");
			background-size: contain;
			background-repeat: no-repeat;
			position: absolute;
			left: -70%;
			top: -10%;
			z-index: -1;
			width: 535px;
			height: 498px; }
			@media screen and (max-width: 768px) {
				#contactArea #contactWrap::before {
					top: auto;
					left: -50px;
					bottom: -223px;
					width: 267px;
					height: 249px; } }
			@media screen and (max-width: 479px) {
				#contactArea #contactWrap::before {
					top: auto;
					left: -50px;
					bottom: -223px;
					width: 267px;
					height: 249px; } }
		#contactArea #contactWrap::after {
			content: "";
			background-image: url("../images/home/contact_bg_sp.png");
			position: absolute;
			background-size: contain;
			background-repeat: no-repeat;
			right: -100px;
			bottom: -95px;
			width: 211px;
			height: 299px; }
			@media screen and (max-width: 768px) {
				#contactArea #contactWrap::after {
					right: -5%;
					bottom: -223px;
					width: 157px;
					height: 223px; } }
			@media screen and (max-width: 479px) {
				#contactArea #contactWrap::after {
					right: -5%;
					bottom: -223px;
					width: 157px;
					height: 223px; } }
		@media screen and (max-width: 960px) {
			#contactArea #contactWrap {
				width: 90%; } }
		@media screen and (max-width: 768px) {
			#contactArea #contactWrap {
				width: 100%; } }
		#contactArea #contactWrap p {
			display: block;
			line-height: 2.2;
			text-align: center;
			color: white;
			margin-bottom: 35px; }
		#contactArea #contactWrap #telAreaw {
			background-color: rgba(49, 42, 42, 0.3);
			width: 378px;
			padding: 25px 20px;
			border-radius: 10px;
			margin: 0 auto 20px auto;
			display: block; }
			@media screen and (max-width: 960px) {
				#contactArea #contactWrap #telAreaw {
					width: 100%;
					padding: 20px; } }
			#contactArea #contactWrap #telAreaw a {
				display: block;
				font-size: 2.25rem;
				letter-spacing: -1.3px;
				margin-bottom: -2px;
				color: white;
			}
			#contactArea #contactWrap #telAreaw a span {
				display: inline-block;
				transform: translateY( -6% );
			}
				@media screen and (max-width: 768px) {
					#contactArea #contactWrap #telAreaw a {
						font-size: 2.0rem; }
					#contactArea #contactWrap p {
					text-align: left; } }
				#contactArea #contactWrap #telAreaw a::before {
					display: inline-block;
					content: url("../images/home/tel.png");
					margin: 0 0 0 5px; }
				#contactArea #contactWrap #telAreaw a:hover {
					opacity: 0.8; }
			#contactArea #contactWrap #telAreaw p {
				font-family: 'Noto Sans JP', serif;
				font-size: 15px;
				text-align: center;
				letter-spacing: 1.4px;
				margin: 0;
			}
				@media screen and (max-width: 768px) {
					#contactArea #contactWrap #telAreaw p {
						font-size: 1rem; } }
		#contactArea #contactWrap .btnArea a {
			width: 372px; }
			@media screen and (max-width: 768px) {
				#contactArea #contactWrap .btnArea a {
					width: 100%; } }

#columnArea {
	width: 100%;
	margin-bottom: 120px; }
	#columnArea .ttlWrap .ttl_en {
		color: #22a791; }
	#columnArea .ttlWrap h1:first-letter {
		color: #22a791; }
	#columnArea .leadTxt {
		text-align: center;
		line-height: 2.2;
		margin-bottom: 30px; }
	#columnArea #columnList {
		background-image: url("../images/common/hr_dot.gif");
		background-repeat: repeat-x;
		background-position: center top;
		padding-top: 30px;
		margin-bottom: 50px; }
		@media screen and (max-width: 768px) {
			#columnArea #columnList {
				padding-top: 0; } }
		#columnArea #columnList a {
			width: 100%;
			display: flex;
			background-image: url("../images/common/hr_dot.gif");
			background-repeat: repeat-x;
			background-position: center bottom;
			padding: 33px 0; }
			#columnArea #columnList a .blogThmb {
				width: 31.3%;
				position: relative; }
				@media screen and (max-width: 768px) {
					#columnArea #columnList a .blogThmb {
						width: 45%; } }
				#columnArea #columnList a .blogThmb img {
					width: 100%;
					height: 225px;
					border-radius: 10px;
					object-fit: cover;
					border-radius: 10px; }
				#columnArea #columnList a .blogThmb .catName {
					box-sizing: border-box;
					position: absolute;
					top: 10px;
					left: 0;
					display: flex;
					justify-content: center;
					align-items: center;
					font-size: 0.875rem;
					padding: 10px 15px 10px 20px;
					height: 32px;
					color: white; }
					#columnArea #columnList a .blogThmb .catName::after {
						display: block;
						content: '';
						position: absolute;
						top: 0;
						right: -10.5px;
						border-top: 16px solid #22ac38;
						border-bottom: 16px solid #22ac38;
						border-right: 10.5px solid transparent;
						border-left: 10.5px solid transparent; }
					#columnArea #columnList a .blogThmb .catName.news::before {
						background: #ec4326; }
						#columnArea #columnList a .blogThmb .catName.news::after {
							border-top: 16px solid #ec4326;
							border-bottom: 16px solid #ec4326;
							border-right: 10.5px solid transparent;
							border-left: 10.5px solid transparent; }
			#columnArea #columnList a .blogInfo {
				box-sizing: border-box;
				width: 60%;
				padding: 50px;
				position: relative;
				padding: 0 0 15px 3.9%;
				display: flex;
				flex-direction: column;
				justify-content: center;
				align-items: flex-start; }
				@media screen and (max-width: 768px) {
					#columnArea #columnList a .blogInfo {
						width: 55%;
						padding: 0 0 5px 18px; }
					#columnArea #columnList a .blogThmb img {
						height: 30vw;
					}
					#columnArea #columnList a .blogInfo .more::before {
						width: 15px;
						height: 15px;
						transform: translateY( 0 );
					} }
				#columnArea #columnList a .blogInfo .date {
					color: #d9d9d9;
					display: block;
					margin-bottom: 12px; }
				#columnArea #columnList a .blogInfo .title {
					font-size: 1.5rem;
					font-weight: bold;
					line-height: 1.6;
					letter-spacing: 1.6px;
					margin-bottom: 16px; }
				#columnArea #columnList a .blogInfo .more {
					color: #22ac38;
					letter-spacing: 1.6px;
					text-decoration: underline; }
					#columnArea #columnList a .blogInfo .more::before {
						display: inline-block;
						content: '';
						background: url( ../images/common/list_icon.gif ) center center / contain no-repeat;
						width: 17px;
						height: 17px;
						margin-right: 6px;
						transform: translateY( 2px ); }
			#columnArea #columnList a:hover {
				opacity: 0.75; }
	#columnArea .bnrArea {
		margin-top: 60px; }
		#columnArea .bnrArea img {
			width: 100%; }

header {
	padding: 27px 0 0 0;
	background-color: white;
	position: fixed;
	top: 0;
	min-height: 100vh;
	z-index: 99999; }
	@media screen and (max-width: 1200px) {
		header {
			padding: 0 0 0 0;
			text-align: left;
			background-color: transparent;
			backface-visibility: hidden;
			/*pointer-events: none; */ } }
	header h1 {
		margin-bottom: 20px; }
		@media screen and (max-width: 1200px) {
			header h1 {
				z-index: 999999;
				position: fixed;
				height: 70px;
				pointer-events: auto; } }
		header h1 a {
			display: flex;
			flex-direction: column;
			justify-content: center;
			align-items: center; }
			@media screen and (max-width: 1200px) {
				header h1 a {
					flex-direction: row;
					justify-content: flex-start;
					padding: 10px 0 0 15px; } }
			@media screen and (max-width: 479px) {
				header h1 a {
					flex-direction: row;
					justify-content: flex-start;
					padding: 20px 0 0 15px; } }
			header h1 a img#vi {
				width: 58px;
				margin-bottom: 8px; }
				@media screen and (max-width: 1200px) {
					header h1 a img#vi {
						width: auto;
						height: 40px;
						margin: 0;
						margin: 0 5px 0 0; } }
				@media screen and (max-width: 479px) {
					header h1 a img#vi {
						height: 35px; } }
			header h1 a img#txt {
				width: 208px; }
				@media screen and (max-width: 1200px) {
					header h1 a img#txt {
						width: auto;
						height: 25px; } }
				@media screen and (max-width: 479px) {
					header h1 a img#txt {
						width: auto;
						height: 20px; } }
			@media screen and (max-width: 1200px) {
				#navInput:checked ~ header h1 a {
					display: flex;
					flex-direction: column;
					justify-content: center;
					align-items: center;
					margin-bottom: 10px; } }
			@media screen and (max-width: 768px) {
				#navInput:checked ~ header h1 a {
					flex-direction: row;
					justify-content: flex-start;
					padding: 10px 0 0 15px; } }
			@media screen and (max-width: 479px) {
				#navInput:checked ~ header h1 a {
					flex-direction: row;
					justify-content: flex-start;
					padding: 20px 0 0 15px; } }
			@media screen and (max-width: 1200px) {
				#navInput:checked ~ header h1 a img#vi {
					width: 60px;
					margin-bottom: 10px; } }
			@media screen and (max-width: 768px) {
				#navInput:checked ~ header h1 a img#vi {
					width: auto;
					height: 40px;
					margin: 0 5px 0 0; } }
			@media screen and (max-width: 479px) {
				#navInput:checked ~ header h1 a img#vi {
					height: 35px; } }
			@media screen and (max-width: 1200px) {
				#navInput:checked ~ header h1 a img#txt {
					width: 210px; } }
			@media screen and (max-width: 768px) {
				#navInput:checked ~ header h1 a img#txt {
					width: auto;
					height: 25px; } }
			@media screen and (max-width: 479px) {
				#navInput:checked ~ header h1 a img#txt {
					width: auto;
					height: 20px; } }
	@media screen and (max-width: 1200px) {
		header #gNavArea {
			display: flex;
			flex-direction: column;
			opacity: 0;
			backface-visibility: hidden;
			padding-top: 130px;
			-webkit-transition: ease 0.5s 0s;
			transition: ease 0.5s 0s;
			pointer-events: none; }
			#navInput:checked ~ header #gNavArea {
				opacity: 1;
				backface-visibility: visible;
				pointer-events: auto; }
				#navInput:checked ~ header #gNavArea::before {
					content: "";
					width: 240px;
					height: 100vh;
					position: fixed;
					background-color: white;
					z-index: -1;
					top: 0; } }
			@media screen and (max-width: 1200px) and (max-width: 768px) {
				#navInput:checked ~ header #gNavArea::before {
					width: 100%; } }

	@media screen and (max-width: 768px) {
		header #gNavArea {
			padding-top: 70px;
			flex-direction: row;
			flex-wrap: wrap; } }
	@media screen and (max-width: 768px) {
		header #gNavArea #snsNav {
			order: 4;
			width: 50%; }
			header #gNavArea #snsNav ul {
				justify-content: flex-start; }
		header #gNavArea #globalMenu {
			order: 1;
			width: 100%;
			margin-bottom: 0; }
		nav#globalMenu::before, nav#globalMenu::after {
			display: none;
		}
		header #gNavArea #telArea {
			order: 2;
			width: 100%; }
		header #gNavArea #bannerArea {
			order: 3;
			width: 100%; }
		header #gNavArea #egaoArea {
			order: 5;
			width: 50%;
			text-align: right; } }
	header #telFixArea {
		background-color: #54a734;
		display: none;
		position: fixed;
		width: 100%;
		bottom: 0;
		left: 0;
		padding: 5%; }
		@media screen and (max-width: 768px) {
			#navInput:checked ~ header #telFixArea {
				display: flex; } }
		header #telFixArea #telBtn {
			width: 60%;
			font-size: 0.8125rem;
			display: flex;
			color: white;
			justify-content: flex-start;
			align-items: center; }
			header #telFixArea #telBtn::before {
				background: url("../images/menu/tel_fix.png");
				content: "";
				width: 40px;
				height: 40px;
				background-position: center center;
				background-size: contain;
				margin-right: 10px; }
		header #telFixArea #snsNavFix {
			width: 40%; }
			header #telFixArea #snsNavFix ul {
				display: flex;
				justify-content: space-around;
				padding: 0; }
				header #telFixArea #snsNavFix ul li {
					padding: 0 0; }
					header #telFixArea #snsNavFix ul li a img {
						width: 80%; }

#navInput {
	display: none; }

@media screen and (max-width: 1200px) {
	#navDrawer {
		z-index: 99999999999999999999999999999;
		position: fixed;
		box-sizing: border-box;
		display: block;
		text-align: right;
		top: 10px;
		right: 10px;
		width: 55px;
		height: 55px;
		background: linear-gradient(180deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
		border-radius: 50%;
		pointer-events: auto; }
		#navDrawer #humb {
			position: relative;
			display: block;
			width: 55px;
			height: 55px;
			background-image: linear-gradient(to right, white, white);
			background-position: center center;
			background-repeat: no-repeat;
			background-size: 23px 2px; }
			#navDrawer #humb:before, #navDrawer #humb:after {
				width: 23px;
				height: 2px;
				margin: auto;
				background-color: white;
				display: block;
				position: absolute;
				left: 0;
				right: 0;
				content: '';
				-webkit-transition: 0.2s 0s ease;
				transition: 0.2s 0s ease; }
			#navDrawer #humb:before {
				top: 18px; }
			#navDrawer #humb:after {
				bottom: 18px; }
			#navInput:checked ~ header #navDrawer #humb {
				-webkit-animation: humb 0.1s forwards;
				animation: humb 0.1s forwards; }
				#navInput:checked ~ header #navDrawer #humb:before, #navInput:checked ~ header #navDrawer #humb:after {
					background-color: white; }
				#navInput:checked ~ header #navDrawer #humb:before {
					-webkit-transform: translateX(0) translateY(9px) rotate(-45deg);
					transform: translateX(0) translateY(9px) rotate(-45deg); }
				#navInput:checked ~ header #navDrawer #humb:after {
					-webkit-transform: translateX(0) translateY(-9px) rotate(45deg);
					transform: translateX(0) translateY(-9px) rotate(45deg); } }

#snsNav {
	margin-bottom: 20px;
	width: 100%; }
	@media screen and (max-width: 768px) {
		#snsNav {
			padding-left: 5%; } }
	#snsNav ul {
		display: flex;
		justify-content: center; }
		#snsNav ul li {
			padding: 0 5px; }
			#snsNav ul li a span {
				display: block; }
			#snsNav ul li a:hover {
				opacity: 0.8; }

nav#globalMenu {
	margin-bottom: 25px;
	padding-top: 25px;
	border-top: 1px dotted #999999;
	border-bottom: 1px dotted #999999; }
	@media screen and (max-width: 1200px) {
		nav#globalMenu {
			margin-bottom: 30px;
			padding-top: 10px; } }
	@media screen and (max-width: 768px) {
		nav#globalMenu {
			border-top: none;
			border-bottom: none; } }
	nav#globalMenu ul {
		padding-left: 13px; }
		@media screen and (max-width: 768px) {
			nav#globalMenu ul {
				display: flex;
				flex-direction: row;
				flex-wrap: wrap;
				justify-content: space-around;
				padding-left: 0;
				width: 90%;
				margin: 0 auto; } }
		nav#globalMenu ul li {
			margin-bottom: 22px;
			transition: all .2s; }
			@media screen and (max-width: 768px) {
				nav#globalMenu ul li {
					width: 33.33333%; } }
			nav#globalMenu ul li a {
				font-size: 0.86rem;
				font-weight: 700;
				display: block;
				position: relative;
				padding-left: 48px;
				line-height: 1.7;
				letter-spacing: 0.005rem; }
				nav#globalMenu ul li a:hover {
					opacity: 0.8; }
				nav#globalMenu ul li a .sp {
					display: none; }
					@media screen and (max-width: 768px) {
						nav#globalMenu ul li a .sp {
							display: block; } }
				@media screen and (max-width: 768px) {
					nav#globalMenu ul li a {
						display: flex;
						flex-direction: column;
						align-items: center;
						padding: 0;
						text-align: center;
						line-height: 1.2; } }
				nav#globalMenu ul li a span {
					display: block;
					font-size: 0.6rem;
					font-weight: normal;
					letter-spacing: 0.1rem; }
					@media screen and (max-width: 768px) {
						nav#globalMenu ul li a span {
							display: none; } }
				nav#globalMenu ul li a::before {
					content: "";
					display: block;
					position: absolute;
					left: 0;
					width: 35px;
					height: 35px;
					background-size: contain;
					background-repeat: no-repeat; }
					@media screen and (max-width: 768px) {
						nav#globalMenu ul li a::before {
							position: relative;
							left: auto;
							width: 19vw;
							height: 19vw; } }
				nav#globalMenu ul li a.to_top span {
					color: #ec4326; }
				nav#globalMenu ul li a.to_top::before {
					background-image: url("../images/menu/top.svg"); }
				nav#globalMenu ul li a.to_about span {
					color: #fa931e; }
				nav#globalMenu ul li a.to_about::before {
					background-image: url("../images/menu/about.svg"); }
				nav#globalMenu ul li a.to_profile span {
					color: #febb3f; }
				nav#globalMenu ul li a.to_profile::before {
					background-image: url("../images/menu/profile.svg"); }
				nav#globalMenu ul li a.to_memory span {
					background-image: #22ac38; }
				nav#globalMenu ul li a.to_memory::before {
					background-image: url("../images/menu/memory.svg"); }
				nav#globalMenu ul li a.to_column span {
					color: #22a791; }
				nav#globalMenu ul li a.to_column::before {
					background-image: url("../images/menu/column.svg"); }
				nav#globalMenu ul li a.to_company span {
					color: #299fdb; }
				nav#globalMenu ul li a.to_company::before {
					background-image: url("../images/menu/company.svg"); }
nav#footerNav {
	background-image: url("../images/common/hr_dot.gif");
	background-repeat: repeat-x;
	background-position: center bottom;
	margin-bottom: 20px; }
	nav#footerNav.wrapper {
		width: 100% !important; }
	nav#footerNav h2 {
		text-align: left;
		font-size: 1.25rem;
		background-color: #f7f6e9;
		position: relative;
		text-align: left;
		padding: 10px; }
		@media screen and (max-width: 768px) {
			nav#footerNav h2 {
				font-weight: bold;
				letter-spacing: 0.1rem; } }
		nav#footerNav h2::before {
			position: absolute;
			display: block;
			content: "";
			background-image: url("../images/common/hr_dot.gif");
			background-repeat: repeat-x;
			width: 90%;
			height: 2px;
			top: 50%;
			right: 0; }
			@media screen and (max-width: 768px) {
				nav#footerNav h2::before {
					content: none; } }
	nav#footerNav ul {
		padding: 30px 0 20px 0;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		text-align: left; }
		@media screen and (max-width: 768px) {
			nav#footerNav ul {
				background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
				padding: 3px 0 3px 0; } }
		nav#footerNav ul li {
			margin-bottom: 10px;
			width: 33%; }
			@media screen and (max-width: 768px) {
				nav#footerNav ul li {
					width: 100%;
					background: white;
					margin: 0;
					border-bottom: 1px solid #d9d9d9; } }
			nav#footerNav ul li a {
				font-size: 0.9375rem;
				display: block;
				position: relative;
				padding-left: 45px;
				display: flex;
				align-items: center; }
				@media screen and (max-width: 768px) {
					nav#footerNav ul li a {
						font-size: 1.125rem;
						padding: 30px; } }
				nav#footerNav ul li a:hover {
					opacity: 0.8; }
				nav#footerNav ul li a::before {
					content: "";
					display: block;
					margin-right: 20px;
					width: 36px;
					height: 36px;
					background-size: contain;
					background-repeat: no-repeat; }
			nav#footerNav ul li ul {
				display: block;
				padding: 10px 0 0 60px; }
				@media screen and (max-width: 768px) {
					nav#footerNav ul li ul {
						padding: 0; } }
				nav#footerNav ul li ul li {
					width: 100%;
					margin-bottom: 11px;
					border-bottom: none; }
					@media screen and (max-width: 768px) {
						nav#footerNav ul li ul li {
							margin-bottom: 0;
							border-top: 1px solid #d9d9d9; } }
					@media screen and (max-width: 768px) {
						nav#footerNav ul li ul li a {
							margin-bottom: 0;
							padding: 30px 30px 30px 80px; } }
					nav#footerNav ul li ul li a::before {
						content: "" !important;
						width: 10px;
						height: 2px;
						margin-right: 10px; }
			nav#footerNav ul li.to_top a::before {
				background-image: url("../images/menu/top.png"); }
			nav#footerNav ul li.to_top ul li a::before {
				background-image: linear-gradient(to right, #ec4326, #ec4326); }
			nav#footerNav ul li.to_about a::before {
				background-image: url("../images/menu/about.png"); }
			nav#footerNav ul li.to_about ul li a::before {
				background-image: linear-gradient(to right, #fa931e, #fa931e); }
			nav#footerNav ul li.to_profile a::before {
				background-image: url("../images/menu/profile.png"); }
			nav#footerNav ul li.to_profile ul li a::before {
				background-image: linear-gradient(to right, #febb3f, #febb3f); }
			nav#footerNav ul li.to_memory a::before {
				background-image: url("../images/menu/memory.png"); }
			nav#footerNav ul li.to_memory ul li a::before {
				background-image: linear-gradient(to right, #22ac38, #22ac38); }
			nav#footerNav ul li.to_column a::before {
				background-image: url("../images/menu/column.png"); }
			nav#footerNav ul li.to_column ul li a::before {
				background-image: linear-gradient(to right, #22a791, #22a791); }
			nav#footerNav ul li.to_company a::before {
				background-image: url("../images/menu/company.png"); }
			nav#footerNav ul li.to_company ul li a::before {
				background-image: linear-gradient(to right, #22ac38, #22ac38); }

#telArea {
	text-align: center;
	margin-bottom: 20px; }
	@media screen and (max-width: 768px) {
		#telArea {
			border: 2px solid #22ac38;
			margin: 0 20px 20px 20px;
			padding: 20px 20px;
			border-radius: 10px; } }
	#telArea a {
		display: block;
		font-size: 1.5rem;
		margin-bottom: 5px;
		letter-spacing: -0.05rem; }
		@media screen and (max-width: 768px) {
			#telArea a {
				font-size: 1.75rem; } }
		#telArea a::before {
			display: inline-block;
			content: url("../images/menu/tel.png"); }
			@media screen and (max-width: 768px) {
				#telArea a::before {
					margin-right: 0; } }
		#telArea a:hover {
			opacity: 0.8; }
	#telArea p {
		font-size: 0.70rem;
		letter-spacing: 0.05rem; }
		@media screen and (max-width: 768px) {
			#telArea p {
				font-size: 0.875rem; } }

#bannerArea {
	padding: 0 20px;
	width: 100%;
	margin-bottom: 0; }
	#bannerArea a {
		margin-bottom: 10px;
		text-align: center; }
		#bannerArea a img {
			display: block;
			margin: 0 auto; }
		#bannerArea a.grad {
			position: relative;
			display: block;
			width: 100%;
			padding: 3px;
			font-size: 0.85rem;
			border-radius: 10px;
			color: white;
			background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%); }
			@media screen and (max-width: 768px) {
				#bannerArea a.grad {
					border-radius: 50px;
					width: 90%;
					margin: 0 auto 20px auto; } }
			#bannerArea a.grad span {
				display: block;
				padding: 15px;
				letter-spacing: 0.1rem; }
				@media screen and (max-width: 768px) {
					#bannerArea a.grad span {
						padding: 13px;
						font-size: 1.125rem;
						font-weight: bold; } }
			@media screen and (max-width: 768px) {
				#bannerArea a.grad::after {
					content: "";
					position: absolute;
					right: 30px;
					top: 50%;
					display: block;
					width: 10px;
					height: 10px;
					border: 3px solid;
					border-color: white white transparent transparent;
					-webkit-transform: rotate(45deg) translateY(-5px);
					transform: rotate(45deg) translateY(-5px); } }
		@media screen and (max-width: 768px) {
			#bannerArea a#sdgs {
				border-radius: 10px;
				width: 100%; } }
		@media screen and (max-width: 768px) {
			#bannerArea a#sdgs::after {
				content: none; } }
		#bannerArea a#sdgs span {
			background-image: url("../images/menu/sdgs.png");
			background-position: center 35%;
			border-radius: 10px; }
			@media screen and (max-width: 768px) {
				#bannerArea a#sdgs span {
					border-radius: 10px;
					padding: 30px 20px; } }

#egaoArea {
	padding: 10px 20px 0 20px;
	text-align: center; }

footer {
	background-image: url(../images/common/hr_line.gif), url(../images/common/grass.png);
	background-repeat: repeat-x;
	background-position: center top,center bottom;
	background-size: auto,contain;
	padding: 80px 0 230px 0;
	text-align: center; }
	@media screen and (max-width: 768px) {
		footer {
			flex-direction: column;
			padding-top: 35px;
			padding-bottom: 100px; }
			footer h1 {
				margin-bottom: 20px;
				padding: 0 5%; }
				footer h1 img {
					width: 100%; } }
	footer #footerInfo {
		display: flex;
		justify-content: space-between;
		margin-bottom: 20px; }
		@media screen and (max-width: 768px) {
			footer #footerInfo {
				flex-direction: column; }
				footer #footerInfo h1 {
					margin-bottom: 20px; } }
		footer #footerInfo #telAreaFooter {
			text-align: center;
			margin-bottom: 20px; }
			@media screen and (max-width: 768px) {
				footer #footerInfo #telAreaFooter {
					width: 100%;
					border: 3px solid #22ac38;
					margin: 0 0 20px 0;
					padding: 2%;
					border-radius: 20px;
					background-color: white; } }
			footer #footerInfo #telAreaFooter a {
				display: block;
				font-size: 2rem;
				margin-bottom: 5px; }
				footer #footerInfo #telAreaFooter a::before {
					display: inline-block;
					content: '';
					width: 27px;
					height: 27px;
					background: url( ../images/common/tel.png ) center center / contain no-repeat;
					transform: translate( 2px, 2px ); }
				footer #footerInfo #telAreaFooter a:hover {
					opacity: 0.8; }
			footer #footerInfo #telAreaFooter p {
				font-size: 0.75rem; }
		footer #footerInfo .ftbtn {
			text-align: center; }
			@media screen and (max-width: 768px) {
				footer #footerInfo .ftbtn {
					width: 100%; }
				footer #footerInfo #telAreaFooter a::before {
					width: 23px;
					height: 23px;
				} }
			footer #footerInfo .ftbtn a {
				position: relative;
				display: block;
				width: 100%;
				margin: 0 auto;
				background: linear-gradient(90deg, #e83828 0%, #f18e1d 33.3%, #22ac38 66.6%, #299fdb 100%);
				border-radius: 30px;
				padding: 20px 40px;
				font-size: 1rem;
				font-weight: bold;
				color: white;
				text-align: center;
				letter-spacing: 0.1rem; }
	footer .license {
		font-size: 0.75rem;
		margin-bottom: 50px;
		line-height: 1.7; }
		@media screen and (max-width: 768px) {
			footer .license {
				width: 90%;
				margin: 0 auto 50px auto; } }
	footer .egao {
		display: block;
		margin-bottom: 20px; }

/* Slider */
.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent; }

.slick-list {
	position: relative;
	overflow: hidden;
	display: block;
	margin: 0;
	padding: 0; }
	.slick-list:focus {
		outline: none; }
	.slick-list.dragging {
		cursor: pointer;
		cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	-ms-transform: translate3d(0, 0, 0);
	-o-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0); }

.slick-track {
	position: relative;
	left: 0;
	top: 0;
	display: block;
	margin-left: auto;
	margin-right: auto; }
	.slick-track:before, .slick-track:after {
		content: "";
		display: table; }
	.slick-track:after {
		clear: both; }
	.slick-loading .slick-track {
		visibility: hidden; }

.slick-slide {
	float: left;
	height: 100%;
	min-height: 1px;
	display: none; }
	[dir="rtl"] .slick-slide {
		float: right; }
	.slick-slide img {
		display: block; }
	.slick-slide.slick-loading img {
		display: none; }
	.slick-slide.dragging img {
		pointer-events: none; }
	.slick-initialized .slick-slide {
		display: block; }
	.slick-loading .slick-slide {
		visibility: hidden; }
	.slick-vertical .slick-slide {
		display: block;
		height: auto;
		border: 1px solid transparent; }

.slick-arrow.slick-hidden {
	display: none; }

/* Slider */
.slick-loading .slick-list {
	background: #fff url("./ajax-loader.gif") center center no-repeat; }

/* Icons */
@font-face {
	font-family: "slick";
	src: url("./fonts/slick.eot");
	src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
	font-weight: normal;
	font-style: normal; }
/* Arrows */
.slick-prev,
.slick-next {
	position: absolute;
	display: block;
	height: 52px;
	width: 51px;
	line-height: 0px;
	font-size: 0px;
	cursor: pointer;
	background: transparent;
	color: transparent;
	top: 50%;
	-webkit-transform: translate(0, -50%);
	-ms-transform: translate(0, -50%);
	transform: translate(0, -50%);
	padding: 0;
	border: none;
	outline: none;
	z-index: 99; }
	.slick-prev:hover, .slick-prev:focus,
	.slick-next:hover,
	.slick-next:focus {
		outline: none;
		background: transparent;
		color: transparent;
		opacity: 0.75; }
		.slick-prev:hover:before, .slick-prev:focus:before,
		.slick-next:hover:before,
		.slick-next:focus:before {
			opacity: 1; }
	.slick-prev.slick-disabled:before,
	.slick-next.slick-disabled:before {
		opacity: 0.25; }
	.slick-prev:before,
	.slick-next:before {
		font-family: "slick";
		font-size: 40px;
		line-height: 1;
		color: white;
		opacity: 1;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
		text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3); }

.slick-prev {
	left: -15px; }
	[dir="rtl"] .slick-prev {
		left: auto;
		right: -25px; }
	.slick-prev:before {
		content: url("../images/common/slider_left.png"); }
		[dir="rtl"] .slick-prev:before {
			content: "→"; }

.slick-next {
	right: -15px; }
	[dir="rtl"] .slick-next {
		left: -25px;
		right: auto; }
	.slick-next:before {
		content: url("../images/common/slider_right.png"); }
		[dir="rtl"] .slick-next:before {
			content: "←"; }

/* Dots */
.slick-dotted.slick-slider {
	margin-bottom: 30px; }

.slick-dots {
	position: absolute;
	bottom: -25px;
	list-style: none;
	display: block;
	text-align: center;
	padding: 0;
	margin: 0;
	width: 100%; }
	.slick-dots li {
		position: relative;
		display: inline-block;
		height: 20px;
		width: 20px;
		margin: 0 5px;
		padding: 0;
		cursor: pointer; }
		.slick-dots li button {
			border: 0;
			background: transparent;
			display: block;
			height: 20px;
			width: 20px;
			outline: none;
			line-height: 0px;
			font-size: 0px;
			color: transparent;
			padding: 5px;
			cursor: pointer; }
			.slick-dots li button:hover, .slick-dots li button:focus {
				outline: none; }
				.slick-dots li button:hover:before, .slick-dots li button:focus:before {
					opacity: 1; }
			.slick-dots li button:before {
				position: absolute;
				top: 0;
				left: 0;
				content: "•";
				width: 20px;
				height: 20px;
				font-family: "slick";
				font-size: 6px;
				line-height: 20px;
				text-align: center;
				color: black;
				opacity: 0.25;
				-webkit-font-smoothing: antialiased;
				-moz-osx-font-smoothing: grayscale; }
		.slick-dots li.slick-active button:before {
			color: black;
			opacity: 1; }
