/*
Theme Name: ESOLAB theme
Theme URI: https://esolab.co.jp/
Author: Esolab
Author URI: https://esolab.co.jp/
Description: Original Theme of ESOLAB
Version: 1.0
License: ESOLAB Inc.
License URI: https://esolab.co.jp/
*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font: inherit;
	font-size: 100%;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	display: block;
	appearance: none;
	width: 100%;
	border: 1px solid #888;
	border-radius: none;
	outline: none;
	background: transparent;
	font: inherit;
}

textarea {
	resize: vertical;
}

* {
	box-sizing: border-box;
}

*:focus {
	outline: none;
}

html {
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	visibility: hidden;
	min-height: -webkit-fill-available;
	font-size: 62.5%;
}

html.wf-active,
html.loading-delay {
	visibility: visible;
}

body {
	width: 100%;
	min-height: 100vh;
	min-height: 100dvh;
	min-height: -webkit-fill-available;
	line-height: var(--lh-bsc);
	font-family: var(--fo-yuGo);
}

body.ofh {
	overflow: hidden;
}

h2,
h3,
h4,
h5 {
	line-height: var(--lh-bsc);
	font-family: var(--fo-shs-jp);
}

p {
	font-weight: 500;
	font-family: var(--fo-shs-jp);
}

img {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	vertical-align: middle;
}

address {
	font-style: normal;
}

a {
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	color: var(--wp--preset--color--black);
	text-decoration: none;
	cursor: pointer;
}

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

:root {
	--fl-sz: 100%;
	--bg-rp-n: no-repeat;
	--bg-po-c: 0 0;
	--sz-cn: contain;
	--sz-cv: cover;
	--co-blc: #1a1a1a;
	--co-blc-ex-th: #4D4D4D;
	--co-gr-ex-dr: #808080;
	--co-gr-dr: #a1a1a1;
	--co-gr-th-dr: #ccc;
	--co-gr: #f2f2f2;
	--co-rd-ex-dk: #ED1C24;
	--co-yl-dk: #F7931E;
	--co-gr-dk: #00A99D;
	--co-gr-tsp: rgb(170, 170, 170, .45);
	--fo-clv2: "corporate-logo-ver2", sans-serif;
	--fo-mtsr: "montserrat", sans-serif;
	--fo-jps: "Josefin Sans", sans-serif;
	--fo-shs-jp: "source-han-sans-japanese", sans-serif;
	--fo-kosugi: "Kosugi Maru", sans-serif;
	--lh-nml: 1;
	--lh-lw: 1.75;
	--lh-bsc: 2.5;
	--lh-hg: 3.3;
	--trs-bsc: all ease .4s;
	--trs-tsf: transform ease .4s;
	--trs-opc: opacity ease .4s;
	--trs-mxh: max-height ease .6s;
	--trs-bgc: background-color ease .4s;
	--trs-bgi: background-image ease .4s;
	--trs-boc: border-color ease .4s;
	--trs-col: color ease .4s;
}

.wrapper {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

.ib {
	display: inline-block;
}

.util { /*-------------------------------------------*/ /* title
  /*-------------------------------------------*/ /*-------------------------------------------*/ /* text
  /*-------------------------------------------*/
}

.util-title-logo {
	font-weight: 700;
	line-height: var(--lh-nml);
	font-family: var(--fo-clv2);
}

.util-title-logo span:nth-of-type(1) {
	animation-delay: 0.1s;
}

.util-title-logo span:nth-of-type(2) {
	animation-delay: 0.2s;
}

.util-title-logo span:nth-of-type(3) {
	animation-delay: 0.3s;
}

.util-title-logo span:nth-of-type(4) {
	animation-delay: 0.4s;
}

.util-title-logo span:nth-of-type(5) {
	animation-delay: 0.5s;
}

.util-title-logo span:nth-of-type(6) {
	animation-delay: 0.6s;
}

.util-title-logo span:nth-of-type(7) {
	animation-delay: 0.7s;
}

.util-title-logo span:nth-of-type(8) {
	animation-delay: 0.8s;
}

.util-title-logo span:nth-of-type(9) {
	animation-delay: 0.9s;
}

.util-title-logo span:nth-of-type(10) {
	animation-delay: 1s;
}

.util-title-logo span:nth-of-type(11) {
	animation-delay: 1.1s;
}

.util-title-logo span:nth-of-type(12) {
	animation-delay: 1.2s;
}

.util-title-logo span:nth-of-type(13) {
	animation-delay: 1.3s;
}

.util-title-logo span:nth-of-type(14) {
	animation-delay: 1.4s;
}

.util-title-logo span:nth-of-type(15) {
	animation-delay: 1.5s;
}

.util-title-logo span:nth-of-type(16) {
	animation-delay: 1.6s;
}

.util-title-logo span:nth-of-type(17) {
	animation-delay: 1.7s;
}

.util-title-logo span:nth-of-type(18) {
	animation-delay: 1.8s;
}

.util-title-logo span:nth-of-type(19) {
	animation-delay: 1.9s;
}

.util-title-logo span:nth-of-type(20) {
	animation-delay: 2s;
}

.util-title-logo span:nth-of-type(21) {
	animation-delay: 2.1s;
}

.util-title-logo span:nth-of-type(22) {
	animation-delay: 2.2s;
}

.util-title-logo span:nth-of-type(23) {
	animation-delay: 2.3s;
}

.util-title-logo span:nth-of-type(24) {
	animation-delay: 2.4s;
}

.util-title-logo span:nth-of-type(25) {
	animation-delay: 2.5s;
}

.util-title-logo span:nth-of-type(26) {
	animation-delay: 2.6s;
}

.util-title-logo span:nth-of-type(27) {
	animation-delay: 2.7s;
}

.util-title-logo span:nth-of-type(28) {
	animation-delay: 2.8s;
}

.util-title-logo span:nth-of-type(29) {
	animation-delay: 2.9s;
}

.util-title-logo span:nth-of-type(30) {
	animation-delay: 3s;
}

.util-title-logo span:nth-of-type(31) {
	animation-delay: 3.1s;
}

.util-title-logo span:nth-of-type(32) {
	animation-delay: 3.2s;
}

.util-title-logo span:nth-of-type(33) {
	animation-delay: 3.3s;
}

.util-title-logo span:nth-of-type(34) {
	animation-delay: 3.4s;
}

.util-title-logo span:nth-of-type(35) {
	animation-delay: 3.5s;
}

.util-title-logo span:nth-of-type(36) {
	animation-delay: 3.6s;
}

.util-title-logo span:nth-of-type(37) {
	animation-delay: 3.7s;
}

.util-title-logo span:nth-of-type(38) {
	animation-delay: 3.8s;
}

.util-title-logo span:nth-of-type(39) {
	animation-delay: 3.9s;
}

.util-title-logo span:nth-of-type(40) {
	animation-delay: 4s;
}

.util-title-logo span:nth-of-type(41) {
	animation-delay: 4.1s;
}

.util-title-logo span:nth-of-type(42) {
	animation-delay: 4.2s;
}

.util-title-logo span:nth-of-type(43) {
	animation-delay: 4.3s;
}

.util-title-logo span:nth-of-type(44) {
	animation-delay: 4.4s;
}

.util-title-logo span:nth-of-type(45) {
	animation-delay: 4.5s;
}

.util-title-logo span:nth-of-type(46) {
	animation-delay: 4.6s;
}

.util-title-logo span:nth-of-type(47) {
	animation-delay: 4.7s;
}

.util-title-logo span:nth-of-type(48) {
	animation-delay: 4.8s;
}

.util-title-logo span:nth-of-type(49) {
	animation-delay: 4.9s;
}

.util-title-logo span:nth-of-type(50) {
	animation-delay: 5s;
}

.util-title-logo span:nth-of-type(51) {
	animation-delay: 5.1s;
}

.util-title-logo span:nth-of-type(52) {
	animation-delay: 5.2s;
}

.util-title-logo span:nth-of-type(53) {
	animation-delay: 5.3s;
}

.util-title-logo span:nth-of-type(54) {
	animation-delay: 5.4s;
}

.util-title-logo span:nth-of-type(55) {
	animation-delay: 5.5s;
}

.util-title-logo span:nth-of-type(56) {
	animation-delay: 5.6s;
}

.util-title-logo span:nth-of-type(57) {
	animation-delay: 5.7s;
}

.util-title-logo span:nth-of-type(58) {
	animation-delay: 5.8s;
}

.util-title-logo span:nth-of-type(59) {
	animation-delay: 5.9s;
}

.util-title-logo span:nth-of-type(60) {
	animation-delay: 6s;
}

.util-title-logo span:nth-of-type(61) {
	animation-delay: 6.1s;
}

.util-title-logo span:nth-of-type(62) {
	animation-delay: 6.2s;
}

.util-title-logo span:nth-of-type(63) {
	animation-delay: 6.3s;
}

.util-title-logo span:nth-of-type(64) {
	animation-delay: 6.4s;
}

.util-title-logo span:nth-of-type(65) {
	animation-delay: 6.5s;
}

.util-title-logo span:nth-of-type(66) {
	animation-delay: 6.6s;
}

.util-title-logo span:nth-of-type(67) {
	animation-delay: 6.7s;
}

.util-title-logo span:nth-of-type(68) {
	animation-delay: 6.8s;
}

.util-title-logo span:nth-of-type(69) {
	animation-delay: 6.9s;
}

.util-title-logo span:nth-of-type(70) {
	animation-delay: 7s;
}

.util-title-logo span:nth-of-type(71) {
	animation-delay: 7.1s;
}

.util-title-logo span:nth-of-type(72) {
	animation-delay: 7.2s;
}

.util-title-logo span:nth-of-type(73) {
	animation-delay: 7.3s;
}

.util-title-logo span:nth-of-type(74) {
	animation-delay: 7.4s;
}

.util-title-logo span:nth-of-type(75) {
	animation-delay: 7.5s;
}

.util-title-logo span:nth-of-type(76) {
	animation-delay: 7.6s;
}

.util-title-logo span:nth-of-type(77) {
	animation-delay: 7.7s;
}

.util-title-logo span:nth-of-type(78) {
	animation-delay: 7.8s;
}

.util-title-logo span:nth-of-type(79) {
	animation-delay: 7.9s;
}

.util-title-logo span:nth-of-type(80) {
	animation-delay: 8s;
}

.util-title-logo span:nth-of-type(81) {
	animation-delay: 8.1s;
}

.util-title-logo span:nth-of-type(82) {
	animation-delay: 8.2s;
}

.util-title-logo span:nth-of-type(83) {
	animation-delay: 8.3s;
}

.util-title-logo span:nth-of-type(84) {
	animation-delay: 8.4s;
}

.util-title-logo span:nth-of-type(85) {
	animation-delay: 8.5s;
}

.util-title-logo span:nth-of-type(86) {
	animation-delay: 8.6s;
}

.util-title-logo span:nth-of-type(87) {
	animation-delay: 8.7s;
}

.util-title-logo span:nth-of-type(88) {
	animation-delay: 8.8s;
}

.util-title-logo span:nth-of-type(89) {
	animation-delay: 8.9s;
}

.util-title-logo span:nth-of-type(90) {
	animation-delay: 9s;
}

.util-title-logo span:nth-of-type(91) {
	animation-delay: 9.1s;
}

.util-title-logo span:nth-of-type(92) {
	animation-delay: 9.2s;
}

.util-title-logo span:nth-of-type(93) {
	animation-delay: 9.3s;
}

.util-title-logo span:nth-of-type(94) {
	animation-delay: 9.4s;
}

.util-title-logo span:nth-of-type(95) {
	animation-delay: 9.5s;
}

.util-title-logo span:nth-of-type(96) {
	animation-delay: 9.6s;
}

.util-title-logo span:nth-of-type(97) {
	animation-delay: 9.7s;
}

.util-title-logo span:nth-of-type(98) {
	animation-delay: 9.8s;
}

.util-title-logo span:nth-of-type(99) {
	animation-delay: 9.9s;
}

.util-title-logo span:nth-of-type(100) {
	animation-delay: 10s;
}

.util-title-logo span {
	display: inline-block;
	opacity: 0;
}

.util-title-logo span.fade-action {
	animation-duration: 1s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: per;
}

.util-title-mont {
	font-weight: 300;
	line-height: var(--lh-lw);
	font-family: var(--fo-mtsr);
}

.util-text-en,
.util-text-ja {
	color: var(--wp--preset--color--black);
	line-height: var(--lh-lw);
}

.util-text-en {
	font-family: var(--fo-mtsr);
}

.util-text-ja {
	font-family: var(--fo-kosugi);
}

.fade-appear {
	opacity: 0;
}

.fade-appear.fade-action {
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: appear;
}

.fade-in {
	opacity: 0;
}

.fade-in.fade-action {
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: fade-in;
}

.fade-up {
	opacity: 0;
}

.fade-up.fade-action {
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: fade-up;
}

.fade-right {
	opacity: 0;
}

.fade-right.fade-action {
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: fade-right;
}

.fade-left {
	opacity: 0;
}

.fade-left.fade-action {
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
	animation-name: fade-left;
}

.j-out {
	animation-duration: 0.8s;
	animation-fill-mode: both;
	animation-name: disappear;
}

header {
	z-index: 900;
	position: fixed;
	top: 0;
	width: 100%;
	background-color: var(--wp--preset--color--black);
	transition: height ease 0.4s;
}

header .outer {
	width: 100%;
	height: 100%;
}

header .wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
}

header .content-sp {
	display: flex;
	z-index: 999;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	height: 100%;
	background-color: var(--wp--preset--color--black);
}

header .header_logo_figure {
	width: 100%;
}

header .header_nav {
	width: 100%;
	max-width: 49rem;
}

header .header_nav_list {
	display: flex;
	justify-content: space-between;
	width: 100%;
}

header .header_nav_list_item:first-of-type .header_nav_list_item_container .text::before {
	height: 400%;
}

header .header_nav_list_item:nth-of-type(2) {
	-moz-column-gap: 6%;
	column-gap: 6%;
}

header .header_nav_list_item:nth-of-type(2) .header_nav_list_item_container .text::before {
	height: 200%;
}

header .header_nav_list_item:hover .header_nav_list_item_container {
	visibility: visible;
	opacity: 1;
}

header .header_nav_list_item > a,
header .header_nav_list_item > span {
	color: var(--wp--preset--color--white);
	font-family: var(--fo-mtsr);
}

header .header_nav_list_item > a:hover::after,
header .header_nav_list_item > span:hover::after {
	transform: translateX(-50%) scale(1, 1);
	transform-origin: left top;
}

header .header_nav_list_item > a::after,
header .header_nav_list_item > span::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 110%;
	height: 0.2rem;
	transform: translateX(-50%) scale(0, 1);
	transform-origin: right top;
	background: var(--wp--preset--color--white);
	content: "";
	transition: var(--trs-tsf);
}

header .header_nav_list_item > span {
	font-size: 1.6rem;
	cursor: pointer;
}

header .header_nav_list_item a {
	display: block;
	font-size: 1.6rem;
}

header .header_nav_list_item > .text {
	cursor: pointer;
}

header .header_nav_list_item_container {
	transition: var(--trs-bsc);
}

header .header_nav_list_item_container .text {
	font-family: var(--fo-mtsr);
}

header .header_nav_list_item_container ul li:last-of-type {
	margin-bottom: clamp(0.4rem, 1.1538461538vw, 0.6rem);
}

header .header_nav_list_item_container ul li a {
	display: block;
	transition: var(--trs-opc);
}

header .header_nav_list_item_container ul li a .image img {
	transition: var(--trs-tsf);
}

header .header_nav_list_item_container ul li a .dcp {
	font-family: var(--fo-shs-jp);
}

header .header_nav_other_item a {
	display: block;
	color: var(--wp--preset--color--white);
	font-family: var(--fo-shs-jp);
}

.post_sidebar {
	flex-shrink: 1;
	width: 100%;
	padding-top: clamp(2rem, 3.125vw, 2.4rem);
	padding-right: clamp(3.6rem, 3.8541666667vw, 7.4rem);
	padding-bottom: clamp(3.2rem, 5.2777777778vw, 7.6rem);
	padding-left: clamp(3.6rem, 3.8541666667vw, 7.4rem);
	background-color: var(--co-blc);
}

.post_sidebar h2,
.post_sidebar .icon p {
	color: var(--wp--preset--color--white);
}

.post_sidebar_title {
	font-weight: bold;
	font-size: clamp(1.8rem, 3.125vw, 2.4rem);
	font-family: var(--fo-clv2);
}

.post_sidebar_category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: clamp(0.6rem, 1.0416666667vw, 0.8rem);
}

.post_sidebar_category + .post_sidebar_title {
	margin-top: clamp(1.8rem, 3.90625vw, 3rem);
	border-top: solid 0.1rem var(--wp--preset--color--white);
}

.post_sidebar_category_item {
	height: 100%;
}

.post_sidebar_category_item_link {
	display: inline-block;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

.post_sidebar_category_item.current {
	display: inline-block;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

.post_sidebar_list {
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
}

.post_sidebar_list_item:not(:first-of-type) {
	margin-top: clamp(2.4rem, 4.1666666667vw, 3.2rem);
}

.post_sidebar_list_item_link figure {
	aspect-ratio: 214/125;
}

.post_sidebar_list_item_link figure img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
}

.post_sidebar_list_item_link .textarea {
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
}

.post_sidebar_list_item_link .textarea h2 {
	margin-top: clamp(0.8rem, 1.5625vw, 1.2rem);
	font-size: clamp(1.6rem, 2.6041666667vw, 2rem);
	line-height: 1.5;
}

.post_sidebar_list_item_link .textarea time {
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
	color: var(--wp--preset--color--white);
	font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
	font-family: var(--fo-shs-jp);
}

.post_sidebar_list_item_link .textarea .icon {
	-moz-column-gap: 5%;
	display: flex;
	column-gap: 5%;
	align-items: center;
	margin-top: clamp(1rem, 2.0833333333vw, 1.6rem);
	padding-top: clamp(1.2rem, 2.6041666667vw, 2rem);
	border-top: solid 0.1rem var(--wp--preset--color--white);
}

.post_sidebar_list_item_link .textarea .icon_figure {
	aspect-ratio: 1/1;
	width: 5.5rem;
}

.post_sidebar_list_item_link .textarea .icon_figure img {
	height: 100%;
	border-radius: 5.5rem;
}

.post_sidebar_list_item_link .textarea .category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: clamp(0.6rem, 1.0416666667vw, 0.8rem);
}

