:root {
	--shot-runout: 52vw;
	--shot-runout-up: 60vh;
	--jp-headline: "Zen Kaku Gothic New", "BIZ UDPGothic", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", system-ui, sans-serif;
	--color-orange: #F06423;
	--color-orange-light: #FFB78F;
	--color-orange-hair: #FFD7C2;
	--color-border-light: #FFD0B8;
	--color-muted: #6F6F6F;
	--color-border: #EFE7E2;
	--color-noise: rgb(0 0 0 / 3.5%);
	--card-grad1: #FFF7F2;
	--card-grad2: #FFF1E9;
	--shadow-rgb: 240 100 35;
}

.p-recruit-hero {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	background-color: #f06423;
}

.p-recruit-hero__stage {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
}

.hero-intro {
	position: absolute;
	inset: 0;
	background-color: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
}

.hero-intro__text {
	font-size: clamp(32px, 8vw, 100px);
	font-weight: 900;
	font-family: var(--jp-headline);
	color: #fff;
	letter-spacing: 0.03em;
	text-transform: none;
	opacity: 0;
	transform: scale(1.1);
	animation: introTextIn 0.9s ease forwards;
	text-align: center;
}

@keyframes introTextIn {
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.hero-intro.is-out {
	animation: introOut 1s ease forwards;
}

@keyframes introOut {
	to {
		opacity: 0;
		visibility: hidden;
	}
}

.hero-shot {
	position: absolute;
	bottom: 0;
	left: 50%;
	height: 100vh;
	aspect-ratio: 3/4;
	width: auto;
	background-size: auto 100%;
	background-repeat: no-repeat;
	background-position: center bottom;
	z-index: 2;
	opacity: 0;
	will-change: transform, opacity;
}

.hero-shot--left {
	transform: translate(-60vw, 0);
}

.hero-shot--left.is-in {
	animation: shotInLeft 0.55s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes shotInLeft {
	from {
		transform: translate(-60vw, 0);
		opacity: 0;
	}

	to {
		transform: translate(-50%, 0);
		opacity: 1;
	}
}

.hero-shot--left.is-out {
	animation: shotOutLeft 2.6s cubic-bezier(0.3, 0, 0.2, 1) forwards;
}

@keyframes shotOutLeft {
	from {
		transform: translate(-50%, 0);
		opacity: 1;
	}

	95% {
		transform: translate(calc(-50% + var(--shot-runout)), 0) scale(0.985);
		opacity: 1;
	}

	to {
		transform: translate(calc(-50% + var(--shot-runout)), 0) scale(0.985);
		opacity: 0;
	}
}

.hero-shot--right {
	transform: translate(60vw, 0);
}

.hero-shot--right.is-in {
	animation: shotInRight 0.55s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes shotInRight {
	from {
		transform: translate(60vw, 0);
		opacity: 0;
	}

	to {
		transform: translate(-50%, 0);
		opacity: 1;
	}
}

.hero-shot--right.is-out {
	animation: shotOutRight 2.6s cubic-bezier(0.3, 0, 0.2, 1) forwards;
}

@keyframes shotOutRight {
	from {
		transform: translate(-50%, 0);
		opacity: 1;
	}

	95% {
		transform: translate(calc(-50% - var(--shot-runout)), 0) scale(0.985);
		opacity: 1;
	}

	to {
		transform: translate(calc(-50% - var(--shot-runout)), 0) scale(0.985);
		opacity: 0;
	}
}

.hero-shot--up {
	transform: translate(-50%, 60vh);
}

.hero-shot--up.is-in {
	animation: shotInUp 0.55s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes shotInUp {
	from {
		transform: translate(-50%, 60vh);
		opacity: 0;
	}

	to {
		transform: translate(-50%, 0);
		opacity: 1;
	}
}

.hero-shot--up.is-out {
	animation: shotOutUp 2.6s cubic-bezier(0.3, 0, 0.2, 1) forwards;
}

@keyframes shotOutUp {
	from {
		transform: translate(-50%, 0);
		opacity: 1;
	}

	95% {
		transform: translate(-50%, calc(-1 * var(--shot-runout-up))) scale(0.985);
		opacity: 1;
	}

	to {
		transform: translate(-50%, calc(-1 * var(--shot-runout-up))) scale(0.985);
		opacity: 0;
	}
}

.hero-headline {
	position: absolute;
	inset: 0;
	z-index: 5;
	display: grid;
	align-content: center;
	padding: 10vh clamp(16px, 6vw, 80px);
	pointer-events: none;
}

.hero-headline__line {
	margin: 0;
	line-height: 0.95;
	font-family: var(--jp-headline);
	font-weight: 900;
	font-size: clamp(42px, 12vw, 200px);
	color: #fff;
	transform: translateY(-120%);
	opacity: 0;
	text-transform: none;
}

.hero-headline__line.is-solid {
	letter-spacing: 0.02em;
}

.hero-headline__line.is-outline {
	color: transparent;
	-webkit-text-stroke: clamp(1.5px, 0.6vw, 6px) #fff;
	letter-spacing: 0.03em;
	paint-order: stroke fill;
	text-rendering: optimizeLegibility;
}

.hero-headline.is-revealed .hero-headline__line {
	animation: slideDown 0.9s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

.hero-headline.is-revealed .hero-headline__line.is-outline {
	animation-delay: 0.12s;
}

@keyframes slideDown {
	from {
		transform: translateY(-120%);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

.hero-headline.is-out {
	animation: headlineOut 0.6s ease forwards;
}

@keyframes headlineOut {
	from {
		opacity: 1;
		transform: translateY(0);
	}

	to {
		opacity: 0;
		transform: translateY(-40px);
	}
}

@media (prefers-reduced-motion: reduce) {

	.hero-shot--left.is-in,
	.hero-shot--left.is-out,
	.hero-shot--right.is-in,
	.hero-shot--right.is-out,
	.hero-shot--up.is-in,
	.hero-shot--up.is-out,
	.hero-headline.is-revealed .hero-headline__line,
	.hero-headline.is-out {
		animation-duration: 0.01ms;
		animation-iteration-count: 1;
	}
}

.hero-headline--right {
	justify-items: end;
	text-align: right;
	padding: 10vh clamp(16px, 6vw, 80px) 10vh clamp(8px, 3vw, 48px);
}

.hero-headline--right .hero-headline__line {
	justify-self: end;
}

.hero-headline--bottom {
	align-content: end;
	justify-items: center;
	text-align: center;
	padding: 0 clamp(16px, 6vw, 80px) 12vh;
}

.hero-headline--bottom .hero-headline__line {
	transform: translateY(40%);
}

.hero-headline--bottom.is-revealed .hero-headline__line {
	animation: bottomRise 0.9s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes bottomRise {
	from {
		transform: translateY(40%);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

@media (max-width: 768px) {
	:root {
		--shot-runout: 56vw;
		--shot-runout-up: 64vh;
	}

	.hero-shot {
		height: 92vh;
	}

	.hero-headline--right {
		padding: 8vh 16px;
	}

	.hero-headline--bottom {
		padding: 0 16px 12vh;
	}
}

.trio-stage {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 6;
}

.trio-item {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 33.34vw;
	height: 100%;
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: center top;
	opacity: 0;
	transform: translateX(calc(-50% + var(--tx, 0))) translateY(10px) scale(0.94);
	will-change: transform, opacity;
	filter: drop-shadow(0 14px 24px rgb(0 0 0 / 22%));
}

.trio-item.pos-c {
	--tx: 0vw;
}

.trio-item.pos-r {
	--tx: 33.34vw;
}

.trio-item.pos-l {
	--tx: -33.34vw;
}

.trio-item.is-enter {
	animation: trioPop 0.38s cubic-bezier(0.2, 0.9, 0.2, 1.05) forwards;
}

@keyframes trioPop {
	0% {
		opacity: 0;
		transform: translateX(calc(-50% + var(--tx))) translateY(10px) scale(0.94);
	}

	70% {
		opacity: 1;
		transform: translateX(calc(-50% + var(--tx))) translateY(0) scale(1.02);
	}

	to {
		opacity: 1;
		transform: translateX(calc(-50% + var(--tx))) translateY(0) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.trio-item.is-enter {
		animation-duration: 0.01ms;
		animation-iteration-count: 1;
	}
}

.trio-headline {
	position: absolute;
	inset: 0;
	display: grid;
	align-content: end;
	justify-items: center;
	padding: 0 clamp(16px, 6vw, 80px) 8vh;
	z-index: 7;
	pointer-events: none;
}

.trio-headline__line {
	margin: 0;
	line-height: 0.95;
	font-family: var(--jp-headline);
	font-weight: 900;
	font-size: clamp(42px, 12vw, 200px);
	color: #fff;
	opacity: 0;
	transform: translateY(30%);
	text-transform: none;
	white-space: nowrap;
}

.trio-headline__line.is-solid {
	letter-spacing: 0.02em;
}

.trio-headline__line.is-outline {
	color: transparent;
	-webkit-text-stroke: clamp(1.5px, 0.6vw, 6px) #fff;
	letter-spacing: 0.03em;
	paint-order: stroke fill;
	text-rendering: optimizeLegibility;
}

.trio-headline.is-revealed .trio-headline__line {
	animation: trioTextIn 0.75s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

.trio-headline.is-revealed .trio-headline__line.is-outline {
	animation-delay: 0.12s;
}

@keyframes trioTextIn {
	from {
		opacity: 0;
		transform: translateY(30%);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.trio-headline.is-out .trio-headline__line {
	animation: trioTextOut 0.5s ease forwards;
}

@keyframes trioTextOut {
	from {
		opacity: 1;
		transform: translateY(0);
	}

	to {
		opacity: 0;
		transform: translateY(20%);
	}
}

.trio-stage--vertical {
	display: none;
}

.trio-headline--vertical {
	display: none;
}

@media (max-width: 768px) {

	.trio-stage,
	.trio-headline {
		display: none;
	}

	.trio-stage--vertical {
		overflow: hidden;
		position: relative;
		display: grid;
		grid-template-rows: repeat(3, 1fr);
		height: 100vh;
		z-index: 6;
	}

	.trio-vert {
		background-repeat: no-repeat;
		background-size: 200% auto;
		filter: drop-shadow(0 10px 20px rgb(0 0 0 / 18%));
		opacity: 0.92;
	}

	.trio-vert.pos-top {
		background-position: 50% 4%;
	}

	.trio-vert.pos-mid {
		background-position: 40% 4%;
	}

	.trio-vert.pos-btm {
		background-position: 40% 2%;
	}

	.trio-headline--vertical {
		position: absolute;
		top: 0;
		left: 0;
		display: grid;
		grid-template-rows: repeat(2, 1fr);
		justify-content: center;
		gap: 8px;
		height: 100%;
		padding: 16px 10px;
		font-family: var(--jp-headline);
		font-weight: 900;
		font-size: calc(54 * (100vh / 844));
		line-height: 1.08;
		letter-spacing: 0.08em;
		writing-mode: vertical-rl;
		text-orientation: mixed;
		color: #fff;
		opacity: 0;
		transform: translateX(-144px);
		transition: all 0.5s;
		z-index: 8;
	}

	.trio-headline--vertical.is-revealed {
		opacity: 1;
		transform: translateX(0);
	}

	.trio-vert__line {
		height: fit-content;
		color: #fff;
		text-shadow: 0 0 2px rgb(0 0 0 / 15%);
	}

	.trio-vert__line.is-solid {
		transform: translateY(-3em);
	}

	.trio-vert__line.is-outline {
		transform: translateY(3em);
	}
}

.p-openings {
	padding: 40px 20px 120px;
}

.p-openings__card {
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	background-color: #fff;
	border: 2px solid var(--color-border);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 4px 16px rgb(240 100 35 / 40%);
}

.p-openings__card::after {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 64px;
	pointer-events: none;
	background: radial-gradient(8px 8px at 20% 50%, rgb(240 100 35 / 10%) 20%, transparent 22%) repeat-x;
	opacity: 0.4;
}

.p-openings__head {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 20px;
}

.p-openings__heading {
	display: flex;
	align-items: center;
	gap: 10px;
}

.p-openings__tag {
	display: inline-block;
	padding: 8px 16px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 700;
	color: #fff;
	background-color: var(--color-orange);
}

.p-openings__title {
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.04em;
}

.p-openings__note {
	display: flex;
	align-items: center;
	gap: 4px;
	color: #333;
	opacity: 0.9;
}

.p-openings__note-icon {
	display: inline-block;
	width: 18px;
	height: 18px;
	color: var(--color-orange);
}

.p-openings__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	border-top: 2px solid var(--color-border);
}

.p-openings__item {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	gap: 20px;
	padding: 20px;
	border-left: 2px solid var(--color-border);
	transition: all 0.12s;
}

.p-openings__item:first-child {
	border-left: none;
}

@media (any-hover: hover) {
	.p-openings__item:hover {
		background-color: #FFF7F2;
		transform: translateY(-1px);
	}
}

.p-openings__shop {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 20px;
	font-weight: 700;
}

.p-openings__shop-icon {
	display: inline-block;
	width: 24px;
	color: var(--color-orange);
}

.p-openings__jobs {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.p-openings__job {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	/* gap: 8px; */
}

.p-openings__role {
	font-weight: 700;
	color: #222;
}

.p-openings__status {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	width: fit-content;
	padding: 8px 16px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	background-color: var(--color-orange);
	box-shadow: 0 8px 16px rgb(240 100 35 / 25%);
}

.p-openings__status.is-closed {
	background-color: #cfcfcf;
	color: #fff;
	box-shadow: none;
}

.p-openings__ft {
	display: flex;
	justify-content: flex-end;
	padding: 16px 20px;
	border-top: 2px solid var(--color-border);
	background-color: #fff;
}

.p-openings__updated {
	font-size: 12px;
	color: var(--color-muted);
}

@media screen and (max-width:768px) {
	.p-openings {
		padding-top: 0;
		padding-bottom: 80px;
	}

	.p-openings__head {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
	}

	.p-openings__note {}

	.p-openings__list {
		grid-template-columns: 1fr;
	}

	.p-openings__item {
		grid-template-columns: 1fr;
		align-items: flex-start;
		border-left: none;
		border-top: 1px solid var(--color-border);
	}

	.p-openings__item:first-child {
		border-top: none;
	}

	.p-openings__jobs {
		flex-direction: row;
	}
}

.p-env {
	padding: 80px 20px;
	background-color: #fff9f5;
}

.p-env__inner {
	display: grid;
	grid-template-columns: 1fr minmax(280px, 380px);
	align-items: center;
	gap: 40px;
	max-width: 1200px;
	margin: 0 auto;
}

.p-env__lead {
	position: static;
	width: auto;
}

.p-env__eyebrow {
	font-size: 18px;
	letter-spacing: 0.12em;
	color: #3a3a3a;
}

.p-env__title {
	font-size: 34px;
	font-weight: 700;
	line-height: 1.5;
	color: var(--color-orange);
	margin-top: 16px;
}

.p-env__desc {
	margin-top: 20px;
	line-height: 1.9;
	color: #222;
}

.p-env__right {
	position: relative;
	width: 100%;
}

.p-env__visualWrap {
	width: 100%;
	max-width: 380px;
	margin: 0 0 0 auto;
}

.p-env__visual {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	aspect-ratio: 1/1;
}

.p-env__visual::before,
.p-env__visual::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	pointer-events: none;
	z-index: 1;
}

.p-env__visual::before {
	border: 3px solid var(--color-orange-light);
	transform: scale(0.94);
}

.p-env__visual::after {
	border: 2px solid var(--color-orange-hair);
	transform: scale(1.02);
}

.p-env__image {
	position: relative;
	overflow: hidden;
	display: grid;
	place-items: flex-start center;
	width: 82%;
	border-radius: 50%;
	aspect-ratio: 1/1;
	z-index: 2;
}

.p-env__image img {
	width: 100%;
}

.p-env__navBtn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 56px;
	aspect-ratio: 1/1;
	border: none;
	border-radius: 50%;
	background-color: var(--color-orange);
	box-shadow: 0 8px 20px rgb(var(--shadow-rgb) / 22%);
	z-index: 2;
}

.p-env__navBtn--prev {
	left: -28px;
}

.p-env__navBtn--next {
	right: -28px;
}

.p-env__navBtn::before {
	content: "";
	position: absolute;
	inset: 0;
	margin: auto;
	width: 10px;
	height: 10px;
	border: 3px solid #fff;
	border-top: 0;
	border-right: 0;
	transform: rotate(45deg);
}

.p-env__navBtn--next::before {
	transform: rotate(-135deg);
}

.p-env__profile {
	position: relative;
	display: grid;
	gap: 8px;
	margin-top: 10px;
	z-index: 3;
}

.p-env__nameBadge {
	display: block;
	width: fit-content;
	padding: 8px 12px;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: 4px;
	box-shadow: 0 6px 16px rgb(var(--shadow-rgb) / 18%);
	font-size: 16px;
	font-weight: 700;
	white-space: nowrap;
}

.p-env__quote {
	padding: 8px 12px;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: 4px;
	box-shadow: 0 6px 16px rgb(var(--shadow-rgb) / 18%);
	font-size: 20px;
	font-weight: 800;
	letter-spacing: 0.04em;
}

.p-env__dots {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 14px;
}

.p-env__dots span,
.p-env__dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: var(--color-orange-light);
	display: inline-block;
}

.p-env__dots .is-active,
.p-env__dot.is-active {
	width: 8px;
	height: 8px;
	background-color: var(--color-orange);
}

@media screen and (max-width: 1040px) {
	.p-env__inner {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.p-env__visualWrap {
		margin: 0 auto;
	}
}

@media screen and (max-width: 768px) {
	.p-env {
		padding: 56px 20px;
	}

	.p-env__eyebrow {
		font-size: 14px;
		letter-spacing: 0.16em;
		color: #6b6b6b;
	}

	.p-env__title {
		font-size: 28px;
		line-height: 1.45;
		color: var(--color-orange);
		margin: 10px 0 14px;
	}

	.p-env__title br {
		display: none;
	}

	.p-env__desc {
		margin-top: 10px;
		line-height: 1.85;
		font-size: 15px;
	}

	.p-env__visualWrap {
		width: 68vw;
		max-width: 460px;
		margin: 6px auto 0;
	}

	.p-env__image {
		width: 86%;
		margin: 0 auto;
	}

	.p-env__navBtn {
		width: 44px;
		box-shadow: 0 6px 16px rgb(var(--shadow-rgb) / 20%);
	}

	.p-env__navBtn--prev {
		left: -22px;
	}

	.p-env__navBtn--next {
		right: -22px;
	}

	.p-env__profile {
		margin-top: 6px;
		justify-items: center;
		text-align: center;
	}

	.p-env__nameBadge {
		font-size: 14px;
	}

	.p-env__quote {
		font-size: 16px;
	}

	.p-env__dots {
		gap: 6px;
		margin-top: 12px;
	}
}

.p-philo {
	display: grid;
	gap: 120px;
	padding: 80px 20px;
	background: radial-gradient(1px 1px at 40px 60px, rgb(0 0 0 / 3%) 1px, transparent 1px), radial-gradient(1px 1px at 120px 140px, rgb(0 0 0 / 3%) 1px, transparent 1px), #fff;
	background-size: 160px 160px, 160px 160px, auto;
}

.p-philo__row {
	display: grid;
	grid-template-columns: 1.02fr 1fr;
	align-items: center;
	gap: 48px;
	max-width: 1280px;
	margin: 0 auto;
}

.p-philo__row--img-right .p-philo__text {
	order: 1;
}

.p-philo__row--img-left .p-philo__text {
	grid-template-columns: 1fr 1.02fr;
	order: 2;
}

.p-philo__eyebrow {
	font-size: 14px;
	letter-spacing: 0.2em;
	color: var(--color-muted);
	margin: 0 0 8px;
}

.p-philo__title {
	font-family: "Times New Roman", Georgia, serif;
	font-size: clamp(38px, 6vw, 64px);
	font-weight: 700;
	margin: 0 0 12px;
}

.p-philo__lead {
	font-size: clamp(24px, 3.2vw, 34px);
	font-weight: 700;
	line-height: 1.5;
	margin: 0 0 22px;
}

.p-philo__desc {
	line-height: 2;
	margin: 0 0 28px;
}

.p-philo__cta {
	position: relative;
	display: inline-block;
	width: fit-content;
	padding: 0 46px 8px 0;
	font-weight: 700;
	border-bottom: 2px solid #222;
}

.p-philo__cta::after,
.p-philo__cta::before {
	content: '';
	position: absolute;
	inset: 50% 0 auto auto;
	transform: translate(-2px, -50%);
	transition: all 0.2s;
}

.p-philo__cta::after {
	width: 26px;
	height: 2px;
	background-color: #222;
}

.p-philo__cta::before {
	width: 10px;
	height: 10px;
	border-right: 2px solid #222;
	border-top: 2px solid #222;
	transform: translate(-2px, -50%) rotate(45deg);
}

@media (any-hover: hover) {
	.p-philo__cta:hover {
		color: inherit;
	}

	.p-philo__cta:hover::after {
		transform: translate(0, -50%);
	}

	.p-philo__cta:hover::before {
		transform: translate(0, -50%) rotate(45deg);
	}
}

.p-philo__media {
	position: relative;
}

.p-philo__row--img-right .p-philo__media {
	order: 2;
}

.p-philo__row--img-left .p-philo__media {
	order: 1;
}

.p-philo__photo {
	position: relative;
	display: block;
	width: 100%;
	max-width: 400px;
	z-index: 2;
}

.p-philo__photo img {
	display: block;
	width: 100%;
	height: auto;
}

.p-philo__brush {
	position: absolute;
	inset: auto 0 -14% -4%;
	opacity: 0;
	transform: scale(0.5) rotate(-8deg);
	transition: transform 0.8s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.8s ease;
	z-index: 1;
}

.p-philo__brush img {
	display: block;
	width: 100%;
	height: auto;
}

.p-philo__row--img-left .p-philo__brush {
	inset: -12% -4% auto 0;
}

.p-philo__row.is-inview .p-philo__brush {
	opacity: 1;
	transform: scale(1) rotate(0deg);
}

@media screen and (max-width: 1040px) {
	.p-philo {
		gap: 40px;
	}

	.p-philo__row {
		position: relative;
		grid-template-columns: 1fr;
		gap: 0;
	}

	.p-philo__text {
		position: relative;
		z-index: 3;
	}

	.p-philo__row--img-right .p-philo__text {
		order: 0;
	}

	.p-philo__row--img-left .p-philo__text {
		order: 0;
	}

	.p-philo__media {
		position: static;
	}

	.p-philo__row--img-right .p-philo__media {
		order: 0;
	}

	.p-philo__row--img-left .p-philo__media {
		order: 0;
	}

	.p-philo__photo {
		position: absolute;
		inset: auto 0 0 auto;
		width: fit-content;
		height: 160px;
	}

	.p-philo__photo img {
		height: 100%;
		object-fit: contain;
		object-position: 100% 100%;
	}

	.p-philo__brush {
		inset: 0;
	}

	.p-philo__brush img {
		height: 100%;
		object-fit: contain;
	}

	.p-philo__row--img-left .p-philo__brush {
		inset: 0;
	}
}

@media screen and (max-width: 768px) {
	.p-philo__text {
		padding-bottom: 96px;
	}

	.p-philo__lead {
		font-size: 20px;
	}

	.p-philo__lead br {
		display: none;
	}
}

.p-recruit {
	display: grid;
	gap: 64px;
	padding: 80px 20px;
	background: radial-gradient(1px 1px at 40px 60px, var(--color-noise) 1px, transparent 1px), radial-gradient(1px 1px at 120px 140px, var(--color-noise) 1px, transparent 1px), #fff;
	background-size: 160px 160px, 160px 160px, auto;
}

.p-job {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

.p-job__hero {
	background: linear-gradient(180deg, #FFA573 0%, var(--color-orange) 60%);
	border-radius: 12px;
	box-shadow: 0 18px 40px rgb(240 100 35 / 25%);
	color: #fff;
}

.p-job__heroInner {
	display: flex;
	align-items: flex-end;
	gap: 24px;
	padding: clamp(24px, 5vw, 40px);
}

.p-job__lead {
	flex: 1 1 auto;
}

.p-job__illust {
	flex: 0 0 240px;
	margin: 0;
	text-align: right;
}

.p-job__illust img {
	max-width: 140px;
	width: 100%;
	height: auto;
}

.p-job__eyebrow {
	margin: 0 0 6px;
	font-size: 12px;
	letter-spacing: 0.28em;
	opacity: 0.9;
}

.p-job__title {
	margin: 0 0 6px;
	font-weight: 900;
	letter-spacing: 0.02em;
	font-size: clamp(28px, 4.2vw, 40px);
}

.p-job__copy {
	margin: 8px 0 16px;
	font-size: 18px;
	font-weight: 700;
	text-shadow: 1px 0 var(--color-orange), -1px 0 var(--color-orange), 0 1px var(--color-orange), 0 -1px var(--color-orange), 1px 1px var(--color-orange), -1px -1px var(--color-orange), 1px -1px var(--color-orange), -1px 1px var(--color-orange);
}

.p-job__ctaWrap {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

a.p-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 18px;
	border-radius: 999px;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-decoration: none;
	transition: transform 0.12s ease, box-shadow 0.12s ease;
}

a.p-btn--solid {
	background-color: #fff;
	color: var(--color-orange);
	box-shadow: 0 6px 18px rgb(255 255 255 / 25%);
}

@media (any-hover: hover) {
	a.p-btn--solid:hover {
		transform: translateY(-1px);
	}
}

.p-spec {
	overflow: hidden;
	margin-top: 16px;
	background-color: #fff;
	box-shadow: 0 10px 28px rgb(0 0 0 / 6%);
	border: 1px solid var(--color-border);
	border-radius: 12px;
}

.p-spec__hd {
	margin: 0;
	padding: 18px 22px;
	font-weight: 800;
	letter-spacing: 0.04em;
	border-left: 8px solid var(--color-orange);
	background: linear-gradient(90deg, rgb(240 100 35 / 8%), transparent);
}

.p-spec__table {
	margin: 0;
	padding: 8px 0 16px;
}

.p-spec__row {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 20px;
	padding: 18px 22px;
	border-top: 1px solid var(--color-border);
}

.p-spec__row:first-of-type {
	border-top: none;
}

.p-spec__row dt {
	color: var(--color-muted);
	font-weight: 700;
}

.p-spec__row dd {
	margin: 0;
	line-height: 1.9;
}

@media screen and (max-width: 768px) {
	.p-job__hero {
		position: relative;
		overflow: hidden;
	}

	.p-job__heroInner {
		padding: 28px 20px 32px;
		flex-direction: column;
		align-items: flex-start;
	}

	.p-job__lead {
		position: relative;
		z-index: 2;
	}

	.p-job__illust {
		position: absolute;
		top: 8px;
		right: 8px;
		flex: none;
		width: 120px;
		margin: 0;
		opacity: 0.8;
		pointer-events: none;
		z-index: 1;
	}

	.p-job__illust img {
		width: 100%;
		height: auto;
		max-width: none;
	}

	.p-spec__row {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.p-spec__row dt,
	.p-spec__row dd {
		font-size: 14px;
		line-height: 1.6;
	}

	.p-spec__hd {
		font-size: 15px;
	}
}