/*
	HTML5 Reset :: style.css
	----------------------------------------------------------
	We have learned much from/been inspired by/taken code where offered from:

	Eric Meyer					:: http://meyerweb.com
	HTML5 Doctor				:: http://html5doctor.com
	and the HTML5 Boilerplate	:: http://html5boilerplate.com

-------------------------------------------------------------------------------*/

/* Let's default this puppy out
-------------------------------------------------------------------------------*/

html,
body,
body div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
figure,
footer,
header,
menu,
nav,
section,
time,
mark,
audio,
video,
details,
summary {
	background: transparent;
	border: 0;
	font-size: 100%;
	font-weight: normal;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

article,
aside,
figure,
footer,
header,
nav,
section,
details,
summary {
	display: block;
}

/* Handle box-sizing while better addressing child elements:
   http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */

html {
	box-sizing: border-box;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

/* consider resetting the default cursor: https://gist.github.com/murtaugh/5247154 */

/* Responsive images and other embedded objects */

/* if you don't have full control over `img` tags (if you have to overcome attributes), consider adding height: auto */

img,
object,
embed {
	max-width: 100%;
}

/*
   Note: keeping IMG here will cause problems if you're using foreground images as sprites.
	In fact, it *will* cause problems with Google Maps' controls at small size.
	If this is the case for you, try uncommenting the following:

#map img {
		max-width: none;
}
*/

/* force a vertical scrollbar to prevent a jumpy page */

html {
	overflow-y: scroll;
}

/* we use a lot of ULs that aren't bulleted.
	you'll have to restore the bullets within content,
	which is fine because they're probably customized anyway */

ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

a {
	background: transparent;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

del {
	text-decoration: line-through;
}

abbr[title],
dfn[title] {
	border-bottom: 1px dotted #000;
	cursor: help;
}

/* tables still need cellspacing="0" in the markup */

table {
	border-collapse: collapse;
	border-spacing: 0;
}

th {
	font-weight: bold;
	vertical-align: bottom;
}

td {
	font-weight: normal;
	vertical-align: top;
}

hr {
	border: 0;
	border-top: 1px solid #ccc;
	display: block;
	height: 1px;
	margin: 1em 0;
	padding: 0;
}

input,
select {
	vertical-align: middle;
}

pre { /* CSS 3 (and 2.1 as well, actually) */
	word-wrap: break-word;
	white-space: pre; /* CSS2 */
	white-space: pre-wrap; /* CSS 2.1 */
	white-space: pre-line; /* IE */
}

input[type="radio"] {
	vertical-align: text-bottom;
}

input[type="checkbox"] {
	vertical-align: bottom;
}

.ie7 input[type="checkbox"] {
	vertical-align: baseline;
}

.ie6 input {
	vertical-align: text-bottom;
}

select,
input,
textarea {
	font: 99% sans-serif;
}

table {
	font: 100%;
	font-size: inherit;
}

small {
	font-size: 85%;
}

strong {
	font-weight: bold;
}

td,
td img {
	vertical-align: top;
}

/* Make sure sup and sub don't mess with your line-heights http://gist.github.com/413930 */

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
}

sup {
	top: -0.5em;
}

sub {
	bottom: -0.25em;
}

/* standardize any monospaced elements */

pre,
code,
kbd,
samp {
	font-family: monospace, sans-serif;
}

/* hand cursor on clickable elements */

.clickable,
label,
input[type=button],
input[type=submit],
input[type=file],
button {
	cursor: pointer;
}

/* Webkit browsers add a 2px margin outside the chrome of form elements */

button,
input,
select,
textarea {
	margin: 0;
}

/* make buttons play nice in IE */

button,
input[type=button] {
	overflow: visible;
	width: auto;
}

/* scale images in IE7 more attractively */

.ie7 img {
	-ms-interpolation-mode: bicubic;
}

/* prevent BG image flicker upon hover
   (commented out as usage is rare, and the filter syntax messes with some pre-processors)
.ie6 html {filter: expression(document.execCommand("BackgroundImageCache", false, true));}
*/

/* let's clear some floats */

.clearfix:before,
.clearfix:after {
	content: "\0020";
	display: block;
	height: 0;
	overflow: hidden;
}

.clearfix:after {
	clear: both;
}

.clearfix {
	zoom: 1;
}

/*!
 * ress.css • v4.0.0
 * MIT License
 * github.com/filipelinhares/ress
 */

/* # =================================================================
   # Global selectors
   # ================================================================= */

html {
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
	tab-size: 4; /* Prevent adjustments of font size after orientation changes in iOS */
	word-break: normal;
}

*,
::before,
::after {
	background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
	box-sizing: inherit;
}

::before,
::after {
	text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
	vertical-align: inherit;
}

* { /* Reset `padding` and `margin` of all elements */
	margin: 0;
	padding: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */

hr { /* Add the correct box sizing in Firefox */
	color: inherit; /* Show the overflow in Edge and IE */
	height: 0;
	overflow: visible; /* Correct border color in Firefox. */
}

details,
main {
	display: block; /* Render the `main` element consistently in IE. */
}

summary {
	display: list-item; /* Add the correct display in all browsers */
}

small {
	font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden] {
	display: none; /* Add the correct display in IE */
}

abbr[title] {
	-webkit-text-decoration: underline dotted;
	border-bottom: none; /* Remove the bottom border in Chrome 57 */ /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
	text-decoration: underline;
	text-decoration: underline dotted;
}

a {
	background-color: transparent; /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
	outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
	font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
	font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
	font-weight: bolder; /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

table {
	border-color: inherit; /* Correct border color in all Chrome, Edge, and Safari. */
	text-indent: 0; /* Remove text indentation in Chrome, Edge, and Safari */
}

/* # =================================================================
   # Forms
   # ================================================================= */

input {
	border-radius: 0;
}

/* Replace pointer cursor in disabled elements */

[disabled] {
	cursor: default;
}

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
	height: auto; /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type='search'] {
	-webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
	outline-offset: -2px; /* Correct the outline style in Safari */
}

[type='search']::-webkit-search-decoration {
	-webkit-appearance: none; /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
	overflow: auto; /* Internet Explorer 11+ */
	resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
	font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
	font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
	overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
	text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */

button,
[type='button'],
[type='reset'],
[type='submit'],
[role='button'] {
	color: inherit;
	cursor: pointer;
}

/* Remove inner padding and border in Firefox 4+ */

button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/* Replace focus style removed in the border reset above */

button:-moz-focusring,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
	outline: 1px dotted ButtonText;
}

button,
html [type='button'],
[type='reset'],
[type='submit'] {
	-webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

/* Remove the default button styling in all browsers */

button,
input,
select,
textarea {
	background-color: transparent;
	border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
	outline-width: 0;
}

/* Style select like a standard input */

select {
	-moz-appearance: none; /* Firefox 36+ */
	-webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
	display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
	color: currentColor; /* Internet Explorer 11+ */
}

legend {
	border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
	color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
	display: table; /* Correct the text wrapping in Edge and IE */
	max-width: 100%; /* Correct the text wrapping in Edge and IE */
	max-width: 100%; /* Correct the text wrapping in Edge and IE */
	white-space: normal; /* Correct the text wrapping in Edge 18- and IE */
}

::-webkit-file-upload-button { /* Correct the inability to style clickable types in iOS and Safari */
	-webkit-appearance: button;
	color: inherit;
	font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */

img {
	border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */

progress {
	vertical-align: baseline;
}

/* # =================================================================
   # Accessibility
   # ================================================================= */

/* Specify the progress cursor of updating elements */

[aria-busy='true'] {
	cursor: progress;
}

/* Specify the pointer cursor of trigger elements */

[aria-controls] {
	cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */

[aria-disabled='true'] {
	cursor: default;
}

@font-face {
	font-family: 'brandon-grotesque';
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/Brandon_reg.otf) format("opentype");
}

@font-face {
	font-family: 'brandon-grotesque';
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/Brandon_med.otf) format("opentype");
}

@font-face {
	font-family: 'brandon-grotesque';
	font-style: normal;
	font-weight: 700;
	src: url(../fonts/Brandon_bld.otf) format("opentype");
}

@font-face {
	font-family: 'Gen Jyuu Gothic X';
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/GenJyuuGothicX-Monospace-Normal.ttf) format("truetype");
}

@font-face {
	font-family: 'Gen Jyuu Gothic X';
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/GenJyuuGothicX-Monospace-Medium.ttf) format("truetype");
}

@font-face {
	font-family: 'Noto Sans JP';
	src: url(../fonts/NotoSansJP-Regular.otf) format("opentype");
	font-weight: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Noto Sans JP';
	src: url(../fonts/NotoSansJP-Bold.otf) format("opentype");
	font-weight: bold;
	font-display: swap;
}

/**
 * Swiper 7.4.1
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2021 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: December 24, 2021
 */

@font-face {
	font-family: swiper-icons;
	font-style: normal;
	font-weight: 400;
	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");
}

:root {
	--swiper-theme-color: #007aff;
}

.swiper {
	list-style: none;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
	padding: 0;
	position: relative;
	z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
	flex-direction: column;
}

.swiper-wrapper {
	box-sizing: content-box;
	display: flex;
	height: 100%;
	position: relative;
	transition-property: transform;
	width: 100%;
	z-index: 1;
}

.swiper-android .swiper-slide,
.swiper-wrapper {
	transform: translate3d(0px, 0, 0);
}

.swiper-pointer-events {
	touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
	touch-action: pan-x;
}

.swiper-slide {
	flex-shrink: 0;
	height: 100%;
	position: relative;
	transition-property: transform;
	width: 100%;
}

.swiper-slide-invisible-blank {
	
}

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
	height: auto;
}

.swiper-autoheight .swiper-wrapper {
	align-items: flex-start;
	transition-property: transform,height;
}

.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
	perspective: 1200px;
}

.swiper-3d .swiper-cube-shadow,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-wrapper {
	transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top {
	height: 100%;
	left: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
	background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
	background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
	background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
	background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-css-mode > .swiper-wrapper {
	-ms-overflow-style: none;
	overflow: auto;
	scrollbar-width: none;
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
	display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
	scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
	scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
	scroll-snap-type: y mandatory;
}

.swiper-centered > .swiper-wrapper::before {
	content: '';
	flex-shrink: 0;
	order: 9999;
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
	margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
	height: 100%;
	min-height: 1px;
	width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
	margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
	height: var(--swiper-centered-offset-after);
	min-width: 1px;
	width: 100%;
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
	scroll-snap-align: center center;
}

.swiper-pagination {
	position: absolute;
	text-align: center;
	transform: translate3d(0, 0, 0);
	transition: .3s opacity;
	z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
	
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
	bottom: 10px;
	left: 0;
	width: 100%;
}

.swiper-pagination-bullets-dynamic {
	font-size: 0;
	overflow: hidden;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	position: relative;
	transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
	transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
	transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
	transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
	transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
	transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
	transform: scale(0.33);
}

.swiper-pagination-bullet {
	background: var(--swiper-pagination-bullet-inactive-color, #000);
	border-radius: 50%;
	display: inline-block;
	height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
	opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
	width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
}

button.swiper-pagination-bullet {
	-webkit-appearance: none;
	appearance: none;
	border: none;
	box-shadow: none;
	margin: 0;
	padding: 0;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
	cursor: pointer;
}

.swiper-pagination-bullet:only-child {
	display: none !important;
}

.swiper-pagination-bullet-active {
	background: var(--swiper-pagination-color, var(--swiper-theme-color));
	opacity: var(--swiper-pagination-bullet-opacity, 1);
}

.swiper-pagination-vertical.swiper-pagination-bullets,
.swiper-vertical > .swiper-pagination-bullets {
	right: 10px;
	top: 50%;
	transform: translate3d(0px, -50%, 0);
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
	display: block;
	margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	top: 50%;
	transform: translateY(-50%);
	width: 8px;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	display: inline-block;
	transition: .2s transform,.2s top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
	left: 50%;
	transform: translateX(-50%);
	white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	transition: .2s transform,.2s left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
	transition: .2s transform,.2s right;
}

.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));
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scale(0);
	transform-origin: left top;
	width: 100%;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
	height: 4px;
	left: 0;
	top: 0;
	width: 100%;
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-vertical > .swiper-pagination-progressbar {
	height: 100%;
	left: 0;
	top: 0;
	width: 4px;
}

.swiper-pagination-lock {
	display: none;
}

.swiper-fade.swiper-free-mode .swiper-slide {
	transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
	pointer-events: none;
	transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
	pointer-events: none;
}

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
	pointer-events: auto;
}

:root {
	--swiper-navigation-size: 44px;
}

.swiper-button-next,
.swiper-button-prev {
	align-items: center;
	color: var(--swiper-navigation-color, var(--swiper-theme-color));
	cursor: pointer;
	display: flex;
	height: var(--swiper-navigation-size);
	justify-content: center;
	margin-top: calc(0px - (var(--swiper-navigation-size)/ 2));
	position: absolute;
	top: 50%;
	width: calc(var(--swiper-navigation-size)/ 44 * 27);
	z-index: 10;
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
	cursor: auto;
	opacity: .35;
	pointer-events: none;
}

.swiper-button-next:after,
.swiper-button-prev:after {
	font-family: swiper-icons;
	font-size: var(--swiper-navigation-size);
	font-variant: initial;
	letter-spacing: 0;
	line-height: 1;
	text-transform: none !important;
	text-transform: none;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
	left: 10px;
	right: auto;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
	content: 'prev';
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
	left: auto;
	right: 10px;
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
	content: 'next';
}

.swiper-button-lock {
	display: none;
}

.inner,
body#history.page-child .history-detail,
body#sdgs #other #news {
	padding-left: 40px;
	padding-right: 40px;
}

html {
	height: 100%;
}

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background-color: #FFF;
	color: #3F352F;
	font-family: "brandon-grotesque", "Gen Jyuu Gothic X", sans-serif;
	font-variant-ligatures: none;
	font-weight: 400;
	height: 100%;
	letter-spacing: 0.1em;
	line-height: 2.5;
	min-width: 320px;
}

a {
	color: #3F352F;
	outline: none;
	text-decoration: none;
}

img {
	display: inline-block;
	height: auto;
	vertical-align: bottom;
}

img[data-src] {
	
}

img.lazyloaded {
	opacity: 1;
	transition: opacity 0.5s ease-in;
}

input,
textarea,
button {
	color: #3F352F;
	line-height: 2.5;
	outline: none;
}

hr {
	border-color: #000;
}

.sp {
	display: none;
}

span.br {
	display: inline-block;
	font-weight: inherit;
	text-indent: initial;
}

.inner {
	box-sizing: content-box;
	margin-left: auto;
	margin-right: auto;
	max-width: 75em;
}

.inner * {
	box-sizing: border-box;
}

.img.cover {
	overflow: hidden;
	position: relative;
}

.img.cover:before {
	content: "";
	display: block;
	padding-top: 100%;
}

#home .img.cover:after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,0.5));
}

.img.cover .no-image,
.img.cover img {
	bottom: 0;
	height: 100%;
	left: 0;
	object-fit: cover;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
}

.img.cover .no-image {
	background: url(../images/icon_logo01.svg) no-repeat center #383433;
	background-size: 25%;
	overflow: hidden;
	text-indent: 200%;
	white-space: nowrap;
}

input[id^="switch-"] {
	display: none;
}

#switch-global:checked ~ .global {
	pointer-events: fill;
	transform: translateX(0);
	transition: transform 0.3s, visibility 0.3s;
	visibility: visible;
}

.btn-menu {
	border: 1.25em solid transparent;
	box-sizing: content-box;
	display: block;
	height: 1.5em;
	pointer-events: fill;
	position: absolute;
	right: 43px;
	text-align: right;
	top: 18px;
	width: 5.5em;
	z-index: 1;
}

.btn-menu:before,
.btn-menu:after {
	background-color: currentColor;
	content: "";
	display: block;
	height: 2px;
	position: absolute;
	width: 100%;
	transition: all .3s ease;
}

.btn-menu.blk:before,
.btn-menu.blk:after,
.smaller .btn-menu:before,
.smaller .btn-menu:after {
	background-color: #3f352f;
}

.btn-menu:after {
	bottom: 0;
}

.btn-menu span {
	bottom: -0.6875em;
	display: inline-block;
	letter-spacing: 0.285em;
	line-height: 1;
	position: relative;
	right: -0.125em;
	transform: scale(62.5%);
	transform-origin: right bottom;
}

.btn-menu.blk span {
	color: #3f352f;
}

.smaller .btn-menu span {
	color: #3f352f;
}

.btn-menu.open:before {
	transform: rotate(13deg);
	transform-origin: center;
	background-color: #3F352F;
	top: 10px;
	left: 0;
}

.btn-menu.open:after {
	transform: rotate(-13deg);
	transform-origin: center;
	background-color: #3F352F;
	top: 10px;
	left: 0;
	bottom: auto;
}

.btn-menu.open span {
	display: none;
}