.post_sidebar_list_item_link .textarea .category_list {
	display: inline-block;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

main.sub .form {
	position: relative;
	background-color: var(--wp--preset--color--black);
}

main.sub .form::after {
	position: absolute;
	bottom: -0.1rem;
	aspect-ratio: 30/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub .form .outer {
	padding-top: 4.8rem;
}

main.sub .form_table {
	display: block;
	background-color: var(--wp--preset--color--white);
}

main.sub .form_table tbody {
	display: block;
}

main.sub .form_table_row:not(:nth-child(-n+3)) {
	display: block;
}

main.sub .form_table_row:not(:nth-child(-n+3)) .content {
	display: block;
}

main.sub .form_table_row input,
main.sub .form_table_row textarea,
main.sub .form_table_row select {
	border: none;
	outline: none;
}

main.sub .form_table_row textarea {
	width: 100%;
	padding: 0.6rem 1.6rem;
	color: var(--co-gr-th-dr);
}

main.sub .form_table_row select {
	color: var(--wp--preset--color--black);
}

main.sub .form_table_row_title {
	font-weight: 700;
	font-size: 2.4rem;
	font-family: var(--fo-clv2);
}

main.sub .form_table_row_subtitle {
	font-weight: 700;
	font-size: 1.8rem;
}

main.sub .form_table_row .content .select {
	display: inline-block;
	position: relative;
	width: 100%;
	padding-right: 1rem;
	padding-left: 1rem;
	border: solid 0.2rem var(--wp--preset--color--black);
	border-radius: 1rem;
}

main.sub .form_table_row .content .select::after {
	-webkit-mask-image: url(./images/common/svg/icon-arrow-round-blc.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	position: absolute;
	top: 50%;
	right: 1rem;
	aspect-ratio: 2/1;
	width: 1.2rem;
	transform: translateY(-50%);
	background-color: var(--co-blc);
	content: "";
	mask-image: url(./images/common/svg/icon-arrow-round-blc.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
}

main.sub .form_table_row .content .input {
	position: relative;
}

main.sub .form_table_row .content .input input {
	padding: 0.6rem 1.6rem;
	color: var(--co-gr-th-dr);
}

main.sub .form_table_row .content .input .error {
	position: absolute;
	right: 0;
}

main.sub .form_table_row .content .radio .mwform-radio-field label input[type=radio] {
	-webkit-appearance: none;
	-moz-appearance: none;
	display: none;
	appearance: none;
}

main.sub .form_table_row .content .radio .mwform-radio-field label input[type=radio]:checked + span::before {
	background-image: url(./images/common/svg/icon-circle-wht.svg);
	background-position: 50% 50%;
	background-size: 80%;
	background-repeat: no-repeat;
	background-color: var(--co-blc);
}

main.sub .form_table_row .content .radio .mwform-radio-field label input[type=radio] + span {
	-moz-column-gap: 0.6rem;
	display: inline-flex;
	position: relative;
	column-gap: 0.6rem;
	align-items: center;
	cursor: pointer;
}

main.sub .form_table_row .content .radio .mwform-radio-field label input[type=radio] + span::before {
	display: inline-block;
	width: 1.2rem;
	height: 1.2rem;
	margin-top: 0.4rem;
	border: solid 0.2rem var(--co-blc);
	border-radius: 1.2rem;
	content: "";
}

main.sub .form_table_row .content .checkbox {
	-moz-column-gap: 1rem;
	display: flex;
	column-gap: 1rem;
	flex-wrap: wrap;
}

main.sub .form_table_row .content .checkbox .mwform-checkbox-field + .horizontal-item {
	margin-left: 0;
}

main.sub .form_table_row .content .checkbox .mwform-checkbox-field label input[type=checkbox] {
	-webkit-appearance: none;
	-moz-appearance: none;
	display: none;
	appearance: none;
}

main.sub .form_table_row .content .checkbox .mwform-checkbox-field label input[type=checkbox]:checked + span::before {
	background-image: url(./images/common/svg/icon-check-wht.svg);
	background-position: 50% 50%;
	background-size: 80%;
	background-repeat: no-repeat;
	background-color: var(--co-blc);
}

main.sub .form_table_row .content .checkbox .mwform-checkbox-field label input[type=checkbox] + span {
	-moz-column-gap: 0.6rem;
	display: flex;
	column-gap: 0.6rem;
	align-items: center;
}

main.sub .form_table_row .content .checkbox .mwform-checkbox-field label input[type=checkbox] + span::before {
	display: inline-block;
	width: 1.8rem;
	height: 1.8rem;
	margin-top: 0.2rem;
	border: solid 0.2rem var(--co-blc);
	border-radius: 0.4rem;
	content: "";
}

main.sub .form_text {
	margin-top: 2rem;
	padding-top: 2.4rem;
	border-top: solid 0.1rem var(--wp--preset--color--white);
}

main.sub .form_text .mwform-checkbox-field {
	display: flex;
	align-items: center;
	justify-content: center;
}

main.sub .form_text .mwform-checkbox-field label input[type=checkbox] {
	-webkit-appearance: none;
	-moz-appearance: none;
	display: none;
	appearance: none;
}

main.sub .form_text .mwform-checkbox-field label input[type=checkbox]:checked + span::before {
	background-image: url(./images/common/svg/icon-check-wht.svg);
	background-position: 50% 50%;
	background-size: 80%;
	background-repeat: no-repeat;
	background-color: var(--co-blc);
}

main.sub .form_text .mwform-checkbox-field label input[type=checkbox] + span {
	-moz-column-gap: 0.6rem;
	display: flex;
	column-gap: 0.6rem;
	align-items: center;
	color: var(--wp--preset--color--white);
}

main.sub .form_text .mwform-checkbox-field label input[type=checkbox] + span::before {
	display: inline-block;
	width: 1.8rem;
	height: 1.8rem;
	margin-top: 0.2rem;
	border: solid 0.2rem var(--wp--preset--color--white);
	border-radius: 0.4rem;
	content: "";
}

main.sub .form_text + p {
	text-align: center;
}

main.sub .form_text + p a {
	padding-bottom: 0.6rem;
	border-bottom: solid 0.1rem var(--wp--preset--color--white);
	color: var(--wp--preset--color--white);
	font-size: 1.4rem;
	transition: var(--trs-opc);
}

main.sub .form_text + p a:hover {
	opacity: 0.4;
}

main.sub .form_text .error {
	text-align: center;
}

main.sub .form .submit-btn {
	-moz-column-gap: 8%;
	display: flex;
	column-gap: 8%;
	align-items: center;
	justify-content: center;
}

main.sub .form .submit-btn .confirm,
main.sub .form .submit-btn .send,
main.sub .form .submit-btn .previous {
	position: relative;
	width: 100%;
	max-width: 30.5rem;
	height: 6rem;
	overflow: hidden;
	border-radius: 6rem;
}

main.sub .form .submit-btn .confirm::before,
main.sub .form .submit-btn .confirm::after,
main.sub .form .submit-btn .send::before,
main.sub .form .submit-btn .send::after,
main.sub .form .submit-btn .previous::before,
main.sub .form .submit-btn .previous::after {
	position: absolute;
	content: "";
}

main.sub .form .submit-btn .confirm::before,
main.sub .form .submit-btn .send::before,
main.sub .form .submit-btn .previous::before {
	z-index: 10;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transform: scale(0, 1);
	transform-origin: right top;
	border-radius: 6rem;
	transition: var(--trs-tsf);
}

main.sub .form .submit-btn .confirm::after,
main.sub .form .submit-btn .send::after,
main.sub .form .submit-btn .previous::after {
	z-index: 20;
	top: 50%;
	right: 2.4rem;
	aspect-ratio: 1/1;
	width: 2.5rem;
	transform: translateY(-50%);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	transition: var(--trs-bgi);
}

main.sub .form .submit-btn .confirm input,
main.sub .form .submit-btn .send input,
main.sub .form .submit-btn .previous input {
	z-index: 20;
	position: relative;
	width: 100%;
	height: 100%;
	border-width: 0.2rem;
	border-style: solid;
	border-radius: 6rem;
	outline: none;
	font-family: var(--fo-shs-jp);
	cursor: pointer;
	transition: var(--trs-col);
}

main.sub .form .submit-btn .confirm,
main.sub .form .submit-btn .send {
	background-color: var(--wp--preset--color--white);
}

main.sub .form .submit-btn .confirm::before,
main.sub .form .submit-btn .send::before {
	background-color: var(--wp--preset--color--black);
}

main.sub .form .submit-btn .confirm::after,
main.sub .form .submit-btn .send::after {
	background-image: url(./images/common/svg/icon-arrow-wht-flame-blc.svg);
}

main.sub .form .submit-btn .confirm input,
main.sub .form .submit-btn .send input {
	border-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--black);
	font-weight: 700;
	font-size: 2rem;
}

main.sub .form .submit-btn .previous {
	background-color: var(--wp--preset--color--black);
}

main.sub .form .submit-btn .previous::before {
	background-color: var(--wp--preset--color--white);
}

main.sub .form .submit-btn .previous::after {
	background-image: url(./images/common/svg/icon-arrow-blc-flame-wht.svg);
}

main.sub .form .submit-btn .previous input {
	border-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--white);
	font-weight: 700;
	font-size: 2rem;
}

main.sub .form.confirm .form_text + p,
main.sub .form.complete .form_text + p {
	display: none;
}

main.sub .form.complete .btn-white {
	margin-right: auto;
	margin-left: auto;
}

main.home .contact,
main.sub .contact {
	position: relative;
	background-image: url(./images/common/jpg/image-cement.jpg);
}

main.home .contact::after,
main.sub .contact::after {
	position: absolute;
	bottom: -0.1rem;
	aspect-ratio: 30/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.home .contact .util-title-mont,
main.sub .contact .util-title-mont {
	text-align: center;
}

main.home .contact .util-text,
main.sub .contact .util-text {
	text-align: center;
}

main.home .contact .btn-area,
main.sub .contact .btn-area {
	display: flex;
	align-items: center;
	justify-content: center;
}

main.home .contact .btn-black .content,
main.home .contact .btn-white .content,
main.sub .contact .btn-black .content,
main.sub .contact .btn-white .content {
	-moz-column-gap: 2.4rem;
	column-gap: 2.4rem;
	flex-direction: row-reverse;
	justify-content: flex-end;
}

main.home .contact .btn-black .content::before,
main.home .contact .btn-white .content::before,
main.sub .contact .btn-black .content::before,
main.sub .contact .btn-white .content::before {
	content: none;
}

main.home .contact .btn-black .content::after,
main.home .contact .btn-white .content::after,
main.sub .contact .btn-black .content::after,
main.sub .contact .btn-white .content::after {
	aspect-ratio: 1/1;
}

main.home .contact .btn-black .content::after,
main.sub .contact .btn-black .content::after {
	width: 2.5rem;
	background-image: url(./images/common/svg/icon-paper-airplane-white.svg);
}

main.home .contact .btn-white .content::after,
main.sub .contact .btn-white .content::after {
	width: 2.5rem;
	background-image: url(./images/common/svg/icon-download-black.svg);
}

.footer {
	padding-top: clamp(4.8rem, 5vw, 9.6rem);
}

.footer_company_logo {
	display: inline-block;
	text-align: center;
}

.footer_company_logo_figure {
	max-width: 100%;
}

.footer_company_logo .text {
	font-weight: bold;
	font-family: var(--fo-clv2);
}

.footer_company_address {
	margin-top: 1rem;
	font-size: 1.8rem;
}

.footer_company_address .address {
	line-height: 1.25;
}

.footer_company_phone {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
}

.footer_company_phone_link {
	-moz-column-gap: 1.2rem;
	display: inline-flex;
	column-gap: 1.2rem;
	align-items: center;
	transition: var(--trs-opc);
}

.footer_company_phone_link_figure {
	aspect-ratio: 1/1;
}

.footer_company_phone_link .text {
	font-weight: 600;
	font-size: clamp(2.6rem, 3.1944444444vw, 4.6rem);
	font-family: var(--fo-mtsr);
}

.footer_company_phone_hours {
	display: inline-block;
}

.footer_nav {
	display: flex;
	justify-content: space-between;
}

.footer_nav_child {
	display: flex;
}

.footer_nav_child_item {
	flex-shrink: 0;
}

.footer_nav_child_item .text {
	font-weight: 500;
	font-size: 1.8rem;
	font-family: var(--fo-mtsr);
}

.footer_nav_child_item .sub-menu li {
	position: relative;
	padding-left: 2em;
}

.footer_nav_child_item .sub-menu li::before {
	position: absolute;
	top: 55%;
	left: 0;
	width: 1.2rem;
	height: 0.1rem;
	transform: translateY(-50%);
	background-color: var(--wp--preset--color--black);
	content: "";
}

.footer_nav_child_item .sub-menu li a {
	font-weight: 500;
	font-family: var(--fo-shs-jp);
	transition: var(--trs-opc);
}

.footer_nav_parent li a {
	font-weight: 500;
	font-size: 1.8rem;
	font-family: var(--fo-mtsr);
	transition: var(--trs-opc);
}

.footer_other {
	display: flex;
	justify-content: space-between;
}

.footer_other_nav {
	display: flex;
	align-items: center;
}

.footer_other_nav_item a {
	display: block;
	font-size: clamp(1.2rem, 2.3333333333vw, 1.4rem);
	font-family: var(--fo-shs-jp);
	transition: var(--trs-opc);
}

.footer_other_copyright {
	text-align: center;
}

.breadcrumbs .wrapper {
	width: 100%;
	max-width: 160rem;
	margin-right: auto;
	margin-left: auto;
}

.breadcrumbs .wrapper a,
.breadcrumbs .wrapper span {
	font-size: 1.4rem;
	font-family: var(--fo-shs-jp);
}

main.sub.concept .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.concept .breadcrumbs span,
main.sub.concept .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

main.sub.category .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.category .breadcrumbs span,
main.sub.category .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

main.sub.works .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.works .breadcrumbs span,
main.sub.works .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

main.sub.contact .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.contact .breadcrumbs span,
main.sub.contact .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

main.sub.recruit .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.recruit .breadcrumbs span,
main.sub.recruit .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

main.sub.single.blog .breadcrumbs {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.single.blog .breadcrumbs span,
main.sub.single.blog .breadcrumbs a {
	color: var(--wp--preset--color--white);
}

.btn-black,
.btn-white {
	display: flex;
	position: relative;
	align-items: center;
	overflow: hidden;
	border-width: 0.2rem;
	border-style: solid;
}

.btn-black::before,
.btn-white::before {
	z-index: 10;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transform: scale(0, 1);
	transform-origin: right top;
	content: "";
	transition: var(--trs-tsf);
}

.btn-black .content,
.btn-white .content {
	display: flex;
	z-index: 20;
	position: relative;
	align-items: center;
	width: 100%;
	transition: var(--trs-tsf);
}

.btn-black .content::before,
.btn-black .content::after,
.btn-white .content::before,
.btn-white .content::after {
	content: "";
}

.btn-black .content::before,
.btn-white .content::before {
	position: absolute;
	top: 50%;
	aspect-ratio: 1/1;
	width: 2.4rem;
	transform: translate(-50%, -50%);
	border-width: 0.2rem;
	border-style: solid;
	border-radius: 0.5rem;
	transition: var(--trs-bsc);
}

.btn-black .content::after,
.btn-white .content::after {
	display: inline-block;
	aspect-ratio: 1/2;
	width: 0.7rem;
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	transition: var(--trs-bgi);
}

.btn-black .content .text,
.btn-white .content .text {
	flex-shrink: 0;
	line-height: var(--lh-nml);
	font-family: var(--fo-shs-jp);
	letter-spacing: 0;
	transition: var(--trs-col);
}

.btn-black .content .text::after,
.btn-white .content .text::after {
	display: block;
	width: 0;
	height: 0;
	content: "";
	line-height: var(--lh-ht-cl);
}

.btn-black .content .text::after,
.btn-white .content .text::after {
	margin-bottom: 0.2rem;
}

.btn-black {
	border-color: var(--co-blc);
	background-color: var(--co-blc);
}

.btn-black::before {
	background-color: var(--wp--preset--color--white);
}

.btn-black .content {
	color: var(--wp--preset--color--white);
}

.btn-black .content::before,
.btn-black .content::after {
	content: "";
}

.btn-black .content::before {
	border-color: var(--wp--preset--color--white);
}

.btn-black .content::after {
	background-image: url(./images/common/svg/icon-arw-wht-rit.svg);
}

.btn-white {
	border-color: var(--co-blc);
	background-color: var(--wp--preset--color--white);
}

.btn-white::before {
	background-color: var(--co-blc);
}

.btn-white .content {
	color: var(--co-blc);
}

.btn-white .content::before,
.btn-white .content::after {
	content: "";
}

.btn-white .content::before {
	border-color: var(--co-blc);
}

.btn-white .content::after {
	background-image: url(./images/common/svg/icon-arw-drk-rit.svg);
}

.loading {
	visibility: visible;
	z-index: 1100;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	height: 100dvh;
	margin: 0;
	padding: 0;
	background-color: var(--wp--preset--color--white);
	opacity: 1;
	transition: var(--trs-bsc);
}

.loading.finished {
	visibility: hidden;
	opacity: 0;
}

.loading_content {
	display: inline-flex;
	position: relative;
	top: 50%;
	left: 50%;
	flex-direction: column;
	align-items: center;
	transform: translate(-50%, -50%);
}

.loading_image {
	max-width: 100%;
}

.cf {
	display: block;
	z-index: 890;
	position: fixed;
	right: 0;
	padding-top: 4rem;
	padding-right: 1rem;
	padding-bottom: 4rem;
	padding-left: 1rem;
	overflow: hidden;
	border-width: 0.1rem;
	border-style: solid;
	border-color: var(--wp--preset--color--white);
	background-color: var(--wp--preset--color--black);
	transition: var(--trs-boc);
	writing-mode: vertical-rl;
}

.cf::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transform: scale(0, 1);
	transform-origin: right top;
	background-color: var(--wp--preset--color--white);
	content: "";
	transition: var(--trs-tsf);
}

.cf .text {
	position: relative;
	color: var(--wp--preset--color--white);
	font-family: var(--fo-shs-jp);
	transition: var(--trs-col);
}

main.sub .law ol,
main.sub .law ul,
main.sub .law li,
main.sub .law a {
	font-family: var(--fo-shs-jp);
}

main.sub .law h2 {
	-moz-column-gap: clamp(1rem, 1.25vw, 1.6rem);
	display: flex;
	column-gap: clamp(1rem, 1.25vw, 1.6rem);
	align-items: center;
	font-weight: bold;
	font-family: var(--fo-clv2);
}

main.sub .law h2::before {
	display: inline-block;
	aspect-ratio: 1/1;
	background-image: url(./images/common/svg/icon-circle-blc.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
}

main.sub .law ol {
	padding-left: 2em;
}

main.sub .law ol li {
	padding-left: 0.2rem;
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	list-style: decimal;
}

main.sub .law ol > li > ol {
	margin-top: clamp(0.6rem, 1.6666666667vw, 1rem);
}

main.sub .law ol > li > ol > li > ol {
	margin-top: clamp(0.6rem, 1.3333333333vw, 0.8rem);
}

main.sub .law ul {
	padding-left: 2em;
}

main.sub .law ul li {
	padding-left: 0.2rem;
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	list-style: disc;
}

main.sub .law strong {
	font-weight: bold;
}

main.sub .law a {
	position: relative;
	transition: var(--trs-opc);
}

main.sub .law a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 0.1rem;
	background-color: var(--wp--preset--color--black);
	content: "";
}

.banner_content {
	max-width: 106rem;
	margin-right: auto;
	margin-left: auto;
	padding: clamp(2.4rem, 3.0555555556vw, 4.4rem) clamp(1.8rem, 2.5vw, 3.6rem);
	background-image: url(./images/common/png/bg-banner.png);
	background-position: 50% 50%;
	background-size: cover;
	background-repeat: no-repeat;
	background-color: var(--co-blc);
}

.banner_textarea {
	text-align: center;
}

.banner_text,
.banner_title,
.banner_subtitle {
	color: var(--wp--preset--color--white);
}

.banner_title,
.banner_subtitle {
	font-weight: bold;
}

.banner_title {
	padding-top: clamp(0.8rem, 0.8333333333vw, 1.2rem);
	font-size: clamp(3.2rem, 3.125vw, 6rem);
	line-height: 1;
	font-family: var(--fo-jps);
}

.banner_subtitle .small {
	font-size: clamp(1.6rem, 1.6666666667vw, 2.4rem);
	font-family: var(--fo-jps);
}

.banner_subtitle .large {
	font-size: clamp(1.6rem, 1.6666666667vw, 2.4rem);
	font-family: var(--fo-clv2);
	letter-spacing: 0.05em;
}

.banner_text {
	line-height: 1.5;
}

.banner .btn-white {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

.banner .btn-white .content::before {
	left: auto;
}

.pagination {
	padding-top: clamp(3.2rem, 3.0555555556vw, 4.4rem);
}

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

.pagination ul.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-right: auto;
	margin-left: auto;
	background-color: var(--wp--preset--color--white);
}

.pagination ul.page-numbers li {
	display: flex;
	align-items: center;
	justify-content: center;
}

.pagination ul.page-numbers li.first a span,
.pagination ul.page-numbers li.previous a span,
.pagination ul.page-numbers li.next a span,
.pagination ul.page-numbers li.last a span {
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	width: 2rem;
	background-color: var(--co-blc);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

.pagination ul.page-numbers li.first a span,
.pagination ul.page-numbers li.last a span {
	-webkit-mask-image: url(./images/common/svg/icon-arrow-dbl-blc-flame-blc.svg);
	mask-image: url(./images/common/svg/icon-arrow-dbl-blc-flame-blc.svg);
}

.pagination ul.page-numbers li.previous a span,
.pagination ul.page-numbers li.next a span {
	-webkit-mask-image: url(./images/common/svg/icon-arrow-blc-flame-blc.svg);
	mask-image: url(./images/common/svg/icon-arrow-blc-flame-blc.svg);
}

.pagination ul.page-numbers li.next a span,
.pagination ul.page-numbers li.last a span {
	transform: rotate(180deg);
}

.pagination ul.page-numbers li a {
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 10/9;
	width: 4rem;
	height: 100%;
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	font-family: var(--fo-shs-jp);
}

.pagination ul.page-numbers li a.page-numbers {
	width: 100%;
}

.pagination ul.page-numbers li span.page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	background-color: var(--co-blc);
	color: var(--wp--preset--color--white);
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	font-family: var(--fo-shs-jp);
}

main.home {
	overflow: hidden;
}

main.home .mv {
	background-color: var(--wp--preset--color--black);
}

main.home .mv .outer {
	padding-top: clamp(2.8rem, 2.0833333333vw, 4rem);
}

main.home .mv .lottie-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

main.home .mv .lottie-container:nth-of-type(2) {
	flex-direction: row-reverse;
}

main.home .mv .lottie-container:not(:first-of-type) {
	margin-top: clamp(4rem, 4.1666666667vw, 8rem);
}

main.home .mv .lottie .movie video {
	width: 100%;
	height: 100%;
}

main.home .mv .lottie-realize svg,
main.home .mv .lottie-picture svg,
main.home .mv .lottie-dream svg {
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: 100%;
	background-color: var(--wp--preset--color--white);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: 100%;
}

main.home .mv .lottie-realize svg {
	-webkit-mask-image: url(./images/common/svg/text-realize.svg);
	mask-image: url(./images/common/svg/text-realize.svg);
}

main.home .mv .lottie-picture svg {
	-webkit-mask-image: url(./images/common/svg/text-picture.svg);
	mask-image: url(./images/common/svg/text-picture.svg);
}

main.home .mv .lottie-dream svg {
	-webkit-mask-image: url(./images/common/svg/text-dream.svg);
	mask-image: url(./images/common/svg/text-dream.svg);
}

main.home .mv_news {
	text-align: right;
}

main.home .mv_news_link {
	display: inline-flex;
	transition: var(--trs-opc);
}

main.home .mv_news_article {
	display: inline-block;
	text-align: start;
}

main.home .mv_news_article time,
main.home .mv_news_article_title {
	color: var(--wp--preset--color--white);
}

main.home .mv_news_article time {
	font-weight: 500;
	font-size: 1.6rem;
	font-family: var(--fo-mtsr);
}

main.home .concept .mission,
main.home .concept .vision,
main.home .concept .service {
	position: relative;
}

main.home .concept .mission::before,
main.home .concept .vision::before,
main.home .concept .service::before {
	position: absolute;
	aspect-ratio: 206/207;
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
}

main.home .concept .mission::before {
	background-image: url(./images/common/svg/icon-geometry01.svg);
	animation: gear 60s linear infinite;
}

main.home .concept .mission .btn-black {
	margin-top: clamp(3.2rem, 3.3333333333vw, 6.4rem);
}

main.home .concept .vision {
	margin-top: clamp(6.4rem, 6.6666666667vw, 12.8rem);
}

main.home .concept .vision::before {
	background-image: url(./images/common/svg/icon-geometry02.svg);
	animation: gear-reverse 60s linear infinite;
}

main.home .concept .vision .wrapper {
	display: flex;
	flex-direction: column;
}

main.home .concept .vision_content {
	display: inline-block;
}

main.home .concept .vision .btn-black {
	margin-top: clamp(3.2rem, 3.3333333333vw, 6.4rem);
	margin-left: auto;
}

main.home .concept .service {
	margin-top: clamp(5.6rem, 3.75vw, 7.2rem);
}

main.home .concept .service::before {
	top: -6%;
	background-image: url(./images/common/svg/icon-geometry03.svg);
	animation: gear 60s linear infinite;
}

main.home .concept .service_detail {
	margin-top: clamp(8.6rem, 8.9583333333vw, 17.2rem);
}

main.home .concept .service_detail_list {
	display: flex;
}

main.home .concept .service_detail_list_item {
	display: flex;
	z-index: 20;
	position: relative;
	position: relative;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-family: var(--fo-shs-jp);
	cursor: pointer;
	transition: var(--trs-bsc);
}

main.home .concept .service_detail_list_item::before {
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	background-color: var(--co-blc);
	content: "";
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
	transition: var(--trs-bsc);
}

main.home .concept .service_detail_list_item.active::before {
	background-color: var(--wp--preset--color--white);
}

main.home .concept .service_detail_list_item:first-of-type::before {
	-webkit-mask-image: url(./images/common/svg/icon-design-black.svg);
	mask-image: url(./images/common/svg/icon-design-black.svg);
}

main.home .concept .service_detail_list_item:nth-of-type(2)::before {
	-webkit-mask-image: url(./images/common/svg/icon-web-black.svg);
	mask-image: url(./images/common/svg/icon-web-black.svg);
}

main.home .concept .service_detail_list_item:nth-of-type(3)::before {
	-webkit-mask-image: url(./images/common/svg/icon-consulting-black.svg);
	mask-image: url(./images/common/svg/icon-consulting-black.svg);
}

main.home .concept .service_detail_list_item:nth-of-type(4)::before {
	-webkit-mask-image: url(./images/common/svg/icon-system-black.svg);
	mask-image: url(./images/common/svg/icon-system-black.svg);
}

main.home .concept .service_detail_list_item:nth-of-type(5)::before {
	-webkit-mask-image: url(./images/common/svg/icon-movie-black.svg);
	mask-image: url(./images/common/svg/icon-movie-black.svg);
}

main.home .concept .service_detail_list_item:last-of-type::before {
	-webkit-mask-image: url(./images/common/svg/icon-camera-black.svg);
	mask-image: url(./images/common/svg/icon-camera-black.svg);
}

main.home .concept .service_detail_list_item:not(.active) {
	background-color: transparent;
}

main.home .concept .service_detail_list_item.active {
	color: var(--wp--preset--color--white);
}

main.home .concept .service_detail_list_item.active::after {
	background-color: var(--co-blc);
}

main.home .concept .service_detail_list_item::after {
	z-index: -1;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: transparent;
	content: "";
	transition: var(--trs-bsc);
}

main.home .concept .service_detail_content {
	-moz-column-gap: clamp(3.2rem, 3.3333333333vw, 4.8rem);
	display: none;
	visibility: hidden;
	column-gap: clamp(3.2rem, 3.3333333333vw, 4.8rem);
	align-items: center;
	margin-top: clamp(4.8rem, 4.5833333333vw, 6.6rem);
	opacity: 0;
	transition: var(--trs-bsc);
}

main.home .concept .service_detail_content.appear {
	display: flex;
	visibility: visible;
	opacity: 1;
}

main.home .concept .service_detail_title {
	display: flex;
	flex-direction: column;
	margin-bottom: clamp(3.2rem, 2.2916666667vw, 4.4rem);
	font-weight: bold;
	line-height: 1;
}

main.home .concept .service_detail_title .en {
	color: var(--co-gr);
	font-family: var(--fo-mtsr);
}

main.home .concept .service_detail_title .ja {
	font-family: var(--fo-shs-jp);
}

main.home .concept .service_detail_textarea {
	display: flex;
	flex-grow: 1;
	flex-direction: column;
}

main.home .concept .service_detail_textarea .btn-black {
	margin-top: clamp(4rem, 4.1666666667vw, 8rem);
	margin-left: auto;
}

main.home .works {
	margin-top: clamp(8rem, 7.2916666667vw, 14rem);
}

main.home .works_content {
	margin-top: clamp(3.2rem, 3.0555555556vw, 4.4rem);
}

main.home .works_list {
	display: flex;
	row-gap: clamp(3.2rem, 3.75vw, 5.4rem);
	flex-wrap: wrap;
	justify-content: space-between;
}

main.home .works_article_link_figure {
	aspect-ratio: 414/276;
	background-color: var(--co-gr);
	box-shadow: 0.7rem 0.7rem 0.5rem var(--co-gr-tsp);
}

main.home .works_article_link_figure img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
}

main.home .works_article_link_title {
	margin-top: clamp(1.8rem, 1.6666666667vw, 2.4rem);
	font-weight: bold;
	font-size: clamp(1.8rem, 1.5277777778vw, 2.2rem);
	line-height: var(--lh-lw);
}

main.home .works_article_link_list {
	-moz-column-gap: 1.8rem;
	display: flex;
	column-gap: 1.8rem;
	flex-wrap: wrap;
	align-items: center;
}

main.home .works_article_link_list_item {
	line-height: 1.5;
	font-family: var(--fo-shs-jp);
}

main.home .works .btn-black {
	margin-right: auto;
	margin-left: auto;
}

main.home .post {
	background-color: var(--co-blc);
	color: var(--wp--preset--color--white);
}

main.home .post a {
	color: var(--wp--preset--color--white);
}

main.home .post .util-title-mont {
	text-align: center;
}

main.home .post .util-text {
	text-align: center;
}

main.home .post .wrapper {
	display: flex;
	justify-content: space-around;
}

main.home .post .news,
main.home .post .media {
	display: flex;
	flex-direction: column;
}

main.home .post .news_content,
main.home .post .media_content {
	display: flex;
	flex-grow: 1;
	flex-direction: column;
}

main.home .post .news_list_item:not(:last-of-type) {
	margin-bottom: 1.8rem;
}

main.home .post .news_article_link {
	display: block;
	border-bottom-width: 0.1rem;
	border-bottom-style: solid;
	border-bottom-color: var(--wp--preset--color--white);
}

main.home .post .news_article_link time {
	font-weight: 500;
	font-size: clamp(1.6rem, 1.3888888889vw, 2rem);
	line-height: var(--lh-lw);
	font-family: var(--fo-mtsr);
}

main.home .post .news_article_link_title {
	margin-bottom: 1rem;
	font-size: clamp(1.4rem, 2.34375vw, 1.8rem);
	line-height: var(--lh-lw);
}

main.home .post .btn-white {
	margin-right: auto;
	margin-left: auto;
}

main.home .recruit {
	background-image: url(./images/home/png/top-recruit.png);
	background-position: 50% 50%;
	background-size: cover;
	background-repeat: no-repeat;
	background-color: var(--co-blc);
	color: var(--wp--preset--color--white);
	text-align: center;
}

main.home .recruit .util-title-logo {
	margin-top: clamp(1rem, 1.5625vw, 2rem);
	line-height: 1.5;
}

main.home .recruit .btn-white {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub .sub_title {
	-moz-column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	display: flex;
	column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	align-items: center;
	font-weight: bold;
}

main.sub .sub_title::before {
	display: inline-block;
	aspect-ratio: 1/1;
	background-image: url(./images/common/svg/icon-circle-blc.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
}

main.sub .sub_title + .sub_text {
	margin-top: clamp(1.6rem, 2.734375vw, 2.8rem);
}

main.sub .mv {
	background-color: var(--wp--preset--color--black);
}

main.sub .mv .wrapper {
	-moz-column-gap: clamp(6rem, 6.25vw, 12rem);
	display: flex;
	column-gap: clamp(6rem, 6.25vw, 12rem);
	justify-content: space-between;
}

main.sub .mv_title {
	display: flex;
	flex-direction: column;
	color: var(--wp--preset--color--white);
}

main.sub .mv_title .en {
	line-height: var(--lh-lw);
	font-family: var(--fo-mtsr);
}

main.sub .mv_title .ja {
	font-weight: bold;
	line-height: 1.3;
	font-family: var(--fo-clv2);
}

main.sub .mv_text {
	color: var(--wp--preset--color--white);
}

main.sub .mv_icon img {
	height: 100%;
}

main.sub .category_order {
	display: flex;
	row-gap: clamp(3.2rem, 3.3333333333vw, 4.8rem);
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	counter-reset: number 0;
}

main.sub .category_order li:nth-of-type(1) {
	animation-delay: 0.1s;
}

main.sub .category_order li:nth-of-type(2) {
	animation-delay: 0.2s;
}

main.sub .category_order li:nth-of-type(3) {
	animation-delay: 0.3s;
}

main.sub .category_order li:nth-of-type(4) {
	animation-delay: 0.4s;
}

main.sub .category_order li:nth-of-type(5) {
	animation-delay: 0.5s;
}

main.sub .category_order li:nth-of-type(6) {
	animation-delay: 0.6s;
}

main.sub .category_order li:nth-of-type(7) {
	animation-delay: 0.7s;
}

main.sub .category_order li:nth-of-type(8) {
	animation-delay: 0.8s;
}

main.sub .category_order li:nth-of-type(9) {
	animation-delay: 0.9s;
}

main.sub .category_order li:nth-of-type(10) {
	animation-delay: 1s;
}

main.sub .category_order li:nth-of-type(11) {
	animation-delay: 1.1s;
}

main.sub .category_order li:nth-of-type(12) {
	animation-delay: 1.2s;
}

main.sub .category_order li:nth-of-type(13) {
	animation-delay: 1.3s;
}

main.sub .category_order li:nth-of-type(14) {
	animation-delay: 1.4s;
}

main.sub .category_order li:nth-of-type(15) {
	animation-delay: 1.5s;
}

main.sub .category_order li:nth-of-type(16) {
	animation-delay: 1.6s;
}

main.sub .category_order li:nth-of-type(17) {
	animation-delay: 1.7s;
}

main.sub .category_order li:nth-of-type(18) {
	animation-delay: 1.8s;
}

main.sub .category_order li:nth-of-type(19) {
	animation-delay: 1.9s;
}

main.sub .category_order li:nth-of-type(20) {
	animation-delay: 2s;
}

main.sub .category_order li:nth-of-type(21) {
	animation-delay: 2.1s;
}

main.sub .category_order li:nth-of-type(22) {
	animation-delay: 2.2s;
}

main.sub .category_order li:nth-of-type(23) {
	animation-delay: 2.3s;
}

main.sub .category_order li:nth-of-type(24) {
	animation-delay: 2.4s;
}

main.sub .category_order li:nth-of-type(25) {
	animation-delay: 2.5s;
}

main.sub .category_order li:nth-of-type(26) {
	animation-delay: 2.6s;
}

main.sub .category_order li:nth-of-type(27) {
	animation-delay: 2.7s;
}

main.sub .category_order li:nth-of-type(28) {
	animation-delay: 2.8s;
}

main.sub .category_order li:nth-of-type(29) {
	animation-delay: 2.9s;
}

main.sub .category_order li:nth-of-type(30) {
	animation-delay: 3s;
}

main.sub .category_order li:nth-of-type(31) {
	animation-delay: 3.1s;
}

main.sub .category_order li:nth-of-type(32) {
	animation-delay: 3.2s;
}

main.sub .category_order li:nth-of-type(33) {
	animation-delay: 3.3s;
}

main.sub .category_order li:nth-of-type(34) {
	animation-delay: 3.4s;
}

main.sub .category_order li:nth-of-type(35) {
	animation-delay: 3.5s;
}

main.sub .category_order li:nth-of-type(36) {
	animation-delay: 3.6s;
}

main.sub .category_order li:nth-of-type(37) {
	animation-delay: 3.7s;
}

main.sub .category_order li:nth-of-type(38) {
	animation-delay: 3.8s;
}

main.sub .category_order li:nth-of-type(39) {
	animation-delay: 3.9s;
}

main.sub .category_order li:nth-of-type(40) {
	animation-delay: 4s;
}

main.sub .category_order li:nth-of-type(41) {
	animation-delay: 4.1s;
}

main.sub .category_order li:nth-of-type(42) {
	animation-delay: 4.2s;
}

main.sub .category_order li:nth-of-type(43) {
	animation-delay: 4.3s;
}

main.sub .category_order li:nth-of-type(44) {
	animation-delay: 4.4s;
}

main.sub .category_order li:nth-of-type(45) {
	animation-delay: 4.5s;
}

main.sub .category_order li:nth-of-type(46) {
	animation-delay: 4.6s;
}

main.sub .category_order li:nth-of-type(47) {
	animation-delay: 4.7s;
}

main.sub .category_order li:nth-of-type(48) {
	animation-delay: 4.8s;
}

main.sub .category_order li:nth-of-type(49) {
	animation-delay: 4.9s;
}

main.sub .category_order li:nth-of-type(50) {
	animation-delay: 5s;
}

main.sub .category_order li:nth-of-type(51) {
	animation-delay: 5.1s;
}

main.sub .category_order li:nth-of-type(52) {
	animation-delay: 5.2s;
}

main.sub .category_order li:nth-of-type(53) {
	animation-delay: 5.3s;
}

main.sub .category_order li:nth-of-type(54) {
	animation-delay: 5.4s;
}

main.sub .category_order li:nth-of-type(55) {
	animation-delay: 5.5s;
}

main.sub .category_order li:nth-of-type(56) {
	animation-delay: 5.6s;
}

main.sub .category_order li:nth-of-type(57) {
	animation-delay: 5.7s;
}

main.sub .category_order li:nth-of-type(58) {
	animation-delay: 5.8s;
}

main.sub .category_order li:nth-of-type(59) {
	animation-delay: 5.9s;
}

main.sub .category_order li:nth-of-type(60) {
	animation-delay: 6s;
}

main.sub .category_order li:nth-of-type(61) {
	animation-delay: 6.1s;
}

main.sub .category_order li:nth-of-type(62) {
	animation-delay: 6.2s;
}

main.sub .category_order li:nth-of-type(63) {
	animation-delay: 6.3s;
}

main.sub .category_order li:nth-of-type(64) {
	animation-delay: 6.4s;
}

main.sub .category_order li:nth-of-type(65) {
	animation-delay: 6.5s;
}

main.sub .category_order li:nth-of-type(66) {
	animation-delay: 6.6s;
}

main.sub .category_order li:nth-of-type(67) {
	animation-delay: 6.7s;
}

main.sub .category_order li:nth-of-type(68) {
	animation-delay: 6.8s;
}

main.sub .category_order li:nth-of-type(69) {
	animation-delay: 6.9s;
}

main.sub .category_order li:nth-of-type(70) {
	animation-delay: 7s;
}

main.sub .category_order li:nth-of-type(71) {
	animation-delay: 7.1s;
}

main.sub .category_order li:nth-of-type(72) {
	animation-delay: 7.2s;
}

main.sub .category_order li:nth-of-type(73) {
	animation-delay: 7.3s;
}

main.sub .category_order li:nth-of-type(74) {
	animation-delay: 7.4s;
}

main.sub .category_order li:nth-of-type(75) {
	animation-delay: 7.5s;
}

main.sub .category_order li:nth-of-type(76) {
	animation-delay: 7.6s;
}

main.sub .category_order li:nth-of-type(77) {
	animation-delay: 7.7s;
}

main.sub .category_order li:nth-of-type(78) {
	animation-delay: 7.8s;
}

main.sub .category_order li:nth-of-type(79) {
	animation-delay: 7.9s;
}

main.sub .category_order li:nth-of-type(80) {
	animation-delay: 8s;
}

main.sub .category_order li:nth-of-type(81) {
	animation-delay: 8.1s;
}

main.sub .category_order li:nth-of-type(82) {
	animation-delay: 8.2s;
}

main.sub .category_order li:nth-of-type(83) {
	animation-delay: 8.3s;
}

main.sub .category_order li:nth-of-type(84) {
	animation-delay: 8.4s;
}

main.sub .category_order li:nth-of-type(85) {
	animation-delay: 8.5s;
}

main.sub .category_order li:nth-of-type(86) {
	animation-delay: 8.6s;
}

main.sub .category_order li:nth-of-type(87) {
	animation-delay: 8.7s;
}

main.sub .category_order li:nth-of-type(88) {
	animation-delay: 8.8s;
}

main.sub .category_order li:nth-of-type(89) {
	animation-delay: 8.9s;
}

main.sub .category_order li:nth-of-type(90) {
	animation-delay: 9s;
}

main.sub .category_order li:nth-of-type(91) {
	animation-delay: 9.1s;
}

main.sub .category_order li:nth-of-type(92) {
	animation-delay: 9.2s;
}

main.sub .category_order li:nth-of-type(93) {
	animation-delay: 9.3s;
}

main.sub .category_order li:nth-of-type(94) {
	animation-delay: 9.4s;
}

main.sub .category_order li:nth-of-type(95) {
	animation-delay: 9.5s;
}

main.sub .category_order li:nth-of-type(96) {
	animation-delay: 9.6s;
}

main.sub .category_order li:nth-of-type(97) {
	animation-delay: 9.7s;
}

main.sub .category_order li:nth-of-type(98) {
	animation-delay: 9.8s;
}

main.sub .category_order li:nth-of-type(99) {
	animation-delay: 9.9s;
}

main.sub .category_order li:nth-of-type(100) {
	animation-delay: 10s;
}

main.sub .category_title {
	display: flex;
	position: relative;
	row-gap: 0.4rem;
	flex-direction: column;
	padding-left: clamp(1.4rem, 2.6041666667vw, 2rem);
}

main.sub .category_title::before {
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 0;
	aspect-ratio: 1/5;
	width: clamp(0.6rem, 1.0416666667vw, 0.8rem);
	transform: translateY(-50%);
	background-color: var(--wp--preset--color--black);
	content: "";
}

main.sub .category_title .en,
main.sub .category_title .ja {
	line-height: 1;
}

main.sub .category_title .en {
	-moz-column-gap: 0.4rem;
	display: inline-flex;
	column-gap: 0.4rem;
	align-items: center;
	color: var(--co-gr-ex-dr);
	font-weight: bold;
	font-size: clamp(1rem, 1.5625vw, 1.2rem);
}

main.sub .category_title .en::after {
	display: inline-block;
	content: "0" counter(number);
	font-weight: 700;
	font-size: clamp(1.6rem, 2.6041666667vw, 2rem);
	font-family: var(--fo-mtsr);
	counter-increment: number 1;
}

main.sub .category_title .ja {
	font-weight: bold;
	font-size: clamp(1.8rem, 1.1111111111vw, 1.8rem);
}

main.sub .category figure {
	margin-top: 1rem;
}

main.sub .category figure img {
	max-width: 100%;
}

main.sub .price_table_item {
	display: flex;
	align-items: center;
	line-height: 4;
}

main.sub .price_table_item dt {
	padding-right: clamp(0.6rem, 0.6944444444vw, 1rem);
	padding-left: clamp(0.6rem, 0.6944444444vw, 1rem);
	font-weight: 700;
	font-family: var(--fo-shs-jp);
}

main.sub .price_table_item .detail-row {
	display: flex;
	align-items: center;
}

main.sub .price_table_item .detail-row:not(:last-of-type) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub .price_table_item .detail-row dd {
	width: 50%;
}

main.sub .price_table_item .detail-row dd:first-of-type {
	font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
	font-family: var(--fo-shs-jp);
}

main.sub .price_table_item .detail-row dd:last-of-type {
	font-weight: 500;
	font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
	font-family: var(--fo-mtsr);
}

main.sub .price_table_item .detail-row dd:nth-of-type(2) {
	text-align: right;
}

main.sub .plan_price {
	background-color: var(--co-blc);
}

main.sub .plan_list {
	display: flex;
	align-items: center;
	align-items: stretch;
}

main.sub .plan_list li:nth-of-type(1) {
	animation-delay: 0.3s;
}

main.sub .plan_list li:nth-of-type(2) {
	animation-delay: 0.6s;
}

main.sub .plan_list li:nth-of-type(3) {
	animation-delay: 0.9s;
}

main.sub .plan_list li:nth-of-type(4) {
	animation-delay: 1.2s;
}

main.sub .plan_list li:nth-of-type(5) {
	animation-delay: 1.5s;
}

main.sub .plan_list li:nth-of-type(6) {
	animation-delay: 1.8s;
}

main.sub .plan_list li:nth-of-type(7) {
	animation-delay: 2.1s;
}

main.sub .plan_list li:nth-of-type(8) {
	animation-delay: 2.4s;
}

main.sub .plan_list li:nth-of-type(9) {
	animation-delay: 2.7s;
}

main.sub .plan_list li:nth-of-type(10) {
	animation-delay: 3s;
}

main.sub .plan_list li:nth-of-type(11) {
	animation-delay: 3.3s;
}

main.sub .plan_list li:nth-of-type(12) {
	animation-delay: 3.6s;
}

main.sub .plan_list li:nth-of-type(13) {
	animation-delay: 3.9s;
}

main.sub .plan_list li:nth-of-type(14) {
	animation-delay: 4.2s;
}

main.sub .plan_list li:nth-of-type(15) {
	animation-delay: 4.5s;
}

main.sub .plan_list li:nth-of-type(16) {
	animation-delay: 4.8s;
}

main.sub .plan_list li:nth-of-type(17) {
	animation-delay: 5.1s;
}

main.sub .plan_list li:nth-of-type(18) {
	animation-delay: 5.4s;
}

main.sub .plan_list li:nth-of-type(19) {
	animation-delay: 5.7s;
}

main.sub .plan_list li:nth-of-type(20) {
	animation-delay: 6s;
}

main.sub .plan_list li:nth-of-type(21) {
	animation-delay: 6.3s;
}

main.sub .plan_list li:nth-of-type(22) {
	animation-delay: 6.6s;
}

main.sub .plan_list li:nth-of-type(23) {
	animation-delay: 6.9s;
}

main.sub .plan_list li:nth-of-type(24) {
	animation-delay: 7.2s;
}

main.sub .plan_list li:nth-of-type(25) {
	animation-delay: 7.5s;
}

main.sub .plan_list li:nth-of-type(26) {
	animation-delay: 7.8s;
}

main.sub .plan_list li:nth-of-type(27) {
	animation-delay: 8.1s;
}

main.sub .plan_list li:nth-of-type(28) {
	animation-delay: 8.4s;
}

main.sub .plan_list li:nth-of-type(29) {
	animation-delay: 8.7s;
}

main.sub .plan_list li:nth-of-type(30) {
	animation-delay: 9s;
}

main.sub .plan_list li:nth-of-type(31) {
	animation-delay: 9.3s;
}

main.sub .plan_list li:nth-of-type(32) {
	animation-delay: 9.6s;
}

main.sub .plan_list li:nth-of-type(33) {
	animation-delay: 9.9s;
}

main.sub .plan_list li:nth-of-type(34) {
	animation-delay: 10.2s;
}

main.sub .plan_list li:nth-of-type(35) {
	animation-delay: 10.5s;
}

main.sub .plan_list li:nth-of-type(36) {
	animation-delay: 10.8s;
}

main.sub .plan_list li:nth-of-type(37) {
	animation-delay: 11.1s;
}

main.sub .plan_list li:nth-of-type(38) {
	animation-delay: 11.4s;
}

main.sub .plan_list li:nth-of-type(39) {
	animation-delay: 11.7s;
}

main.sub .plan_list li:nth-of-type(40) {
	animation-delay: 12s;
}

main.sub .plan_list li:nth-of-type(41) {
	animation-delay: 12.3s;
}

main.sub .plan_list li:nth-of-type(42) {
	animation-delay: 12.6s;
}

main.sub .plan_list li:nth-of-type(43) {
	animation-delay: 12.9s;
}

main.sub .plan_list li:nth-of-type(44) {
	animation-delay: 13.2s;
}

main.sub .plan_list li:nth-of-type(45) {
	animation-delay: 13.5s;
}

main.sub .plan_list li:nth-of-type(46) {
	animation-delay: 13.8s;
}

main.sub .plan_list li:nth-of-type(47) {
	animation-delay: 14.1s;
}

main.sub .plan_list li:nth-of-type(48) {
	animation-delay: 14.4s;
}

main.sub .plan_list li:nth-of-type(49) {
	animation-delay: 14.7s;
}

main.sub .plan_list li:nth-of-type(50) {
	animation-delay: 15s;
}

main.sub .plan_list li:nth-of-type(51) {
	animation-delay: 15.3s;
}

main.sub .plan_list li:nth-of-type(52) {
	animation-delay: 15.6s;
}

main.sub .plan_list li:nth-of-type(53) {
	animation-delay: 15.9s;
}

main.sub .plan_list li:nth-of-type(54) {
	animation-delay: 16.2s;
}

main.sub .plan_list li:nth-of-type(55) {
	animation-delay: 16.5s;
}

main.sub .plan_list li:nth-of-type(56) {
	animation-delay: 16.8s;
}

main.sub .plan_list li:nth-of-type(57) {
	animation-delay: 17.1s;
}

main.sub .plan_list li:nth-of-type(58) {
	animation-delay: 17.4s;
}

main.sub .plan_list li:nth-of-type(59) {
	animation-delay: 17.7s;
}

main.sub .plan_list li:nth-of-type(60) {
	animation-delay: 18s;
}

main.sub .plan_list li:nth-of-type(61) {
	animation-delay: 18.3s;
}

main.sub .plan_list li:nth-of-type(62) {
	animation-delay: 18.6s;
}

main.sub .plan_list li:nth-of-type(63) {
	animation-delay: 18.9s;
}

main.sub .plan_list li:nth-of-type(64) {
	animation-delay: 19.2s;
}

main.sub .plan_list li:nth-of-type(65) {
	animation-delay: 19.5s;
}

main.sub .plan_list li:nth-of-type(66) {
	animation-delay: 19.8s;
}

main.sub .plan_list li:nth-of-type(67) {
	animation-delay: 20.1s;
}

main.sub .plan_list li:nth-of-type(68) {
	animation-delay: 20.4s;
}

main.sub .plan_list li:nth-of-type(69) {
	animation-delay: 20.7s;
}

main.sub .plan_list li:nth-of-type(70) {
	animation-delay: 21s;
}

main.sub .plan_list li:nth-of-type(71) {
	animation-delay: 21.3s;
}

main.sub .plan_list li:nth-of-type(72) {
	animation-delay: 21.6s;
}

main.sub .plan_list li:nth-of-type(73) {
	animation-delay: 21.9s;
}

main.sub .plan_list li:nth-of-type(74) {
	animation-delay: 22.2s;
}

main.sub .plan_list li:nth-of-type(75) {
	animation-delay: 22.5s;
}

main.sub .plan_list li:nth-of-type(76) {
	animation-delay: 22.8s;
}

main.sub .plan_list li:nth-of-type(77) {
	animation-delay: 23.1s;
}

main.sub .plan_list li:nth-of-type(78) {
	animation-delay: 23.4s;
}

main.sub .plan_list li:nth-of-type(79) {
	animation-delay: 23.7s;
}

main.sub .plan_list li:nth-of-type(80) {
	animation-delay: 24s;
}

main.sub .plan_list li:nth-of-type(81) {
	animation-delay: 24.3s;
}

main.sub .plan_list li:nth-of-type(82) {
	animation-delay: 24.6s;
}

main.sub .plan_list li:nth-of-type(83) {
	animation-delay: 24.9s;
}

main.sub .plan_list li:nth-of-type(84) {
	animation-delay: 25.2s;
}

main.sub .plan_list li:nth-of-type(85) {
	animation-delay: 25.5s;
}

main.sub .plan_list li:nth-of-type(86) {
	animation-delay: 25.8s;
}

main.sub .plan_list li:nth-of-type(87) {
	animation-delay: 26.1s;
}

main.sub .plan_list li:nth-of-type(88) {
	animation-delay: 26.4s;
}

main.sub .plan_list li:nth-of-type(89) {
	animation-delay: 26.7s;
}

main.sub .plan_list li:nth-of-type(90) {
	animation-delay: 27s;
}

main.sub .plan_list li:nth-of-type(91) {
	animation-delay: 27.3s;
}

main.sub .plan_list li:nth-of-type(92) {
	animation-delay: 27.6s;
}

main.sub .plan_list li:nth-of-type(93) {
	animation-delay: 27.9s;
}

main.sub .plan_list li:nth-of-type(94) {
	animation-delay: 28.2s;
}

main.sub .plan_list li:nth-of-type(95) {
	animation-delay: 28.5s;
}

main.sub .plan_list li:nth-of-type(96) {
	animation-delay: 28.8s;
}

main.sub .plan_list li:nth-of-type(97) {
	animation-delay: 29.1s;
}

main.sub .plan_list li:nth-of-type(98) {
	animation-delay: 29.4s;
}

main.sub .plan_list li:nth-of-type(99) {
	animation-delay: 29.7s;
}

main.sub .plan_list li:nth-of-type(100) {
	animation-delay: 30s;
}

main.sub .plan_list_item {
	display: flex;
	flex-direction: column;
	padding: clamp(2rem, 2.2222222222vw, 3.2rem);
	background-color: var(--wp--preset--color--white);
}

main.sub .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-video-movie.svg);
}

main.sub .plan_list_item:first-of-type .plan_text {
	color: var(--co-rd-ex-dk);
}

main.sub .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-video-hp.svg);
}