.logo {
	line-height: 1;
	max-width: 12.5em;
	transition: all .3s ease;
}

.logo a {
	display: block;
}

.logo svg.SvgIcon {
	width: 0;
	height: 0;
}

.logo svg.Svg01 {
	max-width: 12.5em;
	width: 175px;
	height: 21px;
	transition: all .3s ease;
}

.logo .white {
    fill: #fff;
}

.smaller .logo .white {
    fill: #d00746;
}

.logo a svg {
	vertical-align: top;
}

#header {
	color: #FFF;
	height: 6.25em;
	pointer-events: none;
	position: fixed;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 100;
}

#header .logo {
	margin-left: 2.1875em;
	margin-top: 2.75em;
	pointer-events: fill;
	position: absolute;
}

#header .global {
	background-color: #d9d7d5;
	min-height: 100vh;
	margin-left: auto;
	width: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 0.3s;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack: end;
	-webkit-justify-content: flex-end;
	justify-content: flex-end;
}

#header .menu {
	padding: 6.25em 3.125em;
	width: 50%;
	order: 2;
}

#header .menu.main li {
	font-size: 3em;
	font-size: 2.5em;
	font-weight: bold;
	text-align: right;
	line-height: 1;
	margin-bottom: 0.5em;
	letter-spacing: 0.285em;
}
#header .menu.main li a {
	line-height: 1;
}
#header .menu.main li span {
	display: block;
	font-size: 0.75rem;
	line-height: 1;
	letter-spacing: 0.1em;
}
#header .menu.main li ul {
	padding-top: 0.5em;
}
#header .menu.main li li {
	font-size: 0.45em;
	font-weight: normal;
	letter-spacing: 0.1em;
	margin-bottom: 1em;
}
#header .menu.main li li a {
}
#header .menu.main li li a:hover {
	border-bottom: 2px dotted #CF0067;
}



#header figure {
	width: 50%;
	order: 1;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
}
#header figure img {
	width: 38%;
}

#footer {
	background: url(../images/footer_bg01.jpg) no-repeat center/cover;
	color: #FFF;
	min-height: 56.25em;
	padding-top: 19.0625em;
	position: relative;
}

#footer.simple {
	background: #333130;
	min-height: 6.25em;
	padding-top: 2em;
}

#footer.simple #copyright {
	margin-top: 0;
}

#footer.sdgs {
	background: url(../images/footer_bg02.svg) no-repeat center bottom/91.75em 13.75em;
	height: 13.75em;
	min-height: 13.75em;
	overflow: hidden;
	padding-top: 0;
}

#footer.sdgs .logo {
	filter: brightness(0.9);
	margin: 8.35em auto 1.05em;
	max-width: 9.375em;
}

#footer.sdgs .pagetop {
	bottom: 6.65em;
	position: absolute;
	right: 2.5%;
}

#footer.sdgs .pagetop a {
	background: url(../images/page_top_bg01.svg) no-repeat center/cover;
	color: #777;
	display: block;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 0.75em;
	font-weight: bold;
	height: calc(60 / 12 * 1em);
	letter-spacing: 0.05em;
	line-height: 1;
	padding-top: 1em;
	position: relative;
	text-align: center;
	width: calc(65 / 12 * 1em);
	writing-mode: inherit;
}

.desktop #footer.sdgs .pagetop a:hover:before {
	transform: translateY(-0.75em);
}
.desktop #footer.sdgs .pagetop a:hover:after {
	opacity: 1;
}

#footer.sdgs .pagetop a:before {
	background: url(../images/arrow01.svg) no-repeat center/cover;
	content: "";
	display: block;
	height: calc(24 / 12 * 1em);
	margin: auto;
	margin-bottom: 0.55em;
	position: relative;
	width: calc(20.45 / 12 * 1em);
	z-index: 1;
	transition: all .3s;
}

#footer.sdgs .pagetop a:after {
	background: url(../images/page_top_bg01.svg) no-repeat center/cover;
	content: "";
	display: block;
	filter: brightness(0.95);
	height: 100%;
	left: 0;
	
	position: absolute;
	top: 0;
	transition: opacity 0.3s;
	width: 100%;
	z-index: 0;
}

#footer.sdgs .pagetop a span {
	position: relative;
	z-index: 1;
}

#footer.sdgs #copyright {
	margin-top: 0;
}

#footer.sdgs #copyright small {
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0.055em;
}

#footer > .inner {
	max-width: 100em;
}

#footer .wrap {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

#footer .logo {
	max-width: 17.0625em;
}

#footer .address {
	font-family: "Gen Jyuu Gothic X", sans-serif;
	font-size: 1.0625em;
	font-weight: 500;
	margin: 2.05em 0 1.5em;
}

#footer .btn.small {
	margin: 1em 0;
}
#footer .btn.small a {
	border: 1px solid #fff;
	transition: all .3s ease;
}
#footer .btn.white a:hover {
	background-color: transparent;
	color: #fff;
}

#footer .btn.border {
	margin: 1em 0 1.875em;
}

#footer .btn.border a {
	transition: all .3s ease;
}

#footer .btn.border a:hover {
	background-color: #fff;
	color: #3F352F;
}

#footer .catchcopy {
	font-size: 1.8125em;
	font-weight: bold;
	letter-spacing: 0.285em;
	margin-top: 2.1em;
}

.pagetop {
	bottom: 0;
	position: absolute;
	right: 2.9%;
}

.pagetop a {
	color: #FFF;
	display: block;
	font-size: 0.75em;
	font-weight: bold;
	height: 11.8334em;
	letter-spacing: 0.285em;
	writing-mode: vertical-rl;
}

.pagetop a:after {
	background-color: currentColor;
	content: "";
	display: block;
	height: 100%;
	margin-right: 0.875em;
	width: 2px;
}

#copyright {
	margin-top: 13.925em;
	padding-bottom: 1.6984375em;
	text-align: center;
}

#copyright small {
	display: inline-block;
	font-family: "Yu Gothic", sans-serif;
	font-size: 0.75em;
	letter-spacing: 0;
	line-height: 1;
}

.page-title .en {
	font-size: 4.25em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1.25;
}

.page-title .jp {
	font-size: 1.125em;
	letter-spacing: 0.1em;
}

.page .section-title.center {
	text-align: center;
}

.page .section-title .en {
	font-size: 4.25em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1.75;
}

.page .section-title .jp {
	font-size: 1.125em;
	letter-spacing: 0.1em;
	margin-top: -1.3em;
}

body#page_service #service_archive .section-title {
	text-align: center;
}

.page .hero {
	background-color: #D9D7D5;
}

.page .hero .inner {
	align-items: flex-end;
	display: flex;
	justify-content: space-between;
	max-width: 118.125em;
	padding-bottom: 3.75em;
	padding-top: 9.925em;
}

.breadcrumb {
	margin: 1.75em 0.5em;
}

.breadcrumb .separate {
	display: inline-block;
	line-height: 1;
	margin: 0 2.15em;
	overflow: hidden;
	position: relative;
	text-indent: 200%;
	width: 5em;
}

.breadcrumb .separate:before {
	background-color: currentColor;
	bottom: 26%;
	content: "";
	display: block;
	height: 1px;
	position: absolute;
	width: 100%;
}

.breadcrumb [property="itemListElement"] span {
	font-size: 0.75em;
	font-weight: 500;
	letter-spacing: 0.285em;
}

.content-post {
	overflow: hidden;
	padding-bottom: 7.175em;
	padding-top: 4.25em;
}

.content-post h3 {
	font-size: 1.8em;
}
.content-post li,
.content-post em,
.content-post address,
.content-post p {
	font-family: "Gen Jyuu Gothic X", sans-serif;
	font-size: 1.5em;
	letter-spacing: 0;
	margin: 2.4em 0;
	font-style: normal;
}
.content-post address {
	margin: 0 0 -2.4em 0;
}

.content-post li li {
	font-size: 100%;
}

.content-post li ul,
.content-post li ol {
	margin: 0.85em 0 1.6em;
}

.content-post li ul > li,
.content-post li ol > li {
	margin: 0.6em 0;
}

.content-post ul,
.content-post ol {
	counter-reset: num;
	margin: 4.5em 0;
}

.content-post ul > li,
.content-post ol > li {
	margin: 1.9em 0;
	padding-left: 1.675em;
	position: relative;
}

.content-post ul > li:before,
.content-post ol > li:before {
	content: '・';
	left: -0.25em;
	position: absolute;
	top: 0;
}

.content-post ol > li {
	padding-left: 2.5em;
}

.content-post ol > li:before {
	content: counter(num) ".";
	counter-increment: num;
	font-size: 83.3334%;
	left: 0;
	top: 0.175em;
}

#loading {
	align-items: center;
	background-color: #FFF;
	display: none;
	height: 100%;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	transition: opacity 0.3s, visibility 0.3s;
	width: 100%;
	z-index: 9999;
}

#loading.is-done {
	
	
}

#loading.is-animated svg {
	fill-opacity: 1;
	stroke-
}

#loading svg {
	fill: #D00746;
	fill-
	stroke: #3F352F;
	stroke-width: 1px;
	max-width: calc(404 / 16 * 1em);
	transition: fill-opacity 0.5s;
	width: 100%;
}


.btn {
	display: flex;
}

.btn.center {
	justify-content: center;
}

.btn.right {
	justify-content: flex-end;
}

.btn.white > * {
	background-color: #FFF;
	color: #3F352F;
	transition: all .3s ease;
}

.btn.white > *:hover {
	background-color: #3F352F;
	color: #fff;
}

.btn.border > * {
	background: transparent;
	border: 1px solid currentColor;
}

.btn.border.white > * {
	color: #FFF;
}

.btn.small > * {
	border-radius: 1.125em;
	font-size: 1em;
	height: 2.25em;
	letter-spacing: 0.285em;
	min-width: 6.25em;
	padding: 0 1em;
}

.btn.font-jp > * {
	font-family: "Gen Jyuu Gothic X", sans-serif;
}

.btn.bold > * {
	font-weight: bold;
}

.btn > * {
	align-items: center;
	background-color: #3F352F;
	border-radius: 1.35em;
	color: #FFF;
	display: flex;
	font-size: 1.25em;
	height: 2.7em;
	justify-content: center;
	letter-spacing: 0.05em;
	line-height: 1;
	min-width: 15em;
	padding: 0 2.25em;
	white-space: nowrap;
	transition: all .3s ease;
	border: 1px solid #3F352F;
}

.btn > *:hover {
	background-color: #fff;
	color: #3F352F;
}

.detail-btn > * {
	background-color: #423E3E;
	border: 1px solid #858585;
	border-radius: 100%;
	color: #FFF;
	display: inline-block;
	font-weight: 700;
	height: 8.125em;
	line-height: 8.125em;
	text-align: center;
	transition: background-color 0.3s;
	width: 8.125em;
}

.desktop .detail-btn > *:hover {
	background-color: #923440;
}

.swiper .arrow-wrapper {
	display: flex;
	justify-content: space-between;
	margin-top: 4em;
	max-width: 12.78125em;
}

.swiper .arrow-next,
.swiper .arrow-prev {
	background-color: #F5F5F5;
	border-radius: 100%;
	cursor: pointer;
	display: block;
	height: 5em;
	position: relative;
	transition: opacity 0.3s;
	width: 5em;
}

.swiper .arrow-next:before,
.swiper .arrow-prev:before {
	background: url(../images/icon_arrow01.svg) no-repeat center/1.875em;
	content: "";
	display: block;
	height: 100%;
	transition: opacity 0.3s;
	width: 100%;
}

.swiper .arrow-prev {
	transform: scale(-1);
}

#main .swiper-pagination {
	margin: 1.25em 0 1em;
	position: relative;
	text-align: left;
}

#main .swiper-pagination-bullet {
	background-color: #5B5757;
	height: 0.9375em;
	margin: 0 1.0625em 0 0;
	opacity: 1;
	transition: background-color 0.3s;
	width: 0.9375em;
}

#main .swiper-pagination-bullet-active {
	background-color: #858585;
}

#error .content {
	align-items: center;
	display: flex;
	min-height: calc(100vh - 454px);
	padding-top: 180px;
	text-align: center;
}

#error .content .page-title .title {
	opacity: 0.35;
}

#error .content .code {
	font-size: 200px;
	letter-spacing: 0.01em;
	line-height: 1;
	margin: 0;
	opacity: 0.35;
}

#error .content .code + p {
	font-size: 15px;
	line-height: 160%;
}

#error .content .btn {
	display: inline-block;
	margin-top: 20px;
}

#archive .content .inner {
	padding-bottom: 244px;
}

body#company .content .inner {
	max-width: 100em;
}

body#company #philosophy {
	padding: 18.1em 0 13em;
	text-align: center;
}
body#company #philosophy .message {
    font-size: 2.3125em;
    letter-spacing: 0;
    margin: 2.325em 0;
}

body#company #slogan {
	padding: 0 0 13em 0;
}

body#company #slogan .slogan {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack:justify;
	-webkit-justify-content: space-between;
	justify-content:space-between;
}
body#company #slogan .section-title {
	padding-right: 7em;
}

body#company #slogan h5 {
	font-weight: bold;
	font-size: 2em;
	margin-top: 0.5em;
	letter-spacing: 0.1em;
}


body#company #slogan p {
	font-size: 1.125em;
}

body#company #promise {
	background: url(../images/company_promise_bg01.jpg) no-repeat center/cover;
	padding: 6.8em 0 5.45em;
}

body#company #promise .text {
	margin-left: auto;
	max-width: 46.875em;
}

body#company #promise .text h4 {
	font-size: 1.5em;
	letter-spacing: 0;
	margin: 2em 0;
}

body#company #promise .text p {
	font-size: 1.125em;
	letter-spacing: 0;
	margin: 1.625em 0;
	line-height: 1.7;
}

body#company .page-nav {
	padding: 14.65em 0 15.7em;
}

body#company .page-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-left: -3.125%;
}

body#company .page-list li {
	margin-left: 3.03%;
	width: 30.303%;
}

body#company .page-list li a {
	display: block;
}

body#company .page-list li .title-en {
	font-size: 2.125em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1;
	white-space: nowrap;
}

body#company .page-list li .title-jp {
	font-size: 0.875em;
	font-weight: 500;
	letter-spacing: 0.285em;
	line-height: 1;
	margin-left: -0.1em;
	margin-top: 1.65em;
	position: absolute;
	white-space: nowrap;
	writing-mode: vertical-lr;
}

body#company .page-list li .img {
	margin-left: 2.5em;
	margin-top: 0.65em;
}

body#company #message .inner {
	padding: 8.9em 0;
}

body#company #message .container {
	margin: auto;
	max-width: 87.5em;
	max-width: 96%;
}

body#company #message .container .img {
	margin: 1.75em auto 1.6em;
}

body#company #message .container p {
	font-size: 1.25em;
	letter-spacing: 0;
	line-height: 2.4;
	margin-bottom: 2.4em;
}

body#history.page-child .history-nav ul li.current a,
.desktop body#history.page-child .history-nav ul li a:hover {
	background-color: #5B5757;
	margin-right: 0;
	padding-left: 11%;
}

body#history.page-child .history-nav ul li.current a .year,
.desktop body#history.page-child .history-nav ul li a:hover .year {
	color: #6D6A6A;
}

body#history {
	background-color: #383433;
}

body#history:before {
	background: url(../images/history_archive_bg01.png) no-repeat center/cover;
	content: "";
	display: block;
	height: 100vh;
	left: 0;
	opacity: 0.5;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: -1;
}

body#history #main {
	font-family: "Yu Mincho", serif;
}

body#history .content {
	color: #FFF;
}

body#history .content .history-list {
	margin: -12.875em auto 3.75em;
	max-width: 112.5em;
	padding-top: 12.875em;
	position: relative;
}

body#history .content .history-list:before {
	background-color: #595757;
	border-radius: 100%;
	content: "";
	display: block;
	height: 1.1875em;
	left: 50%;
	position: absolute;
	top: 0;
	transform: translate(-50%, -50%);
	width: 1.1875em;
}

body#history .content .history-list:after {
	background-color: #595757;
	bottom: 5%;
	content: "";
	display: block;
	left: calc(50% - 1px);
	position: absolute;
	top: 0;
	width: 2px;
}

body#history .content .history-list > li {
	padding-top: 6.625em;
	position: relative;
	z-index: 1;
}

body#history .content .history-list > li:before {
	background-color: #595757;
	border-radius: 100%;
	content: "";
	display: block;
	height: 2.5em;
	left: 50%;
	position: absolute;
	top: 10em;
	transform: translate(-50%, -50%);
	width: 2.5em;
}

body#history .content .history-list > li:nth-child(odd) .text {
	margin-right: 50%;
}

body#history .content .history-list > li:nth-child(odd) .images {
	margin-left: auto;
}

body#history .content .history-list > li:nth-child(even) .detail-btn {
	right: 0;
}

body#history .content .history-list .text {
	margin-left: auto;
	max-width: 46.875em;
	width: 50%;
}

body#history .content .history-list .text > p {
	font-size: 1.125em;
	letter-spacing: 0;
	line-height: 2;
	margin: 1.5em 0 2.75em;
}

body#history .content .history-list .headline {
	position: relative;
}

body#history .content .history-list .detail-btn {
	position: absolute;
}

body#history .content .history-list .images {
	max-width: 75.625em;
}

body#history .content .history-list .images .img {
	aspect-ratio: 1210 / 660;
}

body#history .content .history-title {
	bottom: 0.6em;
	font-size: 2.25em;
	font-weight: 700;
	left: 0;
	letter-spacing: 0;
	line-height: 1;
	position: absolute;
}

body#history .content .history-year {
	color: #6D6868;
	font-size: 8.125em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	white-space: nowrap;
}

body#history .content .history-year .tilde {
	font-weight: inherit;
	margin-left: 0.25em;
}

body#history .hero {
	background-color: transparent;
	height: 100vh;
	position: relative;
	text-align: center;
}

body#history .hero > .inner {
	align-items: center;
	box-sizing: border-box;
	display: flex;
	height: 100%;
	justify-content: center;
}

body#history .hero .block {
	margin-bottom: 3em;
	position: relative;
}

body#history .hero .history-logo {
	margin: auto;
	max-width: 43.1875em;
	position: relative;
	z-index: 1;
}

body#history .hero .history-start {
	color: #6D6868;
	font-size: 14.25em;
	font-weight: 700;
	left: 50%;
	line-height: 1;
	opacity: 0.7;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
}

body#history .hero .next {
	bottom: 6em;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

body#history .hero .next a {
	color: #FFF;
	filter: brightness(77%);
	letter-spacing: 0.15em;
}

body#history .hero .next a span {
	font-size: 1.125em;
}

body#history .hero .next a:after {
	background: url(../images/icon_arrow01.svg) no-repeat center/cover;
	content: "";
	display: block;
	filter: invert(1);
	height: 1.875em;
	margin: auto;
	transform: rotate(90deg) scaleY(1.2);
	width: 1.875em;
}

body#history #intro {
	height: 100vh;
	position: relative;
	text-align: center;
}

body#history #intro > .inner {
	align-items: center;
	box-sizing: border-box;
	display: flex;
	height: 100%;
	justify-content: center;
}

body#history #intro .block {
	margin: 0 auto 1em;
	max-width: 62.5em;
}

body#history #intro .block p {
	font-size: 1.125em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 3;
	margin: 3em 0;
}

body#history.page-child {
	background-image: url(../images/history_detail_bg01.png);
}

body#history.page-child:before {
	display: none;
}

body#history.page-child .hero {
	background: url(../images/history_hero_bg01.jpg) no-repeat center/cover;
	border-top: 8.75em solid #333130;
	box-sizing: content-box;
	height: 25em;
}

body#history.page-child .hero:after {
	background-color: rgba(0, 0, 0, 0.45);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

body#history.page-child .hero .block {
	margin-bottom: 3.75em;
	z-index: 1;
}

body#history.page-child .hero .history-title {
	color: #FFF;
	font-size: 2.5em;
	font-weight: 700;
	letter-spacing: 0;
	position: relative;
	text-indent: 0.1em;
	z-index: 1;
}

body#history.page-child .hero .history-start {
	color: #808080;
	font-size: 5.25em;
	letter-spacing: 0;
	opacity: 1;
	top: 22.5%;
	white-space: nowrap;
}

body#history.page-child .hero .history-start .tilde {
	font-weight: inherit;
	margin-left: 0.25em;
}

body#history.page-child .content {
	display: flex;
	padding-top: 100px;
}

body#history.page-child .history-nav {
	flex-basis: 20%;
	min-width: 17em;
}

body#history.page-child .history-nav ul li {
	margin-bottom: 1.25em;
}

body#history.page-child .history-nav ul li.to-archive a .title {
	font-size: 1.125em;
	font-weight: 400;
	letter-spacing: 0.05em;
	width: calc(7.7em * (1.625 / 1.125));
}

body#history.page-child .history-nav ul li a {
	align-items: center;
	background-color: #423E3E;
	border-bottom-right-radius: calc(6.875em / 2);
	border-top-right-radius: calc(6.875em / 2);
	display: flex;
	filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.1));
	height: 6.875em;
	justify-content: center;
	margin-right: 20%;
	min-width: 16em;
	position: relative;
	transition: background-color 0.3s, margin-right 0.3s, padding-left 0.3s;
}

body#history.page-child .history-nav ul li a .title {
	color: #FFF;
	font-size: 1.625em;
	font-weight: 700;
	letter-spacing: 0;
	position: relative;
	top: 0.1em;
	width: 7.7em;
	z-index: 1;
}

body#history.page-child .history-nav ul li a .year {
	color: #565250;
	font-size: 2.875em;
	font-weight: 700;
	letter-spacing: 0;
	margin-right: -1.675em;
	margin-top: -0.5em;
	position: absolute;
	transition: color 0.3s;
	width: 4em;
}

body#history.page-child .history-nav ul li a .year .tilde {
	font-weight: inherit;
	margin-left: 0.25em;
}

body#history.page-child .history-detail {
	box-sizing: content-box;
	margin: auto;
	max-width: 87.5em;
	width: 100%;
}

body#history.page-child .history-detail-header {
	display: flex;
	justify-content: space-between;
	margin-top: -0.5em;
}

body#history.page-child .history-detail-header .headline {
	flex-basis: 50%;
	text-align: center;
}

body#history.page-child .history-detail-header .headline .en {
	color: #565250;
	font-size: 3.75em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
}

body#history.page-child .history-detail-header .headline .jp {
	font-size: 1.625em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	margin-top: -0.9em;
}

body#history.page-child .history-detail-list {
	margin-bottom: 6.25em;
	margin-top: 9.0625em;
	padding-top: 0.005em;
	position: relative;
}

body#history.page-child .history-detail-list:after {
	background-color: #6D6A6A;
	bottom: 0;
	content: "";
	display: block;
	left: calc(50% - 1px);
	position: absolute;
	top: 0;
	width: 2px;
}

body#history.page-child .history-detail-list li {
	display: flex;
	justify-content: space-between;
	margin: 2em 0 3.9em;
	position: relative;
}

body#history.page-child .history-detail-list li:last-child .block .img {
	margin-bottom: 0;
}

body#history.page-child .history-detail-list li:before {
	background-color: #6D6A6A;
	border-radius: 100%;
	content: "";
	display: block;
	height: 1.25em;
	left: 50%;
	position: absolute;
	top: 2.5em;
	transform: translate(-50%, -50%);
	width: 1.25em;
}

body#history.page-child .history-detail-list li .block {
	box-sizing: border-box;
	flex-basis: 50%;
}

body#history.page-child .history-detail-list li .block:before {
	background-color: #6D6A6A;
	content: "";
	display: block;
	font-size: 3em;
	height: 2px;
	position: absolute;
	top: 0.8125em;
	width: 7.1%;
}

body#history.page-child .history-detail-list li .block.company {
	padding-right: 7.1%;
	text-align: right;
}

body#history.page-child .history-detail-list li .block.company:before {
	right: 50%;
}

body#history.page-child .history-detail-list li .block.product {
	margin-left: auto;
	padding-left: 7.1%;
}

body#history.page-child .history-detail-list li .block.product:before {
	left: 50%;
}

body#history.page-child .history-detail-list li .block .year {
	color: #6D6A6A;
	display: inline-block;
	font-size: 3em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	position: relative;
}

body#history.page-child .history-detail-list li .block .year:after {
	background-color: #6D6A6A;
	content: "";
	display: block;
	height: 2px;
	position: absolute;
	top: 0.8125em;
	width: 100%;
}

body#history.page-child .history-detail-list li .block p {
	font-size: 1.25em;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.75;
	margin: 0.5em 0;
}

body#history.page-child .history-detail-list li .block .img {
	margin: 1.375em 0 1.125em;
}

body#history.page-child .history-detail-list li .block .img img {
	object-fit: contain;
}

body#history.page-child .history-detail-list li .block .img + p {
	margin-top: 2.25em;
}

body#page_service #service_archive .inner {
	max-width: 100em;
}
body#page_service #certified {
    padding: 18.1em 0 13em;
}

body#page_service #certified .section-title {
	text-align: center;
}

body#page_service #service_archive {
    padding: 18.1em 0 0 0;
}


#home .section-title {
	font-size: 4.25em;
	font-weight: bold;
	letter-spacing: 0.285em;
	letter-spacing: 0.15em;
	line-height: 1.75;
}

#home .hero {
	height: 100vh;
	position: relative;
}

#home .hero .img {
	height: 100%;
}

#home .hero .catchcopy {
	align-items: center;
	color: #FFF;
	display: flex;
	height: 100%;
	justify-content: center;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

#home .hero .catchcopy .cup {
	align-items: center;
	border: 2.5625em solid currentColor;
	border-radius: 100%;
	display: flex;
	height: 24.59375em;
	justify-content: center;
	pointer-events: none;
	position: relative;
	width: 24.59375em;
}

#home .hero .catchcopy .cup .handle {
	align-items: center;
	animation: cup-rotate 10s infinite;
	display: flex;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

#home .hero .catchcopy .cup .handle:after {
	background-color: currentColor;
	border-radius: 1.65625em;
	content: "";
	height: 3.3125em;
	position: absolute;
	right: 0;
	transform: translateX(100%);
	width: 8.6875em;
}

#home .hero .catchcopy .cup h2 {
	font-size: 1.75em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1.75;
	margin-top: 0.4em;
	text-align: center;
}

#home .hero .next {
	bottom: 0;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

#home .hero .next a {
	color: #FFF;
	display: block;
	font-size: 0.6875em;
	letter-spacing: 0.18em;
	line-height: 1;
	text-indent: 0.18em;
}

#home .hero .next a .bar {
	background-color: rgba(255, 255, 255, 0.35);
	display: block;
	height: calc(5.25em * 1.4545);
	margin: calc(1.125em * 1.4545) auto 0;
	overflow: hidden;
	width: 1px;
}

#home .hero .next a .bar:after {
	animation: scroll-bar 3.5s infinite;
	background-color: currentColor;
	content: "";
	display: block;
	height: 100%;
	position: relative;
	top: 50%;
	width: 100%;
}

#home #intro {
	background: #3F352F;
	background: linear-gradient(0deg, #000 0%, #3F352F 100%);
	color: #FFF;
	overflow: hidden;
}

#home #intro .catchphrase {
	margin: 5.25em auto;
	position: relative;
	text-align: center;
}

#home #intro .catchphrase figure {
	filter: blur(6px);
	margin: auto;
	max-width: 79.6875em;
	mix-blend-mode: multiply;
	opacity: 0.3;
}

#home #intro .catchphrase h2 {
	font-size: 4.5em;
	letter-spacing: 0.1em;
	line-height: 1.75;
	margin-top: -0.775em;
	position: absolute;
	text-indent: 0.5em;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}

#home #intro #history {
	align-items: center;
	display: flex;
	margin: 6.15em auto;
}

#home #intro #history > * {
	flex-basis: 45%;
}

#home #intro #history .img figure {
	max-width: 41.25em;
}

#home #intro #history .text {
	color: #FFF;
	padding: 0 0 5.125em 2.2em;
}

#home #intro #history .text p {
	font-family: "Gen Jyuu Gothic X", sans-serif;
	font-size: 1.25em;
	letter-spacing: 0.1em;
}

#home #intro #history .text .btn {
	margin: 3.75em auto;
}

#home #intro .coffee {
	margin-top: -27.25em;
	padding: 0 0.625em 3em 0;
	text-align: right;
	pointer-events: none;
}

#home #intro .coffee .wrap {
	display: inline-block;
	max-width: 43em;
	position: relative;
}

#home #intro .coffee .wrap > img {
	position: relative;
	z-index: 1;
}

#home #intro .coffee .wrap:after {
	background: url(../images/coffee-shadow01.svg) no-repeat center/cover;
	bottom: 0;
	content: "";
	display: block;
	height: 100%;
	mix-blend-mode: multiply;
	position: absolute;
	right: 0;
	width: 100%;
}

#home #intro .coffee .steam-box {
	height: 100%;
	left: 0;
	max-width: 31em;
	pointer-events: none;
	position: absolute;
	top: 10%;
	width: 72.0931%;
	z-index: 2;
}

#home #intro .coffee .steam-box > div {
	
	position: absolute;
}

#home #intro .coffee .steam-box .steam01 {
	animation: steam-move01 10s infinite linear;
}

#home #intro .coffee .steam-box .steam02 {
	animation: steam-move01 9s infinite linear;
	animation-delay: 5s;
}

#home #service {
	height: 400vh;
	position: relative;
}

#home #service .section-title {
	left: 0;
	margin: calc(114 / 68 * -1em) 0 0 calc(90 / 68 * 1em);
	position: absolute;
	top: 0;
	writing-mode: vertical-rl;
	z-index: 10;
}

#home #service .scroll_container {
	align-items: center;
	display: flex;
	height: 100vh;
	justify-content: center;
	margin-top: 13.84375em;
	overflow: hidden;
	position: sticky;
	top: 0;
}

#home #service .scroll_wrap {
	align-items: center;
	aspect-ratio: 1400 / 900;
	display: flex;
	height: 100%;
	max-width: 87.5em;
	position: relative;
}

#home #service .scroll_wrap_inner {
	column-gap: 1.25em;
	display: flex;
	position: absolute;
}

#home #service .scroll_box {
	box-sizing: border-box;
	max-width: 87.5em;
	position: relative;
	width: calc(1400 / 2000 * 100vw);
}

#home #service .scroll_box .img {
	aspect-ratio: 1400 / 900;
}

#home #service .scroll_box .text {
	bottom: 5em;
	box-sizing: content-box;
	color: #FFF;
	left: 5em;
	max-width: 40.125em;
	padding: 0 0.625em;
	position: absolute;
	z-index: 10;
}

#home #service .scroll_box .text .sub {
	font-size: 0.875em;
	font-weight: bold;
	margin-bottom: -0.1em;
}

#home #service .scroll_box .text .main {
	font-size: 2.75em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1.2;
}

#home #service .scroll_box .text .jp {
	font-size: 1.125em;
	font-weight: bold;
}

#home #service .scroll_box .text p {
	letter-spacing: 0.1em;
	line-height: 2.286;
	margin-top: 0.625em;
}
#home #service02 {
	display: none;
}

#home #sdgs {
	display: flex;
	margin-top: 10.875em;
	overflow: hidden;
	padding-bottom: 16.5em;
}

#home #sdgs > * {
	flex-basis: 50%;
}

#home #sdgs .img .wrap {
	aspect-ratio: 1 / 1;
	margin-left: -36.25%;
	max-width: 85em;
	position: relative;
	width: 136%;
}

#home #sdgs .img .wrap > * {
	position: absolute;
}

#home #sdgs .img .logo {
	left: 51.45%;
	max-width: 24.375em;
	top: 47.7%;
	transform: translate(-50%, -50%);
	width: 29.3234%;
	z-index: 4;
	padding: 2em;
	background-color: #fff;
}

#home #sdgs .img .img01 {
	left: 28.85%;
	max-width: 30.625em;
	top: 35.5%;
	width: 36.8422%;
	z-index: 3;
}

#home #sdgs .img .img02 {
	left: 72.225%;
	max-width: 23.75em;
	top: 63.825%;
	width: 28.5715%;
	z-index: 2;
}

#home #sdgs .img .circle.front {
	animation: sdgs-rotate 120s linear infinite;
	z-index: 5;
}

#home #sdgs .img .circle.back {
	animation: sdgs-rotate 130s linear infinite;
	z-index: 1;
}

#home #sdgs .text {
	align-items: center;
	display: flex;
	justify-content: center;
}

#home #sdgs .text .wrap {
	margin-right: 0.375em;
	max-width: 37.125em;
}

#home #sdgs .text .section-title {
	margin-bottom: 0.455em;
}

#home #sdgs .text p {
	font-family: "Gen Jyuu Gothic X", sans-serif;
	font-size: 1.25em;
	letter-spacing: 0.1em;
}

#home #sdgs .text .btn {
	margin: 6.85em auto 5.8em;
}

#home #news {
	margin-bottom: 99px;
	overflow: hidden;
}

#home #news > .inner {
	max-width: 93.75em;
}

#home #news .swiper {
	margin-top: 3.5em;
	overflow: visible;
}

#home #news .swiper-slide {
	max-width: 28.125em;
}

#home #news .swiper-slide:not(:last-child) {
	margin-right: 1.875em;
}

#home #news .swiper-slide .text {
	border: 1px solid #CCC;
}

#home #news .swiper-slide .text > * {
	display: block;
	height: 100%;
	padding: 0.85em 1.825em 1.4em;
	width: 100%;
}

#home #news .swiper-slide .text > *:after {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: 1.875em;
	margin: 0.125em -1.375em -0.125em auto;
	width: 1.875em;
}

#home #news .swiper-slide .text.detail a:after {
	background-image: url(../images/icon_arrow01.svg);
}