main.sub .plan_list_item:nth-of-type(2) .plan_text {
	color: var(--co-gr-dk);
}

main.sub .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-video-live.svg);
}

main.sub .plan_list_item:last-of-type .plan_text {
	color: var(--co-yl-dk);
}

main.sub .plan_list_item::before {
	position: relative;
	left: 50%;
	aspect-ratio: 1/1;
	width: clamp(6.4rem, 5.7291666667vw, 11rem);
	margin-top: -6.8rem;
	padding: 16px;
	transform: translateX(-50%);
	border-radius: clamp(6.4rem, 5.7291666667vw, 11rem);
	background-position: 50% 50%;
	background-size: 85%;
	background-repeat: no-repeat;
	background-color: var(--wp--preset--color--white);
	content: "";
}

main.sub .plan_list_item ul {
	margin-right: auto;
	margin-left: auto;
}

main.sub .plan_list_item .plan_title {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: clamp(1rem, 1.25vw, 1.6rem);
	font-weight: bold;
	line-height: 1.3;
	text-align: center;
}

main.sub .plan_list_item .plan_text {
	border-bottom: solid 0.1rem var(--wp--preset--color--black);
	font-weight: bold;
	text-align: center;
}

main.sub .plan_list_item .plan_text .small {
	font-size: clamp(1.4rem, 1.5625vw, 1.6rem);
}

main.sub .plan_list_item .sub-list {
	margin-top: clamp(1.2rem, 1.5625vw, 1.6rem);
	font-weight: 500;
	line-height: 2;
	font-family: var(--fo-shs-jp);
}

main.sub .plan_list_item .sub-list .third-list {
	padding-left: 1.5em;
}

main.sub .plan_list_item .sub-list .third-list-item {
	position: relative;
}

main.sub .plan_list_item .sub-list .third-list-item::before {
	position: absolute;
	top: 50%;
	left: -1.6rem;
	width: 1rem;
	height: 0.1rem;
	transform: translateY(-50%);
	background-color: var(--wp--preset--color--black);
	content: "";
}

main.sub .rental .outer {
	padding-top: clamp(3.6rem, 3.125vw, 6rem);
	padding-bottom: clamp(3.6rem, 3.8541666667vw, 7.4rem);
}

main.sub .rental_title {
	font-weight: bold;
	font-size: clamp(2rem, 2.0833333333vw, 3rem);
	text-align: center;
}

main.sub .rental_list {
	display: flex;
	row-gap: clamp(2rem, 2.5vw, 3.6rem);
	flex-wrap: wrap;
	justify-content: space-between;
	max-width: 140rem;
	margin-top: clamp(4.8rem, 5vw, 9.6rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub .rental_list_item {
	-moz-column-gap: clamp(2rem, 2.5vw, 3.6rem);
	display: flex;
	column-gap: clamp(2rem, 2.5vw, 3.6rem);
	align-items: center;
	padding-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-right: clamp(1.6rem, 2.0833333333vw, 3rem);
	padding-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-left: clamp(1.6rem, 2.0833333333vw, 3rem);
	box-shadow: 0.4rem 0.4rem 0.8rem 0 rgba(40, 40, 40, 0.75);
}

main.sub .rental_list_item .textarea {
	width: 100%;
}

main.sub .rental_list_item .btn-black {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

main.sub.photograph .category_order {
	max-width: 123rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.photograph .price_table {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	padding-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	border-top: 1rem solid #000;
	border-bottom: 1rem solid #000;
}

main.sub.photograph .price_table_item:first-of-type .detail-row dd {
	width: 100%;
}

main.sub.photograph .price_table_item:first-of-type .detail-row b {
	display: inline-block;
	font-weight: bold;
}

main.sub.photograph .price_table_item:nth-of-type(3) .detail-row {
	flex-direction: column;
}

main.sub.photograph .price_table_item:nth-of-type(3) .detail-row dd {
	width: 100%;
}

main.sub.photograph .price_table_item:nth-of-type(4) {
	grid-row: 4/5;
	grid-column: 1/2;
	justify-content: flex-end;
	font-weight: bold;
}

main.sub.photograph .price_table_item:nth-of-type(5) {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.photograph .price_table_item:nth-of-type(6) {
	grid-row: 2/3;
	grid-column: 2/3;
}

main.sub.photograph .price_table_item:nth-of-type(6) .detail-row dd {
	font-weight: bold;
}

main.sub.photograph .price_table_item:last-of-type {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.photograph .price_table_item:last-of-type .detail-row dd {
	font-weight: bold;
}

main.sub.photograph .price_table_item:not(:nth-of-type(3)):not(:nth-of-type(4)):not(:nth-of-type(5)):not(:last-of-type) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.photograph .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-design-camera.svg);
}

main.sub.photograph .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-design-cooking.svg);
}

main.sub.photograph .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-design-hp.svg);
}

main.sub.video .price_table {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	padding-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	border-top: 1rem solid #000;
	border-bottom: 1rem solid #000;
}

main.sub.video .price_table_item:nth-of-type(3) .detail-row dd {
	width: 100%;
	font-weight: 700;
}

main.sub.video .price_table_item:last-of-type dt {
	align-self: start;
}

main.sub.video .price_table_item:not(:nth-of-type(3)):not(:last-of-type) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.video .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-video-movie.svg);
}

main.sub.video .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-video-hp.svg);
}

main.sub.video .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-video-live.svg);
}

main.sub.system .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-system-wordpress.svg);
}

main.sub.system .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-system-ec.svg);
}

main.sub.system .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-system-app.svg);
}

main.sub.system .plan_list_item:last-of-type .sub-list .third-list-item::before {
	top: 1.9rem;
}

main.sub.consulting .category_order {
	max-width: 123rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.consulting .plan_list_item:first-of-type:before {
	background-image: url(./images/common/svg/icon-consulting-food.svg);
}

main.sub.consulting .plan_list_item:nth-of-type(2):before {
	background-image: url(./images/common/svg/icon-consulting-support.svg);
}

main.sub.consulting .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-consulting-clientup.svg);
}

main.sub.consulting .plan_list_item:last-of-type .sub-list .third-list-item::before {
	top: 1.9rem;
}

main.sub.consulting .price_table {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	padding-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	border-top: 1rem solid #000;
	border-bottom: 1rem solid #000;
}

main.sub.consulting .price_table_item dt {
	line-height: 1.5;
}