#home #news .swiper-slide .text.external a:after {
	background-image: url(../images/icon_external01.svg);
}

#home #news .swiper-slide .text.pdf a:after {
	background-image: url(../images/icon_pdf01.svg);
}

#home #news .swiper-slide .text .date {
	color: #BCBCBC;
	display: block;
	font-weight: bold;
	letter-spacing: 0.1em;
	margin-bottom: -0.025em;
}

#home #news .swiper-slide .text .headline {
	font-size: 1.125em;
	letter-spacing: 0.1em;
	line-height: 2;
	min-height: 4em;
}

#single .header {
	margin-top: -25px;
}

#single .header .headline {
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 0.075em;
	line-height: 2;
}

#single .header .date {
	display: block;
	font-size: 20px;
	letter-spacing: 0.075em;
	line-height: 1.5;
	margin-top: 0.4em;
}

#single .eyecatch {
	margin: 32px 0;
}

#single .eyecatch:before {
	padding-top: 52.8635%;
}

#single .content-post {
	margin-top: 93px;
	padding-bottom: 142px;
}

#single .content > .inner:last-of-type {
	padding-bottom: 250px;
}

#single .news-list + .btn {
	margin-top: 41px;
}


/*---------------------------------------------------------------------------service*/
#certified {

}
#certified ul {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack:justify;
	-webkit-justify-content: space-between;
	justify-content:space-between;
	margin-top: 7.75em;
}
#certified ul li {
	width: 29.5%;
}
#certified figure {
	position: relative;
	width: 100%;
	border: 1px solid #ddd;

}
#certified figure:before {
	content:"";
	display: block;
	padding-top: 90%;
}
#certified figure img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	max-width: 74%;
}
#certified h5 {
	font-weight: bold;
	font-size: 1.1875em;
}
#certified p {
	font-size: 1em;
}

#service_archive ul.page-list {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
	margin-top: 10em;
}

#service_archive ul.page-list li {
	width: 47%;
	position: relative;
	margin-bottom: 7em;
}

#service_archive ul.page-list li:nth-of-type(2n) {
	margin-left: 6%;
}

#service_archive ul.page-list li .title-en {
	position: absolute;
	top: -1.25em;
	left: 0.2em;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: sideways;
	font-size: 2.25em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1;
	z-index: 10;
}
#service_archive ul.page-list li .title-jp {
	position: absolute;
	bottom: -2.5em;
	right: 0;
}

#service_archive ul.page-list li a figure:before {
	content: "";
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 9;
	display: block;
	transition: all .3s ease;
}
#service_archive ul.page-list li a:hover figure:before {
	background-color: rgba(255, 255, 255, 0.4);
}

#service_archive ul.page-list li a img {
	transition: all .3s ease;
}
#service_archive ul.page-list li a:hover img {
	filter: grayscale(100%);
}

/*---------------------------------------------------------------------------SUSTAINABILITY*/
body#sdgs #materiality .section-title-sub:before,
body#sdgs #initiative .section-title-sub:before {
	content: "";
	display: inline-block;
	height: calc(30 / 36 * 1em);
	margin-left: 0.025em;
	margin-right: 0.425em;
	position: relative;
	top: -0.025em;
	vertical-align: middle;
	width: calc(20.65 / 36 * 1em);
}

body#sdgs {
	background-color: #E9E8E7;
}

body#sdgs #header .logo a {
	display: block;
	width: 12.5em;
}

body#sdgs #header .logo a:before {
	aspect-ratio: 273 / 32.79;
	background: url(../images/logo01.svg) no-repeat top center/cover;
	content: "";
	display: block;
	width: 100%;
}

body#sdgs #header .logo a img {
	display: none;
}

body#sdgs #header .btn-menu {
	color: #000;
}

body#sdgs #main {
	font-family: "Century Gothic", "CenturyGothic", "Noto Sans JP", sans-serif;
}

body#sdgs .content {
	color: #7A7370;
}

body#sdgs .hero {
	align-items: center;
	display: flex;
	height: 100vh;
	padding-top: 6.4em;
}

body#sdgs .hero .inner {
	max-width: 93.75em;
	width: 100%;
}

body#sdgs .hero .block {
	display: flex;
	justify-content: space-between;
}

body#sdgs .hero .catchcopy {
	color: #156D0F;
}

body#sdgs .hero .catchcopy h2 {
	font-size: 3.75em;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
}

body#sdgs .hero .catchcopy h2.en {
	font-size: 1.875em;
	letter-spacing: 0;
	margin-top: 1.225em;
}

body#sdgs .hero .img {
	margin-top: 5.8em;
	max-width: 48.8em;
}

body#sdgs .hero .img .kv-sp {
	display: none;
}

body#sdgs .page-title,
body#sdgs .section-title {
	color: #D8DCD8;
	font-size: 6.25em;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1;
	white-space: nowrap;
}

body#sdgs .page-title.small,
body#sdgs .section-title.small {
	font-size: 4.625em;
}

body#sdgs .page-title-sub,
body#sdgs .section-title-sub {
	color: #156D0F;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 2.25em;
	font-weight: bold;
	letter-spacing: 0.05em;
}

body#sdgs .page-title-sub.small,
body#sdgs .section-title-sub.small {
	font-size: 1.625em;
	line-height: 1.5;
}

body#sdgs .goals {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25em;
	margin: 2.55em auto 1.575em;
}

body#sdgs .goals > li {
	max-width: 3.75em;
}

body#sdgs .btn > * {
	background-color: #D9D5D3;
	border-radius: calc(30 / 16 * 1em);
	color: #444444;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1em;
	height: 6.25em;
	max-width: 30em;
	transition: all 0.3s;
	width: 100%;
	border: 0;
}

.desktop body#sdgs .btn > *:hover {
	background-color: #726d6b;
	color: #f4f4f4;
}

body#sdgs .btn.pdf a:after {
	background: url(../images/icon_pdf02.svg) no-repeat center/cover;
	content: "";
	display: inline-block;
	height: 1.875em;
	margin-right: calc(-1.875em - 0.2em);
	position: relative;
	right: -0.2em;
	width: 1.875em;
	transition: all .3s;
}

.desktop body#sdgs .btn.pdf a:hover:after {
	background: url(../images/icon_pdf03.svg) no-repeat center/cover;
}

body#sdgs .initiative-list {
	column-gap: 4%;
	display: flex;
	flex-wrap: wrap;
	margin-top: 6.7em;
}

body#sdgs .initiative-list > li {
	margin-bottom: 3.5295%;
	max-width: 48%;
	width: 100%;
}

body#sdgs .initiative-list > li a {
	background-color: #F4F4F4;
	border: 3px solid #F4F4F4;
	border-radius: 1.875em;
	color: #666;
	display: block;
	overflow: hidden;
	padding: calc(8.5% - 2px) calc(8.5785% - 2px) calc(4.85% - 2px);
	transition: all 0.3s;
}

.desktop body#sdgs .initiative-list > li a:hover {
	border-color: #cec8c5;
	background-color: #edeceb;
}

body#sdgs .initiative-list > li h4 {
	font-size: 1.625em;
	font-weight: bold;
	letter-spacing: 0.05em;
	line-height: 1.75;
}

body#sdgs .initiative-list > li p {
	font-size: 1.125em;
	letter-spacing: 0.05em;
	line-height: 2;
	margin: 1.7em auto;
}

body#sdgs .initiative-list .link {
	text-align: right;
}

body#sdgs .initiative-list .link > * {
	color: #777;
	font-size: 0.875em;
	letter-spacing: 0.05em;
	position: relative;
}

body#sdgs .initiative-list .link > *:after {
	background: url(../images/arrow02.svg) no-repeat center/cover;
	content: "";
	display: inline-block;
	height: calc(10.22 / 14 * 1em);
	margin-left: 0.675em;
	position: relative;
	top: -0.1em;
	vertical-align: middle;
	width: calc(14 / 14 * 1em);
}

body#sdgs #slogan {
	overflow: hidden;
	padding-bottom: 12.5em;
	padding-top: 4.15em;
	position: relative;
}

body#sdgs #slogan:after {
	background: url(../images/sdgs_materiality_bg01.svg) no-repeat top center/cover;
	bottom: 0;
	content: "";
	display: block;
	height: 10.3125em;
	left: 0;
	position: absolute;
	width: 100%;
	z-index: -1;
}

body#sdgs #slogan .section-title {
	font-size: 7.5em;
	letter-spacing: 0.075em;
	margin-bottom: 0.275em;
	position: relative;
	text-align: center;
	text-indent: 0.075em;
	z-index: 2;
}

body#sdgs #slogan .inner {
	display: flex;
	justify-content: space-between;
	max-width: 108.75em;
}

body#sdgs #slogan .block {
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 1;
}

body#sdgs #slogan .block:after {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	position: absolute;
	z-index: -1;
}

body#sdgs #slogan .block h3 {
	font-size: 2.25em;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.75;
	margin-bottom: 0.825em;
	margin-top: 1.175em;
}

body#sdgs #slogan .block h3.en {
	font-size: 2.5em;
	letter-spacing: 0;
}

body#sdgs #slogan .block p {
	font-size: 1.125em;
	letter-spacing: 0.05em;
	line-height: 2;
	margin-bottom: 2.175em;
	max-width: 36.1112em;
}

body#sdgs #slogan .block:nth-child(1):after {
	background-image: url(../images/sdgs_slogan_bg01.svg);
	height: 48.5em;
	left: -20.6em;
	top: -9.75em;
	width: 52.5em;
}

body#sdgs #slogan .block:nth-child(1) .img {
	left: -0.25em;
	margin: auto;
	max-width: 26.3125em;
	order: 3;
	position: relative;
}

body#sdgs #slogan .block:nth-child(1) .img .clip {
	clip-path: url(#cpath02);
}

body#sdgs #slogan .block:nth-child(2):after {
	background-image: url(../images/sdgs_slogan_bg02.svg);
	bottom: -8.25em;
	height: 50.5625em;
	right: -16.25em;
	width: 50.625em;
}

body#sdgs #slogan .block:nth-child(2) .img {
	margin-left: auto;
	max-width: 26.25em;
}

body#sdgs #slogan .block:nth-child(2) .img .clip {
	clip-path: url(#cpath03);
}

body#sdgs #slogan .block:nth-child(2) h3 {
	margin-bottom: 1em;
	margin-top: 1.25em;
}

body#sdgs #slogan .block:nth-child(2) p {
	margin-left: auto;
}

body#sdgs #materiality {
	background-color: #DDD9D7;
	overflow: hidden;
	padding-bottom: 1.25em;
	padding-top: 6.675em;
}

body#sdgs #materiality .headline {
	margin: auto;
	max-width: 106.25em;
}

body#sdgs #materiality .section-title {
	color: #C9CDC9;
}

body#sdgs #materiality .section-title-sub {
	line-height: 1.75;
	margin-top: 0.3em;
}

body#sdgs #materiality .section-title-sub:before {
	background: url(../images/icon_bean01.svg) no-repeat top center/cover;
}

body#sdgs #materiality .wrap {
	color: #444444;
	display: flex;
	margin-top: 5.6em;
	padding-left: 40px;
}

body#sdgs #materiality .wrap > .block {
	flex-basis: 50%;
}

body#sdgs #materiality .text {
	margin-left: auto;
	margin-right: 0.625em;
	max-width: 53.75em;
}

body#sdgs #materiality .text li,
body#sdgs #materiality .text p {
	font-size: 1.125em;
	letter-spacing: 0.05em;
	line-height: 2;
}

body#sdgs #materiality .text ul {
	margin: 5.9em 0;
}

body#sdgs #materiality .text ul li {
	margin: 1.5em 0;
	padding-left: 1.05em;
	position: relative;
}

body#sdgs #materiality .text ul li:before {
	background-color: #156D0F;
	border-radius: 100%;
	content: "";
	display: block;
	height: calc(7 / 18 * 1em);
	left: 0;
	position: absolute;
	top: 0.825em;
	width: calc(7 / 18 * 1em);
}

body#sdgs #materiality .img {
	box-sizing: content-box;
	margin-left: auto;
	max-width: 53.125em;
	padding-left: 40px;
	padding-top: 0.625em;
}

body#sdgs #materiality .img img {
	border-bottom-left-radius: calc(30 / 16 * 1em);
	border-top-left-radius: calc(30 / 16 * 1em);
	overflow: hidden;
}

body#sdgs #initiative {
	background-color: #E5E2E0;
	padding-bottom: 19.825em;
	padding-top: 20.875em;
	position: relative;
}

body#sdgs #initiative:before {
	background: url(../images/sdgs_materiality_bg01.svg) no-repeat bottom center/cover;
	content: "";
	display: block;
	height: 10.3125em;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

body#sdgs #initiative:after {
	background: url(../images/sdgs_tree01.svg) no-repeat center/cover;
	content: "";
	display: block;
	height: calc(363.33 / 16 * 1em);
	position: absolute;
	right: 6.675%;
	top: -4.775em;
	width: calc(324.6 / 16 * 1em);
}

body#sdgs #initiative > .inner {
	max-width: 106.25em;
	position: relative;
	z-index: 2;
}

body#sdgs #initiative .section-title {
	color: #D3D7D3;
	text-align: center;
	text-indent: 0.075em;
}

body#sdgs #initiative .section-title-sub {
	margin-top: -0.275em;
	text-align: center;
}

body#sdgs #initiative .section-title-sub:before {
	background: url(../images/icon_bean02.svg) no-repeat top center/cover;
}

body#sdgs #other {
	background-color: #E9E8E7;
	padding-bottom: 10em;
	padding-top: 10.25em;
	position: relative;
}

body#sdgs #other:before {
	background: url(../images/sdgs_other_bg01.svg) no-repeat top center/cover;
	content: "";
	display: block;
	height: 5.625em;
	left: 0;
	position: absolute;
	top: -5.625em;
	width: 100%;
}

body#sdgs #other:after {
	background: url(../images/sdgs_tree02.svg) no-repeat center/cover;
	content: "";
	display: block;
	height: calc(334.3 / 16 * 1em);
	left: 2.75%;
	position: absolute;
	top: -16.2em;
	width: calc(269.72 / 16 * 1em);
}

body#sdgs #other .inner {
	max-width: 87.5em;
}

body#sdgs #other .wrap {
	display: flex;
}

body#sdgs #other .wrap:not(:last-child) {
	margin-bottom: 6.125em;
}

body#sdgs #other .wrap > .block {
	flex-basis: 50%;
}

body#sdgs #other .wrap > .block .img {
	border-radius: calc(30 / 16 * 1em);
	margin-top: 0.625em;
	max-width: 42.5em;
	overflow: hidden;
}

body#sdgs #other .wrap > .block .text {
	box-sizing: content-box;
	max-width: 35em;
}

body#sdgs #other .wrap > .block .text .section-title-sub {
	margin: 0.45em 0;
}

body#sdgs #other .wrap > .block .text p {
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0.05em;
	line-height: 2;
	margin-top: 4.1em;
}

body#sdgs #other .wrap > .block .text .btn {
	margin-top: 2.75em;
}

body#sdgs #other .wrap:nth-child(odd) > .block:nth-child(1) {
	order: 2;
}

body#sdgs #other .wrap:nth-child(odd) > .block .img {
	margin-left: auto;
}

body#sdgs #other .wrap:nth-child(odd) > .block .text {
	padding-right: 1.25em;
}

body#sdgs #other .wrap:nth-child(even) > .block .text {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.25em;
}

body#sdgs #other #news {
	overflow: hidden;
}

body#sdgs #other #news .inner {
	background-color: #E5E2E0;
	box-sizing: border-box;
	margin: 10.75em auto;
	max-width: 106.25em;
	padding-bottom: 5em;
	padding-top: 4.875em;
	position: relative;
}

body#sdgs #other #news .inner:before {
	background: url(../images/sdgs_tree03.svg) no-repeat center/cover;
	content: "";
	display: block;
	height: calc(256.38 / 16 * 1em);
	position: absolute;
	right: -5.7%;
	top: -7.875em;
	width: calc(257.34 / 16 * 1em);
}

body#sdgs #other #news .section-title {
	color: #D3D7D3;
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs #other #news .section-title-sub {
	margin: 0.6em 0;
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs #other #news .link {
	margin-bottom: 0.4em;
	margin-top: 4.9em;
	text-align: center;
}

body#sdgs #other #news .link > * {
	letter-spacing: 0.05em;
	margin-left: -1.5em;
	position: relative;
	transition: opacity 0.3s;
}

.desktop body#sdgs #other #news .link > *:hover {
	opacity: 0.6;
}

body#sdgs #other #news .link > *:before {
	background-color: #999;
	bottom: -0.45em;
	content: "";
	height: 2px;
	position: absolute;
	width: 100%;
}

body#sdgs #other #news .link > *:after {
	background: url(../images/arrow02.svg) no-repeat center/cover;
	content: "";
	display: inline-block;
	height: calc(10.22 / 16 * 1em);
	margin-left: 0.6em;
	position: absolute;
	top: 0.425em;
	vertical-align: middle;
	width: calc(14 / 16 * 1em);
	transition: all .3s;
}

.desktop body#sdgs #other #news .link > *:hover:after {
	transform: translateX(0.5em);
}

body#sdgs #other #report {
	padding-top: 0.325em;
}

body#sdgs #other #report .section-title {
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs #other #report .section-title-sub {
	margin: 0.55em 0;
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs #other #report .btn {
	justify-content: center;
	margin: 4.675em auto 2.675em;
}

body#sdgs #other #report .btn > * {
	max-width: 46.875em;
}

body#sdgs .news-list {
	margin: 4.175em auto;
	max-width: 75em;
	overflow: hidden;
}

body#sdgs .news-list li {
	margin: 2.25em auto;
}

body#sdgs .news-list li a,
body#sdgs .news-list li.nolink {
	column-gap: 3.55em;
	display: flex;
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0.055em;
	line-height: 2;
	transition: all 0.3s;
}

.desktop body#sdgs .news-list li a:hover {
	opacity: 0.6;
}

body#sdgs .news-list li a .date,
body#sdgs .news-list li.nolink .date {
	color: #777;
	font-weight: 700;
	padding-top: 0.1em;
}

body#sdgs .news-list li a .title,
body#sdgs .news-list li.nolink .title {
	color: #444444;
	font-size: 1.125em;
}

body#sdgs .news-list li a .title span {
	font-weight: inherit;
	padding-right: calc(1.875em * (16 / 18));
}

.desktop body#sdgs .news-list li a:hover .title span {
	border-bottom: 2px solid #cec8c5;
}


body#sdgs .news-list li a[href$=".pdf"] .title:after {
	background: url(../images/icon_pdf02.svg) no-repeat center/cover;
	content: "";
	display: inline-block;
	height: calc(1.875em * (16 / 18));
	left: 0.2em;
	margin-left: calc(-1.875em * (16 / 18));
	position: relative;
	top: -0.1em;
	vertical-align: middle;
	width: calc(1.875em * (16 / 18));
}

body#sdgs[class*="news"],
body#sdgs.single,
body#sdgs.category {
	background-color: #ECEBEA;
}

body#sdgs[class*="news"] .hero,
body#sdgs.single .hero,
body#sdgs.category .hero {
	background-color: #E8E5E3;
	display: block;
	height: auto;
	overflow: hidden;
	padding-top: 5.625em;
	position: relative;
}

body#sdgs[class*="news"] .hero:after,
body#sdgs.single .hero:after,
body#sdgs.category .hero:after {
	background: url(../images/sdgs_page_bg01.svg) no-repeat top center/cover;
	bottom: 0;
	content: "";
	display: block;
	height: 10.3125em;
	left: 0;
	position: absolute;
	width: 100%;
}

body#sdgs[class*="news"] .hero .inner,
body#sdgs.single .hero .inner,
body#sdgs.category .hero .inner {
	max-width: 100em;
	position: relative;
	z-index: 1;
}

body#sdgs[class*="news"] .hero .wrap,
body#sdgs.single .hero .wrap,
body#sdgs.category .hero .wrap {
	display: flex;
	justify-content: space-between;
	padding-bottom: 2.2em;
}

body#sdgs[class*="news"] .hero .block,
body#sdgs.single .hero .block,
body#sdgs.category .hero .block {
	display: block;
}

body#sdgs[class*="news"] .hero .block:nth-child(1),
body#sdgs.single .hero .block:nth-child(1),
body#sdgs.category .hero .block:nth-child(1) {
	flex-basis: calc((1600 - 706) / 1600 * 100%);
	padding-top: 14.15em;
}

body#sdgs[class*="news"] .hero .block:nth-child(2),
body#sdgs.single .hero .block:nth-child(2),
body#sdgs.category .hero .block:nth-child(2) {
	flex-basis: calc(706 / 1600 * 100%);
}

body#sdgs[class*="news"] .hero .title,
body#sdgs.single .hero .title,
body#sdgs.category .hero .title {
	margin-left: auto;
	max-width: 49.625em;
}

body#sdgs[class*="news"] .hero .title .page-title,
body#sdgs.single .hero .title .page-title,
body#sdgs.category .hero .title .page-title {
	color: #D6DAD6;
}

body#sdgs[class*="news"] .hero .title .page-title-sub,
body#sdgs.single .hero .title .page-title-sub,
body#sdgs.category .hero .title .page-title-sub {
	line-height: 1.5;
	margin-top: 0.21em;
	text-indent: 0.05em;
}

body#sdgs[class*="news"] .hero .img,
body#sdgs.single .hero .img,
body#sdgs.category .hero .img {
	margin-top: 8.15em;
	max-width: 44.125em;
}

body#sdgs[class*="news"] .hero .img .clip,
body#sdgs.single .hero .img .clip,
body#sdgs.category .hero .img .clip {
	clip-path: url(#cpath01);
}

body#sdgs[class*="news"] .content,
body#sdgs.single .content,
body#sdgs.category .content {
	padding-top: 6.675em;
}

body#sdgs[class*="news"] .content > .inner,
body#sdgs.single .content > .inner,
body#sdgs.category .content > .inner {
	max-width: 82.5em;
}

body#sdgs .description {
	color: #444444;
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0.05em;
	line-height: 2;
	text-align: center;
}

body#sdgs .sdgs-list {
	column-gap: 3.788%;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 9.3em;
	margin-top: 4.75em;
}

body#sdgs .sdgs-list > li {
	margin-bottom: 3.875%;
	max-width: 48.106%;
	width: 100%;
}

body#sdgs .sdgs-list > li a {
	align-items: center;
	background-color: #F4F4F4;
	border-radius: 1.875em;
	color: #666;
	display: flex;
	overflow: hidden;
	padding: calc(4.65% - 2px) calc(4.75% - 2px);
	transition: all 0.3s;
}

.desktop body#sdgs .sdgs-list > li a:hover {
	background-color: #cec8c5;
}

body#sdgs .sdgs-list .icon {
	flex-shrink: 0;
	margin-right: 5.125%;
	max-width: 5em;
}

body#sdgs .sdgs-list .title {
	font-size: 1.125em;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
	max-width: 25em;
}

body#sdgs .sdgs-list .title span {
	font-weight: inherit;
	padding-right: calc(1.875em * (16 / 18));
}

body#sdgs .sdgs-list .title:after {
	background: url(../images/icon_pdf02.svg) no-repeat center/cover;
	content: "";
	display: inline-block;
	height: calc(1.875em * (16 / 18));
	left: 0.2em;
	margin-left: calc(-1.875em * (16 / 18));
	position: relative;
	top: -0.15em;
	vertical-align: middle;
	width: calc(1.875em * (16 / 18));
}

body#sdgs.single .section-title {
	color: #DBDFDB;
	line-height: 1.175;
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs.single .section-title-sub {
	margin-top: 0.15em;
	text-align: center;
	text-indent: 0.05em;
}

body#sdgs.single .content > section > .inner {
	max-width: 87.5em;
}

body#sdgs.single .description {
	font-size: 1.125em;
	margin-top: 4.825em;
	text-indent: 0.5em;
}

body#sdgs.single .activities-list > li {
	color: #666;
	font-family: "Noto Sans JP", sans-serif;
	margin: 4.6em auto 5.15em;
}

body#sdgs.single .activities-list > li .title {
	font-size: 1.625em;
	font-weight: 700;
	letter-spacing: 0.05em;
}

body#sdgs.single .activities-list > li .title .underline {
	background-image: linear-gradient(to right, #156D0F, #156D0F 5px, transparent 5px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 10px 2px;
	font-weight: inherit;
	padding: 0.725em 0;
}

body#sdgs.single .activities-list > li .goals {
	gap: 0.9375em;
	margin: 2.75em auto 1.95em;
}

body#sdgs.single .activities-list > li .goals > li {
	max-width: 4.25em;
}

body#sdgs.single .activities-list > li .text {
	letter-spacing: 0.05em;
	line-height: 2;
}

body#sdgs.single .activities-list > li .images {
	column-gap: calc(((1700 - (544 * 3)) / 2) / 1700 * 100%);
	display: flex;
	flex-wrap: wrap;
	margin: 2.075em auto;
}

body#sdgs.single .activities-list > li .images > li {
	flex-basis: calc(544 / 1700 * 100%);
	margin-bottom: 1%;
}

body#sdgs.single .activities-list > li .images .caption {
	font-size: 0.875em;
	letter-spacing: 0.05em;
	line-height: 1.5;
	margin: 0.875em 0;
	text-align: center;
}

body#sdgs.single #others {
	padding-bottom: 9.4em;
	padding-top: 2.65em;
}

body#sdgs.single #others .section-title {
	color: #D4D8D4;
}

body#sdgs.single #others .initiative-list {
	column-gap: calc(((1700 - (533 * 3)) / 2) / 1700 * 100%);
	margin-top: 4.75em;
}

body#sdgs.single #others .initiative-list > li {
	margin-bottom: 2.9%;
	max-width: calc(533 / 1700 * 100%);
}

body#sdgs.single #others .initiative-list > li a {
	padding: 7.8% 9.35% 3.4%;
}

body#sdgs.single #others .initiative-list > li h4 {
	font-size: 1.25em;
}

body#sdgs.single #others .initiative-list .goals {
	gap: 0.625em;
	margin: 0.8em auto 0.375em;
}

body#sdgs.single #others .initiative-list .goals > li {
	max-width: 2.5em;
}

body#sdgs[class*="news"] .content {
	padding-bottom: 12.325em;
	padding-top: 0;
}

body#sdgs[class*="news"] .news-list li {
	margin: 2.8em auto;
}

body#sdgs .pagination {
	margin-top: 5.75em;
}

body#sdgs .pagination ul.page-numbers {
	display: flex;
	justify-content: center;
	margin: -0.625em;
}

body#sdgs .pagination ul.page-numbers li {
	margin: 0.625em;
}

.desktop body#sdgs .pagination ul.page-numbers li a:hover,
body#sdgs .pagination ul.page-numbers li .page-numbers.current {
	background-color: #A09997;
	color: #DDD;
}

body#sdgs .pagination ul.page-numbers li a {
	transition: background-color 0.3s, color 0.3s;
}

body#sdgs .pagination ul.page-numbers .page-numbers {
	background-color: #D9D5D3;
	border-radius: calc(5 / 20 * 1em);
	color: #555;
	display: block;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.25em;
	font-weight: bold;
	height: 2.5em;
	line-height: 2.35em;
	text-align: center;
	text-indent: 0.05em;
	width: 2.5em;
}

body#sdgs .pagination ul.page-numbers .page-numbers.prev,
body#sdgs .pagination ul.page-numbers .page-numbers.next {
	overflow: hidden;
	position: relative;
	text-indent: 200%;
	white-space: nowrap;
}

body#sdgs .pagination ul.page-numbers .page-numbers.prev:before,
body#sdgs .pagination ul.page-numbers .page-numbers.prev:after,
body#sdgs .pagination ul.page-numbers .page-numbers.next:before,
body#sdgs .pagination ul.page-numbers .page-numbers.next:after {
	background-color: currentColor;
	content: "";
	display: block;
	height: calc(2.5 / 20 * 1em);
	left: calc(50% - 4.75px);
	position: absolute;
	top: calc(50% - (2.5 / 2 / 20 * 1em));
	transform: rotate(45deg) translateY(calc(-2.5 / 2 / 20 * 1em));
	transform-origin: left center;
	width: calc(9.5 / 20 * 1em);
}

body#sdgs .pagination ul.page-numbers .page-numbers.prev:after,
body#sdgs .pagination ul.page-numbers .page-numbers.next:after {
	transform: rotate(-45deg) translateY(calc(2.5 / 2 / 20 * 1em));
}

body#sdgs .pagination ul.page-numbers .page-numbers.next {
	transform: scale(-1);
}


/*---------------------------------------------------------------------------961pxupper*/
@media (min-width: 961px) {

body#history.page-child .history-nav ul {
	position: sticky;
	top: calc(100 / 16 * 1em);
}

body#history.page-child .history-detail-header .headline:nth-child(1) {
	padding-right: 14%;
}

}


/*---------------------------------------------------------------------------1900px*/
@media (max-width: 1900px) {

body#sdgs #other #news .inner:before {
	right: -2.75%;
}

}

/*---------------------------------------------------------------------------1800px*/
@media (max-width: 1800px) {

body {
	font-size: 87.5%;
}

}


/*---------------------------------------------------------------------------1480px*/
@media (max-width: 1480px) {

body {
	font-size: 68.75%;
}

#home #intro .catchphrase {
	height: 100vh;
}
#home #intro .catchphrase figure {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	max-width: 100%;
	width: 100%;
}
#home #intro #history .text p {
	font-size: 1.636em;
}

#home #service .scroll_box .text p {
	font-size: 1.27em;
}

#home #sdgs .text p {
	font-size: 1.636em;	
}

#home #news .swiper-slide .text .headline {
	font-size: 1.454em;
}

body#company #slogan p {
	font-size: 1.45em;
}
	
body#company #promise .text h4 {
	font-size: 1.875em;
}

body#company #promise .text p {
	font-size: 1.45em;
}

body#company #message .container p {
	font-size: 1.9em;
}

body#history .content .history-list .text > p,
body#history #intro .block p,
body#sdgs .initiative-list > li p,
body#sdgs #slogan .block p,
body#sdgs #materiality .text li,
body#sdgs #materiality .text p,
body#sdgs #other .wrap > .block .text p,
body#sdgs .news-list li a .title,
body#sdgs .news-list li.nolink .title,
body#sdgs .description,
body#sdgs.single .description {
	font-size: calc(16 / 11 * 1em);
}

body#sdgs .initiative-list .link > *,
body#sdgs #other #news .link > *,
body#sdgs .news-list li a .date,
body#sdgs .news-list li.nolink .date,
body#sdgs.single .activities-list > li .text {
	font-size: calc(15 / 11 * 1em);
}

body#sdgs .btn > * {
	font-size: calc(14 / 11 * 1em);
}

body#sdgs.single .activities-list > li .images .caption {
	font-size: calc(11 / 11 * 1em);
}

body#sdgs .sdgs-list .title {
	font-size: calc(15 / 11 * 1em);
}
}

@media (max-width: 1120px) {

body#sdgs .hero .block {
	display: block;
}

body#sdgs .hero .img {
	margin-left: auto;
	margin-top: 0;
}

}

@media (max-width: 1040px) {

body#history .content .history-list {
	max-width: 75.625em;
}

body#history .content .history-list > li:nth-child(odd) .text {
	margin-right: auto;
}

body#history .content .history-list > li:nth-child(odd) .images {
	margin-left: 0;
}

body#history .content .history-list .text {
	margin-bottom: 2em;
	margin-left: 0;
}

body#history .content .history-list .text > p {
	margin-bottom: 1.5em;
}

body#history .content .history-list .detail-btn {
	position: relative;
}
}

/*---------------------------------------------------------------------------960px*/
@media (max-width: 960px) {

#header .menu {
	width: 100%;
}

#footer.sdgs .pagetop {
	bottom: 9.5em;
}

#header figure {
	display: none;
}

.page .hero .inner {
	display: block;
}

body#history.page-child .history-nav ul li.current a,
.desktop body#history.page-child .history-nav ul li a:hover {
	background-color: transparent;
	padding-left: 0;
}

body#history.page-child .content {
	display: block;
}

body#company #slogan .slogan {
	display: block;
}

body#history.page-child .history-detail {
	box-sizing: border-box;
}

#home #service02 .text p {
	font-size: 1.27em;
}

#home #sdgs .text p {
	font-size: 1.45em;	
}

body#history.page-child .history-nav ul li.current a,
.desktop body#history.page-child .history-nav ul li a:hover {
	background-color: transparent;
	padding-left: 0;
}

body#history.page-child .history-nav ul li.current a:before,
.desktop body#history.page-child .history-nav ul li a:hover:before,
body#history.page-child .history-nav ul li.current a:after,
.desktop body#history.page-child .history-nav ul li a:hover:after {
	filter: brightness(1.4);
}

body#history .content .history-list:before {
	display: none;
}

body#history .content .history-list:after {
	display: none;
}

body#history .content .history-list > li:before {
	display: none;
}

body#history .content .history-list .text {
	width: 100%;
}

body#history.page-child .content {
	display: block;
	padding-top: 15px;
}

body#history.page-child .history-nav ul {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 8em;
}

body#history.page-child .history-nav ul li {
	margin-bottom: 0;
	width: 25%;
}

body#history.page-child .history-nav ul li.to-archive {
	margin-left: auto;
	max-width: 11em;
	width: 29.25%;
}

body#history.page-child .history-nav ul li.to-archive a {
	border-radius: 0;
	height: 2.1em;
	margin-top: 0.75em;
}

body#history.page-child .history-nav ul li.to-archive a .title {
	font-size: 1em;
	margin-left: 0.25em;
}