main.sub.consulting .price_table_item dt .small {
	display: block;
	font-size: 1.6rem;
}

main.sub.web .category_order {
	max-width: 123rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.web .price_contents {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	border-top: 1rem solid #000;
	border-bottom: 1rem solid #000;
}

main.sub.web .price_table_item {
	border-bottom: 0.1rem solid var(--co-blc);
	line-height: 1.5;
}

main.sub.web .price_table_item:nth-of-type(3) .detail-row {
	flex-direction: column;
}

main.sub.web .price_table_item:nth-of-type(3) .detail-row dd {
	width: 100%;
}

main.sub.web .price_table_item:nth-of-type(4) {
	grid-row: 4/5;
	grid-column: 1/2;
}

main.sub.web .price_table_item:nth-of-type(5) {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.web .price_table_item:nth-of-type(6) {
	grid-row: 2/3;
	grid-column: 2/3;
}

main.sub.web .price_table_item:last-of-type {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.web .price_table_item dt {
	width: 64%;
}

main.sub.web .price_table_item dd {
	width: 36%;
	font-weight: 500;
	font-family: var(--fo-mtsr);
	text-align: right;
}

main.sub.web .price_note {
	margin-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	text-align: right;
}

main.sub.web .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-web-basic.svg);
}

main.sub.web .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-web-standard.svg);
}

main.sub.web .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-web-pro.svg);
}