body#history.page-child .history-nav ul li.to-archive a .title:after {
	border: 0.75px solid #A5A09F;
	border-bottom: none;
	border-left: none;
	content: "";
	display: inline-block;
	height: 0.4em;
	margin-left: 0.8em;
	position: relative;
	top: -0.2em;
	transform: rotate(45deg);
	width: 0.4em;
}

body#history.page-child .history-nav ul li.to-archive a:before {
	display: none;
}

body#history.page-child .history-nav ul li.to-archive a:after {
	background: #423E3E;
	bottom: 0;
	height: 0.7em;
}

body#history.page-child .history-nav ul li:first-child a:after {
	background-image: url(../images/history_nav_sp_bg01.svg);
}

body#history.page-child .history-nav ul li a {
	background-color: transparent;
	display: flex;
	height: 3.8em;
	margin-right: 0;
	min-width: auto;
	overflow: hidden;
	text-align: center;
	transition: none;
	width: 100%;
}

body#history.page-child .history-nav ul li a:before {
	background-color: #423E3E;
	content: "";
	display: block;
	height: 100%;
	position: absolute;
	right: 0;
	transition: filter 0.3s;
	width: 90%;
}

body#history.page-child .history-nav ul li a:after {
	background: url(../images/history_nav_sp_bg02.svg) no-repeat left center/contain;
	content: "";
	display: block;
	height: 100%;
	position: absolute;
	transition: filter 0.3s;
	width: 100%;
}

body#history.page-child .history-nav ul li a .title {
	font-size: 1.4em;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-top: 0.35em;
	text-align: left;
	white-space: nowrap;
	width: 3.125em;
}

body#history.page-child .history-nav ul li a .year {
	font-size: 1em;
	margin-left: -0.75em;
	margin-right: 0;
	margin-top: -1.85em;
	z-index: 1;
}

body#history.page-child .history-detail {
	box-sizing: border-box;
}

body#sdgs .initiative-list > li {
	max-width: none;
}

body#sdgs #slogan .section-title {
	margin-bottom: 0.75em;
}

body#sdgs #slogan .inner {
	flex-wrap: wrap;
}

body#sdgs #slogan .block:nth-child(1):after {
	bottom: -6em;
	top: auto;
}

body#sdgs #slogan .block:nth-child(1) .img {
	order: 0;
}

body#sdgs #slogan .block:nth-child(2) {
	margin-left: auto;
}

body#sdgs #materiality {
	padding-bottom: 7.25em;
}

body#sdgs #materiality .wrap {
	flex-wrap: wrap;
}

body#sdgs #materiality .wrap > .block {
	flex-basis: 100%;
}

body#sdgs #materiality .text {
	margin-left: 0;
	margin-right: 40px;
	max-width: none;
}

body#sdgs #other .wrap {
	flex-wrap: wrap;
}

body#sdgs #other .wrap > .block {
	flex-basis: 100%;
}

body#sdgs #other .wrap > .block .img {
	margin-left: auto;
	margin-right: auto;
	max-width: 50em;
}

body#sdgs #other .wrap > .block .text {
	margin-left: auto;
	margin-right: auto;
	margin-top: 2.25em;
	max-width: 50em;
}

body#sdgs #other .wrap > .block .text p {
	margin-top: 2em;
}

body#sdgs #other .wrap:nth-child(odd) > .block:nth-child(1) {
	order: 0;
}

body#sdgs #other .wrap:nth-child(odd) > .block .text {
	padding-right: 0;
}

body#sdgs #other .wrap:nth-child(even) > .block .text {
	padding-left: 0;
}

body#sdgs[class*="news"] .hero .wrap,
body#sdgs.single .hero .wrap,
body#sdgs.category .hero .wrap {
	display: block;
}

body#sdgs[class*="news"] .hero .block:nth-child(1),
body#sdgs.single .hero .block:nth-child(1),
body#sdgs.category .hero .block:nth-child(1) {
	padding-top: 7.25em;
}

body#sdgs[class*="news"] .hero .title,
body#sdgs.single .hero .title,
body#sdgs.category .hero .title {
	margin-left: 0;
}

body#sdgs[class*="news"] .hero .img,
body#sdgs.single .hero .img,
body#sdgs.category .hero .img {
	margin-top: 0;
	max-width: 34em;
}

body#sdgs.single .activities-list > li .images {
	column-gap: 2%;
	justify-content: space-between;
}

body#sdgs.single .activities-list > li .images > li {
	flex-basis: 48%;
	margin-bottom: 2%;
}

body#sdgs.single #others .initiative-list {
	column-gap: 2%;
	justify-content: space-between;
}

body#sdgs.single #others .initiative-list > li {
	margin-bottom: 4%;
	max-width: 48%;
}

#single .header .headline {
	font-size: 25px;
	line-height: 1.8572;
}

#single .header .date {
	font-size: 15px;
}

#home #intro #history {
	display: block;
}

#home #intro #history .img figure {
	max-width: 480px;
	width: 80%;
	margin: 0 auto 5em auto;
}

#home #intro #history .text {
	width: 80%;
	margin: 0 auto;
	padding: 0;
	text-align: center;
}

#home #intro #history .text p {
	display: inline-block;
	text-align: left;
}

#home #intro #history .text .btn a {
	margin: 0 auto;
}

#home #intro .coffee {
	margin-top: -12em;
}

#service {
	display: none;
}

#home #service02 {
	display: block;
	margin-top: 10em;
}

#home #service02 .section-title {
	text-align: center;
}

#service02 ul {
	width: 80%;
	max-width: 700px;
	margin: 0 auto;
}

#service02 li {
	margin-bottom: 4em;
}

#service02 .img.cover img {
	position: static;
	height: auto;
}

#service02 .img.cover {
	height: auto;
}

#service02 .img.cover:before {
	padding: 0;
}

#home #service02 .text {
	/*transform: translateY(-88.8px);*/
	margin-left: 1em;
	margin-top: -88.8px;
	position: relative;
	z-index: 5;
}

#home #service02 .text .sub {
    font-size: 0.875em;
    font-weight: bold;
    margin-bottom: -0.1em;
    color: #fff;
}

#home #service02 .text .main {
    font-size: 2.75em;
    font-weight: bold;
    letter-spacing: 0.285em;
    line-height: 1.2;
    color: #fff;
}

#home #service02 .text .jp {
    font-size: 1.125em;
    font-weight: bold;
    color: #fff;
}
#home #service02 .text p {
	margin-left: -1em;
}

#home #sdgs {
	-webkit-flex-direction: column;
	-ms-flex-direction: column;
	flex-direction: column;	
}

#home #sdgs .text {
	order: 1;
}
#home #sdgs .text .wrap {
	width: 80%;
	max-width: none;
}

#home #sdgs .img {
	order: 2;
}

body#company #promise {
	background-position: 30% center;
}

body#company .page-list {
	display: block;
}

body#company .page-list li {
	width: 100%;
	max-width: 480px;
	margin: 0 auto 6em auto;
}

#certified ul {
	display: block;
}

#certified ul li {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	width: 100%;
	margin-bottom: 4em;
}

#certified figure {
	width: 40%;
	order: 2;
}

#certified h5 {
	width: 100%;
	order: 1;
}

#certified p {
	width: 55%;
	margin-left: 5%;
	order: 3;
}

}

/*---------------------------------------------------------------------------680px*/
@media (max-width: 680px) {

.inner,
body#history.page-child .history-detail {
	padding-left: 20px;
	padding-right: 20px;
}

.inner,
body#history.page-child .history-detail,
body#sdgs #other #news {
	padding-left: 20px;
	padding-right: 20px;
}

body#history .content .history-list .text > p,
body#history #intro .block p,
body#sdgs .initiative-list > li p,
body#sdgs #slogan .block p,
body#sdgs #materiality .text li,
body#sdgs #materiality .text p,
body#sdgs #other .wrap > .block .text p,
body#sdgs .news-list li a .title,
body#sdgs .description,
body#sdgs.single .description {
	font-size: 1.3em;
}

body#sdgs .initiative-list .link > *,
body#sdgs #other #news .link > *,
body#sdgs .news-list li a .date,
body#sdgs.single .activities-list > li .text {
	font-size: 1.2em;
}

body#sdgs .btn > * {
	font-size: 1.1em;
}

body#sdgs.single .activities-list > li .images .caption {
	font-size: 1em;
}

body {
	font-size: 62.5%;
}

.sp {
	display: inherit;
}

.pc {
	display: none;
}

body#company #promise {
	background-position: center;
}

.btn-menu {
    right: 0.15em;
}

#certified ul li {
	display: block;
	width: 100%;
	max-width: 400px;
	margin: 0 auto 4em auto;
}

#certified figure {
	width: 100%;
}

#certified p {
	width: 100%;
	margin-left: 0;
}

#service_archive ul.page-list {
	display: block;
}

#service_archive ul.page-list li {
	width: 90%;
	max-width: 460px;
	margin: 0 auto 6em auto;
}

#service_archive ul.page-list li:nth-of-type(2n) {
	margin: 0 auto 6em auto;
}

#error .content {
	padding-top: 160px;
}

#error .content .code + p {
	font-size: 14px;
}

#archive .content .inner {
	padding-bottom: 100px;
}

body#history .content .history-list {
	margin-bottom: 9em;
}

body#history #intro {
	text-align: left;
}

body#history.page-child .hero {
	border-width: 8em;
}

body#history.page-child .hero .block {
	margin-bottom: 3.25em;
}

body#history.page-child .hero .history-title {
	font-size: 2.2em;
	text-indent: 0.25em;
}

body#history.page-child .hero .history-start {
	font-size: 5em;
	top: 15%;
}

body#history.page-child .history-nav ul {
	margin-bottom: 5em;
}

body#history.page-child .history-detail {
	max-width: 50em;
}

body#history.page-child .history-detail-header {
	display: none;
}

body#history.page-child .history-detail-list {
	margin-top: 5em;
	padding-bottom: 0.5em;
}

body#history.page-child .history-detail-list:after {
	left: 0;
}

body#history.page-child .history-detail-list li {
	flex-wrap: wrap;
}

body#history.page-child .history-detail-list li:before {
	left: 0;
}

body#history.page-child .history-detail-list li .block {
	flex-basis: 100%;
}

body#history.page-child .history-detail-list li .block.company {
	margin-left: auto;
	padding-left: 7.1%;
	padding-right: 0;
	text-align: left;
}

body#history.page-child .history-detail-list li .block.company:before {
	left: 0;
	right: 0;
}

body#history.page-child .history-detail-list li .block.company + .product:before,
body#history.page-child .history-detail-list li .block.company + .product .year {
	display: none;
}

body#history.page-child .history-detail-list li .block.company + .product .year + p {
	margin-top: calc(2.25em - 1.125em);
}

body#history.page-child .history-detail-list li .block.product:before {
	left: 0;
}

body#sdgs .hero {
	max-height: 57.5em;
}

body#sdgs .hero .block {
	margin: auto -5px;
}

body#sdgs .hero .catchcopy h2 {
	font-size: 3.25em;
	line-height: 1.69;
}

body#sdgs .hero .catchcopy h2.en {
	font-size: 1.6em;
	margin-top: 1.125em;
}

body#sdgs .hero .img {
	margin-top: 4.65em;
	max-width: 33.75em;
}

body#sdgs .hero .img .kv-pc {
	display: none;
}

body#sdgs .hero .img .kv-sp {
	display: block;
}

body#sdgs .page-title,
body#sdgs .section-title {
	font-size: 4.625em;
}

body#sdgs .page-title.small,
body#sdgs .section-title.small {
	font-size: 3.5em;
}

body#sdgs .page-title-sub,
body#sdgs .section-title-sub {
	font-size: 2em;
}

body#sdgs .page-title-sub.small,
body#sdgs .section-title-sub.small {
	font-size: 1.8em;
}

body#sdgs .initiative-list > li h4 {
	font-size: 1.8em;
}

body#sdgs #slogan {
	padding-top: 7.25em;
}

body#sdgs #slogan .section-title {
	font-size: 5.8em;
}

body#sdgs #slogan .inner {
	margin-bottom: 5em;
}

body#sdgs #slogan .block {
	margin: auto auto 1.275em;
}

body#sdgs #slogan .block h3 {
	font-size: 2em;
	margin-bottom: 0.65em;
	margin-top: 0.85em;
}

body#sdgs #slogan .block h3.en {
	font-size: 2.4em;
}

body#sdgs #slogan .block:nth-child(1):after {
	bottom: auto;
	height: 31.2em;
	left: 50%;
	top: 9.625em;
	transform: translateX(-50%);
	width: 33.8em;
}

body#sdgs #slogan .block:nth-child(1) .img {
	max-width: 20em;
}

body#sdgs #slogan .block:nth-child(2) {
	margin-top: 3em;
}

body#sdgs #slogan .block:nth-child(2):after {
	bottom: auto;
	height: 33.7em;
	left: 50%;
	top: 9.625em;
	transform: translateX(-50%);
	width: 33.8em;
}

body#sdgs #slogan .block:nth-child(2) .img {
	margin-right: auto;
	max-width: 20em;
}

body#sdgs #slogan .block:nth-child(2) h3 {
	margin-bottom: 0.75em;
	margin-top: 1.1em;
}

body#sdgs #materiality {
	padding-top: 3.75em;
}

body#sdgs #materiality .wrap {
	padding-left: 20px;
}

body#sdgs #materiality .text {
	margin-right: 20px;
}

body#sdgs #materiality .img {
	padding-left: 20px;
}

body#sdgs #initiative:after {
	font-size: 80%;
}

body#sdgs #other:after {
	font-size: 85%;
}

body#sdgs #other #news .inner {
	margin: 15em auto 10em;
	padding-top: 6.5em;
}

body#sdgs #other #news .inner:before {
	font-size: 80%;
	top: -9.5em;
}

body#sdgs .news-list li a {
	display: block;
}

body#sdgs[class*="news"] .hero,
body#sdgs.single .hero,
body#sdgs.category .hero {
	max-height: 50.25em;
}

body#sdgs[class*="news"] .hero .title .page-title,
body#sdgs.single .hero .title .page-title,
body#sdgs.category .hero .title .page-title {
	font-size: 5.5em;
}

body#sdgs[class*="news"] .hero .title .page-title-sub,
body#sdgs.single .hero .title .page-title-sub,
body#sdgs.category .hero .title .page-title-sub {
	font-size: 2.2em;
	margin-top: 0.55em;
}

body#sdgs[class*="news"] .hero .img,
body#sdgs.single .hero .img,
body#sdgs.category .hero .img {
	margin-bottom: 1em;
	margin-top: 1em;
	max-width: 30em;
}

body#sdgs .sdgs-list > li {
	max-width: 100%;
}

body#sdgs .sdgs-list .title {
	font-size: 1.3em;
	max-width: none;
}

body#sdgs.single .activities-list > li .title {
	font-size: 1.75em;
	line-height: 2.05;
}

body#sdgs.single .activities-list > li .title .underline {
	background-size: 10px 1.5px;
	padding: 0.425em 0;
}

body#sdgs.single #others .initiative-list > li h4 {
	font-size: 1.5em;
}


#single .header {
	margin-top: -45px;
}

#single .eyecatch {
	margin: 33px 0;
}

#single .content-post {
	margin-top: 49px;
	padding-bottom: 72px;
}

#single .content > .inner:last-of-type {
	padding-bottom: 100px;
}

#single .news-list {
	margin-top: 0;
}

#single .news-list + .btn {
	margin-top: 27px;
}

#footer .wrap {
	display: block;
}

body#sdgs .hero {
	max-height: 57.5em;
}

body#sdgs .hero .block {
	margin: auto -5px;
}

body#sdgs .hero .catchcopy h2 {
	font-size: 3.25em;
	line-height: 1.69;
}

body#sdgs .hero .catchcopy h2.en {
	font-size: 1.6em;
	margin-top: 1.125em;
}

body#sdgs .hero .img {
	margin-top: 4.65em;
	max-width: 33.75em;
}

body#sdgs .hero .img .kv-pc {
	display: none;
}

body#sdgs .hero .img .kv-sp {
	display: block;
}

body#sdgs .page-title,
body#sdgs .section-title {
	font-size: 4.625em;
}

body#sdgs .page-title.small,
body#sdgs .section-title.small {
	font-size: 3.5em;
}

body#sdgs .page-title-sub,
body#sdgs .section-title-sub {
	font-size: 2em;
}

body#sdgs .page-title-sub.small,
body#sdgs .section-title-sub.small {
	font-size: 1.8em;
}

body#sdgs .initiative-list > li h4 {
	font-size: 1.8em;
}

body#sdgs #slogan {
	padding-top: 7.25em;
}

body#sdgs #slogan .section-title {
	font-size: 5.8em;
}

body#sdgs #slogan .inner {
	margin-bottom: 5em;
}

body#sdgs #slogan .block {
	margin: auto auto 1.275em;
}

body#sdgs #slogan .block h3 {
	font-size: 2em;
	margin-bottom: 0.65em;
	margin-top: 0.85em;
}

body#sdgs #slogan .block h3.en {
	font-size: 2.4em;
}

body#sdgs #slogan .block:nth-child(1):after {
	bottom: auto;
	height: 31.2em;
	left: 50%;
	top: 9.625em;
	transform: translateX(-50%);
	width: 33.8em;
}

body#sdgs #slogan .block:nth-child(1) .img {
	max-width: 20em;
}

body#sdgs #slogan .block:nth-child(2) {
	margin-top: 3em;
}

body#sdgs #slogan .block:nth-child(2):after {
	bottom: auto;
	height: 33.7em;
	left: 50%;
	top: 9.625em;
	transform: translateX(-50%);
	width: 33.8em;
}

body#sdgs #slogan .block:nth-child(2) .img {
	margin-right: auto;
	max-width: 20em;
}

body#sdgs #slogan .block:nth-child(2) h3 {
	margin-bottom: 0.75em;
	margin-top: 1.1em;
}

body#sdgs #materiality {
	padding-top: 3.75em;
}

body#sdgs #materiality .wrap {
	padding-left: 20px;
}

body#sdgs #materiality .text {
	margin-right: 20px;
}

body#sdgs #materiality .img {
	padding-left: 20px;
}

body#sdgs #initiative:after {
	font-size: 80%;
}

body#sdgs #other:after {
	font-size: 85%;
}

body#sdgs #other #news .inner {
	margin: 15em auto 10em;
	padding-top: 6.5em;
}

body#sdgs #other #news .inner:before {
	font-size: 80%;
	top: -9.5em;
}

body#sdgs .news-list li a {
	display: block;
}

body#sdgs[class*="news"] .hero,
body#sdgs.single .hero,
body#sdgs.category .hero {
	max-height: 50.25em;
}

body#sdgs[class*="news"] .hero .title .page-title,
body#sdgs.single .hero .title .page-title,
body#sdgs.category .hero .title .page-title {
	font-size: 5.5em;
}

body#sdgs[class*="news"] .hero .title .page-title-sub,
body#sdgs.single .hero .title .page-title-sub,
body#sdgs.category .hero .title .page-title-sub {
	font-size: 2.2em;
	margin-top: 0.55em;
}

body#sdgs[class*="news"] .hero .img,
body#sdgs.single .hero .img,
body#sdgs.category .hero .img {
	margin-bottom: 1em;
	margin-top: 1em;
	max-width: 30em;
}

body#sdgs .sdgs-list > li {
	max-width: 100%;
}

body#sdgs .sdgs-list .title {
	font-size: 1.3em;
	max-width: none;
}

body#sdgs.single .activities-list > li .title {
	font-size: 1.75em;
	line-height: 2.05;
}

body#sdgs.single .activities-list > li .title .underline {
	background-size: 10px 1.5px;
	padding: 0.425em 0;
}

body#sdgs.single #others .initiative-list > li h4 {
	font-size: 1.5em;
}




}

@media (max-width: 680px) and (orientation: landscape) {

#header .menu.main li {
	font-size: 22px;
}

}

/*---------------------------------------------------------------------------480px*/
@media (max-width: 480px) and (max-height: 800px) {
.btn-menu {
	right: 1em;
}
}

@media (max-width: 480px) {
#home #intro .coffee {
	margin-top: -10em;
}

#home .hero .catchcopy .cup {
	width: 20em;
	height: 20em;
}

#home #intro #history .img figure {
	width: 96%;
}

#home #intro #history .text {
	width: 96%;
}

#home #intro #history .text p {
	font-size: 1.4em;
}

#service02 ul {
	width: 96%;
}

#home .section-title {
	letter-spacing: 0.1em;
}

#home #sdgs .text .wrap {
	width: 96%;
}

#home #sdgs .text .btn a {
	margin: 0 auto;
}

.breadcrumb .separate {
	width: 2em;
	margin: 0 1em;
}

.page .section-title .en {
	font-size: 3.75em;
}

body#company #philosophy .message {
	font-size: 1.875em;
}

#error .content .code {
	font-size: 160px;
}

#single .header .headline {
	font-size: 17.5px;
}

#single .header .date {
	font-size: 10px;
	margin-top: 1em;
}

#header .menu.main li {
	font-size: 2.5em;
}

body#sdgs .hero {
	max-height: 49.5em;
}

body#sdgs .hero .catchcopy h2 {
	font-size: 2.6em;
}

body#sdgs .hero .catchcopy h2.en {
	font-size: 1.4em;
}

body#sdgs .hero .img {
	max-width: 27.6em;
}

body#sdgs #slogan .block {
	margin: auto -5px 1.275em;
}

body#sdgs #slogan .block:nth-child(2) {
	margin-left: -5px;
}

body#sdgs #other .wrap > .block .text .btn {
	justify-content: center;
}

body#sdgs[class*="news"] .hero .title .page-title,
body#sdgs.single .hero .title .page-title,
body#sdgs.category .hero .title .page-title {
	font-size: 4.25em;
}

body#sdgs[class*="news"] .hero .title .page-title-sub,
body#sdgs.single .hero .title .page-title-sub,
body#sdgs.category .hero .title .page-title-sub {
	font-size: 1.9em;
}

body#sdgs[class*="news"] .hero .img,
body#sdgs.single .hero .img,
body#sdgs.category .hero .img {
	margin-right: -2.5em;
	margin-top: 2.65em;
	max-width: 27.6em;
}

body#sdgs.single #others .initiative-list > li {
	max-width: none;
}

#single .header .headline {
	font-size: 17.5px;
}

#single .header .date {
	font-size: 10px;
	margin-top: 1em;
}

}

@media (max-width: 350px) {

#error .content .code + p span.br {
	display: inline;
}

body#sdgs .hero .catchcopy h2 {
	font-size: 2.5em;
}

body#sdgs .page-title,
body#sdgs .section-title {
	font-size: 4em;
}

body#sdgs .page-title.small,
body#sdgs .section-title.small {
	font-size: 3em;
}

body#sdgs .page-title-sub.small,
body#sdgs .section-title-sub.small {
	font-size: 1.7em;
}

body#sdgs .initiative-list > li h4 {
	font-size: 1.7em;
}

body#sdgs #slogan .section-title {
	font-size: 5em;
}

body#sdgs #slogan .block h3 {
	font-size: 1.8em;
}

body#sdgs #slogan .block h3.en {
	font-size: 2.1em;
}

body#sdgs[class*="news"] .hero .title .page-title,
body#sdgs.single .hero .title .page-title,
body#sdgs.category .hero .title .page-title {
	font-size: 3.7em;
}

body#sdgs[class*="news"] .hero .title .page-title-sub,
body#sdgs.single .hero .title .page-title-sub,
body#sdgs.category .hero .title .page-title-sub {
	font-size: 1.8em;
}

body#sdgs.single .activities-list > li .title {
	font-size: 1.65em;
}

body#sdgs.single #others .initiative-list > li h4 {
	font-size: 1.4em;
}

}

@media (max-width: 400px) {
#home .section-title {
	letter-spacing: 0.05em;
}
}


@media (max-width: 350px) {

#error .content .code + p span.br {
	display: inline;
}

}

@keyframes cup-rotate {

0% {
	transform: rotate(0deg);
}

90% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(360deg);
}

}

@keyframes scroll-bar {

0% {
	top: -100%;
}

45% {
	top: 0;
}

55% {
	top: 0;
}

100% {
	top: 100%;
}

}

@keyframes steam-move01 {

0% {
	filter: blur(13px);
	
	top: 0;
	transform: scale(0.8, 0.8) rotateY(0deg);
}

6% {
	opacity: 0.15;
}

33% {
	opacity: 0.5;
	transform: scale(0.9, 1.1) rotateY(30deg);
}

66% {
	opacity: 1;
	transform: scaleY(1, 0.8) rotateY(4deg);
}

100% {
	filter: blur(24px);
	
	top: -20%;
	transform: scaleY(1.5, 1.3) rotateY(50deg);
}

}

@keyframes sdgs-rotate {

0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(360deg);
}

}


/***************************************************↓杉浦記述↓**/
/*----------------------------↓recruit*/
body#recruit #thought {
    padding: 9.375em 0;
}
body#recruit #thought .section-title {
    margin-bottom: 5em;
}
body#recruit #thought .container figure {
    margin: 0 auto 2.5em;
}
body#recruit #thought .container div {
	margin-bottom: 2.5em;
}
body#recruit #thought .container .heading {
	font-size: 2.3125em;
    letter-spacing: 0;
    line-height: 1.4;
    margin-bottom: calc(1em / 2.3125 * 1.25);
}
body#recruit #application {
    padding: 0 0 9.375em;
}
body#recruit #application .section-title {
	margin-bottom: 5em;
}
body#recruit #application .container ul {
	display: flex;
	flex-wrap: wrap;
}
body#recruit #application .container li {
	width: calc((100% - 3.125em * 2) / 3);
	margin-right: 3.125em;
	margin-bottom: 3.125em;
}
body#recruit #application .container li:nth-of-type(3n) {
	margin-right: 0;
}
body#recruit #application .container li a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 1.25em 1.875em;
	height: 100%;
	border: 1px solid #cccccc;
	transition: all .4s;
}
body#recruit #application .container li a:hover {
	opacity: 0.45;
}

@media screen and (max-width: 899px) {
	body#recruit #application .container li {
	    width: calc((100% - 1.875em * 2) / 3);
	    margin-right: 1.875em;
	    margin-bottom: 1.875em;
	}
}
@media screen and (max-width: 599px) {
	body#recruit #application .container li {
	    width: 48%;
	    margin-right: 4%;
	    margin-bottom: 4%;
	}
	body#recruit #application .container li:nth-of-type(3n) {
		margin-right: 4%;
	}
	body#recruit #application .container li:nth-of-type(2n) {
		margin-right: 0;
	}
}


/*----------------------------↓news*/
body#news #newslist {
	padding: 9.375em 0;
}
body#news #newslist .section-title {
	margin-bottom: 5em;
}
body#news #newslist .container dl {
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid #dddddd;
	margin-bottom: 5em;
}
body#news #newslist .container dt {
	width: 15.625em;
	border-bottom: 1px solid #dddddd;
	padding: 1.9125em 0;
	line-height: 2;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
}
body#news #newslist .container dt time {
	color: #BCBCBC;
    letter-spacing: 0.1em;
	font-weight: bold;
}
body#news #newslist .container dd {
	font-size: 1.125em;
	width: calc(100% - 15.625em / 1.125);
	border-bottom: 1px solid #dddddd;
}
body#news #newslist .container dd.nolink {
	line-height: 2;
	padding: 1.7em 2.8em 1.7em 0;
}
body#news #newslist .container dd a {
	line-height: 2;
	display: block;
	padding: 1.7em 2.8em 1.7em 0;
	position: relative;
}
body#news #newslist .container dd a::after {
	content: "";
	display: block;
	width: 1.875em;
	height: 1.875em;
	background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
body#news #newslist .container dd.detail a::after {
	background-image: url(../images/icon_arrow01.svg);
}
body#news #newslist .container dd.external a::after {
	background-image: url(../images/icon_external01.svg);
}
body#news #newslist .container dd.pdf a::after {
	background-image: url(../images/icon_pdf01.svg);
}
body#news #newslist .container nav ol {
	list-style: none;
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
}
body#news #newslist .container nav li {
	font-size: 1.25em;
	width: 2em;
	font-family: "Gen Jyuu Gothic X", sans-serif;
	line-height: 2;
	text-align: center;
	margin: 0 0.5em;
}
body#news #newslist .container nav li a {
	display: block;
	height: 100%;
	color: #fff;
	background-color: #3f352f;
}
body#news #newslist .container nav li.current {
	color: #fff;
	background-color: #8c8483;
}
body#news #newslist .container nav li.prev,
body#news #newslist .container nav li.next {
	position: relative;
}
body#news #newslist .container nav li.prev::after,
body#news #newslist .container nav li.next::after {
	content: "";
	display: block;
	width: 0.35em;
	height: 0.6em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}
body#news #newslist .container nav li.prev::after {
	background-image: url(../images/arrow_prev.svg);
}
body#news #newslist .container nav li.next::after {
	background-image: url(../images/arrow_next.svg);
}
/*----------------------------↓news_selectbox*/
.yearselect {
	margin-bottom: 5em;
}

/* Old-Select */
.old-select{
    position: absolute;
    top: -9999px;
    left: -9999px;
}

/* New-Select */
.new-select{
    max-width: 25em;
    height: 3.375em;
    margin: 0 auto;
    text-align: center;
    color: #fff;
    line-height: 3.375em;
    position: relative;
}
.new-select .selection{
    width: 100%;
    height: 100%;
    background-color: #3F352F;
    border-bottom: 0.1875em solid #fff;
    cursor: pointer;
    position: relative;
    z-index: 20; /* オプションの数より大きくなければならない */
}
.new-select .selection p{
    width: calc(100% - 2.7em);
    position: relative;
    color: #fff;
    font-size: 1.25em;
    
    transition:         all 200ms ease-in-out;
    -o-transition:      all 200ms ease-in-out;
    -ms-transition:     all 200ms ease-in-out;
    -moz-transition:    all 200ms ease-in-out;
    -webkit-transition: all 200ms ease-in-out;
}
.new-select .selection:hover p, .new-select .selection.open p{
    color: #aaaaaa;
}
.new-select .selection i{
    display: block;
    width: 0.15em;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    border: none;
    background-color: #fff;
}
.new-select .selection > span{
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.625em 0.46875em 0 0.46875em; /* Height: 10px / Width: 15px */
    border-color: #fff transparent transparent transparent;
    position: absolute;
    top: 50%;
    right: 1.21875em;
    transform: translateY(-30%);
}
.new-select .selection.open > span{
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0.46875em 0.625em 0.46875em;
    border-color: transparent transparent #fff transparent;
    transform: translateY(-50%);
}
.new-option{
    text-align: center;
    color: #3F352F;
    background-color: #D9D7D5;
    cursor: pointer;
    position: relative;
    border-bottom: 0.1875em solid #fff;
    position: absolute;
    left: 0; right: 0;
    
    transition:         all 300ms ease-in-out;
    -o-transition:      all 300ms ease-in-out;
    -ms-transition:     all 300ms ease-in-out;
    -moz-transition:    all 300ms ease-in-out;
    -webkit-transition: all 300ms ease-in-out;
}
.new-option p{
    width: calc(100% - 2.7em);
    font-size: 1.25em;
}
.new-option.reveal a {
	color: #3F352F;
	transition:         all 300ms ease-in-out;
    -o-transition:      all 300ms ease-in-out;
    -ms-transition:     all 300ms ease-in-out;
    -moz-transition:    all 300ms ease-in-out;
    -webkit-transition: all 300ms ease-in-out;
}
.new-option.reveal:hover{
    background-color: #3F352F;
    color: #fff;
}
.new-option.reveal a:hover {
	color: #fff;
}

/*----------------------------↓news_detail*/
body#news #newsdetail {
	padding: 9.375em 0;
}

.page #newsdetail .section-title .en {
	font-size: 3.143em;
	margin-bottom: 1em;
	font-weight: normal;
}

#newsdetail div.container.editor p {
	margin-bottom: 1em;
}

#newsdetail div.container.editor h2 {
	font-size: 1.5rem;
	color: #2b74f6;
	border-bottom: 1px solid #dfdfdf;
}
#newsdetail div.container.editor h3 {
	border-bottom: 1px dotted #dfdfdf;
	margin-bottom: 20px;
}
#newsdetail div.container.editor h4 {
}
#newsdetail div.container.editor {
	font-size: 1.125rem;
}
#newsdetail div.container.editor img {
	width: auto;
	max-width: 100%;
}
#newsdetail div.container.editor table {
	width: 100%;
	margin: 0 0 1.5em 0;
	border-top:1px solid #d2d2d2;
}
#newsdetail div.container.editor th,
#newsdetail div.container.editor td {
	border-bottom:1px solid #d2d2d2;
	padding: 5px;
}

#newsdetail div.container.editor ul {
	padding:0 0 0 2em;
	margin: 0 0 1.5em 0;
}
#newsdetail div.container.editor ol {
	padding:0 0 0 2em;
	margin: 0 0 1.5em 0;
}
#newsdetail div.container.editor ul li {
	list-style: disc;
}
#newsdetail div.container.editor ol li {
	list-style: decimal;
}
#newsdetail div.container.editor blockquote {
	background: #f3f3f3;
	padding: 20px;
	display:block;
	margin:1em 0;
}
#newsdetail div.container.editor blockquote p {
	margin-bottom:0;
}
#newsdetail div.container.editor a {
	color:#d00746;
	text-decoration:underline;
}
#newsdetail div.container.editor a:hover {
	color:#000;
	text-decoration:none;
}
#newsdetail div.container.editor img.alignleft {
	float: left;
	margin: 0 50px 20px 0;
}
#newsdetail div.container.editor img.aligncenter {
	clear:both;
	display:block;
	margin:auto auto 20px auto;
}
#newsdetail div.container.editor img.alignright {
	float: right;
	margin: 0 0 20px 50px;
}
@media screen and (max-width: 479px) {
	#newsdetail div.container.editor img.alignleft,
	#newsdetail div.container.editor img.aligncenter,
	#newsdetail div.container.editor img.alignright {
		width: 100%;
		float: none;
		margin: 0 0 20px 0;
	}
}