main.sub.design .category_order {
	max-width: 123rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.design .plan_list_item:first-of-type::before {
	background-image: url(./images/common/svg/icon-design-media.svg);
}

main.sub.design .plan_list_item:nth-of-type(2)::before {
	background-image: url(./images/common/svg/icon-design-support.svg);
}

main.sub.design .plan_list_item:last-of-type::before {
	background-image: url(./images/common/svg/icon-design-request.svg);
}

main.sub.design .plan_list_item:last-of-type .sub-list .third-list-item::before {
	top: 1.9rem;
}

main.sub.design .price_table {
	margin-top: clamp(3.2rem, 2.9166666667vw, 5.6rem);
	padding-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	border-top: 1rem solid #000;
	border-bottom: 1rem solid #000;
}

main.sub.design .price_table_item dt {
	line-height: 1.5;
}

main.sub.design .price_table_item dt .small {
	display: block;
	font-size: 1.6rem;
}

main.sub.company .profile_table {
	max-width: 100rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.company .profile_table_item {
	display: flex;
	align-items: center;
}

main.sub.company .profile_table_item:not(:last-of-type) {
	border-bottom: solid 0.1rem var(--co-blc);
}

main.sub.company .profile_table_item dt {
	width: 20%;
	font-weight: 700;
	font-family: var(--fo-clv2);
}

main.sub.company .profile_table_item dd {
	width: 80%;
	line-height: 1.75;
	font-family: var(--fo-shs-jp);
}

main.sub.company .access .wrapper {
	display: flex;
}

main.sub.company .access_map iframe {
	display: block;
	width: 100%;
	height: 100%;
	filter: grayscale(100%);
}

main.sub.company .access_textarea {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.company .access_textarea_title {
	display: flex;
	flex-direction: column;
	align-items: center;
	line-height: 1.5;
	font-family: var(--fo-mtsr);
}

main.sub.company .access_textarea_title .small {
	font-weight: 600;
}

main.sub.company .access_textarea_title .text {
	font-weight: 700;
}

main.sub.company .access_textarea address {
	color: var(--wp--preset--color--white);
	line-height: 2;
	text-align: center;
}

main.sub.company .access_textarea address .ib {
	margin-left: clamp(0rem, 0.625vw, 1.2rem);
}

main.sub.company .access_textarea .btn-white {
	margin-right: auto;
	margin-left: auto;
}

main.sub.concept {
	overflow: hidden;
}

main.sub.concept .philosophy,
main.sub.concept .mission,
main.sub.concept .value,
main.sub.concept .plan {
	background-color: var(--wp--preset--color--black);
}

main.sub.concept .philosophy .util-text-en,
main.sub.concept .mission .util-text-en,
main.sub.concept .value .util-text-en,
main.sub.concept .plan .util-text-en {
	display: flex;
	row-gap: clamp(1rem, 2.6041666667vw, 2rem);
	flex-direction: column;
	align-items: center;
}

main.sub.concept .philosophy .util-text-en::before,
main.sub.concept .mission .util-text-en::before,
main.sub.concept .value .util-text-en::before,
main.sub.concept .plan .util-text-en::before {
	-webkit-mask-image: url(./images/common/svg/icon-circle-blc.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	background-color: var(--wp--preset--color--white);
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
	mask-image: url(./images/common/svg/icon-circle-blc.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.concept .philosophy h2,
main.sub.concept .philosophy p,
main.sub.concept .mission h2,
main.sub.concept .mission p,
main.sub.concept .value h2,
main.sub.concept .value p {
	color: var(--wp--preset--color--white);
}

main.sub.concept .philosophy .util-text-en::before,
main.sub.concept .mission .util-text-en::before,
main.sub.concept .value .util-text-en::before {
	background-color: var(--wp--preset--color--white);
}

main.sub.concept .philosophy .util-title-logo,
main.sub.concept .mission .util-title-logo,
main.sub.concept .value .util-title-logo {
	margin-top: clamp(1rem, 2.6041666667vw, 2rem);
	text-align: center;
}

main.sub.concept .philosophy .sub_text,
main.sub.concept .mission .sub_text,
main.sub.concept .value .sub_text {
	text-align: center;
}

main.sub.concept .philosophy,
main.sub.concept .mission {
	position: relative;
}

main.sub.concept .philosophy::before,
main.sub.concept .mission::before {
	position: absolute;
	aspect-ratio: 206/207;
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
}

main.sub.concept .philosophy::before {
	z-index: 10;
	background-image: url(./images/common/svg/icon-geometry01.svg);
	animation: gear 60s linear infinite;
}

main.sub.concept .mission::before {
	background-image: url(./images/common/svg/icon-geometry02.svg);
	animation: gear-reverse 60s linear infinite;
}

main.sub.concept .mission .outer {
	z-index: 20;
	position: relative;
}

main.sub.concept .plan {
	position: relative;
}

main.sub.concept .plan::after {
	position: absolute;
	aspect-ratio: 15/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub.concept .plan .wrapper {
	container-name: plan-wrapper;
	container-type: inline-size;
	padding-top: clamp(2.4rem, 5.2083333333vw, 4rem);
	padding-right: clamp(6rem, 6.25vw, 12rem);
	padding-bottom: clamp(3.2rem, 6.25vw, 6rem);
	padding-left: clamp(6rem, 6.25vw, 12rem);
	background-color: var(--wp--preset--color--white);
}

main.sub.concept .plan .wrapper .util-text-en::before {
	background-color: var(--wp--preset--color--black);
}

main.sub.concept .plan .wrapper .util-title-logo {
	margin-top: clamp(4rem, 3.125vw, 6rem);
	font-size: clamp(6rem, 4.6875vw, 9rem);
	letter-spacing: -0.06em;
	text-align: center;
}

main.sub.concept .plan .wrapper .sub_text {
	margin-top: clamp(2.4rem, 2.7777777778vw, 4rem);
	text-align: center;
}

main.sub.concept .plan_message_textarea {
	margin-top: clamp(1rem, 2.6041666667vw, 2rem);
}

main.sub.concept .plan_message .sub_strong {
	display: block;
	font-weight: bold;
	font-family: var(--fo-shs-jp);
	text-align: center;
}

main.sub.recruit .job {
	background-color: var(--wp--preset--color--black);
}

main.sub.recruit .job_title {
	-moz-column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	display: flex;
	position: relative;
	column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	align-items: center;
	max-width: 132rem;
	margin-right: auto;
	margin-left: auto;
	color: var(--wp--preset--color--white);
	font-weight: bold;
	font-family: var(--fo-clv2);
}

main.sub.recruit .job_title::before {
	-webkit-mask-image: url(./images/common/svg/icon-circle-blc.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	background-color: var(--wp--preset--color--white);
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
	mask-image: url(./images/common/svg/icon-circle-blc.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.recruit .job_title .btn {
	position: absolute;
	right: 0;
	aspect-ratio: 1/1;
	width: 2.4rem;
	border: solid 0.2rem var(--wp--preset--color--white);
	border-radius: 0.4rem;
}

main.sub.recruit .job_title .btn-content {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
}

main.sub.recruit .job_title .btn-content-line {
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 50%;
	aspect-ratio: 6/1;
	width: 1.2rem;
	border-radius: 0.5rem;
	background-color: var(--wp--preset--color--white);
	transition: var(--trs-tsf);
}

main.sub.recruit .job_title .btn-content-line:first-of-type {
	transform: translate(-50%, -50%);
}

main.sub.recruit .job_title .btn-content-line:last-of-type {
	transform: translate(-50%, -50%) rotate(90deg);
}

main.sub.recruit .job_subtitle {
	font-weight: bold;
	font-size: clamp(2rem, 3.3854166667vw, 2.6rem);
	font-family: var(--fo-clv2);
}

main.sub.recruit .job_subtitle + p {
	margin-top: clamp(0.6rem, 1.5625vw, 1.2rem);
}

main.sub.recruit .job_list_item_titlearea {
	border: solid 0.2rem var(--wp--preset--color--white);
	cursor: pointer;
}

main.sub.recruit .job_list_item_titlearea.open .job_title .btn-content-line:last-of-type {
	transform: translate(-50%, -50%) rotate(0deg);
}

main.sub.recruit .job_list_item_container {
	max-height: 0;
	overflow: hidden;
	background-color: var(--wp--preset--color--white);
	transition: var(--trs-mxh);
}

main.sub.recruit .job_list_item_container_block {
	max-width: 132rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.recruit .job_list_item_container_block:not(:first-of-type) {
	margin-top: clamp(1.2rem, 3.125vw, 2.4rem);
}

main.sub.recruit .job_list_item_container_block:not(:last-of-type) {
	padding-bottom: clamp(1.2rem, 3.125vw, 2.4rem);
	border-bottom: solid 0.1rem var(--co-blc);
}

main.sub.recruit .job_list-sub_item {
	position: relative;
	font-family: var(--fo-shs-jp);
}

main.sub.recruit .job_list-sub_item::before {
	display: inline-block;
	position: absolute;
	left: 0;
	aspect-ratio: 1/1;
	border-radius: 1.6rem;
	background-color: var(--wp--preset--color--black);
	content: "";
}

main.sub.recruit .entry {
	position: relative;
	background-color: var(--wp--preset--color--black);
}

main.sub.recruit .entry::after {
	position: absolute;
	bottom: -0.1rem;
	aspect-ratio: 30/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub.recruit .entry .recruit_titlearea {
	background-color: var(--wp--preset--color--white);
}

main.sub.recruit .entry .recruit_title {
	-moz-column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	display: flex;
	column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	align-items: center;
	max-width: 132rem;
	margin-right: auto;
	margin-left: auto;
	font-weight: bold;
	font-family: var(--fo-mtsr);
}

main.sub.recruit .entry .recruit_title::before {
	display: inline-block;
	aspect-ratio: 1/1;
	background-image: url(./images/common/svg/icon-circle-blc.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
}

main.sub.recruit .entry .form_table tbody {
	max-width: 118rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.recruit .entry .form_table_row:nth-child(-n+2) .content {
	padding-bottom: 0.8rem;
	border-bottom: solid 0.3rem var(--wp--preset--color--black);
}

main.sub.recruit .entry .form_table_row input {
	background-color: var(--co-blc-ex-th);
}

main.sub.recruit .entry .form_table_row input::-moz-placeholder {
	color: var(--co-gr-th-dr);
}

main.sub.recruit .entry .form_table_row input::placeholder {
	color: var(--co-gr-th-dr);
}

main.sub.recruit .entry .form_table_row textarea {
	border: solid 0.2rem var(--wp--preset--color--black);
	color: var(--wp--preset--color--black);
}

main.sub.recruit .entry .addNew {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-top: 2.4rem;
}

main.sub.recruit .entry .addNew .addFile {
	background-color: inherit;
}

main.sub.recruit .entry .addNew .select {
	display: flex;
	padding: 0.5rem 1rem;
}

main.sub.recruit .entry .addNew .select:after {
	display: none;
}

main.sub.recruit .entry .addNew .content.fileArea .select {
	display: flex;
	align-items: center;
	gap: 0 1rem;
}

main.sub.recruit .entry .addNew .content.fileArea .select input {
	font-size: 16px;
	line-height: 1.5;
}

main.sub.recruit .entry .submit-btn {
	-moz-column-gap: 8%;
	display: flex;
	column-gap: 8%;
	align-items: center;
	justify-content: center;
}

main.sub.recruit .entry .submit-btn .confirm {
	position: relative;
	width: 100%;
	max-width: 30.5rem;
	height: 6rem;
	overflow: hidden;
	border-radius: 6rem;
	background-color: var(--wp--preset--color--white);
}

main.sub.recruit .entry .submit-btn .confirm::before,
main.sub.recruit .entry .submit-btn .confirm::after {
	position: absolute;
	content: "";
}

main.sub.recruit .entry .submit-btn .confirm::before {
	z-index: 10;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transform: scale(0, 1);
	transform-origin: right top;
	border-radius: 6rem;
	background-color: var(--wp--preset--color--black);
	transition: var(--trs-tsf);
}

main.sub.recruit .entry .submit-btn .confirm::after {
	z-index: 20;
	top: 50%;
	right: 2.4rem;
	aspect-ratio: 1/1;
	width: 2.5rem;
	transform: translateY(-50%);
	background-image: url(./images/common/svg/icon-arrow-wht-flame-blc.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	transition: var(--trs-bgi);
}

main.sub.recruit .entry .submit-btn .confirm input {
	z-index: 20;
	position: relative;
	width: 100%;
	height: 100%;
	border-width: 0.2rem;
	border-style: solid;
	border-radius: 6rem;
	border-color: var(--wp--preset--color--white);
	outline: none;
	color: var(--wp--preset--color--black);
	font-weight: 700;
	font-size: 2rem;
	font-family: var(--fo-shs-jp);
	cursor: pointer;
	transition: var(--trs-col);
}

main.sub.recruit .entry .mw_wp_form_complete {
	background-color: var(--wp--preset--color--white);
}

main.sub.recruit .entry .mw_wp_form_complete p {
	text-align: center;
}

main.sub.recruit .entry .mw_wp_form_complete p .btn-black {
	margin-right: auto;
	margin-left: auto;
}

main.sub.contact .form_table_row:nth-child(-n+3) .content {
	padding-bottom: 0.8rem;
	border-bottom: solid 0.3rem var(--wp--preset--color--black);
}

main.sub.contact .form_table_row input,
main.sub.contact .form_table_row textarea {
	background-color: var(--co-blc-ex-th);
}

main.sub.contact .form_table_row input::-moz-placeholder,
main.sub.contact .form_table_row textarea::-moz-placeholder {
	color: var(--co-gr-th-dr);
}

main.sub.contact .form_table_row input::placeholder,
main.sub.contact .form_table_row textarea::placeholder {
	color: var(--co-gr-th-dr);
}

main.sub.contact .form_table_row .content .select {
	max-width: 14rem;
}

main.sub.single.blog .post:not(span) {
	position: relative;
	padding-bottom: clamp(8rem, 8.3333333333vw, 16rem);
	background-color: var(--wp--preset--color--black);
}

main.sub.single.blog .post:not(span)::after {
	position: absolute;
	bottom: -0.1rem;
	left: 0;
	aspect-ratio: 20/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub.single.blog .post .wrapper {
	display: grid;
}

main.sub.single.blog .post_contents {
	grid-row: 1/2;
	grid-column: 1/2;
	width: 100%;
}

main.sub.single.blog .post_contents time,
main.sub.single.blog .post_contents .post_title {
	color: var(--wp--preset--color--white);
}

main.sub.single.blog .post_contents .post_title {
	margin-bottom: clamp(0.6rem, 1.3020833333vw, 1rem);
	padding-bottom: clamp(0.6rem, 1.3020833333vw, 1rem);
	border-bottom: solid 0.1rem var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(2.2rem, 2.0833333333vw, 3rem);
	line-height: 1.5;
}

main.sub.single.blog .post_contents .post_figure {
	margin-top: clamp(2.4rem, 3.125vw, 4rem);
}

main.sub.single.blog .post_contents .post_figure img {
	width: auto;
	max-width: 100%;
}

main.sub.single.blog .post_contents .post_tos {
	margin-bottom: clamp(2.8rem, 3.90625vw, 4rem);
	border: solid 0.1rem var(--wp--preset--color--white);
	background-color: var(--wp--preset--color--white);
	counter-reset: number 0;
}

main.sub.single.blog .post_contents .post_tos_inner {
	max-height: 0;
	overflow-y: hidden;
	transition: max-height ease 0.4s;
}

main.sub.single.blog .post_contents .post_tos_order {
	padding: 1.6rem;
}

main.sub.single.blog .post_contents .post_tos_order > li {
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
}

main.sub.single.blog .post_contents .post_tos_order li {
	color: var(--wp--preset--color--black);
}

main.sub.single.blog .post_contents .post_tos_order li > a {
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	transition: var(--trs-opc);
}

main.sub.single.blog .post_contents .post_tos_order li > a::before {
	display: inline-block;
	margin-right: 1rem;
	content: counter(number) ".";
	counter-increment: number 1;
}

main.sub.single.blog .post_contents .post_tos_order li ol {
	padding-left: 1em;
	counter-reset: number 0;
}

main.sub.single.blog .post_contents time {
	font-weight: bold;
}

main.sub.single.blog .post_contents time[class*=post_time] {
	display: inline-flex;
	align-items: center;
}

main.sub.single.blog .post_contents time[class*=post_time]::before {
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	width: 2rem;
	margin-right: clamp(0.8rem, 1.171875vw, 1.2rem);
	background-color: var(--wp--preset--color--white);
	content: "";
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.single.blog .post_contents time.post_time-publish::before {
	-webkit-mask-image: url(./images/common/svg/icon-publish.svg);
	mask-image: url(./images/common/svg/icon-publish.svg);
}

main.sub.single.blog .post_contents time.post_time-republish {
	margin-left: clamp(2.4rem, 3.125vw, 4rem);
}

main.sub.single.blog .post_contents time.post_time-republish::before {
	-webkit-mask-image: url(./images/common/svg/icon-republish.svg);
	mask-image: url(./images/common/svg/icon-republish.svg);
}

main.sub.single.blog .post_contents .category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
}

main.sub.single.blog .post_contents .category_list a {
	display: block;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	transition: var(--trs-opc);
}

main.sub.single.blog .post .blog-card {
	word-wrap: break-word;
	max-width: 100%;
	margin: 3rem 0;
	padding: 1rem;
	background-color: #fff;
}

main.sub.single.blog .post .blog-card a {
	display: flex;
	text-decoration: none;
	transition: 0.3s;
}

main.sub.single.blog .post .blog-card a:hover {
	opacity: 0.8;
}

main.sub.single.blog .post .blog-card a:hover .cardContents .cardTitle {
	color: #f03f3f;
}

main.sub.single.blog .post .blog-card a .thumb {
	width: 30%;
}

main.sub.single.blog .post .blog-card a .thumb img {
	-o-object-fit: cover;
	display: block;
	aspect-ratio: 50/30;
	height: 100%;
	object-fit: cover;
	transition: 0.3s ease-in-out;
}

main.sub.single.blog .post .blog-card a .cardContents {
	width: 70%;
	padding-left: 1rem;
}

main.sub.single.blog .post .blog-card a .cardContents .cardTitle {
	-webkit-transition: 0.3s;
	display: block;
	margin-bottom: 0.8rem;
	color: #000;
	font-weight: 700;
}

main.sub.single.blog .post .blog-card a .cardContents .cardExcerpt {
	margin-bottom: 0;
	color: #000;
	font-size: 0.7rem;
}

main.sub.single.blog .post .blog-card a .clear {
	clear: both;
}

main.sub.single.blog .post_area {
	margin-top: clamp(4rem, 4.1666666667vw, 6rem);
	color: var(--wp--preset--color--white);
}

main.sub.single.blog .post_area h4,
main.sub.single.blog .post_area h5,
main.sub.single.blog .post_area h6 {
	font-weight: bold;
}

main.sub.single.blog .post_area ol,
main.sub.single.blog .post_area ul,
main.sub.single.blog .post_area li {
	font-family: var(--fo-shs-jp);
}

main.sub.single.blog .post_area h2:not(.post_tos h2) {
	-moz-column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	display: flex;
	column-gap: clamp(1.2rem, 1.875vw, 2.4rem);
	align-items: center;
	margin-top: clamp(3.2rem, 3.3333333333vw, 4.8rem);
	margin-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(0.6rem, 1.3020833333vw, 1rem);
	border-bottom: solid 0.1rem var(--wp--preset--color--white);
	font-weight: bold;
	font-weight: bold;
	font-size: clamp(1.8rem, 2.34375vw, 2.4rem);
}

main.sub.single.blog .post_area h2:not(.post_tos h2)::before {
	-webkit-mask-image: url(./images/common/svg/icon-circle-blc.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	width: clamp(3.2rem, 3.90625vw, 4rem);
	background-color: var(--wp--preset--color--white);
	content: "";
	mask-image: url(./images/common/svg/icon-circle-blc.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.single.blog .post_area h2.post_tos_title {
	-moz-column-gap: 1.2rem;
	display: flex;
	column-gap: 1.2rem;
	align-items: center;
	padding-right: 1.6rem;
	padding-left: 1.6rem;
	background-color: var(--wp--preset--color--black);
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
	cursor: pointer;
}

main.sub.single.blog .post_area h2.post_tos_title::before {
	display: inline-block;
	aspect-ratio: 23/18;
	width: 2.3rem;
	background-image: url(./images/common/svg/icon-index-wht.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
}

main.sub.single.blog .post_area h3:not(.post_tos h3) {
	margin-top: clamp(1.6rem, 1.6666666667vw, 2.4rem);
	margin-bottom: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-bottom: clamp(0.6rem, 1.3020833333vw, 1rem);
	padding-left: clamp(1rem, 2.0833333333vw, 1.6rem);
	border-bottom: solid 0.1rem var(--wp--preset--color--white);
	border-left: solid clamp(1rem, 2.0833333333vw, 1.6rem) var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.6rem, 1.953125vw, 2rem);
	line-height: 1.8;
}

main.sub.single.blog .post_area h4 {
	display: flex;
	margin-top: clamp(2.8rem, 2.5vw, 3.6rem);
	margin-bottom: clamp(2.4rem, 2.2222222222vw, 3.2rem);
	padding-bottom: clamp(0.6rem, 1.3020833333vw, 1rem);
	border-bottom: solid 0.1rem var(--wp--preset--color--white);
	font-size: clamp(1.6rem, 1.7578125vw, 1.8rem);
}

main.sub.single.blog .post_area h4::before {
	width: 1rem;
	height: 1rem;
	margin-top: clamp(1.6rem, 1.7578125vw, 1.8rem);
	margin-right: clamp(1.4rem, 1.5625vw, 1.6rem);
	background-color: var(--wp--preset--color--white);
	content: "";
}

main.sub.single.blog .post_area p + p,
main.sub.single.blog .post_area p + figure {
	margin-top: clamp(2.4rem, 3.125vw, 4rem);
}

main.sub.single.blog .post_area figure {
	margin-bottom: clamp(3.2rem, 3.3333333333vw, 4.8rem);
}

main.sub.single.blog .post_area figure figcaption {
	margin-top: clamp(1rem, 1.5625vw, 1.2rem);
	font-size: clamp(1rem, 2vw, 1.2rem);
}

main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub),
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) {
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
	padding: 1.6rem;
	background-color: var(--wp--preset--color--white);
}

main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub) li,
main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub) a,
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) li,
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) a {
	color: var(--wp--preset--color--black);
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
}

main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub) li,
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) li {
	display: flex;
}

main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub) li::before,
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) li::before {
	display: inline-block;
	margin-right: 1rem;
}

main.sub.single.blog .post_area ul:not(.post_tos_order):not(.post_tos_order_sub) + p,
main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) + p {
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
}

main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) {
	counter-reset: number 0;
}

main.sub.single.blog .post_area ol:not(.post_tos_order):not(.post_tos_order_sub) li::before {
	content: counter(number) ".";
	counter-increment: number 1;
}

main.sub.single.blog .post_area ul li::before {
	flex-shrink: 0;
	width: 0.6rem;
	height: 0.6rem;
	margin-top: clamp(1.6rem, 3vw, 1.8rem);
	border-radius: 0.8rem;
	background-color: var(--wp--preset--color--black);
	content: "";
}

main.sub.single.blog .post_area a {
	color: #FFF;
	font-size: 1.6rem;
	text-decoration: underline;
}

main.sub.single.blog .post_writer {
	margin-top: clamp(6.4rem, 6.4583333333vw, 12.4rem);
}

main.sub.single.blog .post_writer h2,
main.sub.single.blog .post_writer p {
	font-weight: bold;
}

main.sub.single.blog .post_writer h2 {
	-moz-column-gap: 0.6rem;
	display: flex;
	column-gap: 0.6rem;
	align-items: center;
	border: solid 0.1rem var(--wp--preset--color--white);
	color: var(--wp--preset--color--white);
	font-size: clamp(1.6rem, 2.6041666667vw, 2rem);
}

main.sub.single.blog .post_writer h2::before {
	-webkit-mask-image: url(./images/common/svg/icon-writer-wht.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	width: clamp(2.1rem, 3.515625vw, 2.7rem);
	background-color: var(--wp--preset--color--white);
	content: "";
	mask-image: url(./images/common/svg/icon-writer-wht.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.single.blog .post_writer p {
	line-height: 1.8;
}

main.sub.single.blog .post_writer_inner {
	background-color: var(--wp--preset--color--white);
}

main.sub.single.blog .post_writer_inner .icon {
	-moz-column-gap: 5%;
	display: flex;
	column-gap: 5%;
	align-items: center;
}

main.sub.single.blog .post_writer_inner .icon p {
	font-size: clamp(1.6rem, 2.6041666667vw, 2rem);
}

main.sub.single.blog .post_writer_inner .icon_figure {
	aspect-ratio: 1/1;
	width: 5.5rem;
}

main.sub.single.blog .post_writer_inner .icon_figure img {
	height: 100%;
	border-radius: 5.5rem;
}

main.sub.single.blog .post_writer_inner .textarea {
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
}

main.sub.single.blog .post .btn-white {
	grid-row: 2/3;
	margin-top: clamp(7rem, 7.2916666667vw, 14rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .wrapper {
	flex-direction: column;
}

main.sub.single.works .mv_image {
	width: 100%;
	max-width: 100rem;
	margin-top: clamp(3.6rem, 5vw, 7.2rem);
	margin-right: auto;
	margin-left: auto;
	padding-top: 2.5%;
	padding-bottom: 3%;
}

main.sub.single.works .mv_image figure {
	width: 80%;
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .mv_image_figure-pic {
	padding: 1rem;
	transform: rotate(-3deg);
	background-color: var(--wp--preset--color--white);
}

main.sub.single.works .mv_block {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: 100rem;
	margin-top: clamp(3.6rem, 5vw, 7.2rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .mv_block_title {
	margin-top: clamp(2.4rem, 2.5vw, 3.2rem);
	color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(2rem, 2.1875vw, 2.8rem);
	line-height: 1.8;
}

main.sub.single.works .mv_block_detail .category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: clamp(0.6rem, 1.3020833333vw, 1rem);
}

main.sub.single.works .mv_block_detail .category_list {
	display: block;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	transition: var(--trs-opc);
}

main.sub.single.works .mv_block_detail .btn-white {
	margin-top: clamp(2.4rem, 2.5vw, 3.2rem);
}

main.sub.single.works .mv_block_textarea {
	color: var(--wp--preset--color--white);
}

main.sub.single.works .post_title {
	-moz-column-gap: clamp(0.8rem, 1.40625vw, 1.8rem);
	display: flex;
	column-gap: clamp(0.8rem, 1.40625vw, 1.8rem);
	align-items: center;
	color: var(--co-blc);
}

main.sub.single.works .post_title .en {
	font-weight: bold;
	font-family: var(--fo-mtsr);
}

main.sub.single.works .post_title .ja {
	font-weight: bold;
	font-family: var(--fo-shs-jp);
}

main.sub.single.works .post_title::before {
	-webkit-mask-image: url(./images/common/svg/icon-circle-blc.svg);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	aspect-ratio: 1/1;
	content: "";
	animation-duration: 20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-name: gear;
	mask-image: url(./images/common/svg/icon-circle-blc.svg);
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
}

main.sub.single.works .post_subtitle {
	-moz-column-gap: clamp(0.6rem, 1.5625vw, 1.2rem);
	display: flex;
	column-gap: clamp(0.6rem, 1.5625vw, 1.2rem);
	align-items: center;
	color: var(--co-blc);
}

main.sub.single.works .post_subtitle::before {
	display: inline-block;
	aspect-ratio: 1/1;
	background-color: var(--co-blc);
	content: "";
}

main.sub.single.works .post_subtitle .ja {
	font-weight: bold;
}

main.sub.single.works .post_photograph .post_title::before,
main.sub.single.works .post_movie .post_title::before,
main.sub.single.works .post_system .post_title::before,
main.sub.single.works .post_web .post_title::before,
main.sub.single.works .post_design .post_title::before {
	background-color: var(--wp--preset--color--black);
}

main.sub.single.works .post_comment .post_title::before {
	background-color: var(--wp--preset--color--white);
}

main.sub.single.works .post_photograph_gallery {
	-moz-column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	display: flex;
	column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	row-gap: clamp(2rem, 2.7777777778vw, 4rem);
	flex-wrap: wrap;
	align-items: normal;
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
}

main.sub.single.works .post_photograph_gallery figure {
	align-self: inherit;
}

main.sub.single.works .post_photograph_gallery figure img {
	-o-object-fit: cover;
	flex: 1 0 0%;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

main.sub.single.works .post_photograph_gallery iframe {
	width: 100%;
	height: 100%;
}

main.sub.single.works .post_movie .post_photograph_gallery {
	aspect-ratio: 16/9;
	max-width: 100rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .post_system_block-pc figure {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	box-shadow: 0.8rem 0.8rem 1.2rem 0 rgba(40, 40, 40, 0.2);
}

main.sub.single.works .post_system_block-sp_image {
	-moz-column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	display: flex;
	column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	row-gap: clamp(2rem, 2.7777777778vw, 4rem);
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	max-width: 100rem;
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .post_system_block-sp_image figure {
	width: 100%;
}

main.sub.single.works .post_web .post_title + figure {
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
}

main.sub.single.works .post_web_block-pc_image {
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
}

main.sub.single.works .post_web_block-pc_image figure {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	box-shadow: 0.8rem 0.8rem 1.2rem 0 rgba(40, 40, 40, 0.2);
}

main.sub.single.works .post_web_block-sp_image {
	-moz-column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	display: flex;
	column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	row-gap: clamp(2rem, 2.7777777778vw, 4rem);
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	max-width: 100rem;
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .post_web_block-sp_image figure {
	width: 100%;
}

main.sub.single.works .post_design_gallery {
	-moz-column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	display: flex;
	column-gap: clamp(2rem, 2.7777777778vw, 4rem);
	row-gap: clamp(2rem, 2.7777777778vw, 4rem);
	flex-wrap: wrap;
	max-width: 100rem;
	margin-top: clamp(2.8rem, 3.125vw, 4rem);
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.works .post_design-web_block-sp .post_design_gallery {
	justify-content: center;
}

main.sub.single.works .post_design-web_block-sp .post_design_gallery figure {
	width: 100%;
}

main.sub.single.works .post_design-bnr figure {
	width: 100%;
}

main.sub.single.works .post_design-ppt figure {
	box-shadow: 0.8rem 0.8rem 1.2rem 0 rgba(40, 40, 40, 0.2);
}

main.sub.single.works .post_comment {
	background-color: var(--wp--preset--color--black);
}

main.sub.single.works .post_comment .post_title .ja {
	color: var(--wp--preset--color--white);
	font-weight: bold;
}

main.sub.single.works .post_comment_textarea {
	margin-top: clamp(2rem, 3.125vw, 3.2rem);
	color: var(--wp--preset--color--white);
}

main.sub.single.works .post_comment_textarea p:not(:first-of-type) {
	margin-top: clamp(1.4rem, 2.34375vw, 2.4rem);
}

main.sub.single.works .post .btn-black {
	margin-right: auto;
	margin-left: auto;
}

main.sub.single.news .post .wrapper {
	display: block;
	max-width: 1060px;
}

main.sub.category .mv_textarea {
	color: var(--wp--preset--color--white);
}

main.sub.category .post {
	position: relative;
	background-color: var(--wp--preset--color--black);
}

main.sub.category .post:not(.post-page)::after {
	position: absolute;
	bottom: -0.1rem;
	left: 0;
	aspect-ratio: 20/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub.category .post .wrapper {
	display: grid;
}

main.sub.category .post_list_item_link h2,
main.sub.category .post_list_item_link .time,
main.sub.category .post_list_item_link .icon p {
	color: var(--wp--preset--color--white);
}

main.sub.category .post_list_item_link figure {
	aspect-ratio: 214/125;
}

main.sub.category .post_list_item_link figure img {
	-o-object-fit: cover;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

main.sub.category .post_list_item_link .textarea time {
	color: var(--wp--preset--color--white);
	font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
	font-family: var(--fo-shs-jp);
}

main.sub.category .post_list_item_link .textarea .category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
}

main.sub.category .post_list_item_link .textarea .category_list {
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

main.sub.category .post_list_item_link .textarea h2 {
	margin-top: clamp(0.8rem, 1.5625vw, 1.2rem);
	font-size: clamp(1.6rem, 2.6041666667vw, 2rem);
	line-height: 1.5;
	font-family: var(--fo-shs-jp);
}

main.sub.category .post_list_item_link .textarea .icon {
	margin-top: clamp(0.8rem, 1.5625vw, 1.2rem);
	padding-top: clamp(1rem, 2.0833333333vw, 1.6rem);
	border-top: solid 0.1rem var(--wp--preset--color--white);
}

main.sub.category .post_list {
	grid-row: 1/2;
	grid-column: 1/2;
	flex-shrink: 1;
	width: 100%;
}

main.sub.category .post_list_item {
	width: 100%;
}

main.sub.category .post_list_item_link {
	-moz-column-gap: 6%;
	display: flex;
	column-gap: 6%;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

main.sub.category .post_list_item_link .textarea {
	width: 100%;
}

main.sub.category .post_list_item_link .textarea .icon {
	-moz-column-gap: 5%;
	display: flex;
	column-gap: 5%;
	align-items: center;
}

main.sub.category .post_list_item_link .textarea .icon_figure {
	aspect-ratio: 1/1;
	width: 5.5rem;
}

main.sub.category .post_list_item_link .textarea .icon_figure img {
	height: 100%;
	border-radius: 5.5rem;
}

main.sub.category .post .pagination {
	border-top: solid 0.1rem var(--wp--preset--color--white);
}

main.sub.archive.works .post_category {
	display: flex;
	max-width: 132rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.archive.works .post_category_list a,
main.sub.archive.works .post_category_list span {
	display: flex;
	z-index: 20;
	position: relative;
	position: relative;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-family: var(--fo-shs-jp);
	cursor: pointer;
	transition: var(--trs-bsc);
}

main.sub.archive.works .post_category_list a::before,
main.sub.archive.works .post_category_list span::before {
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 50% 50%;
	-webkit-mask-size: contain;
	display: inline-block;
	background-color: var(--co-blc);
	content: "";
	mask-position: 50% 50%;
	mask-repeat: no-repeat;
	mask-size: contain;
	transition: var(--trs-bsc);
}

main.sub.archive.works .post_category_list a::after,
main.sub.archive.works .post_category_list span::after {
	z-index: -1;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: transparent;
	content: "";
	transition: var(--trs-bsc);
}

main.sub.archive.works .post_category_list.active a::before,
main.sub.archive.works .post_category_list.active span::before {
	background-color: var(--wp--preset--color--white);
}

main.sub.archive.works .post_category_list:first-of-type a::before,
main.sub.archive.works .post_category_list:first-of-type span::before {
	-webkit-mask-image: url(./images/common/svg/icon-all-black.svg);
	mask-image: url(./images/common/svg/icon-all-black.svg);
}

main.sub.archive.works .post_category_list:nth-of-type(2) a::before,
main.sub.archive.works .post_category_list:nth-of-type(2) span::before {
	-webkit-mask-image: url(./images/common/svg/icon-web-black.svg);
	mask-image: url(./images/common/svg/icon-web-black.svg);
}

main.sub.archive.works .post_category_list:nth-of-type(3) a::before,
main.sub.archive.works .post_category_list:nth-of-type(3) span::before {
	-webkit-mask-image: url(./images/common/svg/icon-system-black.svg);
	mask-image: url(./images/common/svg/icon-system-black.svg);
}

main.sub.archive.works .post_category_list:nth-of-type(4) a::before,
main.sub.archive.works .post_category_list:nth-of-type(4) span::before {
	-webkit-mask-image: url(./images/common/svg/icon-design-black.svg);
	mask-image: url(./images/common/svg/icon-design-black.svg);
}

main.sub.archive.works .post_category_list:nth-of-type(5) a::before,
main.sub.archive.works .post_category_list:nth-of-type(5) span::before {
	-webkit-mask-image: url(./images/common/svg/icon-movie-black.svg);
	mask-image: url(./images/common/svg/icon-movie-black.svg);
}

main.sub.archive.works .post_category_list:last-of-type a::before,
main.sub.archive.works .post_category_list:last-of-type span::before {
	-webkit-mask-image: url(./images/common/svg/icon-camera-black.svg);
	mask-image: url(./images/common/svg/icon-camera-black.svg);
}

main.sub.archive.works .post_category_list:not(.active) {
	background-color: transparent;
}

main.sub.archive.works .post_category_list.active {
	color: var(--wp--preset--color--white);
}

main.sub.archive.works .post_category_list.active a::after,
main.sub.archive.works .post_category_list.active span::after {
	background-color: var(--co-blc);
}

main.sub.archive.works .post_list {
	-moz-column-gap: 5%;
	display: flex;
	column-gap: 5%;
	row-gap: 5%;
	flex-wrap: wrap;
}

main.sub.archive.works .post_list_item {
	display: flex;
}

main.sub.archive.works .post_list_item_link {
	display: flex;
	flex-direction: column;
	width: 100%;
}

main.sub.archive.works .post_list_item_link figure {
	width: 100%;
	box-shadow: 0.4rem 0.4rem 1rem 0 rgba(40, 40, 40, 0.4);
}

main.sub.archive.works .post_list_item_link figure img {
	-o-object-fit: cover;
	-o-object-position: top;
	aspect-ratio: 240/149;
	height: 100%;
	object-fit: cover;
	object-position: top;
}

main.sub.archive.works .post_list_item_link .textarea {
	display: flex;
	flex-grow: 1;
	flex-direction: column;
}

main.sub.archive.works .post_list_item_link .textarea h2 {
	display: flex;
	align-items: center;
	margin-top: clamp(1.8rem, 1.6666666667vw, 2.4rem);
	font-weight: bold;
	font-size: clamp(1.6rem, 1.3888888889vw, 2rem);
	line-height: var(--lh-lw);
}

main.sub.archive.works .post_list_item_link .textarea .category {
	-moz-column-gap: 2%;
	display: flex;
	column-gap: 2%;
	row-gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: clamp(0.6rem, 0.9765625vw, 1rem);
}

main.sub.archive.works .post_list_item_link .textarea .category_list {
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

main.sub.archive.works .post_tag {
	-moz-column-gap: clamp(2.4rem, 3.90625vw, 4rem);
	display: flex;
	column-gap: clamp(2.4rem, 3.90625vw, 4rem);
	row-gap: clamp(2.4rem, 3.90625vw, 4rem);
	align-items: center;
	max-width: 90rem;
	margin-right: auto;
	margin-left: auto;
}

main.sub.archive.works .post_tag_list a,
main.sub.archive.works .post_tag_list span {
	display: inline-block;
	height: 100%;
	padding-right: 2.4rem;
	padding-left: 2.4rem;
	border: solid 0.1rem var(--wp--preset--color--black);
	font-weight: bold;
	font-size: clamp(1.2rem, 1.8229166667vw, 1.4rem);
	font-family: var(--fo-shs-jp);
}

main.sub.archive.works .post_tag_list a {
	transition: var(--trs-opc);
}

main.sub.archive.works .post_tag_list span {
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub.works {
	padding-bottom: clamp(4.8rem, 5vw, 9.6rem);
}

main.sub.works .textarea h2 {
	display: inline-block !important;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

main.sub.category .news {
	position: relative;
	background-color: var(--wp--preset--color--black);
}

main.sub.category .news::after {
	position: absolute;
	bottom: -0.1rem;
	left: 0;
	aspect-ratio: 20/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub.category .news_list {
	padding-top: clamp(3.6rem, 4.4444444444vw, 6.4rem);
	padding-right: clamp(2rem, 3.515625vw, 3.6rem);
	padding-bottom: clamp(3.6rem, 4.4444444444vw, 6.4rem);
	padding-left: clamp(2rem, 3.515625vw, 3.6rem);
	background-color: var(--wp--preset--color--white);
}

main.sub.category .news_list_item {
	margin-bottom: clamp(1.2rem, 1.953125vw, 2rem);
	padding-bottom: clamp(1.2rem, 1.953125vw, 2rem);
	border-bottom: solid 0.1rem var(--wp--preset--color--black);
}

main.sub.category .news_list_item_link {
	display: grid;
	position: relative;
	transition: var(--trs-opc);
}

main.sub.category .news_list_item_link::after {
	display: inline-block;
	position: absolute;
	top: 50%;
	aspect-ratio: 1/1;
	transform: translateY(-50%);
	background-image: url(./images/common/svg/icon-arrow-wht-flame-blc.svg);
	background-position: 50% 50%;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
	transition: var(--trs-tsf);
}

main.sub.category .news_list_item_link .category,
main.sub.category .news_list_item_link time,
main.sub.category .news_list_item_link h2 {
	line-height: 1.5;
}

main.sub.category .news_list_item_link time,
main.sub.category .news_list_item_link h2 {
	font-weight: bold;
	font-size: clamp(1.4rem, 2.34375vw, 1.8rem);
}

main.sub.category .news_list_item_link time {
	font-family: var(--fo-shs-jp);
}

main.sub.category .news_list_item_link .category {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-right: clamp(0.8rem, 2.0833333333vw, 1.6rem);
	padding-left: clamp(0.8rem, 2.0833333333vw, 1.6rem);
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
}

main.sub .breadcrumbs a {
	padding-right: 0 !important;
	padding-left: 0 !important;
}

main.sub .document {
	position: relative;
	background-color: var(--wp--preset--color--white);
}

main.sub .document::after {
	position: absolute;
	bottom: -0.1rem;
	left: 0;
	aspect-ratio: 20/1;
	width: 100%;
	background-color: var(--wp--preset--color--white);
	content: "";
	clip-path: polygon(100% 0%, 0% 100%, 100% 100%);
}

main.sub .document .paper-content__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: calc(100% - 8rem);
	max-width: 1000px;
	margin: 0 auto;
}

main.sub .document .paper-content__inner h2 {
	position: relative;
	margin: 3em auto;
	padding: 1.5rem;
	text-align: center;
}

main.sub .document .paper-content__inner h2:before {
	position: absolute;
	bottom: 6px;
	left: calc(50% - 30px);
	width: 60px;
	height: 5px;
	border-radius: 3px;
	background: var(--wp--preset--color--black);
	content: "";
}

main.sub .document .paper-content__inner h2 span {
	font-weight: bold;
	font-size: clamp(2rem, 4.3902439024vw, 3.6rem);
}

main.sub .document .paper-content__inner .doc-box {
	display: flex;
	justify-content: space-between;
	padding: 4em 0;
	border-bottom: 1px solid #ddd;
}

main.sub .document .paper-content__inner .doc-box .thumb {
	width: 40%;
	filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.5));
}

main.sub .document .paper-content__inner .doc-box .thumb__inner {
	display: flex;
	align-items: center;
	cursor: pointer;
}

main.sub .document .paper-content__inner .doc-box .thumb__inner:hover {
	opacity: 0.8;
}

main.sub .document .paper-content__inner .doc-box .thumb__inner img {
	width: 100%;
	height: auto;
	padding-left: 2em;
}

main.sub .document .paper-content__inner .doc-box .thumb__inner input[type=checkbox] {
	-webkit-appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	display: inline-block;
	position: relative;
	width: 2rem;
	min-width: 2rem;
	height: 2rem;
	border-color: #b5b3af;
	box-shadow: none;
	cursor: pointer;
}

main.sub .document .paper-content__inner .doc-box .thumb__inner input[type=checkbox]:checked::before {
	display: inline-block;
	position: absolute;
	width: 2.5rem;
	height: 2.5rem;
	margin: -0.275rem 0 0 -0.45rem;
	content: url(data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2020%2020%27%3E%3Cpath%20d%3D%27M14.83%204.89l1.34.94-5.81%208.38H9.02L5.78%209.67l1.34-1.25%202.57%202.4z%27%20fill%3D%27%23000000%27%2F%3E%3C%2Fsvg%3E);
}

main.sub .document .paper-content__inner .doc-box .thumb__inner input {
	display: inline-block;
	width: 2em;
	height: 2em;
	margin: auto;
	border: 1px solid #333;
}

main.sub .document .paper-content__inner .doc-box .thumb__inner input:before {
	width: 2.75rem;
}

main.sub .document .paper-content__inner .doc-box .text {
	width: 45%;
	margin: auto;
}

main.sub .document .paper-content__inner .doc-box .text .title {
	margin-bottom: 0.5em;
	font-weight: 600;
	font-size: 2.4em;
}

main.sub .document .paper-content__inner .doc-box .text__inner .icon {
	display: flex;
	font-weight: 600;
	line-height: 1em !important;
}

main.sub .document #hidden1 {
	display: none;
}

main.sub .document .popup {
	z-index: 99;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	background: rgba(0, 0, 0, 0.8);
}

main.sub .document .popup__inner {
	padding: 1em;
	color: #fff;
	text-align: center;
}

main.sub .document .popup__inner:first-of-type {
	padding-bottom: 0;
}

main.sub .document .popup-link {
	padding: 0em 0 2em;
	text-align: center;
}

main.sub .document .popup-link input {
	width: -moz-fit-content;
	width: fit-content;
	margin: auto;
	padding: 1rem 2rem;
	border: none;
	background-color: crimson;
	color: #FFF;
}

main.sub .document .popup-link input:hover {
	background-color: rgb(168, 14, 45);
	cursor: pointer;
}

.single.document .post__document {
	width: calc(100% - 8rem) !important;
	max-width: 1400px !important;
	margin: 0 auto;
}

.single.document .post_sidebar {
	background-color: #FFF;
}

.single.document .post_sidebar h2 {
	color: var(--wp--preset--color--black);
}

.single.document .post_sidebar .form-content {
	display: flex;
	justify-content: center;
	gap: 5%;
	font-family: var(--fo-shs-jp);
}

.single.document .post_sidebar .form-content .form-left-content,
.single.document .post_sidebar .form-content .form-right-content {
	width: 50%;
	padding: 1.5em;
}

.single.document .post_sidebar .form-content .form-left-content .form__inner-title,
.single.document .post_sidebar .form-content .form-right-content .form__inner-title {
	margin-bottom: 1.5em;
	font-weight: bold;
	font-size: 2.5em;
}

.single.document .post_sidebar .form-content .form-control {
	-webkit-appearance: none;
	-moz-appearance: none;
	display: block;
	appearance: none;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0.2rem 0.5rem;
	border: 1px solid #DCDCDC;
	border-radius: 0;
	background-color: #FDFDFD;
	box-shadow: none;
	font-size: 1.6rem;
	letter-spacing: -0.015em;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact {
	width: 100%;
	font-size: 1.8em;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact .downlist {
	margin-bottom: 1rem;
	padding: 0 1rem;
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
	font-size: 1.6rem;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact .btn-del {
	width: 37px;
	height: 36px;
	padding: 0;
	border: 0;
	background-image: url(images/sub/document/icon-delete.svg);
	background-size: contain;
	background-repeat: no-repeat;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact .btn-del:hover {
	cursor: pointer;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact tr td {
	font-weight: bold;
}

.single.document .post_sidebar .form-content .form-left-content .btn-doc-back {
	margin-top: 5rem;
}

.single.document .post_sidebar .form-content .form-left-content .btn-doc-back button {
	border: none;
	background-color: #eaeaea;
	font-weight: bold;
	font-size: 1.6rem;
}

.single.document .post_sidebar .form-content .form-left-content .btn-doc-back button:hover {
	background-color: #d4d4d4;
	cursor: pointer;
}

.single.document .post_sidebar .form-content .form-left-content .btn-doc-back button br {
	display: none;
}

.single.document .post_sidebar .form-content .form-right-content .tbl-form-contact tr {
	display: flex;
	flex-direction: column;
	margin-bottom: 1rem;
}

.single.document .post_sidebar .form-content .form-right-content .tbl-form-contact tr td {
	font-weight: bold;
}

.single.document .post_sidebar .form-content .form-right-content .tbl-form-contact tr td:first-child {
	font-size: 1.6rem;
}

.single.document .post_sidebar .form-content .form-right-content .txt-endword-form {
	font-size: 1.4rem;
}

.single.document .post_sidebar .form-content .form-right-content .txt-endword-form br {
	display: none;
}

.single.document .post_sidebar .form-content .form-right-content .txt-endword-form a {
	color: #1872B4 !important;
	text-decoration: underline;
}

.single.document .post_sidebar .form-content .form-right-content .btn-confirm {
	margin-top: 3rem;
}

.single.document .post_sidebar .form-content .form-right-content .btn-confirm button {
	padding: 1rem;
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--white);
	font-size: 1.6rem;
}

.single.document .post_sidebar .form-content .form-right-content .btn-confirm button:hover {
	cursor: pointer;
	opacity: 0.8;
}

@media (hover: hover) and (pointer: fine) {

header .header_nav_list_item_container ul li a:hover {
	opacity: 0.6;
}

header .header_nav_list_item_container ul li a:hover .image img {
	transform: scale(1.08);
}

main.sub .form .submit-btn .confirm:hover::before,
main.sub .form .submit-btn .send:hover::before,
main.sub .form .submit-btn .previous:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
}

main.sub .form .submit-btn .confirm:hover::before,
main.sub .form .submit-btn .send:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
	background-color: var(--wp--preset--color--black);
}

main.sub .form .submit-btn .confirm:hover::after,
main.sub .form .submit-btn .send:hover::after {
	background-image: url(./images/common/svg/icon-arrow-blc-flame-wht.svg);
}

main.sub .form .submit-btn .confirm:hover input,
main.sub .form .submit-btn .send:hover input {
	color: var(--wp--preset--color--white);
}

main.sub .form .submit-btn .previous:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
	background-color: var(--wp--preset--color--white);
}

main.sub .form .submit-btn .previous:hover::after {
	background-image: url(./images/common/svg/icon-arrow-wht-flame-blc.svg);
}

main.sub .form .submit-btn .previous:hover input {
	color: var(--wp--preset--color--black);
}

main.home .contact .btn-black:hover .content::after,
main.sub .contact .btn-black:hover .content::after {
	background-image: url(./images/common/svg/icon-paper-airplane-black.svg);
}

main.home .contact .btn-white:hover .content::after,
main.sub .contact .btn-white:hover .content::after {
	background-image: url(./images/common/svg/icon-download-white.svg);
}

.footer_company_phone_link:hover {
	opacity: 0.4;
}

.footer_nav_child_item .sub-menu li a:hover {
	opacity: 0.4;
}

.footer_nav_parent li a:hover {
	opacity: 0.4;
}

.footer_other_nav_item a:hover {
	opacity: 0.4;
}

.btn-black:hover::before,
.btn-white:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
}

.btn-black:hover::before {
	background-color: var(--wp--preset--color--white);
}

.btn-black:hover .content::before {
	border-color: var(--co-blc);
}

.btn-black:hover .content::after {
	background-image: url(./images/common/svg/icon-arw-drk-rit.svg);
}

.btn-black:hover .content .text {
	color: var(--co-blc);
}

.btn-white:hover {
	border: 1px solid #FFF;
}

.btn-white:hover::before {
	background-color: var(--co-blc);
}

.btn-white:hover .content::before {
	border-color: var(--wp--preset--color--white);
}

.btn-white:hover .content::after {
	background-image: url(./images/common/svg/icon-arw-wht-rit.svg);
}

.btn-white:hover .content .text {
	color: var(--wp--preset--color--white);
}

.cf:hover {
	border-color: var(--wp--preset--color--black);
}

.cf:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
	background-color: var(--wp--preset--color--white);
}

.cf:hover .text {
	color: var(--wp--preset--color--black);
}

main.sub .law a:hover {
	opacity: 0.4;
}

main.home .mv_news_link:hover {
	opacity: 0.4;
}

main.home .concept .service_detail_list_item:hover {
	opacity: 0.4;
}

main.sub.recruit .entry .submit-btn .confirm:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
	background-color: var(--wp--preset--color--black);
}

main.sub.recruit .entry .submit-btn .confirm:hover::after {
	background-image: url(./images/common/svg/icon-arrow-blc-flame-wht.svg);
}

main.sub.recruit .entry .submit-btn .confirm:hover input {
	color: var(--wp--preset--color--white);
}

main.sub.single.blog .post_contents .post_tos_order li > a:hover {
	opacity: 0.4;
}

main.sub.single.blog .post_contents .category_list a:hover {
	opacity: 0.4;
}

main.sub.archive.works .post_category_list a:hover {
	opacity: 0.4;
}

main.sub.archive.works .post_tag_list a:hover {
	opacity: 0.4;
}

main.sub.category .news_list_item_link:hover {
	opacity: 0.4;
}

main.sub.category .news_list_item_link:hover::after {
	transform: translate(40%, -50%);
}

}

@media (min-width: 601px) {

p {
	font-size: 1.6rem;
	line-height: var(--lh-bsc);
}

.sp-only {
	display: none;
}

.sp-escape {
	display: block;
}

.util-title-mont {
	font-size: clamp(6.4rem, 5.2083333333vw, 10rem);
}

header {
	height: 10rem;
}

header.thin {
	height: 8rem;
}

main {
	border-top: 10rem solid var(--wp--preset--color--black);
}

main.sub .form_table_row input,
main.sub .form_table_row textarea,
main.sub .form_table_row select {
	border-radius: 1rem;
}

main.sub .form_table_row textarea {
	height: 34.2rem;
}

main.sub .form_table_row .content .input .error {
	top: -5rem;
}

main.sub .form.complete .btn-white .content {
	-moz-column-gap: 6.5rem;
	column-gap: 6.5rem;
}

.footer_company_phone_link_figure {
	width: 4rem;
}

.footer_company_phone_hours {
	margin-left: clamp(2.8rem, 2.9166666667vw, 5.6rem);
	font-size: 1.6rem;
}

.footer_nav_child_item {
	width: 50%;
}

.footer_nav_child_item .sub-menu li a {
	font-size: 1.6rem;
}

.breadcrumbs {
	padding-top: clamp(1.2rem, 1.6666666667vw, 2.4rem);
	padding-bottom: clamp(1.2rem, 1.6666666667vw, 2.4rem);
}

.btn-black,
.btn-white {
	width: 30.5rem;
	height: 6rem;
	padding-right: 3.6rem;
	padding-left: 3.6rem;
	border-radius: 6rem;
}

.btn-black::before,
.btn-white::before {
	border-radius: 6rem;
}

.btn-black .content,
.btn-white .content {
	-moz-column-gap: 7.9rem;
	column-gap: 7.9rem;
}

.btn-black .content::before,
.btn-white .content::before {
	left: 87.5%;
}

.btn-black .content .text,
.btn-white .content .text {
	font-size: 2.2rem;
}

.cf {
	top: 16.4rem;
}

.cf .text {
	font-size: clamp(1.6rem, 1.953125vw, 2rem);
}

main.sub .law h2 {
	font-size: clamp(2rem, 2.34375vw, 2.4rem);
}

main.sub .law h2:not(:first-of-type) {
	margin-top: clamp(2.4rem, 3.125vw, 3.2rem);
}

main.sub .law h2::before {
	width: clamp(2rem, 2.34375vw, 2.4rem);
}

.banner .btn-white .content {
	-moz-column-gap: 2.3rem;
	column-gap: 2.3rem;
}

.banner .btn-white .content::before {
	right: -7%;
}

.pagination ul.page-numbers {
	padding: clamp(0.8rem, 1.6666666667vw, 1rem) clamp(1.6rem, 4vw, 2.4rem);
	border: solid 0.3rem var(--wp--preset--color--black);
	border-radius: 4.5rem;
}

.pagination ul.page-numbers li {
	width: 5.6rem;
	height: 3rem;
}

.pagination ul.page-numbers li:not(:last-of-type) {
	border-right: solid 0.1rem var(--wp--preset--color--black);
}

.pagination ul.page-numbers li a.page-numbers {
	aspect-ratio: 10/9;
	max-width: 4rem;
}

.pagination ul.page-numbers li span.page-numbers {
	aspect-ratio: 10/9;
	max-width: 4rem;
}

main.home .mv .outer {
	padding-bottom: clamp(1.8rem, 2.03125vw, 2.6rem);
}

main.home .mv .lottie .movie {
	display: block;
	width: 19%;
}

main.home .mv .lottie-realize {
	width: 69.889%;
}

main.home .mv .lottie-picture {
	width: 73.09%;
}

main.home .mv .lottie-dream {
	width: 62%;
	margin-left: 11%;
}

main.home .mv_news_article_title {
	font-size: 1.6rem;
}

main.home .concept {
	padding-top: clamp(6rem, 6.25vw, 12rem);
}

main.home .concept .util-title-logo {
	margin-top: clamp(1.4rem, 1.3888888889vw, 2rem);
}

main.home .concept .mission::before {
	top: -35%;
	right: -26%;
	width: clamp(51.5rem, 53.6458333333vw, 103rem);
}

main.home .concept .vision::before {
	left: -11%;
	width: clamp(32.6rem, 33.9583333333vw, 65.2rem);
}

main.home .concept .service::before {
	right: -24%;
	width: clamp(36.2rem, 37.7083333333vw, 72.4rem);
}

main.home .concept .service_detail_list_item::before {
	width: clamp(6rem, 6.25vw, 9rem);
	height: clamp(6.5rem, 6.7708333333vw, 9.75rem);
}

main.home .concept .service_detail_title .en {
	font-size: clamp(5.6rem, 5.2083333333vw, 10rem);
}

main.home .concept .service_detail_title .ja {
	margin-top: -3.2rem;
	font-size: clamp(3.6rem, 2.6041666667vw, 5rem);
}

main.home .works_article_link_list_item {
	font-size: 1.8rem;
}

main.home .works .btn-black {
	margin-top: clamp(5.6rem, 3.75vw, 7.2rem);
}

main.home .post .news_content,
main.home .post .media_content {
	margin-top: clamp(3.2rem, 3.8888888889vw, 5.6rem);
}

main.home .post .btn-white {
	margin-top: clamp(3.2rem, 7.2916666667vw, 5.6rem);
}

main.home .recruit {
	background-attachment: fixed;
}

main.home .recruit .util-title-logo {
	font-size: clamp(4.8rem, 3.6458333333vw, 7rem);
}

main.sub .mv_text:not(:first-of-type) {
	margin-top: clamp(1.2rem, 1.25vw, 2.4rem);
}

main.sub .category .outer {
	padding-top: clamp(5.6rem, 5.2083333333vw, 10rem);
	padding-bottom: clamp(3.6rem, 4.1666666667vw, 8rem);
}

main.sub .category_order {
	margin-top: clamp(5.6rem, 5.2083333333vw, 10rem);
}

main.sub .price .outer {
	padding-top: clamp(3.6rem, 4.1666666667vw, 8rem);
	padding-bottom: 0;
}

main.sub .price_table {
	padding-right: clamp(1.6rem, 2.0833333333vw, 3rem);
	padding-left: clamp(1.6rem, 2.0833333333vw, 3rem);
}

main.sub .price_table_item dt {
	width: 38%;
	font-size: clamp(1.8rem, 1.5277777778vw, 2.2rem);
}

main.sub .price_table_item .detail {
	width: 62%;
}

main.sub .price_table_item .detail-row {
	padding-right: clamp(1.6rem, 2.0833333333vw, 3rem);
	padding-left: clamp(1.6rem, 2.0833333333vw, 3rem);
}

main.sub .plan_textarea .outer {
	padding-top: clamp(4.8rem, 4.6875vw, 9rem);
	padding-bottom: clamp(4.8rem, 4.6875vw, 9rem);
}

main.sub .plan_list_item .plan_title {
	font-size: clamp(2.4rem, 2.3611111111vw, 3.4rem);
}

main.sub .plan_list_item .sub-list {
	font-size: clamp(1.6rem, 1.25vw, 1.8rem);
}

main.sub .rental_list_item {
	width: 49%;
}

main.sub .rental_list_item .btn-black {
	max-width: 25rem;
}

main.sub .rental_list_item .btn-black .content {
	-moz-column-gap: 4.2rem;
	column-gap: 4.2rem;
}

main.sub .rental_list_item .btn-black .content .text {
	font-size: 2rem;
}

main.sub.photograph .price_table_item:nth-of-type(4) {
	padding-right: clamp(1.6rem, 2.0833333333vw, 3rem);
	padding-left: clamp(1.6rem, 2.0833333333vw, 3rem);
	font-size: 1.6rem;
}

main.sub.photograph .price_table_item:nth-of-type(6) .detail-row {
	justify-content: flex-end;
}

main.sub.photograph .price_table_item:last-of-type .detail-row {
	justify-content: flex-end;
}

main.sub.photograph .contact {
	margin-top: clamp(7rem, 7.2916666667vw, 14rem);
}

main.sub.video .contact {
	margin-top: clamp(7rem, 7.2916666667vw, 14rem);
}

main.sub.web .price_table_item {
	padding-top: clamp(2.4rem, 3.125vw, 3.2rem);
	padding-bottom: clamp(2.4rem, 3.125vw, 3.2rem);
}

main.sub.web .price_table_item dd {
	padding-right: clamp(1.6rem, 2.0833333333vw, 3rem);
	font-size: 1.6rem;
}

main.sub.web .price_note {
	padding-right: clamp(2.4rem, 2.7777777778vw, 4rem);
	padding-left: clamp(2.4rem, 2.7777777778vw, 4rem);
}

main.sub.company .profile_table_item dt {
	font-size: 2.2rem;
}

main.sub.company .profile_table_item dd {
	font-size: 1.6rem;
}

main.sub.company .access_map {
	aspect-ratio: 3/2;
}

main.sub.company .access_textarea {
	padding: clamp(2.4rem, 2.0833333333vw, 4rem);
}

main.sub.company .access_textarea address {
	font-size: 2rem;
}

main.sub.company .access_textarea .btn-white {
	margin-top: clamp(2.4rem, 3.125vw, 3.2rem);
}

main.sub.company .access_textarea .btn-white .content {
	-moz-column-gap: 7.6rem;
	column-gap: 7.6rem;
}

main.sub.concept .philosophy::before {
	top: 25%;
	right: -26%;
	width: clamp(51.5rem, 53.6458333333vw, 103rem);
}

main.sub.concept .mission::before {
	top: 75%;
	left: 0;
	width: clamp(32.6rem, 33.9583333333vw, 65.2rem);
}

main.sub.concept .plan::after {
	bottom: -0.4rem;
}

main.sub.concept .plan_message .sub_strong {
	font-size: 1.6rem;
}

main.sub.recruit .job_list-sub_item {
	padding-left: 2rem;
	font-size: 1.6rem;
}

main.sub.recruit .job_list-sub_item::before {
	top: 1.3rem;
	width: 1.6rem;
}

main.sub.recruit .entry .mw_wp_form_complete p .btn-black .content {
	-moz-column-gap: 6.5rem;
	column-gap: 6.5rem;
}

main.sub.single.blog .post .wrapper {
	align-items: flex-start;
	justify-content: space-between;
}

main.sub.single.blog .post_contents time {
	font-size: 1.6rem;
}

main.sub.single.blog .post_writer h2 {
	padding-right: clamp(1rem, 2.0833333333vw, 1.6rem);
	padding-left: clamp(1rem, 2.0833333333vw, 1.6rem);
}

main.sub.single.blog .post_writer_inner {
	padding: clamp(1rem, 2.0833333333vw, 1.6rem);
}

main.sub.single.blog .post .btn-white .content {
	-moz-column-gap: 8.2rem;
	column-gap: 8.2rem;
}

main.sub.single.works .post_title {
	font-size: clamp(2.2rem, 2.0833333333vw, 3rem);
}

main.sub.single.works .post_subtitle {
	padding-left: 4em;
}

main.sub.single.works .post_subtitle .ja {
	font-size: clamp(1.8rem, 1.6666666667vw, 2.4rem);
}

main.sub.single.works .post_design-ppt figure {
	width: 48%;
}

main.sub.single.works .btn-black .content {
	-moz-column-gap: 8.2rem;
	column-gap: 8.2rem;
}

main.sub.category .post .wrapper {
	align-items: flex-start;
}

main.sub.category .post_list {
	container-name: post-item;
	container-type: inline-size;
}

main.sub.category .post_list_item {
	container-name: post-item-link;
	container-type: inline-size;
}

main.sub.archive.works .post_category_list a::before,
main.sub.archive.works .post_category_list span::before {
	width: clamp(6rem, 6.25vw, 9rem);
	height: clamp(6.5rem, 6.7708333333vw, 9.75rem);
}

main.sub.category .news_list_item_link {
	-moz-column-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	grid-template-columns: minmax(14rem, 16rem) 0.9fr;
	column-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
}

main.sub.category .news_list_item_link::after {
	width: 2.5rem;
}

main.sub.category .news_list_item_link .category {
	grid-row: 1/3;
	grid-column: 1/2;
	font-size: clamp(1.4rem, 2.34375vw, 1.8rem);
}

main.sub.category .news_list_item_link time {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.category .news_list_item_link h2 {
	grid-row: 2/3;
	grid-column: 2/3;
}

}

@media (min-width: 601px) and (max-width: 1024px) {

.outer {
	padding-right: clamp(3.2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(3.2rem, 4.6875vw, 4.8rem);
}

.tab-only {
	display: block;
}

.tab-escape {
	display: none;
}

header .header_nav_list {
	padding-right: clamp(3.2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(3.2rem, 4.6875vw, 4.8rem);
}

header .header_nav_other {
	display: flex;
	justify-content: space-between;
}

header .header_nav_other_item a {
	font-size: 1.4rem;
}

.post_sidebar {
	padding-right: clamp(3.2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(3.2rem, 4.6875vw, 4.8rem);
}

.footer_nav {
	width: 95%;
}

.footer_nav_child {
	width: 70%;
}

.footer_nav_parent {
	width: 25%;
}

.footer_other {
	width: 95%;
}

.breadcrumbs {
	padding-right: clamp(3.2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(3.2rem, 4.6875vw, 4.8rem);
}

.banner_textarea {
	width: 60%;
}

.banner .btn-white {
	max-width: 30.4rem;
}

.banner .btn-white .content {
	-moz-column-gap: 3.4rem;
	column-gap: 3.4rem;
}

.banner .btn-white .content .text {
	font-size: 1.8rem;
}

main.home .concept .service_detail_list_item:first-of-type,
main.home .concept .service_detail_list_item:nth-of-type(4) {
	border-left-width: 0.1rem;
	border-left-style: solid;
	border-left-color: rgba(0, 0, 0, 0.54);
}

main.home .works_list_item {
	width: 47%;
}

main.sub .mv .outer {
	padding-top: clamp(3.2rem, 6.25vw, 6.4rem);
}

main.sub.photograph .category_order {
	-moz-column-gap: 2%;
	column-gap: 2%;
}

main.sub.photograph .category_order_item {
	width: 48%;
}

main.sub.video .category_order {
	-moz-column-gap: 2%;
	column-gap: 2%;
}

main.sub.video .category_order_item {
	width: 48%;
}

main.sub.consulting .category_order {
	-moz-column-gap: 2%;
	column-gap: 2%;
}

main.sub.consulting .category_order_item {
	width: 48%;
}

main.sub.web .category_order {
	-moz-column-gap: 2%;
	column-gap: 2%;
}

main.sub.web .category_order_item {
	width: 48%;
}

main.sub.design .category_order {
	-moz-column-gap: 2%;
	column-gap: 2%;
}

main.sub.design .category_order_item {
	width: 48%;
}

main.sub.recruit .entry .form_table_row:nth-child(3),
main.sub.recruit .entry .form_table_row:nth-child(4) {
	display: flex;
	justify-content: space-between;
}

main.sub.recruit .entry .form_table_row:nth-child(3) .content,
main.sub.recruit .entry .form_table_row:nth-child(4) .content {
	width: 48%;
}

main.sub.single.blog .post:not(span) {
	padding-right: clamp(3.2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(3.2rem, 4.6875vw, 4.8rem);
}

main.sub.single.works .post_photograph_gallery figure {
	width: 48%;
}

main.sub.single.works .post_system_block-sp_image figure {
	max-width: 40%;
}

main.sub.single.works .post_web_block-sp_image figure {
	max-width: 40%;
}

main.sub.single.works .post_design-web_block-sp .post_design_gallery figure {
	max-width: 40%;
}

main.sub.archive.works .post_category_list:first-of-type,
main.sub.archive.works .post_category_list:nth-of-type(4) {
	border-left-width: 0.1rem;
	border-left-style: solid;
	border-left-color: rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_list_item {
	width: 47%;
}

main.sub.category .news_list_item_link::after {
	right: 2rem;
}

}

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

main.sub .plan_list_item {
	width: 80%;
}

}

@media (min-width: 769px) {

.pagination {
	margin-top: clamp(3.2rem, 3.0555555556vw, 4.4rem);
}

main.sub .plan_price .outer {
	padding-top: clamp(5.6rem, 5vw, 7.2rem);
	padding-bottom: clamp(3.2rem, 3.3333333333vw, 4.8rem);
}

main.sub .plan_list_item .plan_title {
	min-height: clamp(7.2rem, 6.25vw, 9rem);
}

}

@media (min-width: 769px) and (max-width: 1024px) {

main.sub .plan_list {
	justify-content: space-between;
}

main.sub .plan_list_item {
	width: 60%;
}

main.sub .plan_list_item .plan_text .large {
	font-size: clamp(2.4rem, 3.515625vw, 3.6rem);
}

main.sub.concept .plan_message_figure {
	width: 100%;
}

}

@media (max-width: 1024px) and (min-width: 601px) and (max-width: 1024px) {

header .header_hamburger .line:first-of-type {
	top: 10%;
}

header .header_hamburger .line:last-of-type {
	bottom: 10%;
}

}

@media (min-width: 1025px) {

.outer {
	padding-right: clamp(4.8rem, 5vw, 9.6rem);
	padding-left: clamp(4.8rem, 5vw, 9.6rem);
}

main.home .wrapper {
	max-width: 140rem;
}

main.sub .wrapper {
	max-width: 160rem;
}

.pc-only {
	display: block;
}

.pc-escape {
	display: none;
}

.tab-only {
	display: none;
}

.tab-escape {
	display: block;
}

.util-text-en,
.util-text-ja {
	font-size: clamp(3.6rem, 2.6041666667vw, 5rem);
}

header .header_logo_figure {
	max-width: 24rem;
}

header .header_nav_list_item {
	position: relative;
}

header .header_nav_list_item:first-of-type .header_nav_list_item_container {
	justify-content: space-between;
	width: clamp(47rem, 48.9583333333vw, 94rem);
}

header .header_nav_list_item:first-of-type .header_nav_list_item_container ul {
	width: 80%;
}

header .header_nav_list_item:first-of-type .header_nav_list_item_container ul::after {
	display: inline-block;
	width: clamp(9rem, 9.375vw, 18rem);
	content: "";
}

header .header_nav_list_item:nth-of-type(2) .header_nav_list_item_container {
	justify-content: space-between;
	width: clamp(35.5rem, 36.9791666667vw, 71rem);
}

header .header_nav_list_item:nth-of-type(2) .header_nav_list_item_container ul {
	width: 73%;
}

header .header_nav_list_item > span {
	display: block;
}

header .header_nav_list_item_container {
	display: flex;
	visibility: hidden;
	z-index: 9999;
	position: absolute;
	top: 6rem;
	left: 50%;
	align-items: center;
	padding-top: 3.6rem;
	padding-right: clamp(6.2rem, 6.3541666667vw, 12.2rem);
	padding-bottom: 2.2rem;
	padding-left: clamp(2.8rem, 2.8125vw, 5.4rem);
	transform: translateX(-50%);
	background-color: var(--wp--preset--color--white);
	opacity: 0;
}

header .header_nav_list_item_container.shadow {
	box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.3);
}

header .header_nav_list_item_container .text {
	position: relative;
	margin-bottom: clamp(1.2rem, 1.4285714286vw, 2.4rem);
	font-size: clamp(1.6rem, 1.25vw, 2.4rem);
}

header .header_nav_list_item_container .text::before {
	position: absolute;
	top: 50%;
	right: clamp(-3rem, -1.5625vw, -1.5rem);
	width: 0.1rem;
	transform: translateY(-50%);
	background-color: var(--co-blc);
	content: "";
}

header .header_nav_list_item_container ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}

header .header_nav_list_item_container ul li {
	width: clamp(9rem, 9.375vw, 18rem);
}

header .header_nav_list_item_container ul li a .image {
	overflow: hidden;
}

header .header_nav_list_item_container ul li a .dcp {
	font-size: clamp(1rem, 0.9523809524vw, 1.6rem);
}

header .header_nav_other {
	display: none;
}

header .header_hamburger {
	display: none;
}

.post_sidebar {
	grid-row: 1/2;
	grid-column: 2/3;
	padding-right: clamp(3.6rem, 3.8541666667vw, 7.4rem);
	padding-left: clamp(3.6rem, 3.8541666667vw, 7.4rem);
}

main.sub .form .outer {
	padding-bottom: 12rem;
}

main.sub .form_table_row:nth-child(-n+3) {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

main.sub .form_table_row:nth-of-type(2),
main.sub .form_table_row:nth-of-type(3) {
	margin-top: 2.4rem;
}

main.sub .form_table_row:nth-of-type(4) {
	margin-top: 4.8rem;
}

main.sub .form_table_row:nth-of-type(4) .content:nth-of-type(2) {
	margin-top: 1.6rem;
}

main.sub .form_table_row:last-of-type {
	margin-top: 4rem;
}

main.sub .form.enter .submit-btn {
	margin-top: 5.6rem;
}

main.home .contact .outer,
main.sub .contact .outer {
	padding-top: clamp(3.2rem, 3.0555555556vw, 4.4rem);
	padding-bottom: clamp(8.2rem, 7.5vw, 14.4rem);
}

main.home .contact .btn-area,
main.sub .contact .btn-area {
	-moz-column-gap: clamp(4.8rem, 4.2708333333vw, 8.2rem);
	column-gap: clamp(4.8rem, 4.2708333333vw, 8.2rem);
	margin-top: clamp(6rem, 4.8958333333vw, 9.4rem);
}

.footer {
	padding-bottom: clamp(5.4rem, 5.46875vw, 10.5rem);
}

.footer .wrapper {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.footer_company {
	grid-row: 1/2;
	grid-column: 1/2;
}

.footer_company_logo_figure {
	width: 30.5rem;
}

.footer_company_logo .text {
	font-size: 2.4rem;
}

.footer_company_phone_link {
	margin-top: 1.2rem;
}

.footer_company_phone_hours {
	margin-top: 1.2rem;
	font-size: 2rem;
}

.footer_nav {
	grid-row: 1/2;
	grid-column: 2/3;
}

.footer_nav_child {
	width: 80%;
}

.footer_other {
	grid-row: 2/3;
	grid-column: 1/3;
	margin-top: clamp(7.8rem, 8.0208333333vw, 15.4rem);
}

.footer_other_nav {
	-moz-column-gap: 4.8rem;
	column-gap: 4.8rem;
}

.breadcrumbs {
	padding-right: clamp(4.8rem, 5vw, 9.6rem);
	padding-left: clamp(4.8rem, 5vw, 9.6rem);
}

.loading_image {
	width: 30.5rem;
}

.loading_text {
	width: 20rem;
	margin-top: 1.2rem;
}

.banner_content {
	background-size: 100%;
}

.banner_textarea {
	width: 45%;
}

.banner .btn-white {
	max-width: 39.5rem;
}

main.home .mv_news {
	margin-top: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.home .mv_news_link {
	width: 55%;
}

main.home .concept .util-title-logo + .util-text {
	margin-top: clamp(2.8rem, 2.9166666667vw, 5.6rem);
}

main.home .concept .mission .util-title-logo span.per,
main.home .concept .vision .util-title-logo span.per,
main.home .concept .service .util-title-logo span.per {
	font-size: clamp(9.6rem, 7.2916666667vw, 14rem);
}

main.home .concept .mission .util-title-logo span.per-small,
main.home .concept .vision .util-title-logo span.per-small,
main.home .concept .service .util-title-logo span.per-small {
	font-size: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.home .concept .vision_content {
	margin-left: auto;
}

main.home .concept .service_detail_list_item {
	width: 16.6666666667%;
}

main.home .concept .service_detail_list_item:not(:last-of-type) {
	border-right-width: 0.1rem;
	border-right-style: solid;
	border-right-color: rgba(0, 0, 0, 0.54);
}

main.home .works_list_item {
	width: 30.3333333333%;
}

main.home .post {
	margin-top: clamp(8.4rem, 7.1875vw, 13.8rem);
	padding-top: clamp(2.8rem, 3.0555555556vw, 4.4rem);
	padding-bottom: clamp(9.6rem, 7.6041666667vw, 14.6rem);
}

main.home .post .news,
main.home .post .media {
	width: 41%;
}

main.home .post .news_content,
main.home .post .media_content {
	row-gap: clamp(5.6rem, 4.6875vw, 9rem);
}

main.home .post .btn-white {
	margin-top: auto;
}

main.home .recruit .outer {
	padding-top: clamp(2.4rem, 2.5vw, 3.2rem);
	padding-bottom: clamp(4rem, 6.40625vw, 8.2rem);
}

main.sub .sub_title {
	font-size: clamp(3.6rem, 2.6041666667vw, 5rem);
}

main.sub .sub_title::before {
	width: clamp(4rem, 3.125vw, 6rem);
}

main.sub .mv .outer {
	padding-top: clamp(6rem, 6.25vw, 12rem);
	padding-bottom: clamp(4.8rem, 8.7890625vw, 9rem);
}

main.sub .mv_title .en {
	font-size: clamp(3.2rem, 2.6041666667vw, 5rem);
}

main.sub .mv_title .ja {
	font-size: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.sub .mv_text:first-of-type {
	margin-top: clamp(3.6rem, 3.3333333333vw, 6.4rem);
}

main.sub .mv_icon {
	flex-shrink: 0;
	aspect-ratio: 135/121;
	width: 100%;
	max-width: clamp(36rem, 37.5vw, 54rem);
}

main.sub .price_table {
	-moz-column-gap: 5%;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 5%;
}

main.sub .price_table_item:first-of-type {
	grid-row: 1/2;
	grid-column: 1/2;
}

main.sub .price_table_item:nth-of-type(2) {
	grid-row: 2/3;
	grid-column: 1/2;
}

main.sub .price_table_item:nth-of-type(3) {
	grid-row: 3/4;
	grid-column: 1/2;
}

main.sub .plan_list {
	justify-content: space-evenly;
}

main.sub .plan_list_item {
	width: 28.75%;
}

main.sub .plan_list_item .plan_text .large {
	font-size: clamp(3.2rem, 2.8571428571vw, 4.8rem);
}

main.sub .plan_list_item .sub-list .third-list {
	margin-top: 1.2rem;
}

main.sub .rental_list_item .textarea {
	max-width: 25rem;
}

main.sub .rental_list_item figure {
	width: 47%;
}

main.sub.photograph .category_order {
	-moz-column-gap: 3%;
	column-gap: 3%;
}

main.sub.photograph .category_order_item {
	width: 28.618%;
}

main.sub.photograph .price_table_item:first-of-type .detail-row b {
	margin-left: 4.2rem;
}

main.sub.photograph .price_table_item:nth-of-type(4) {
	line-height: 1;
}

main.sub.photograph .price_table_item:last-of-type {
	grid-row: 3/4;
	grid-column: 2/3;
}

main.sub.photograph .price_table_item:not(:nth-of-type(3)):not(:nth-of-type(4)) {
	line-height: 6;
}

main.sub.photograph .price_table_item:nth-of-type(6) .detail-row dd,
main.sub.photograph .price_table_item:last-of-type .detail-row dd {
	width: 100%;
	max-width: 19.6rem;
}

main.sub.video .category_order {
	-moz-column-gap: 3%;
	column-gap: 3%;
}

main.sub.video .category_order_item {
	width: 22%;
}

main.sub.video .price_table_item:last-of-type {
	grid-row: 1/4;
	grid-column: 2/3;
}

main.sub.video .price_table_item:last-of-type dt {
	margin-top: 1.6rem;
}

main.sub.consulting .category_order {
	-moz-column-gap: 3%;
	column-gap: 3%;
}

main.sub.consulting .category_order_item {
	width: 28.618%;
}

main.sub.consulting .price_table:nth-of-type(4) {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.consulting .price_table:nth-of-type(5) {
	grid-row: 2/3;
	grid-column: 2/3;
}

main.sub.consulting .price_table:last-of-type {
	grid-row: 3/4;
	grid-column: 2/3;
}

main.sub.consulting .price_table_item:not(:nth-of-type(3n)) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.web .category_order {
	-moz-column-gap: 3%;
	column-gap: 3%;
}

main.sub.web .category_order_item {
	width: 28.618%;
}

main.sub.web .price_table_item:last-of-type {
	grid-row: 3/4;
	grid-column: 2/3;
}

main.sub.design .category_order {
	-moz-column-gap: 3%;
	column-gap: 3%;
}

main.sub.design .category_order_item {
	width: 28.618%;
}

main.sub.design .price_table:nth-of-type(4) {
	grid-row: 1/2;
	grid-column: 2/3;
}

main.sub.design .price_table:nth-of-type(5) {
	grid-row: 2/3;
	grid-column: 2/3;
}

main.sub.design .price_table:last-of-type {
	grid-row: 3/4;
	grid-column: 2/3;
}

main.sub.design .price_table_item:not(:nth-of-type(3n)) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.company .profile_table_item {
	padding-top: 1.6rem;
	padding-bottom: 1.6rem;
}

main.sub.company .access .outer {
	padding-top: clamp(5.6rem, 4.1666666667vw, 8rem);
}

main.sub.company .access_map {
	width: 54.375%;
}

main.sub.company .access_textarea {
	width: 45.625%;
}

main.sub.company .access_textarea_title .small {
	font-size: clamp(2.4rem, 1.6666666667vw, 3.2rem);
}

main.sub.company .access_textarea_title .text {
	font-size: clamp(4rem, 3.3333333333vw, 6.4rem);
}

main.sub.concept .philosophy .util-text-en::before,
main.sub.concept .mission .util-text-en::before,
main.sub.concept .value .util-text-en::before,
main.sub.concept .plan .util-text-en::before {
	width: clamp(4rem, 3.125vw, 6rem);
}

main.sub.concept .philosophy .util-title-logo span.per,
main.sub.concept .mission .util-title-logo span.per,
main.sub.concept .value .util-title-logo span.per,
main.sub.concept .plan .util-title-logo span.per {
	font-size: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.sub.concept .philosophy .util-title-logo + .sub_text,
main.sub.concept .mission .util-title-logo + .sub_text,
main.sub.concept .value .util-title-logo + .sub_text {
	margin-top: clamp(4.8rem, 3.75vw, 7.2rem);
}

main.sub.concept .philosophy .sub_text:last-of-type,
main.sub.concept .mission .sub_text:last-of-type,
main.sub.concept .value .sub_text:last-of-type {
	margin-top: clamp(3.2rem, 2.5vw, 4.8rem);
}

main.sub.concept .philosophy .outer {
	padding-top: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.sub.concept .mission .outer {
	padding-top: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.sub.concept .value .outer {
	padding-top: clamp(7.2rem, 6.25vw, 12rem);
}

main.sub.concept .plan .outer {
	padding-top: clamp(6rem, 6.4583333333vw, 12.4rem);
	padding-bottom: clamp(15rem, 15.625vw, 30rem);
}

main.sub.concept .plan .wrapper {
	padding-right: clamp(6rem, 6.25vw, 12rem);
	padding-left: clamp(6rem, 6.25vw, 12rem);
}

main.sub.concept .plan_message_figure {
	max-width: 54rem;
	margin: 0 auto;
}

main.sub.recruit .job_title {
	font-size: clamp(2.4rem, 1.6666666667vw, 3.2rem);
}

main.sub.recruit .job_title::before {
	width: clamp(3.2rem, 2.6041666667vw, 5rem);
}

main.sub.recruit .job_list_item:not(:first-of-type) {
	margin-top: clamp(5.6rem, 4.1666666667vw, 8rem);
}

main.sub.recruit .job_list_item .inner {
	padding-top: clamp(4rem, 3.125vw, 6rem);
	padding-right: clamp(4.8rem, 3.75vw, 7.2rem);
	padding-bottom: clamp(4rem, 3.125vw, 6rem);
	padding-left: clamp(4.8rem, 3.75vw, 7.2rem);
}

main.sub.recruit .job_list_item_titlearea {
	padding-right: clamp(4.8rem, 3.75vw, 7.2rem);
	padding-left: clamp(4.8rem, 3.75vw, 7.2rem);
}

main.sub.recruit .entry {
	padding-top: clamp(7.2rem, 5.2083333333vw, 10rem);
	padding-bottom: clamp(24rem, 15.625vw, 30rem);
}

main.sub.recruit .entry .recruit_titlearea {
	padding-top: 2.4rem;
	padding-right: 5.2rem;
	padding-left: 5.2rem;
}

main.sub.recruit .entry .recruit_title {
	font-size: clamp(3.6rem, 2.6041666667vw, 5rem);
}

main.sub.recruit .entry .recruit_title::before {
	width: clamp(4rem, 3.125vw, 6rem);
}

main.sub.recruit .entry .form_table {
	padding: 4rem 5.2rem 8rem;
}

main.sub.recruit .entry .form_table_row:nth-child(-n+4) .content {
	width: 43%;
}

main.sub.recruit .entry .submit-btn {
	margin-top: 5.6rem;
}

main.sub.recruit .entry .mw_wp_form_complete {
	padding: 8rem 5.2rem;
}

main.sub.recruit .entry .mw_wp_form_complete p .btn-black {
	margin-top: 4.8rem;
}

main.sub.contact .form_table {
	padding: 8rem 5.2rem 4rem;
}

main.sub.contact .form_table_row:last-of-type {
	width: 57%;
}

main.sub.contact .form_table_row:nth-child(-n+3) .content {
	width: 47%;
}

main.sub.single.blog .post:not(span) {
	padding-right: clamp(4.8rem, 5vw, 9.6rem);
	padding-left: clamp(4.8rem, 5vw, 9.6rem);
}

main.sub.single.blog .post .wrapper {
	-moz-column-gap: 11.875%;
	grid-template-columns: minmax(43rem, 86rem) minmax(40rem, 55rem);
	column-gap: 11.875%;
}

main.sub.single.blog .post .btn-white {
	grid-column: 1/3;
}

main.sub.single.works .mv_block {
	align-items: center;
}

main.sub.single.works .mv_block_detail {
	width: 40%;
}

main.sub.single.works .mv_block_textarea {
	width: 52%;
}

main.sub.single.works .post {
	padding-top: clamp(4rem, 3.125vw, 6rem);
}

main.sub.single.works .post_title::before {
	width: clamp(2.8rem, 2.7777777778vw, 4rem);
}

main.sub.single.works .post_subtitle::before {
	width: 1.6rem;
}

main.sub.single.works .post_photograph_gallery figure {
	width: calc(40% - var(--wp--style--unstable-gallery-gap, 16px) * 0.66667);
}

main.sub.single.works .post_system_block-pc {
	padding-bottom: clamp(4rem, 3.125vw, 6rem);
}

main.sub.single.works .post_system_block-pc figure {
	max-width: 90rem;
}

main.sub.single.works .post_system_block-sp_image figure {
	max-width: 44rem;
}

main.sub.single.works .post_web {
	padding-top: clamp(4rem, 3.125vw, 6rem);
}

main.sub.single.works .post_web_block-pc {
	padding-bottom: clamp(4rem, 3.125vw, 6rem);
}

main.sub.single.works .post_web_block-pc_image figure {
	max-width: 90rem;
}

main.sub.single.works .post_web_block-sp_image figure {
	max-width: 44rem;
}

main.sub.single.works .post_design-web_block-sp .post_design_gallery figure {
	max-width: 44rem;
}

main.sub.single.works .post_comment {
	margin-top: clamp(5.6rem, 4.6875vw, 9rem);
	padding-top: clamp(5.6rem, 4.6875vw, 9rem);
	padding-bottom: clamp(9rem, 7.2916666667vw, 14rem);
}

main.sub.single.works .post .btn-black {
	margin-top: clamp(5.6rem, 4.6875vw, 9rem);
}

main.sub.category .post .outer {
	padding-bottom: clamp(12rem, 12.5vw, 24rem);
}

main.sub.category .post .wrapper {
	-moz-column-gap: 11.875%;
	grid-template-columns: minmax(43rem, 86rem) minmax(40rem, 55rem);
	column-gap: 11.875%;
	justify-content: space-between;
}

main.sub.category .post_list_item_link figure {
	width: 100%;
	max-width: 42.8rem;
}

main.sub.category .post_list_item:not(:first-of-type) {
	margin-top: clamp(4.8rem, 5.5555555556vw, 8rem);
}

main.sub.category .post .pagination {
	grid-row: 2/3;
	grid-column: 1/3;
}

main.sub.archive.works .outer {
	padding-top: clamp(5.6rem, 4.1666666667vw, 8rem);
}

main.sub.archive.works .post_category_list {
	width: 16.6666666667%;
}

main.sub.archive.works .post_category_list:not(:last-of-type) {
	border-right-width: 0.1rem;
	border-right-style: solid;
	border-right-color: rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_list {
	row-gap: clamp(4rem, 3.3333333333vw, 6.4rem);
	margin-top: clamp(6.4rem, 5.2083333333vw, 10rem);
}

main.sub.archive.works .post_list_item {
	width: 30%;
}

main.sub.category .news .outer {
	padding-bottom: clamp(12rem, 12.5vw, 24rem);
}

main.sub.category .news_list_item_link::after {
	right: 4rem;
}

main.sub .document .outer {
	padding-bottom: clamp(12rem, 12.5vw, 24rem);
}

}

@media (max-width: 1024px) {

.pc-only {
	display: none;
}

.pc-escape {
	display: block;
}

.util-title-logo span.per {
	line-height: 1.3;
}

.util-text-en,
.util-text-ja {
	font-size: clamp(1.6rem, 3.515625vw, 3.6rem);
}

header .header_logo {
	z-index: 999;
	position: relative;
}

header .header_logo_figure {
	max-width: clamp(12rem, 19.53125vw, 24rem);
}

header .header_nav {
	visibility: hidden;
	z-index: 990;
	position: fixed;
	top: 0;
	left: 0;
	max-width: initial;
	height: 100dvh;
	height: 100vh;
	background-color: var(--wp--preset--color--black);
	opacity: 0;
	transition: var(--trs-bsc);
}

header .header_nav.active {
	visibility: visible;
	overflow-y: scroll;
	opacity: 1;
}

header .header_nav_list {
	flex-direction: column;
	margin-top: 10rem;
}

header .header_nav_list_item {
	border-top-width: 0.1rem;
	border-top-style: solid;
	border-top-color: var(--co-gr-dr);
}

header .header_nav_list_item:first-of-type > a,
header .header_nav_list_item:nth-of-type(2) > a {
	display: none;
}

header .header_nav_list_item:last-of-type {
	border-bottom-width: 0.1rem;
	border-bottom-style: solid;
	border-bottom-color: var(--co-gr-dr);
}

header .header_nav_list_item:not(:first-of-type):not(:nth-of-type(2)) > a {
	padding: clamp(0.6rem, 1.9230769231vw, 1rem);
}

header .header_nav_list_item > span {
	display: none;
}

header .header_nav_list_item_container {
	padding-top: clamp(0.6rem, 1.9230769231vw, 1rem);
	padding-bottom: clamp(0.6rem, 1.9230769231vw, 1rem);
}

header .header_nav_list_item_container .text {
	position: relative;
	padding-right: clamp(0.6rem, 1.9230769231vw, 1rem);
	padding-left: clamp(0.6rem, 1.9230769231vw, 1rem);
	color: var(--wp--preset--color--white);
	font-size: 1.6rem;
	line-height: var(--lh-bsc);
}

header .header_nav_list_item_container .text.rotate::after {
	transform: translateY(-50%) rotate(45deg);
}

header .header_nav_list_item_container .text::after {
	position: absolute;
	top: 50%;
	right: clamp(0.6rem, 1.9230769231vw, 1rem);
	aspect-ratio: 1/1;
	width: 2rem;
	transform: translateY(-50%);
	background-image: url(./images/common/svg/icon-plus-white.svg);
	background-position: 50% 50%;
	background-size: 100%;
	background-repeat: no-repeat;
	content: "";
	transition: var(--trs-tsf);
}

header .header_nav_list_item_container .text + ul {
	max-height: 0;
	overflow: hidden;
	transition: ease 0.6s max-height;
}

header .header_nav_list_item_container .text::before {
	content: none;
}

header .header_nav_list_item_container ul li a {
	padding-top: clamp(0.4rem, 1.1538461538vw, 0.6rem);
	padding-right: clamp(0.6rem, 1.9230769231vw, 1rem);
	padding-bottom: clamp(0.4rem, 1.1538461538vw, 0.6rem);
	padding-left: 2em;
}

header .header_nav_list_item_container ul li a .image {
	display: none;
}

header .header_nav_list_item_container ul li a .dcp {
	position: relative;
	color: var(--co-gr-dr);
	font-size: 1.4rem;
}

header .header_nav_list_item_container ul li a .dcp::before {
	position: absolute;
	top: 50%;
	left: -1em;
	width: 0.5em;
	height: 0.1rem;
	transform: translateY(-50%);
	background-color: var(--co-gr-dr);
	content: "";
}

header .header_nav_other {
	width: 100%;
	max-width: 36rem;
	margin-top: clamp(3.2rem, 8vw, 4.8rem);
	margin-right: auto;
	margin-left: auto;
}

header .header_hamburger {
	display: block;
	z-index: 999;
	position: relative;
	aspect-ratio: 1/1;
	width: clamp(4rem, 4.8828125vw, 5rem);
}

header .header_hamburger.active .line:first-of-type {
	top: 48%;
	transform: translateX(-50%) rotate(45deg);
}

header .header_hamburger.active .line:nth-of-type(2) {
	visibility: hidden;
	opacity: 0;
}

header .header_hamburger.active .line:last-of-type {
	bottom: 48%;
	transform: translateX(-50%) rotate(-45deg);
}

header .header_hamburger .line {
	position: absolute;
	left: 50%;
	width: 100%;
	height: 0.1rem;
	transform: translateX(-50%);
	background-color: var(--wp--preset--color--white);
	content: "";
	transition: var(--trs-bsc);
}

header .header_hamburger .line:nth-of-type(2) {
	visibility: visible;
	top: 50%;
	opacity: 1;
}

.post_sidebar {
	grid-row: 3/4;
	grid-column: 1/2;
	margin-top: clamp(4rem, 8.3333333333vw, 6.4rem);
}

main.sub .form .outer {
	padding-bottom: clamp(8rem, 13.0208333333vw, 10rem);
}

main.sub .form_table_row:nth-child(-n+3) {
	display: block;
}

main.sub .form_table_row:nth-child(-n+3) td {
	display: block;
}

main.sub .form_table_row:nth-child(-n+3) .content {
	width: 100%;
}

main.sub .form_table_row textarea {
	height: 25rem;
}

main.sub .form_table_row .content {
	margin-top: 1.6rem;
}

main.sub .form_table_row .content .checkbox {
	row-gap: 0.8rem;
}

main.sub .form .submit-btn {
	row-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	flex-direction: column;
}

main.sub .form.enter .submit-btn {
	margin-top: clamp(3.2rem, 7.2916666667vw, 5.6rem);
}

main.home .contact .outer,
main.sub .contact .outer {
	padding-top: clamp(4rem, 7.2916666667vw, 5.6rem);
	padding-bottom: clamp(5.6rem, 10.4166666667vw, 8rem);
}

main.home .contact .btn-area,
main.sub .contact .btn-area {
	-moz-column-gap: clamp(2.4rem, 3.90625vw, 4.8rem);
	column-gap: clamp(2.4rem, 3.90625vw, 4.8rem);
	row-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	flex-wrap: wrap;
	margin-top: clamp(3.2rem, 7.2916666667vw, 5.6rem);
}

.footer {
	padding-bottom: clamp(2.4rem, 7.03125vw, 5.4rem);
}

.footer_company {
	text-align: center;
}

.footer_company_logo_figure {
	width: clamp(14rem, 21.484375vw, 30.5rem);
}

.footer_company_logo .text {
	font-size: 1.8rem;
}

.footer_company_phone {
	margin-top: 0.8rem;
}

.footer_company_phone_link .text {
	line-height: 1.5;
}

.footer_nav {
	margin-top: clamp(3.2rem, 6.25vw, 4.8rem);
	margin-right: auto;
	margin-left: auto;
}

.footer_other {
	margin-top: clamp(2.4rem, 5.2083333333vw, 4.8rem);
	margin-right: auto;
	margin-left: auto;
}

.footer_other_nav {
	-moz-column-gap: clamp(2.4rem, 6.25vw, 4.8rem);
	column-gap: clamp(2.4rem, 6.25vw, 4.8rem);
}

main.sub.single.blog .breadcrumbs {
	overflow-x: scroll;
}

main.sub.single.blog .breadcrumbs .wrapper {
	min-width: -moz-max-content !important;
	min-width: max-content !important;
	border-collapse: collapse;
}

.loading_image {
	width: 22rem;
}

.loading_text {
	width: 14rem;
	margin-top: 0.4rem;
}

.cf {
	padding-top: clamp(1.6rem, 2.9296875vw, 3rem);
	padding-right: clamp(0.6rem, 1.0416666667vw, 0.8rem);
	padding-bottom: clamp(1.6rem, 2.9296875vw, 3rem);
	padding-left: clamp(0.6rem, 1.0416666667vw, 0.8rem);
	line-height: 1.75;
}

.banner_content {
	background-size: cover;
}

.banner .btn-white {
	height: auto;
	padding-top: 6px;
	padding-bottom: 6px;
}

.banner .btn-white .content .text {
	line-height: 1.3;
}

main.home .mv_news {
	margin-top: clamp(4rem, 6.25vw, 6.4rem);
}

main.home .concept .util-title-logo + .util-text {
	margin-top: clamp(1.6rem, 3.6458333333vw, 2.8rem);
}

main.home .concept .mission .util-title-logo span.per,
main.home .concept .vision .util-title-logo span.per,
main.home .concept .service .util-title-logo span.per {
	font-size: clamp(4rem, 9.375vw, 9.6rem);
	line-height: 1.3;
}

main.home .concept .mission .util-title-logo span.per-small,
main.home .concept .vision .util-title-logo span.per-small,
main.home .concept .service .util-title-logo span.per-small {
	font-size: clamp(3.2rem, 6.25vw, 6.4rem);
}

main.home .concept .service_detail_list {
	flex-wrap: wrap;
}

main.home .concept .service_detail_list_item {
	width: 33.3333333333%;
	padding: clamp(0.6rem, 1.3020833333vw, 1rem);
	border-right-width: 0.1rem;
	border-right-style: solid;
	border-right-color: rgba(0, 0, 0, 0.54);
	font-size: 1.5rem;
}

main.home .concept .service_detail_list_item:nth-of-type(n + 4) {
	border-top-width: 0.1rem;
	border-top-style: solid;
	border-top-color: rgba(0, 0, 0, 0.54);
}

main.home .concept .service_detail_content {
	row-gap: clamp(2.4rem, 3.90625vw, 4rem);
	flex-direction: column;
}

main.home .concept .service_detail_figure {
	width: 100%;
}

main.home .concept .service_detail_textarea {
	width: 100%;
}

main.home .concept .service_detail_textarea .btn-black {
	margin-right: auto;
}

main.home .post {
	margin-top: clamp(5.6rem, 10.4166666667vw, 9.6rem);
	padding-top: clamp(4rem, 7.2916666667vw, 5.6rem);
	padding-bottom: clamp(5.6rem, 10.4166666667vw, 9.6rem);
}

main.home .post .wrapper {
	flex-direction: column;
}

main.home .post .media {
	margin-top: clamp(4rem, 7.2916666667vw, 5.6rem);
}

main.home .recruit .outer {
	padding-top: clamp(4rem, 7.2916666667vw, 5.6rem);
	padding-bottom: clamp(4rem, 7.2916666667vw, 5.6rem);
}

main.sub .sub_title {
	font-size: clamp(2.8rem, 3.515625vw, 3.6rem);
}

main.sub .sub_title::before {
	width: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub .mv {
	background-position: 90% 50%;
	background-size: clamp(20rem, 65vw, 39rem);
	background-repeat: no-repeat;
}

main.sub .mv .outer {
	padding-bottom: clamp(3.2rem, 4.6875vw, 4.8rem);
}

main.sub .mv_title .en {
	font-size: clamp(2.4rem, 3.125vw, 3.2rem);
}

main.sub .mv_title .ja {
	font-size: clamp(3.8rem, 6.25vw, 6.4rem);
}

main.sub .mv_text:first-of-type {
	margin-top: clamp(1.6rem, 3.515625vw, 3.6rem);
}

main.sub .mv_icon {
	display: none;
}

main.sub .plan_list {
	row-gap: 9rem;
	flex-wrap: wrap;
	justify-content: center;
}

main.sub .plan_list_item .sub-list .third-list {
	margin-top: 0.8rem;
}

main.sub .rental_list_item {
	flex-direction: column;
}

main.sub .rental_list_item figure {
	width: 60%;
}

main.sub.photograph .mv {
	background-image: url(./images/common/svg/icon-service-ptg-blc.svg);
}

main.sub.photograph .price_table_item:first-of-type .detail-row b {
	margin-left: 4.2rem;
}

main.sub.video .mv {
	background-image: url(./images/common/svg/icon-video-mv.svg);
}

main.sub.consulting .mv {
	background-image: url(./images/common/svg/icon-design-mv.svg);
}

main.sub.consulting .price_table_item:not(:last-of-type) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.web .mv {
	background-image: url(./images/common/svg/icon-service-web-blc.svg);
}

main.sub.design .mv {
	background-image: url(./images/common/svg/icon-design-mv.svg);
}

main.sub.design .price_table_item:not(:last-of-type) {
	border-bottom: 0.1rem solid var(--co-blc);
}

main.sub.company .profile_table_item {
	padding-top: clamp(0.8rem, 2.0833333333vw, 1.6rem);
	padding-bottom: clamp(0.8rem, 2.0833333333vw, 1.6rem);
}

main.sub.company .profile_table_item dt {
	font-size: clamp(1.8rem, 2.6041666667vw, 2.2rem);
}

main.sub.company .profile_table_item dd {
	font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
}

main.sub.company .access .outer {
	padding-top: clamp(3.6rem, 5.46875vw, 5.6rem);
}

main.sub.company .access .wrapper {
	flex-direction: column;
}

main.sub.company .access_map {
	width: 100%;
}

main.sub.company .access_textarea {
	width: 100%;
	padding: clamp(2rem, 5.3333333333vw, 4rem);
}

main.sub.company .access_textarea_title .small {
	font-size: clamp(1.8rem, 2.6041666667vw, 2.4rem);
}

main.sub.company .access_textarea_title .text {
	font-size: clamp(2.4rem, 4.1666666667vw, 4rem);
}

main.sub.company .access_textarea address {
	font-size: clamp(1.6rem, 2.34375vw, 2rem);
}

main.sub.concept .philosophy .util-text-en::before,
main.sub.concept .mission .util-text-en::before,
main.sub.concept .value .util-text-en::before,
main.sub.concept .plan .util-text-en::before {
	width: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.concept .philosophy .util-title-logo span.per,
main.sub.concept .mission .util-title-logo span.per,
main.sub.concept .value .util-title-logo span.per,
main.sub.concept .plan .util-title-logo span.per {
	font-size: clamp(3rem, 6.25vw, 6.4rem);
}

main.sub.concept .philosophy .util-title-logo + .sub_text,
main.sub.concept .mission .util-title-logo + .sub_text,
main.sub.concept .value .util-title-logo + .sub_text {
	margin-top: clamp(2.8rem, 6.25vw, 4.8rem);
}

main.sub.concept .philosophy .sub_text:last-of-type,
main.sub.concept .mission .sub_text:last-of-type,
main.sub.concept .value .sub_text:last-of-type {
	margin-top: clamp(2rem, 3.125vw, 3.2rem);
}

main.sub.concept .philosophy .outer {
	padding-top: clamp(4rem, 7.2916666667vw, 6.4rem);
}

main.sub.concept .mission .outer {
	padding-top: clamp(4rem, 7.2916666667vw, 6.4rem);
}

main.sub.concept .value .outer {
	padding-top: clamp(4.8rem, 7.8125vw, 7.2rem);
}

main.sub.concept .plan .outer {
	padding-top: clamp(4rem, 6.25vw, 6rem);
	padding-bottom: clamp(7.2rem, 16.1458333333vw, 15rem);
}

main.sub.concept .plan .wrapper {
	padding-right: clamp(2.4rem, 5.859375vw, 6rem);
	padding-left: clamp(2.4rem, 5.859375vw, 6rem);
}

main.sub.concept .plan .wrapper .util-title-logo {
	margin-top: clamp(2.4rem, 2.7777777778vw, 4rem);
}

main.sub.concept .plan .wrapper .sub_text {
	margin-top: clamp(2.4rem, 2.7777777778vw, 4rem);
}

main.sub.recruit .job_title {
	font-size: clamp(2rem, 2.34375vw, 2.4rem);
}

main.sub.recruit .job_title::before {
	width: clamp(2.8rem, 3.125vw, 3.2rem);
}

main.sub.recruit .job_list_item:not(:first-of-type) {
	margin-top: clamp(3.2rem, 5.2083333333vw, 5.6rem);
}

main.sub.recruit .job_list_item .inner {
	padding-top: clamp(2.4rem, 5.2083333333vw, 4rem);
	padding-right: clamp(2.4rem, 6.25vw, 4.8rem);
	padding-bottom: clamp(2.4rem, 5.2083333333vw, 4rem);
	padding-left: clamp(2.4rem, 6.25vw, 4.8rem);
}

main.sub.recruit .job_list_item_titlearea {
	padding-right: clamp(2.4rem, 4.6875vw, 4.8rem);
	padding-left: clamp(2.4rem, 4.6875vw, 4.8rem);
}

main.sub.recruit .entry {
	padding-top: clamp(4.8rem, 8.3333333333vw, 7.2rem);
	padding-bottom: clamp(18rem, 31.25vw, 24rem);
}

main.sub.recruit .entry .recruit_titlearea {
	padding-top: clamp(1.2rem, 3.125vw, 2.4rem);
	padding-right: clamp(2rem, 4.6875vw, 4.8rem);
	padding-left: clamp(2rem, 4.6875vw, 4.8rem);
}

main.sub.recruit .entry .recruit_title {
	font-size: clamp(2.8rem, 3.515625vw, 3.6rem);
}

main.sub.recruit .entry .recruit_title::before {
	width: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.recruit .entry .form_table {
	padding: clamp(1.6rem, 3.125vw, 2.4rem) clamp(2rem, 4.6875vw, 4.8rem) clamp(3.2rem, 6.25vw, 4.8rem);
}

main.sub.recruit .entry .addNew {
	display: block;
}

main.sub.recruit .entry .submit-btn {
	row-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	flex-direction: column;
	margin-top: clamp(3.2rem, 7.2916666667vw, 5.6rem);
}

main.sub.recruit .entry .mw_wp_form_complete {
	padding: clamp(3.2rem, 6.25vw, 4.8rem) clamp(2rem, 4.6875vw, 4.8rem);
}

main.sub.recruit .entry .mw_wp_form_complete p .btn-black {
	margin-top: clamp(3.2rem, 6.25vw, 4.8rem);
}

main.sub.contact .form_table {
	padding: clamp(3.2rem, 6.25vw, 4.8rem) clamp(2rem, 4.6875vw, 4.8rem) clamp(3.2rem, 6.25vw, 4.8rem);
}

main.sub.single.blog .post:not(span) {
	padding-top: clamp(2.4rem, 4.1666666667vw, 3.2rem);
}

main.sub.single.blog .post .btn-white {
	grid-column: 1/2;
}

main.sub.single.works .mv_block {
	row-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	flex-direction: column;
}

main.sub.single.works .post {
	padding-top: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.single.works .post_title::before {
	width: clamp(2.6rem, 7.4666666667vw, 3.2rem);
}

main.sub.single.works .post_subtitle::before {
	width: clamp(1.2rem, 3.2vw, 1.6rem);
}

main.sub.single.works .post_system_block-pc {
	padding-bottom: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.single.works .post_system_block-pc figure {
	max-width: 80%;
}

main.sub.single.works .post_web {
	padding-top: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.single.works .post_web_block-pc {
	padding-bottom: clamp(3.2rem, 3.90625vw, 4rem);
}

main.sub.single.works .post_web_block-pc_image figure {
	max-width: 80%;
}

main.sub.single.works .post_comment {
	margin-top: clamp(3.6rem, 5.46875vw, 5.6rem);
	padding-top: clamp(3.6rem, 5.46875vw, 5.6rem);
	padding-bottom: clamp(5.6rem, 8.7890625vw, 9rem);
}

main.sub.single.works .post .btn-black {
	margin-top: clamp(3.2rem, 6.25vw, 5.6rem);
}

main.sub.category .post {
	padding-top: clamp(2.4rem, 4.1666666667vw, 3.2rem);
}

main.sub.category .post .outer {
	padding-bottom: clamp(6rem, 11.71875vw, 12rem);
}

main.sub.category .post_list_item:not(:first-of-type) {
	margin-top: clamp(3.2rem, 6.25vw, 4.8rem);
}

main.sub.category .post .pagination {
	grid-row: 2/3;
	grid-column: 1/2;
}

main.sub.archive.works .outer {
	padding-top: clamp(3.6rem, 5.46875vw, 5.6rem);
}

main.sub.archive.works .post_category {
	flex-wrap: wrap;
}

main.sub.archive.works .post_category_list {
	width: 33.3333333333%;
	border-right-width: 0.1rem;
	border-right-style: solid;
	border-right-color: rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_category_list a,
main.sub.archive.works .post_category_list span {
	padding: clamp(0.6rem, 1.3020833333vw, 1rem);
	font-size: 1.5rem;
}

main.sub.archive.works .post_category_list:nth-of-type(n + 4) {
	border-top-width: 0.1rem;
	border-top-style: solid;
	border-top-color: rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_list {
	row-gap: clamp(2.4rem, 5.2083333333vw, 4rem);
	margin-top: clamp(4rem, 6.25vw, 6.4rem);
}

main.sub.archive.works .post_tag {
	flex-wrap: wrap;
}

main.sub.category .news {
	padding-top: clamp(2.4rem, 4.1666666667vw, 3.2rem);
}

main.sub.category .news .outer {
	padding-bottom: clamp(6rem, 11.71875vw, 12rem);
}

main.sub .document {
	padding-top: clamp(2.4rem, 4.1666666667vw, 3.2rem);
}

main.sub .document .outer {
	padding-bottom: clamp(6rem, 11.71875vw, 12rem);
}

.single.document .post__document {
	width: 100% !important;
}

.single.document .post_sidebar .form-content {
	flex-direction: column;
}

.single.document .post_sidebar .form-content .form-left-content,
.single.document .post_sidebar .form-content .form-right-content {
	width: 100%;
}

}

@media (max-width: 1024px) and (max-width: 600px) {

header .header_hamburger .line:first-of-type {
	top: 15%;
}

header .header_hamburger .line:last-of-type {
	bottom: 15%;
}

}

@media (max-width: 768px) {

.pagination {
	margin-top: clamp(0.8rem, 1.5625vw, 1.2rem);
}

main.sub .plan_price .outer {
	padding-top: 9rem;
	padding-bottom: 9rem;
}

main.sub .plan_list_item .plan_text .large {
	font-size: clamp(2.8rem, 4.1666666667vw, 3.2rem);
}

main.sub.single.blog .post .blog-card a {
	display: block;
	text-decoration: none;
}

main.sub.single.blog .post .blog-card a .thumb {
	width: 100%;
}

main.sub.single.blog .post .blog-card a .cardContents {
	width: 100%;
	margin-top: 0.8rem;
	padding-left: 0;
}

}

@media (max-width: 600px) {

p {
	font-size: clamp(1.4rem, 3.7333333333vw, 1.6rem);
	line-height: 1.8;
}

.outer {
	padding-right: clamp(2rem, 5.3333333333vw, 3.2rem);
	padding-left: clamp(2rem, 5.3333333333vw, 3.2rem);
}

.tab-only {
	display: none;
}

.tab-escape {
	display: block;
}

.sp-only {
	display: block;
}

.sp-escape {
	display: none;
}

.util-title-mont {
	font-size: 4.8rem;
}

header {
	height: 8rem;
}

header.thin {
	height: 6.4rem;
}

header .header_nav_list {
	padding-right: clamp(2rem, 5.3333333333vw, 3.2rem);
	padding-left: clamp(2rem, 5.3333333333vw, 3.2rem);
}

header .header_nav_other {
	display: block;
}

header .header_nav_other_item a {
	font-size: 1.2rem;
	text-align: center;
}

main {
	border-top: 8rem solid var(--wp--preset--color--black);
}

.post_sidebar {
	padding-right: clamp(2rem, 5.3333333333vw, 3.2rem);
	padding-left: clamp(2rem, 5.3333333333vw, 3.2rem);
}

main.sub .form_table_row:last-of-type {
	margin-top: 3.2rem;
}

main.sub .form_table_row:last-of-type .form_table_row_title {
	line-height: 1.5;
}

main.sub .form_table_row:last-of-type .form_table_row_title + p {
	margin-top: 1.6rem;
}

main.sub .form_table_row input,
main.sub .form_table_row textarea,
main.sub .form_table_row select {
	border-radius: 0.6rem;
}

main.sub .form_table_row .content .select {
	padding-top: 0.4rem;
	padding-bottom: 0.4rem;
}

main.sub .form_table_row .content .input .error {
	top: -4rem;
}

main.sub .form.complete .btn-white .content {
	-moz-column-gap: 5.3rem;
	column-gap: 5.3rem;
}

main.home .contact .btn-black,
main.home .contact .btn-white,
main.sub .contact .btn-black,
main.sub .contact .btn-white {
	padding-right: 2.4rem;
	padding-left: 2.4rem;
}

.footer {
	width: 100%;
}

.footer_company_phone {
	-moz-column-gap: 2.4rem;
	column-gap: 2.4rem;
	justify-content: center;
}

.footer_company_phone_link_figure {
	width: 2.8rem;
}

.footer_nav {
	width: 100%;
	max-width: clamp(26rem, 74.6666666667vw, 36.5rem);
}

.footer_nav_child {
	row-gap: 1rem;
	flex-direction: column;
	width: 100%;
}

.footer_nav_child_item {
	width: 100%;
}

.footer_nav_child_item .sub-menu li a {
	font-size: 1.4rem;
}

.footer_nav_parent {
	width: 30%;
}

.footer_other {
	row-gap: clamp(1.6rem, 6.4vw, 2.4rem);
	flex-direction: column;
	width: 100%;
	max-width: clamp(26rem, 74.6666666667vw, 36.5rem);
}

.footer_other_nav {
	justify-content: space-between;
}

.breadcrumbs {
	padding-right: clamp(2rem, 5.3333333333vw, 3.2rem);
	padding-left: clamp(2rem, 5.3333333333vw, 3.2rem);
}

.btn-black,
.btn-white {
	width: 25rem;
	height: 5.6rem;
	margin-right: auto;
	margin-left: auto;
	padding-right: 3rem;
	padding-left: 3rem;
	border-radius: clamp(5.2rem, 16vw, 6rem);
}

.btn-black::before,
.btn-white::before {
	border-radius: clamp(5.2rem, 16vw, 6rem);
}

.btn-black .content,
.btn-white .content {
	-moz-column-gap: 6.6rem;
	column-gap: 6.6rem;
}

.btn-black .content::before,
.btn-white .content::before {
	left: 89.5%;
}

.btn-black .content .text,
.btn-white .content .text {
	font-size: 1.8rem;
}

.cf {
	top: 13rem;
}

.cf .text {
	font-size: clamp(1.4rem, 2.6666666667vw, 1.6rem);
}

main.sub .law h2 {
	position: relative;
	padding-left: 3rem;
	font-size: 1.8rem;
	line-height: 1.5;
}

main.sub .law h2:first-of-type {
	margin-top: clamp(1.6rem, 4.2666666667vw, 2.4rem);
}

main.sub .law h2:not(:first-of-type) {
	margin-top: clamp(1.6rem, 4.2666666667vw, 2.4rem);
}

main.sub .law h2::before {
	position: absolute;
	top: 0.4rem;
	left: 0;
	width: 1.8rem;
}

main.sub .law h2 + p,
main.sub .law h2 + ol {
	margin-top: clamp(1.6rem, 4.2666666667vw, 2.4rem);
}

.banner .btn-white {
	max-width: 24rem;
}

.banner .btn-white .content {
	-moz-column-gap: 1.8rem;
	column-gap: 1.8rem;
}

.banner .btn-white .content::before {
	right: -11%;
	width: 2rem;
}

.banner .btn-white .content .text {
	font-size: 1.5rem;
}

.pagination ul.page-numbers li {
	width: clamp(4.8rem, 14.9333333333vw, 6rem);
}

.pagination ul.page-numbers li.first,
.pagination ul.page-numbers li.previous,
.pagination ul.page-numbers li.next,
.pagination ul.page-numbers li.last {
	display: none;
}

.pagination ul.page-numbers li a.page-numbers {
	aspect-ratio: 1/1;
	width: clamp(4rem, 12.2666666667vw, 5rem);
	border: 1px solid var(--co-blc);
	background-color: var(--wp--preset--color--white);
}

.pagination ul.page-numbers li span.page-numbers {
	aspect-ratio: 1/1;
	width: clamp(4rem, 12.2666666667vw, 5rem);
	border: 1px solid var(--co-blc);
}

main.home .mv .outer {
	padding-bottom: 3.2rem;
}

main.home .mv .lottie .movie {
	display: none;
}

main.home .mv .lottie-realize {
	width: 95.61%;
}

main.home .mv .lottie-picture {
	width: 100%;
}

main.home .mv .lottie-dream {
	width: 84.84%;
}

main.home .mv_news_article_title {
	font-size: 1.4rem;
	line-height: 1.8;
}

main.home .concept {
	padding-top: clamp(3.2rem, 10.6666666667vw, 6rem);
}

main.home .concept .util-title-logo {
	margin-top: clamp(0.6rem, 1.6vw, 0.6rem);
}

main.home .concept .mission::before {
	top: -20%;
	right: -40%;
	width: clamp(24rem, 80vw, 51.5rem);
}

main.home .concept .vision::before {
	left: -30%;
	width: clamp(20rem, 64vw, 32.6rem);
}

main.home .concept .service::before {
	right: -33%;
	width: clamp(22.6rem, 70.4vw, 36.2rem);
}

main.home .concept .service_detail_list_item {
	width: 50%;
	font-size: 1.4rem;
}

main.home .concept .service_detail_list_item::before {
	width: clamp(4rem, 12.8vw, 5.6rem);
	height: clamp(4.333rem, 3.6111111111vw, 6.066rem);
}

main.home .concept .service_detail_list_item:nth-of-type(2n+1) {
	border-left: 1px solid rgba(0, 0, 0, 0.54);
}

main.home .concept .service_detail_list_item:nth-of-type(2n) {
	border-left: none;
}

main.home .concept .service_detail_list_item:nth-of-type(3) {
	border-top: 1px solid rgba(0, 0, 0, 0.54);
}

main.home .concept .service_detail_title .en {
	font-size: clamp(3.2rem, 10.6666666667vw, 4.8rem);
}

main.home .concept .service_detail_title .ja {
	margin-top: clamp(-3.2rem, -5.8666666667vw, -1.6rem);
	font-size: clamp(2.2rem, 6.9333333333vw, 3.2rem);
}

main.home .works_list {
	flex-direction: column;
}

main.home .works_list_item {
	width: 100%;
}

main.home .works_article_link_list_item {
	font-size: 1.6rem;
}

main.home .works .btn-black {
	margin-top: 4rem;
}

main.home .post .news_content,
main.home .post .media_content {
	margin-top: 1.2rem;
}

main.home .post .btn-white {
	margin-top: 4rem;
}

main.home .recruit .util-title-logo {
	font-size: 2.6rem;
}

main.home .recruit .util-title-logo + p {
	margin-top: 1.6rem;
}

main.sub .mv_text:not(:first-of-type) {
	margin-top: clamp(1.2rem, 3.7333333333vw, 1.6rem);
}

main.sub .category .outer {
	padding-top: clamp(4rem, 10.6666666667vw, 5.6rem);
	padding-bottom: clamp(2rem, 5.3333333333vw, 3.6rem);
}

main.sub .category_order {
	margin-top: clamp(4rem, 10.6666666667vw, 5.6rem);
}

main.sub .price .outer {
	padding-top: clamp(2rem, 5.3333333333vw, 3.6rem);
	padding-bottom: 0;
}

main.sub .price_table_item {
	flex-direction: column;
}

main.sub .price_table_item:not(:first-of-type) dt {
	margin-top: clamp(2.4rem, 8.5333333333vw, 3.2rem);
}

main.sub .price_table_item dt {
	width: 100%;
	font-size: clamp(1.6rem, 4.2666666667vw, 1.8rem);
	line-height: 1.5;
}

main.sub .price_table_item .detail {
	width: 100%;
}

main.sub .plan_textarea .outer {
	padding-top: clamp(2rem, 5.3333333333vw, 3.6rem);
	padding-bottom: clamp(4.8rem, 12.8vw, 5.6rem);
}

main.sub .plan_list_item {
	width: 100%;
}

main.sub .plan_list_item .plan_title {
	font-size: clamp(2rem, 5.3333333333vw, 2.4rem);
}

main.sub .plan_list_item .sub-list {
	font-size: clamp(1.4rem, 3.7333333333vw, 1.6rem);
}

main.sub .rental_list_item {
	width: 100%;
}

main.sub .rental_list_item .btn-black {
	max-width: 24rem;
}

main.sub .rental_list_item .btn-black .content {
	-moz-column-gap: 7rem;
	column-gap: 7rem;
}

main.sub .rental_list_item .btn-black .content .text {
	font-size: 1.6rem;
}

main.sub.photograph .category_order_item {
	width: 100%;
}

main.sub.photograph .price_table_item:nth-of-type(4) {
	align-items: flex-start;
	font-size: 1.4rem;
	line-height: 1.5;
}

main.sub.photograph .price_table_item:nth-of-type(6) .detail-row {
	justify-content: flex-start;
}

main.sub.photograph .price_table_item:last-of-type .detail-row {
	justify-content: flex-start;
}

main.sub.photograph .contact {
	margin-top: clamp(4rem, 12.8vw, 5.6rem);
}

main.sub.video .category_order_item {
	width: 100%;
}

main.sub.video .contact {
	margin-top: clamp(4rem, 12.8vw, 5.6rem);
}

main.sub.consulting .category_order_item {
	width: 100%;
}

main.sub.web .category_order_item {
	width: 100%;
}

main.sub.web .price_table_item {
	flex-direction: row;
	padding-top: 1.6rem;
	padding-bottom: 1.6rem;
}

main.sub.web .price_table_item:not(:first-of-type) dt {
	margin-top: 0;
}

main.sub.web .price_table_item dd {
	font-size: 1.4rem;
}

main.sub.web .price_note {
	margin-bottom: 1rem;
}

main.sub.design .category_order_item {
	width: 100%;
}

main.sub.company .profile_table_item {
	flex-direction: column;
}

main.sub.company .profile_table_item dt {
	width: 100%;
}

main.sub.company .profile_table_item dd {
	width: 100%;
}

main.sub.company .access_map {
	aspect-ratio: 1/1;
}

main.sub.company .access_textarea .btn-white {
	width: 24rem;
	margin-top: clamp(1.6rem, 5.3333333333vw, 2.4rem);
}

main.sub.company .access_textarea .btn-white .content {
	-moz-column-gap: 5.6rem;
	column-gap: 5.6rem;
}

main.sub.concept .philosophy::before {
	top: 75%;
	right: -40%;
	width: clamp(24rem, 80vw, 51.5rem);
}

main.sub.concept .mission::before {
	top: 80%;
	left: -15%;
	width: clamp(20rem, 64vw, 32.6rem);
}

main.sub.concept .plan::after {
	bottom: 0;
}

main.sub.concept .plan_message .sub_strong {
	font-size: 1.4rem;
}

main.sub.recruit .job_list-sub_item {
	padding-left: 1.8rem;
	font-size: 1.4rem;
}

main.sub.recruit .job_list-sub_item::before {
	top: 1.1rem;
	width: 1.4rem;
}

main.sub.recruit .entry .mw_wp_form_complete p .btn-black .content {
	-moz-column-gap: 5.5rem;
	column-gap: 5.5rem;
}

main.sub.single.blog .post:not(span) {
	padding-right: clamp(2rem, 5.3333333333vw, 3.2rem);
	padding-left: clamp(2rem, 5.3333333333vw, 3.2rem);
}

main.sub.single.blog .post_contents time {
	font-size: 1.4rem;
}

main.sub.single.blog .post_writer h2 {
	padding-right: 1.6rem;
	padding-left: 1.6rem;
}

main.sub.single.blog .post_writer_inner {
	padding: 1.6rem;
}

main.sub.single.blog .post .btn-white .content {
	-moz-column-gap: 7rem;
	column-gap: 7rem;
}

main.sub.single.works .post_title {
	font-size: clamp(2rem, 5.8666666667vw, 2.4rem);
}

main.sub.single.works .post_subtitle .ja {
	font-size: clamp(1.6rem, 4.2666666667vw, 1.8rem);
}

main.sub.single.works .post_system_block-sp_image {
	flex-direction: column;
}

main.sub.single.works .post_system_block-sp_image figure {
	max-width: 80%;
}

main.sub.single.works .post_web_block-sp_image {
	flex-direction: column;
}

main.sub.single.works .post_web_block-sp_image figure {
	max-width: 80%;
}

main.sub.single.works .post_design-web_block-sp .post_design_gallery figure {
	max-width: 100%;
}

main.sub.single.works .post_design-ppt figure {
	width: 100%;
}

main.sub.single.works .btn-black .content {
	-moz-column-gap: 6.8rem;
	column-gap: 6.8rem;
}

main.sub.category .post_list_item_link figure {
	width: 100%;
}

main.sub.category .post_list_item_link {
	flex-direction: column;
}

main.sub.category .post .pagination ul.page-numbers {
	background-color: var(--wp--preset--color--black);
}

main.sub.archive.works .post_category_list {
	width: 50%;
}

main.sub.archive.works .post_category_list a,
main.sub.archive.works .post_category_list span {
	font-size: 1.4rem;
}

main.sub.archive.works .post_category_list a::before,
main.sub.archive.works .post_category_list span::before {
	width: clamp(4rem, 12.8vw, 5.6rem);
	height: clamp(4.333rem, 3.6111111111vw, 6.066rem);
}

main.sub.archive.works .post_category_list:nth-of-type(2n+1) {
	border-left: 1px solid rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_category_list:nth-of-type(2n) {
	border-left: none;
}

main.sub.archive.works .post_category_list:nth-of-type(3) {
	border-top: 1px solid rgba(0, 0, 0, 0.54);
}

main.sub.archive.works .post_list_item {
	width: 100%;
}

main.sub.category .news_list_item_link {
	-moz-column-gap: clamp(1.2rem, 4.2666666667vw, 2.4rem);
	grid-template-columns: clamp(10rem, 34.6666666667vw, 16rem) auto;
	column-gap: clamp(1.2rem, 4.2666666667vw, 2.4rem);
	row-gap: clamp(0.8rem, 3.2vw, 1.6rem);
}

main.sub.category .news_list_item_link::after {
	right: 1rem;
	width: clamp(1.5rem, 5.3333333333vw, 2.5rem);
}

main.sub.category .news_list_item_link .category {
	grid-row: 1/2;
	grid-column: 1/2;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: clamp(1.2rem, 3.7333333333vw, 1.8rem);
}

main.sub.category .news_list_item_link time {
	grid-row: 1/2;
	grid-column: 2/3;
	align-self: center;
}

main.sub.category .news_list_item_link h2 {
	grid-row: 2/3;
	grid-column: 1/3;
	padding-right: 15%;
}

main.sub.category .news .pagination ul.page-numbers {
	background-color: var(--wp--preset--color--black);
}

main.sub .document .paper-content__inner {
	width: 100%;
}

main.sub .document .paper-content__inner h2 {
	margin-bottom: 0;
}

main.sub .document .paper-content__inner .doc-box {
	flex-direction: column;
	padding: 2em 0;
}

main.sub .document .paper-content__inner .doc-box .thumb {
	width: calc(100% - 5em);
	margin-bottom: 2em;
}

main.sub .document .paper-content__inner .doc-box .text {
	width: 100%;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact tr {
	display: flex;
	flex-direction: column;
}

.single.document .post_sidebar .form-content .form-left-content .tbl-form-contact tr td {
	font-size: 14px;
}

.single.document .post_sidebar .form-content .form-left-content .btn-doc-back {
	margin-top: 2rem;
}

}

@keyframes fade-in {

0% {
	transform: translateY(25px);
	opacity: 0;
}

100% {
	transform: translateY(0);
	opacity: 1;
}

}

@keyframes fade-up {

0% {
	transform: translateY(-25px);
	opacity: 0;
}

100% {
	transform: translateY(0);
	opacity: 1;
}

}

@keyframes fade-right {

0% {
	transform: translateX(25px);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

@keyframes fade-left {

0% {
	transform: translateX(-25px);
	opacity: 0;
}

100% {
	transform: translateX(0);
	opacity: 1;
}

}

@keyframes appear {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@keyframes disappear {

0% {
	opacity: 1;
}

100% {
	opacity: 0;
}

}

@keyframes per {

0% {
	transform: translateX(-25%) scale(1.3);
	opacity: 0;
}

100% {
	transform: translateX(0) scale(1);
	opacity: 1;
}

}

@keyframes gear {

0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(360deg);
}

}

@keyframes gear-reverse {

0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(-360deg);
}

}