#newsdetail div.container img {
	margin-bottom: 1em;
	display: block;
	width: 70%;
	max-width: 1050px;
	margin: 0 auto 2em auto;
}


@media screen and (max-width: 1800px) {
#newsdetail div.container {
	font-size: 1.42em;
}
}

@media screen and (max-width: 1480px) {
#newsdetail div.container {
	font-size: 1.81em;
}
}




@media screen and (max-width: 599px) {
	body#news #newslist .container dl {
		display: block;
	}
	body#news #newslist .container dt {
		width: 100%;
		padding: 1.9125em 0 0;
		border-bottom: none;
	}
	body#news #newslist .container dd {
		width: 100%;
	}
	body#news #newslist .container dd.nolink {
		padding: 0 2.8em 1.7em 0;
	}
	body#news #newslist .container dd a {
		padding: 0 2.8em 1.7em 0;
	}

	body#news #newslist .container dd a::after {
		top: calc((100% - 1.7em) / 2);
	}
}




/*--------------------------------------------↑杉浦記述↑--------*/




/***************************************************↓小宅記述↓**/
#company .section-title{
    margin-bottom: 6.25em;
}

#profile{
    padding: 18.1em 0 16.4em;
}

body#company #profile .container {
    margin: auto;
    max-width: 87.5em;
}

#company table{
    width: 100%;
	margin-bottom: 4em;
}

#company tr{
    border-top: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
}

#company th,
#company td{
    padding: 2em 0;
    vertical-align: top;
    font-size: 1.25em;
    font-weight: normal;
    letter-spacing: 0;
}

#company th{
    position: relative;
    width: 20%;
    text-align: left;
    font-weight: normal;
}

#company .btn {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
}

/* 沿革のcss 20231220
-------------------------------------------------------------------------------*/
#background{
    padding: 18.1em 0 8.9em;
}

.background-info{
    width: 84%;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    margin: 0 0 10em auto;
}


.background-info .background-txt{
    width: 46%;
    margin-right: 4%;
    font-size: 1.25em;
    letter-spacing: 0;
}

body#company #background .container {
    margin: auto;
    max-width: 87.5em;
}
@media (max-width: 1800px) {
    #company th,
    #company td{
        font-size: 1.428em;
    }

    .background-info .background-txt{
        font-size: 1.428em;
    }
}

@media (max-width: 1700px) {
    .background-info{
        width: 90%;
    }
    .background-info .background-txt {
        width: 60%;
        margin-right: 3%;
    }
}

@media (max-width: 1480px) {
    body#company #background .container {
        margin: auto;
        max-width: 87.5em;
    }

    .background-info{
        width: 95%;
        padding-bottom: 16.4em;
    }
    
    #company th,
    #company td{
        font-size: 1.81em;
    }

    .background-info .background-txt{
        font-size: 1.81em;
    }
}

@media (max-width: 1360px) {
    .background-info{   
        flex-direction:column-reverse;
        width: 90%;
        margin: 0 auto;
    }

    .background-info .background-txt {
        width: 100%;
        margin-right: inherit;
    }

    .background-info figure{   
        margin: 0 auto 5em;
    }
}

@media (max-width: 768px) {
	body#company #philosophy .message_box {
		display: block;
	}
	body#company #philosophy .message {
		text-align: center;
	}
	body#company #philosophy p {
		width: 100%;
	}
    #company th,
    #company td{
        display: block;
        width: 100%;
    }

    #company th{
        padding-bottom: 0;
    }
    
    #company td{
        padding-top: 0;
    }
}

@media (max-width: 680px) {
    #company th,
    #company td{
        font-size: 1.6em;
    }
}

@media (max-width: 450px) {
    
}

/* 事業紹介のcss 20231221
-------------------------------------------------------------------------------*/
#business{
    padding: 18.1em 0 7em
}

body#service-details #business .container {
    margin: auto;
    max-width: 87.5em;
}

#business .section-title{
    margin-bottom: 6.25em;
}

.service-txt{
    width: 57.15%;
    height: auto;
    background-color: #fff;
    padding: 3em;
    margin: -8.5em  2em 8em auto;
    position: relative;
    z-index: 99;
}

body#service-details .service-txt .title-en {
	font-size: 1.75em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1;
	white-space: nowrap;
}

body#service-details .service-txt .title-jp {
	font-size: 0.875em;
	font-weight: 500;
	letter-spacing: 0.285em;
	line-height: 1;
	margin-left: -0.1em;
	margin-top: 1.65em;
	position: absolute;
	white-space: nowrap;
	writing-mode: vertical-lr;
}

body#service-details .service-txt p{
	font-size: 1.25em;
	margin-left: 2.5em;
	margin-top: 0.65em;
}

body#service-details .service-img ul {
	display:-ms-flexbox;
	display:-webkit-flex;
	display: flex;
	-ms-flex-wrap:wrap;
	-webkit-flex-wrap:wrap;
	flex-wrap:wrap;
}

body#service-details .service-img li {
	width: 23%;
}

body#service-details .service-img li:not(:nth-of-type(4n+1)) {
	margin-left: calc(8% / 3);
}

body#service-details .service-img figure {
	position: relative;
}
body#service-details .service-img figure img {
	vertical-align: bottom;
}

body#service-details .service-img a figure img {
	transition: all .3s ease;
}

body#service-details .service-img a:hover figure img {
	filter: grayscale(80%) contrast(120%);
}

body#service-details .service-img figcaption {
	display: block;
	/*width: calc(100% - 20px);
	margin-left: auto;*/
	background-color: #fff;
	transform: translateY(-27px);
	padding: 13px;
	line-height: 1.7;
	font-size: 1em;
	text-align: center;
}

body#service-details .service-img a figcaption {
	position: relative;
	padding-right: 30px;
}

body#service-details .service-img a figcaption:after {
	position: absolute;
	top: 17px;
	top: 50%;
	right: 15px;
	content: "";
	width: 7px;
	height: 14px;
	background: url(../images/arrow_service-img.png) center center no-repeat;
	transition: all .2s ease;
	transform: translatey(-50%);
}

body#service-details .service-img a:hover figcaption:after {
	right: 10px;
}

body#service-details .page-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-left: -3.125%;
}

body#service-details .page-list li {
	margin-left: 3.03%;
	width: 46.97%;
	margin-bottom: 7.3em;
}

body#service-details .page-list li a {
	display: block;
}

body#service-details .page-list li .title-en {
	font-size: 2.125em;
	font-weight: bold;
	letter-spacing: 0.285em;
	line-height: 1;
	white-space: nowrap;
}

body#service-details .page-list li .title-jp {
	font-size: 0.875em;
	font-weight: 500;
	letter-spacing: 0.285em;
	line-height: 1;
	margin-left: -0.1em;
	margin-top: 1.65em;
	position: absolute;
	white-space: nowrap;
	writing-mode: vertical-lr;
}

body#service-details .page-nav {
    padding: 14.65em 0 15.7em;
}

body#service-details .page-nav .inner{
    max-width: 68.75em;
}

body#service-details .page-list li .img {
	margin-left: 2.5em;
	margin-top: 0.65em;
}

body#service-details .page-list li a .img img {
	transition: all .3s ease;
}

body#service-details .page-list li a:hover .img img {
	filter: grayscale(80%) contrast(120%);
}

#factory {
    padding: 18.1em 0 8.9em
}

body#service-details #factory .container {
    margin: auto;
    max-width: 87.5em;
}

#factory .section-title{
    margin-bottom: 6.25em;
}

#factory .service-txt{
    width: 100%;
    height: auto;
    background-color: transparent;
    padding: 0;
    margin: 0 0 5em;
}

#factory .service-txt figure {
	margin-bottom: 2em;
}

body#service-details #factory .service-txt p {
    font-size: 1.25em;
    margin: 0;
}

#factory table {
	width: 100%;
}

#factory tr {
    border-top: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
}

#factory th, #factory td {
    padding: 1em 0.5em;
    vertical-align: top;
    font-size: 1.25em;
    font-weight: normal;
    letter-spacing: 0;
    border-left: 1px solid #ddd;
}

#factory th {
	padding: 1em 0;
	text-align: center;
	font-weight: normal;
	background-color: #D9D7D5;
	white-space: nowrap;
}
#factory tr td:first-of-type {
	text-align: center;
    border-left: 0;
    position: relative;
}

@media (max-width: 1800px){
	#factory th, #factory td {
		font-size: 1.428em;
	}
    
}

@media (max-width: 1480px){
	body#service-details .service-img figcaption {
		font-size: 1.2727em;
	}

	body#service-details #factory .container {
		margin: auto;
		max-width: 87.5em;
	}
	#factory th, #factory td {
		font-size: 1.81em;
	}
}

@media (max-width: 1000px){
    body#service-details #business .container {
        margin: 0 auto;
        width: 90%;
    }

    .service-txt{
        width: 100%;
        height: auto;
        padding: 0 0 5em 2em;
        margin: -7.5em  auto 0 ;
        background-color: inherit;
    }

    body#service-details .service-txt .title-en {
        color: #fff;
        font-size: 2.19em;
    }
    
    body#service-details .service-txt .title-jp {
        writing-mode: horizontal-tb;
        color: #fff;
        font-size: 1.125em;
        position: inherit;
    }

    body#service-details .service-txt p{
       margin-top: 2em;
       margin-left: -2em;
    }

    body#service-details .service-img ul {
    	width: 100%;
    	margin: 0 auto;
		-ms-flex-wrap:wrap;
		-webkit-flex-wrap:wrap;
		flex-wrap:wrap;
    }

    body#service-details .service-img li {
    	width: 45%;
    }
	
	body#service-details .service-img li:not(:nth-of-type(4n+1)) {
    	margin-left: 0;
	}
	
	body#service-details .service-img li:nth-of-type(2n) {
    	margin-left: 10%;
	}


	body#service-details .page-nav {
		padding: 10em 0 15em;
	}

    #factory thead {
    	display: none;
    }
    #factory td {
    	display: block;
    	width: 100%;
		border-left: 0;
		padding: 0.5em;
		line-height: 1.5;
    }
	#factory tr td:first-of-type {
		text-align: left;
		padding-left: 8.5em;
	}
	#factory tr td:first-of-type:before {
		content: "製造所固有記号：";
		position: absolute;
		left: 0.5em;

	}

}

@media (max-width: 680px){
    body#service-details .service-txt .title-en {
        font-size: 1.8em;
    }

    body#service-details .page-list {
        margin-left: 0%;
    }

    body#service-details .page-list li {
        margin-left: 0%; 
        width: 100%;
        margin-bottom: 5em;
    }

    body#service-details .page-list li .title-jp {
        font-size: 1.4em;
    }

    body#service-details .service-img li {
    	width: 48%;
    }
	
	body#service-details .service-img li:nth-of-type(2n) {
    	margin-left: 4%;
	}

    #factory th, #factory td {
    	font-size: 1.6em;
	}
}


@media (max-width: 480px){
	body#service-details .service-img ul {
		display: block;
	}

	body#service-details .service-img li {
		width: 90%;
		margin: 0 auto;
		margin-bottom: 2em;
	}
	body#service-details .service-img li:not(:nth-of-type(4n+1)) {
    	margin-left: auto;
	}
	body#service-details .service-img li:nth-of-type(2n) {
    	margin-left: auto;
	}

	body#service-details .service-img figcaption {
		transform: translateY(0);
		width: 100%;
		padding: 10px 0;
	}

	body#service-details .service-img a figcaption:after {
		top: 14px;
	}
}


/* お問い合わせのcss 20231218
-------------------------------------------------------------------------------*/
#contact-phone {
    text-align: center;
    padding: 18.1em 0 16.4em;
}

#contact-phone .section-title{
    margin-bottom: 9.375em;
}

#contact-mail .section-title{
    padding-bottom: 7em;
    text-align: center;
}

#contact-phone h5{
    color: #3f352f;
    font-size: 1.25em;
}

#contact-phone  p{
    font-family: "Gen Jyuu Gothic X", sans-serif;
    font-size: 1.125em;
}

#contact-phone  p span.biz-hours{
    font-family: "brandon-grotesque", "Gen Jyuu Gothic X", sans-serif;
    font-size: 1.5em;
    letter-spacing: 0.285em;
}

.ppbox a{
    border-bottom:1px solid #6d5f5b;;
}

#contact-phone a span{
    vertical-align: middle;
    font-family: "brandon-grotesque", "Gen Jyuu Gothic X", sans-serif;
    font-weight: bold;
    font-size: 3.4375em;
    letter-spacing: 0.285em;
    margin-right: 0.5em;
    color: #6d5f5b;
}

.formtable{
    width: 100%;
}

.formtable tr{
    border-top: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
}

.formtable th,
.formtable td{
    padding: 2em 0;
    vertical-align: top;
}

.formtable th{
    position: relative;
    width: 20%;
    text-align: left;
}

.formtable label {
    margin-right: 8em;
}

.formtable input[type="radio"] {
    vertical-align: baseline;
    margin-right: 0.5em;
}

.formtable input[type="text"],
.formtable input[type="tel"],
.formtable input[type="email"],
.formtable textarea{
    vertical-align: baseline;
    border:1px solid #aaaaaa;
}

.formtable input[type="email"],
.formtable textarea{
    width: 100%;
}

.required{
    position: absolute;
    right: 10%;
    display: inline-block;
    background-color: #3f352f;
    color: #fff;
    margin-right: 1rem;
    line-height: 1;
    padding : 0.6em 0.8em;
    font-size: 0.5em;
    top: 40px
}

.ppbox{
    background-color: #f2edeb;
    padding: 4.56em 1.5em;
    text-align: center;
    width: 100%;
    margin: 60px auto;
    border-radius: 0px;
}

#contact-mail input[type="checkbox"] {
    vertical-align: baseline;
    margin-right: 0.5em;
}

#contact-mail input[type=submit]{
    display: block;
    width: 300px;
    padding: 0.5em 0;
    letter-spacing: 0.05em;
    border-radius: 54px;
    background-color: #3f352f;
    font-size: 1.25em;
    color: #fff;
    text-align: center;
    margin: 0 auto;
    border: 1px solid #3f352f;
    transition: all .3s ease;
}

#contact-mail input[type=submit]:hover{
    opacity: 0.7;
    
}

.confirm_btn p{
    display:flex;
    margin-bottom: 18.75em;
    justify-content: center;
    align-items: center;
}

input[type=button].wpcf7-previous{
    display: block;
    width: 300px;
    padding: 0.5em 0;
    letter-spacing: 0.05em;
    border-radius: 54px;
    background-color: #ffffff;
    font-size: 1.25em;
    color: #3f352f;
    text-align: center;
    margin: 0 auto;
    border: 1px solid #3f352f;
    transition: all .3s ease;
}

input[type=button].wpcf7-previous:hover{
	opacity: 0.7;
}


@media (max-width: 1480px){
    .required {
        top: 25px;
    }

    #contact-phone  p{
        font-size: 1.454em;
    }

    .formtable th,
    .formtable td{
        font-size: 1.454em;
    }

    .formtable label {
        margin-right: 3em;
    }

    .ppbox{
        font-size: 1.454em;
    }

	#contact-mail input[type=submit]{
		padding: 1em 0;
	}

	input[type=button].wpcf7-previous{
		padding: 1em 0;
	}
}

@media (max-width:800px){
	.confirm_btn p{
		flex-flow: column-reverse;
		margin-bottom: 10em;
	}

	#contact-mail input[type=submit]{
		margin-bottom: 3em;
	}
}

@media (max-width: 768px) {
    .formtable th,
    .formtable td{
        display: block;
        width: 100%;
    }

    .formtable th{
        padding-bottom: 0;
    }
    
    .formtable td{
        padding-top: 0;
    }

    .required{
        right: 10%;
    }

    .required{
        right: inherit;
        margin-right: 0;
        top: 50%;
        margin-left: 10px;
    }

    .formtable label {
        display: block;
        margin-right: inherit;
    }


}

@media (max-width: 680px){
    #contact-phone  p span.biz-hours{
        font-size: 1em;
        letter-spacing: 0;
    }
    
    #contact-phone  p{
        font-size: 1.6em;
    }

    .formtable th,
    .formtable td{
        font-size: 1.6em;
    }

    .ppbox {
        font-size: 1.6em;
    }
}

@media (max-width: 450px) {
    #contact-phone  p{
        font-size: 1.6em;
    }
    
    #contact-phone a{
        line-height: 1.6;
    }

    #contact-phone a span{
        display: block;
        margin-right: inherit;
        font-size: 3em;
    }

    .formtable input[type="text"],
    .formtable input[type="tel"]{
        width: 100%;
    }
    
    
}

/*--------------------------------------------↑小宅記述↑--------*/