/*
Theme Name: クレア歯科クリニック 求人採用サイト
Author: 9Design
Author URI: https://9design.jp/
Description: 採用パッケージテーマ7
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSEbout
Text Domain: 採用パッケージ7
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Header
# Footer
# Navigation
## Links
## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
## Posts and pages
## トップページ
## インタビュー詳細
## 募集要項詳細
## サイドバー
## アーカイブ（お知らせ）
## お知らせ詳細
## 固定ページ
## よくある質問
## 99の質問
## オンライン面談
## マッチング率
## 404ページ
## 検索結果
## Comments
# Infinite scroll
# Media
## Captions
## Galleries
# Break Point
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
* {
	margin: 0;
	padding: 0;
}

html {
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}

body {
	margin: 0;
}

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

audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: employment2line;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

[hidden],
template {
	display: none;
}

a {
	background-color: transparent;
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
}

a:active,
a:hover {
	outline: 0;
}

abbr[title] {
	border-bottom: 1px dotted;
}

b,
strong {
	font-weight: bold;
}

dfn {
	font-style: italic;
}

mark {
	background: linear-gradient(transparent 64%, #ACEBF3 0%);
	font-weight: bold;
	color: inherit;
}

small {
	font-size: 75%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: employment2line;
}

sup {
	top: -0.5em;
}

sub {
	bottom: -0.25em;
}

svg:not(:root) {
	overflow: hidden;
}

figure {
	padding: 0;
	margin: 0;
}

hr {
	box-sizing: content-box;
	height: 0;
}

pre {
	overflow: auto;
}

code,
kbd,
pre,
samp {
	font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
	color: inherit;
	font: inherit;
	margin: 0;
}

button {
	overflow: visible;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

button,
select {
	text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}

button[disabled],
html input[disabled] {
	cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

input {
	line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 0.125rem;
	padding: 0.35em 0.625em 0.75em;
}

legend {
	border: 0;
	padding: 0;
}

textarea {
	overflow: auto;
}

optgroup {
	font-weight: bold;
}

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

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
html {
	font-size: 1rem;
}

body,
button,
input,
select,
textarea {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	color: var(--color-text);
	letter-spacing: 0.05em;
}

h1,
h2,
h3,
h4,
h5,
.zenmaru {
	color: var(--color-main);
	font-weight: 700;
	line-height: 1.8;
	letter-spacing: 0.15em;
}

h1 {
	font-size: clamp(1.5rem, 1.159rem + 1.455vw, 2.25rem);
}

h2 {
	font-size: clamp(1.25rem, 0.795rem + 1.939vw, 2.25rem);
}

h3 {
	font-size: clamp(1.125rem, 0.955rem + 0.727vw, 1.5rem);
}

h4 {
	font-size: 1.5rem;
	font-size: 1.5rem;
}

h5 {
	font-size: 1rem;
	font-size: 1rem;
}

p {
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	line-height: 2;
	/* margin: 1em 0 1.5em 0; */
}

td,
th {
	/* font-size: clamp(0.85rem, 0.521rem + 0.64vw, 1rem); */
	padding: 1.5em;
	line-height: 2;
}

ul,
li {
	line-height: 2;
}

dt {
	font-weight: bold;
}

dd {
	line-height: 1.75em;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-size: 0.9375rem;
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-size: 0.9375rem;
	font-size: 0.9375rem;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	text-decoration: none;
}

big {
	font-size: 125%;
}

td a,
th a {
	font-size: clamp(0.875rem, 0.821rem + 0.24vw, 1rem);
	line-height: 2;
}

@media screen and (max-width: 824px) {
	p>a {
		background-color: transparent;
		font-size: 0.875rem;
	}
}

/*--------------------------------------------------------------
color（色）
--------------------------------------------------------------*/
:root {
	--color-base: #fff;
	--color-main: #00C3DB;
	--color-accent: #FFDA54;
	--color-text: #51514B;

	--pink: #CF2E92;
	--blue: #005884;
	--beige: #F7F5E6;
	--dark-beige: #EEECDB;
	--white: #fff;
	--base-pink: #F8F3F0;
	--base-thin-pink: #F0E5DF;
	--dark-pink: #D88A61;
	--yellow: #FFDEA7;
	--green: #9BBE4E;
	--dark-green: #81B968;
	--dark-blue: #5FB1B9;
	--dark-brown: #55351C;
	--txt-dark-brown: #654226;
	--thin-brown01: #8A716A;
	--thin-brown02: #9A8C82;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
	box-sizing: border-box;
	/* overflow-x: hidden; */
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

body {
	background: var(--color-base);
	overflow-x: hidden;
}

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

blockquote,
q {
	quotes: "" "";
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0;
	padding: 0;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li,
ul.row,
ol.row {
	list-style: none;
}

li>ul,
li>ol {
	margin-bottom: 0;
}

dd {
	margin: 0 0 1.5em 0;
}

img {
	border: 0;
	height: auto;
	max-width: 100%;
	vertical-align: bottom;
	transition: 0.3s;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

a {
	color: var(--color-main);
}

em {
	font-style: normal;
}

figcaption {
	font-weight: bold;
	color: var(--thin-brown01);
	font-size: clamp(0.75rem, 0.707rem + 0.19vw, 0.85rem);
	margin-top: 0.25rem;
}


/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
input[type="button"],
input[type="reset"],
input[type="submit"] {
	display: block;
	color: #fff;
	border-radius: 0.3125rem;
	/* box-shadow: 0 0.1875rem 0.1875rem rgba(0, 0, 0, 0.16); */
	transition: all 0.3s ease-in-out;
}

input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background: #fff;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	border-color: rgba(52, 52, 52, 0.15);
	border-radius: 0.1875rem;
	background: #fff;
	padding: 0.1875rem;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="tel"] {
	max-width: 31.25rem;
	width: 100%;
	height: 3.125rem;
}

select {
	border: 1px solid #ccc;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

textarea {
	width: 100%;
	line-height: 1.3;
}

/*--------------------------------------------------------------
# animation
--------------------------------------------------------------*/
.inview {
	transform: translateY(0.625rem);
	opacity: 0;
	transition: transform 1s, opacity 1s;
}

.inview.show {
	transform: translateY(0);
	opacity: 1;
}

@media screen and (max-width: 824px) {

	.archive .inview,
	.single-recruit .inview {
		transform: translateY(0);
		opacity: 1;
	}
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
	word-wrap: normal !important;
	/* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 0.1875rem;
	box-shadow: 0 0 0.125rem 0.125rem rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 0.3125rem;
	line-height: normal;
	padding: 0.9375rem 1.4375rem 0.875rem;
	text-decoration: none;
	top: 0.3125rem;
	width: auto;
	z-index: 100000;
}

#content[tabindex="-1"]:focus {
	outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {
	display: inline;
	float: left;
	margin-right: 1.5em;
}

.alignright {
	display: inline;
	float: right;
	margin-left: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
	content: "";
	display: table;
	table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
	clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
	margin: 0 0 1.875rem;
}

.widget_archive h2,
.widget_recent_entries h2 {
	margin-bottom: 0.3125rem;
}

.widget select {
	max-width: 100%;
	margin: 0.9375rem 2.1875rem;
	font-size: 1rem;
}

.widget ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.widget li {
	padding: 0.625rem 0 0.4375rem 0;
	line-height: 1.3;
	border-bottom: dotted 1px rgba(52, 52, 52, 0.15);
}

.widget li:last-child {
	border-bottom: none;
}

/* カテゴリー */
.widget li.cat-item {
	border: 0.0938rem solid;
	padding: 0.625rem;
	text-align: center;
	margin-bottom: 0.625rem;
}

.widget li.cat-item a {
	color: #343434;
}

/* アーカイブ */
.widget_archive li::before {
	font-family: "Font Awesome 5 Free";
	content: "\f152";
	font-weight: bold;
	transform: translateY(-50%);
	margin-right: 0.5rem;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
#page.site {
	overflow-x: clip;
}

.sticky {
	display: block;
}

.hentry {
	margin: 0 0 1.5em;
}

.byline,
.updated:not(.published) {
	display: none;
}

.single .byline,
.group-blog .byline {
	display: inline;
}

.page-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.entry-content {
	margin: 4rem 0 0 0;
	padding: 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

.site-content {
	margin: 0;
}

/*row共通クラス*/
.row {
	display: flex;
}

.row.repeat-grow1-1>*,
.row.repeat-grow1-1>* {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-2>*:nth-of-type(1) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-2>*:nth-of-type(2) {
	flex: 2;
	width: 100%;
}

.row.repeat-grow2-1>*:nth-of-type(1) {
	flex: 2;
	width: 100%;
}

.row.repeat-grow2-1>*:nth-of-type(2) {
	flex: 1;
	width: 100%;
}

/**/
.row.repeat-grow1-3>*:nth-of-type(1) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-3>*:nth-of-type(2) {
	flex: 3;
	width: 100%;
}

.row.repeat-grow3-1>*:nth-of-type(1) {
	flex: 3;
	width: 100%;
}

.row.repeat-grow3-1>*:nth-of-type(2) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow4-1>*:nth-of-type(1) {
	flex: 4;
	width: 100%;
}

.row.repeat-grow4-1>*:nth-of-type(2) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-4>*:nth-of-type(1) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-4>*:nth-of-type(2) {
	flex: 4;
	width: 100%;
}

.row.repeat-grow1-5>*:nth-of-type(1) {
	flex: 1;
	width: 100%;
}

.row.repeat-grow1-5>*:nth-of-type(2) {
	flex: 5;
	width: 100%;
}

@media screen and (max-width: 824px) {
	.row {
		flex-direction: column;
	}

	.row.repeat-grow1-2>*:nth-of-type(1),
	.row.repeat-grow1-2>*:nth-of-type(2),
	.row.repeat-grow2-1>*:nth-of-type(1),
	.row.repeat-grow2-1>*:nth-of-type(2),
	.row.repeat-grow1-3>*:nth-of-type(1),
	.row.repeat-grow1-3>*:nth-of-type(2),
	.row.repeat-grow3-1>*:nth-of-type(1),
	.row.repeat-grow3-1>*:nth-of-type(2),
	.row.repeat-grow1-4>*:nth-of-type(1),
	.row.repeat-grow1-4>*:nth-of-type(2),
	.row.repeat-grow4-1>*:nth-of-type(1),
	.row.repeat-grow4-1>*:nth-of-type(2),
	.row.repeat-grow1-5>*:nth-of-type(1),
	.row.repeat-grow1-5>*:nth-of-type(2) {
		flex: 1;
		display: block;
	}
}

.page .repeat-grow1-1,
.page .repeat-grow2-1 {
	gap: 2.5rem 3rem;
}

.page .repeat-grow1-1:not(:last-of-type) {
	margin-bottom: 2.5rem;
}

.main-wrapper {
	max-width: 75rem;
	width: 90%;
	margin: 0 auto;
}

.main-wrapper__narrow {
	max-width: 62.5rem;
	width: 90%;
	margin: 0 auto;
}

@media screen and (max-width: 824px) {

	.main-wrapper,
	.main-wrapper__narrow {
		width: 90%;
	}
}

.ibl {
	display: inline-block;
	vertical-align: middle;
}

.tcenter {
	text-align: center;
}

.tright {
	text-align: right;
}

.tleft {
	text-align: left;
}

.nowrap {
	white-space: nowrap;
}

.img-caption {
	margin-top: 0.625rem;
	font-weight: bold;
}

.btn {
	margin-top: 5rem;
	display: flex;
	justify-content: center;
	gap: 1.25rem;
	align-items: center;
}

@media screen and (max-width: 824px) {
	.btn {
		flex-direction: column;
		margin-top: 2.5rem;
	}
}

.btn a {
	color: var(--blue);
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	text-align: center;
	border-radius: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22.5rem;
	max-width: 100%;
	height: 5rem;
	position: relative;
	transition: 0.3s;
	filter: drop-shadow(0 0.625rem 1.875rem rgba(0, 0, 0, 0.1));
}

@media screen and (max-width:824px) {
	.btn a {
		max-width: 90%;
		height: 3.75rem;
		filter: drop-shadow(0 0.1875rem 0.3125rem rgba(0, 0, 0, 0.1));

	}
}

.btn a:before {
	content: '';
	margin-block: auto;
	position: absolute;
	inset: 0 auto 0 1.25rem;
	width: auto;
	height: 0.75rem;
	aspect-ratio: 1;
	transition: 0.3s;
}

.btn.more-btn a {
	background: var(--color-accent);
}

.btn.more-btn a:before {
	mask: url(./images/common/arrow_w_r.svg) no-repeat center / contain;
	background-color: var(--blue);
}

.btn.more-btn a:hover::before {
	transform: translateX(0.1875rem);
}

.btn.more-btn.-s a {
	height: 3.75rem;
	padding-inline: 2.5rem 1.25rem;
	min-width: 15rem;
	width: fit-content;
}

.btn.instagram-btn a {
	background: var(--pink);
	color: #fff;
}

.btn.instagram-btn a:before {
	background: url(./images/common/ico_instagram.svg) no-repeat center / contain;
	aspect-ratio: 1;
	height: 1.25rem;
}

.btn.instagram-btn a:hover::before {
	transform: translateX(0.1875rem);
}

.btn-wrapper.row {
	gap: 1rem 1.5rem;
	margin-top: 2rem;
}

.btn-wrapper.row>.btn {
	margin: 0;
}

.breadcrumb-list {
	position: relative;
	z-index: 1;
}

.breadcrumb-list,
.breadcrumb-list a {
	padding: 0.9375rem 0 1.875rem;
	font-size: 0.75rem;
}

.breadcrumb-list .sep {
	margin: 0 0.5rem;
	opacity: 0.5;
}

@media screen and (max-width: 510px) {
	.breadcrumb-list {
		line-height: 1.6;
	}
}

.p-directorbox {
	background: url(./images/common/director_box_bg.webp) no-repeat top center / 100% 100%;
	display: flex;
	gap: 4.17%;
	margin-block-start: 5rem;
	padding: 2.5rem 6.25rem;
}

@media (max-width: 824px) {
	.p-directorbox {
		background-image: url(./images/common/director_box_bg_sp.webp);
		flex-direction: column;
		margin-block-start: 2.5rem;
		padding: 0 2.5rem 3.75rem 2.5rem;
	}
}

@media (min-width: 825px) {
	.p-directorbox .c-headtxt_round {
		align-items: flex-start;
	}
}

.p-directorbox__img {
	flex-shrink: 0;
}

.p-directorbox__img img {
	aspect-ratio: 295/433;
	width: 18.4375rem;
	height: auto;
	margin-block-start: -1.25rem;
}

@media (max-width: 824px) {
	.p-directorbox__img {
		text-align: center;
		margin-block-end: 0.625rem;
	}

	.p-directorbox__img img {
		border-radius: 0 0 100vw 100vw;
		width: 8.125rem;
		height: 6.25rem;
		object-fit: cover;
		object-position: top;
		margin-block-start: 0;
	}
}

.p-directorbox__txt {
	flex: 1;
	padding: 4.0625rem 0;
}

@media (max-width: 824px) {
	.p-directorbox__txt {
		padding: 0;
	}
}

@media (max-width: 824px) {
	.p-directorbox__head {
		text-align: center;
	}
}


.p-hukidashi {
	display: flex;
	align-items: flex-start;
	gap: 3.75rem;
	margin-block-start: 6.25rem;
	max-width: 100%;
	position: relative;
}

@media (max-width: 824px) {
	.p-hukidashi {
		flex-direction: column;
		align-items: center;
		gap: 0.625rem;
		margin-block-start: 3.75rem;
	}
}

.p-hukidashi::before {
	content: "";
	background: url(./images/common/leaf_01.webp) no-repeat center / contain;
	aspect-ratio: 311 / 310;
	width: 14.0625rem;
	max-width: 32%;
	height: auto;
	position: absolute;
	inset: -7.125rem -7.125rem auto auto;
	z-index: -1;
	scale: -1 1;
}

@media (max-width: 824px) {
	.p-hukidashi::before {
		inset: -3.75rem -2.5rem auto auto;
		width: 8.75rem;
	}
}

.p-hukidashi__img {
	flex-shrink: 0;
}

@media (max-width: 824px) {
	.p-hukidashi__img {
		margin-inline: auto;
		position: absolute;
		inset: -1.875rem 0 auto;
		z-index: 1;
		width: fit-content;
	}
}

.p-hukidashi__img img {
	aspect-ratio: 1;
	width: 9.375rem;
	height: auto;
}

@media (max-width: 824px) {
	.p-hukidashi__img img {
		width: 5rem;
	}
}

.p-hukidashi__txt {
	flex: 1;
	background-color: #fff;
	border-radius: 1.25rem;
	display: flex;
	justify-content: center;
	flex-direction: column;
	padding: 3.75rem;
	position: relative;
	z-index: 0;
}

.p-hukidashi.-beige .p-hukidashi__txt,
.p-hukidashi.-beige .p-hukidashi__txt::before {
	background-color: var(--beige);
}

@media (max-width: 824px) {
	.p-hukidashi__txt {
		padding: 3.75rem 1.25rem 1.875rem;
		width: 100%;
		align-items: center;
		gap: 1.25rem;
	}
}

.p-hukidashi__txt::before {
	content: "";
	background-color: #fff;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	width: auto;
	height: 2.5rem;
	aspect-ratio: 32/40;
	position: absolute;
	inset: 3.125rem 100% auto auto;
}

@media (max-width: 824px) {
	.p-hukidashi__txt::before {
		display: none;
	}
}

.p-hukidashi__txt::after {
	content: "Staff Voice";
	color: #fff;
	font-size: 5rem;
	font-family: "Damion", cursive;
	font-weight: 400;
	line-height: 1;
	position: absolute;
	inset: auto 1.875rem -0.2em auto;
	z-index: -1;
}

@media (max-width: 824px) {
	.p-hukidashi__txt::after {
		font-size: 2.5rem;
	}
}

.p-hukidashi__head {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	font-weight: 700;
	padding: 0.3125rem 1.5625rem;
	line-height: 1.6;
	text-align: center;
	width: fit-content;
	position: absolute;
	inset: -1em auto auto 3.75rem;
}

@media (max-width: 824px) {
	.p-hukidashi__head {
		padding: 0.3125rem 0.9375rem;
		position: static;
	}
}

.p-hukidashi__ttl {
	color: var(--blue);
	font-weight: 900;
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	margin-block-end: 1.25rem;
	line-height: 1.7;
	letter-spacing: 0.1em;
}

@media (max-width: 824px) {
	.p-hukidashi__ttl {
		text-align: center;
		margin-block-end: 0;
	}
}

.u-color_accent {
	color: var(--color-accent);
}

.u-color_main {
	color: var(--color-main);
}

.u-color_blue {
	color: var(--blue);
}

.u-color_white {
	color: var(--white);
}

.u-fz_12 {
	font-size: 0.75rem;
}

.u-fw_blod {
	font-weight: 700;
}

.u-td_underline {
	text-decoration-color: var(--color-main);
	text-decoration-line: underline;
	text-decoration-thickness: 0.125rem;
	text-underline-offset: 0.6em;
	line-height: 2.2;
}

.u-radius_40 {
	border-radius: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}


.u-mt0 {
	margin-block-start: 0 !important;
}

.u-mt20 {
	margin-block-start: 1.25rem !important;
}

.u-mt160 {
	margin-block-start: 10rem !important;
}

.u-pt0 {
	padding-block-start: 0 !important;
}

.u-pb0 {
	padding-block-end: 0 !important;
}


.c-ttl__primary {
	display: flex;
	gap: 2.1875rem;
	flex-direction: column;
	align-items: center;
	margin-block-end: clamp(2.5rem, 1.932rem + 2.424vw, 3.75rem);
}

@media (max-width: 824px) {
	.c-ttl__primary {
		gap: 0.9375rem;
	}
}

.c-ttl__primary h2 {
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: clamp(2.5rem, 0.227rem + 9.697vw, 7.5rem);
	letter-spacing: 0;
	line-height: 0.9;
	color: #fff;
	text-shadow:
		1px 1px 0 var(--color-main),
		-1px 1px 0 var(--color-main),
		1px -1px 0 var(--color-main),
		-1px -1px 0 var(--color-main),
		1px 0 0 var(--color-main),
		0 1px 0 var(--color-main),
		-1px 0 0 var(--color-main),
		0 -1px 0 var(--color-main),
		0.25rem 0.25rem 0 var(--color-main);
	;
	transform: rotate(-10deg);
}

@media (max-width: 824px) {
	.c-ttl__primary h2 {
		text-shadow:
			1px 1px 0 var(--color-main),
			-1px 1px 0 var(--color-main),
			1px -1px 0 var(--color-main),
			-1px -1px 0 var(--color-main),
			1px 0 0 var(--color-main),
			0 1px 0 var(--color-main),
			-1px 0 0 var(--color-main),
			0 -1px 0 var(--color-main),
			0.125rem 0.125rem 0 var(--color-main);
		;
	}
}

.c-ttl__primary .sbttl {
	font-weight: 900;
	font-size: clamp(1rem, 0.545rem + 1.939vw, 2rem);
	line-height: 1.7;
	color: var(--color-main);
	position: relative;
	z-index: 0;
}

.c-ttl__primary .sbttl::before {
	content: "";
	background: url(./images/common/ttl_line.svg) no-repeat center / contain;
	aspect-ratio: 66/38;
	width: fit-content;
	height: 2.375rem;
	margin-inline: auto;
	position: absolute;
	inset: -2rem 0 auto;
}

@media (max-width: 824px) {
	.c-ttl__primary .sbttl::before {
		height: 1.25rem;
		inset: -1rem 0 auto;
	}
}

@media (min-width: 827px) {
	.c-ttl__primary.-left {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
		margin-block-end: clamp(2.5rem, 1.932rem + 2.424vw, 3.75rem);
	}

	.c-ttl__primary.-left h2 {
		font-family: "Damion", cursive;
		font-weight: 400;
		font-size: clamp(2.5rem, 0.227rem + 9.697vw, 7.5rem);
		letter-spacing: 0;
		line-height: 0.9;
		color: #fff;
		text-shadow:
			1px 1px 0 var(--color-main),
			-1px 1px 0 var(--color-main),
			1px -1px 0 var(--color-main),
			-1px -1px 0 var(--color-main),
			1px 0 0 var(--color-main),
			0 1px 0 var(--color-main),
			-1px 0 0 var(--color-main),
			0 -1px 0 var(--color-main),
			0.25rem 0.25rem 0 var(--color-main);
		;
		transform: rotate(-10deg);
	}

	.c-ttl__primary.-left .sbttl {
		font-weight: 900;
		font-size: clamp(1rem, 0.545rem + 1.939vw, 2rem);
		line-height: 1.7;
		color: var(--color-main);
		margin-inline-start: 6em;
		position: relative;
		z-index: 0;
	}

	.c-ttl__primary.-left .sbttl::before {
		content: "";
		background: url(./images/common/ttl_line.svg) no-repeat center / contain;
		aspect-ratio: 66/38;
		width: fit-content;
		height: 2.375rem;
		position: absolute;
		inset: 0 calc(100% + 0.375rem) auto auto;
	}
}

.c-headtxt_normal {
	color: var(--blue);
	font-size: clamp(1rem, 0.545rem + 1.939vw, 2rem);
	font-weight: 900;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-block-end: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.c-headtxt_normal_s {
	color: var(--blue);
	font-size: clamp(1rem, 0.659rem + 1.455vw, 1.75rem);
	font-weight: 900;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-block-end: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.c-headtxt_normal_ss {
	color: var(--blue);
	font-size: clamp(1rem, 0.830rem + 0.727vw, 1.375rem);
	font-weight: 900;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-block-end: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.c-headtxt_normal_sss {
	color: var(--blue);
	font-size: clamp(1rem, 0.886rem + 0.485vw, 1.25rem);
	font-weight: 900;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-block-end: 1.25rem;
}

.c-headtxt_obi {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	font-weight: 700;
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	text-align: center;
	line-height: 1.6;
	margin: 0 auto 3.125rem;
	padding: 0.625rem;
	position: relative;
	width: 30rem;
	max-width: 100%;
}

@media (max-width: 824px) {
	.c-headtxt_obi {
		margin-block-end: 1.875rem;
	}
}

.c-headtxt_obi::before {
	content: "";
	border: 1px solid #fff;
	border-radius: 100vw;
	position: absolute;
	inset: 0.1875rem;
}

.c-headtxt_obi.-blue {
	background-color: var(--blue);
}

.c-headtxt_line {
	color: var(--blue);
	font-size: clamp(1rem, 0.830rem + 0.727vw, 1.375rem);
	font-weight: 900;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-block-end: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
	border-block-end: 1px solid var(--blue);
	margin-block-end: clamp(1.875rem, 1.023rem + 3.636vw, 3.75rem);
	padding-block-end: 0.75rem;
}

.c-headtxt_accent {
	color: var(--color-accent);
	font-size: clamp(1rem, 0.886rem + 0.485vw, 1.25rem);
}

.c-headtxt_underline {
	color: var(--color-main);
	font-weight: 700;
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	letter-spacing: 0.15em;
	line-height: 2.5;
	margin-block-end: clamp(1.875rem, 1.023rem + 3.636vw, 3.75rem);
}

.c-headtxt_underline span.underline {
	text-decoration-color: var(--color-main);
	text-decoration-line: underline;
	text-decoration-thickness: 0.125rem;
	text-underline-offset: 0.6em;
}

.c-headtxt_round {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.625rem;
	margin-block-end: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.c-headtxt_round .mainttl {
	font-weight: 900;
	font-size: clamp(1.125rem, 0.841rem + 1.212vw, 1.75rem);
	line-height: 1.7;
	text-align: center;
	letter-spacing: 0.1em;
	color: var(--blue);
}

.c-headtxt_round .sbttl {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	font-weight: 700;
	padding: 0.3125rem 1.5625rem;
	line-height: 1.6;
	text-align: center;
}

.c-frame_bearch {
	background: url(./images/common/bg_leafshadow.webp) no-repeat top 1.25rem center / 100% var(--beige);
	position: relative;
	z-index: 0;
}

.c-frame_bearch::before {
	content: "";
	background: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 100%;
}

.c-frame_bearch_w {
	background-color: #fff;
	position: relative;
	z-index: 0;
}

.c-frame_bearch_w::before {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 100%;
}

.c-frame_watercolor {
	background: linear-gradient(180deg, #FFFFFF 0%, rgba(255, 255, 255, 0) 12.5rem), url(./images/common/bg_watercolor.webp) no-repeat top center / cover;
	position: relative;
	z-index: 0;
}

.c-frame_halftone {
	background: url(./images/common/halftone.svg) no-repeat left calc(50% + 37.5rem) top 8.4375rem, url(./images/common/halftone.svg) no-repeat left calc(50% - 37.5rem) top 30.8125rem;
}

@media (max-width: 824px) {
	.c-frame_halftone {
		background-position: right -5.625rem top 8.4375rem, left -5.625rem top 30.8125rem;
		background-size: 17.5rem;
	}
}

.c-frame_wood {
	background: url(./images/common/bg_wood.webp) repeat-y center top / 100%;
	border-block: 0.25rem solid #E4DEDC;
}

.c-txtlink {
	text-decoration: underline;
}

.c-txtlink:hover {
	text-decoration: none;
}

.c-list_disc li {
	padding-inline-start: 1.3em;
	position: relative;
}

.c-list_disc li:before {
	content: "●";
	color: var(--color-main);
	position: absolute;
	inset-inline-start: 0;
}

.c-list_number {
	counter-reset: list;
}

.c-list_number li {
	padding-inline-start: 1.7em;
	position: relative;
}

.c-list_number li:before {
	counter-increment: list;
	content: counter(list, decimal-leading-zero) ".";
	color: var(--color-main);
	font-weight: 700;
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	position: absolute;
	inset-inline-start: 0;
}

.c-list_number li+* {
	margin-block-start: 0.5rem;
}

@media (min-width: 825px) {
	.c-lead {
		text-align: center;
	}
}

.c-box_leaf {
	background: url(./images/common/bg_paint.webp) no-repeat center / cover;
	width: 62.5rem;
	max-width: 100%;
	margin: 9.375rem auto 0;
	padding: 0.625rem;
	position: relative;
	z-index: 0;
}

@media (max-width: 824px) {
	.c-box_leaf {
		margin-block-start: 5rem;
		padding: 0.3125rem;
	}
}

.c-box_leaf::before {
	content: "";
	background: url(./images/common/leaf_01.webp) no-repeat center / contain;
	aspect-ratio: 311/310;
	width: 19.4375rem;
	max-width: 32%;
	height: auto;
	position: absolute;
	inset: -8.625rem auto auto -15.6%;
	z-index: -1;
}

@media (max-width: 824px) {
	.c-box_leaf::before {
		inset-block-start: -4.375rem;
	}
}

.c-box_leaf::after {
	content: "";
	background: url(./images/common/leaf_02.webp) no-repeat center / contain;
	aspect-ratio: 274/251;
	width: 17.125rem;
	max-width: 28%;
	height: auto;
	position: absolute;
	inset: auto -9.8% -10.75rem auto;
	z-index: -1;
}

@media (max-width: 824px) {
	.c-box_leaf::after {
		inset-block-end: -3.75rem;
	}
}

.c-box_leaf__inner {
	background-color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 3.75rem 6%;
}

@media (max-width: 824px) {
	.c-box_leaf__inner {
		padding: 2.5rem 1.25rem;
	}
}

.l-section {
	padding-block: clamp(3.75rem, 0.909rem + 12.121vw, 10rem);
}

.l-row__txtimg {
	display: flex;
	gap: clamp(1.875rem, 0.455rem + 6.061vw, 5rem);
}

.l-row__txtimg>*:first-child {
	flex-shrink: 0;
	width: 50%;
}

.l-row__txtimg>*:nth-child(2) {
	flex: 1;
}

@media screen and (max-width: 824px) {
	.l-row__txtimg {
		flex-direction: column;
	}

	.l-row__txtimg>*:first-child {
		width: 100%;
	}

	.l-row__txtimg .img {
		max-width: 70%;
		margin-inline: auto;
	}
}

/*--------------------------------------------------------------
# 切り替え
--------------------------------------------------------------*/
.sp {
	display: none;
}

.tb {
	display: none;
}

.pc {
	display: block;
}

@media screen and (max-width: 824px) {
	.pc {
		display: none;
	}

	.sp {
		display: none;
	}

	.tb {
		display: block;
	}
}

@media screen and (max-width: 510px) {
	.tb {
		display: none;
	}

	.sp {
		display: block;
	}
}

/*--------------------------------------------------------------
## 共通パーツ
--------------------------------------------------------------*/
.headline .small-hl,
.headline-large .small-hl {
	color: var(--thin-brown01);
	font-size: clamp(1rem, -0.096rem + 2.13vw, 1.5rem);
	position: relative;
	display: block;
	margin-bottom: 0.5rem;
}

.radius-small {
	border-radius: clamp(0.625rem, -0.06rem + 1.33vw, 0.938rem);
}

.radius-midium {
	border-radius: clamp(1.25rem, -2.859rem + 7.98vw, 3.125rem);
}


/*サイト全体_独自の共通css*/
.img-cover {
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
}

.inner {
	margin-top: 3.5rem;
}

@media screen and (max-width: 824px) {
	.inner {
		margin-top: 2.5rem;
	}
}

.txt-pink {
	color: var(--dark-pink);
}

.nowrap {
	white-space: nowrap;
}

@media screen and (max-width: 824px) {
	.sp-order0 {
		order: 0;
	}

	.sp-order1 {
		order: 1;
	}
}

a.wrap-link {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
.site-header {
	position: relative;
}

@media screen and (max-width: 824px) {
	.site-header {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
}

@media screen and (max-width: 510px) {
	.site-header {
		position: sticky;
		top: 0;
		background: #fff;
		z-index: 3;
		width: 100%;
		animation: none;
	}
}

.site-branding {
	margin-inline-end: -1.25rem;
	width: clamp(11.25rem, 8.750rem + 10.667vw, 16.75rem);
	z-index: 1;
}

@media screen and (max-width: 824px) {
	.site-branding {
		width: 10.625rem;
	}
}

@media screen and (max-width: 510px) {
	.site-branding {
		width: 9.375rem;
	}
}

.site-branding a {
	background: #fff;
	border-radius: 0 0 2.5rem 0;
	display: block;
	padding: 0.9375rem 1.25rem;
}

@media screen and (max-width: 824px) {
	.site-branding a {
		padding: 0.625rem 1.25rem;
	}
}

.site-branding_txt {
	position: absolute;
	width: 1px; height: 1px;
	margin: -1px; padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.site-title {
	margin: 0;
}

.site-title a:hover {
	opacity: 1;
}

.site-title a:hover img {
	opacity: 0.7;
}

.hd-top-wrapper.row {
	justify-content: space-between;
	align-items: center;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 998;
}

@media screen and (max-width: 824px) {
	.hd-top-wrapper.row {
		align-items: flex-start;
	}
}

.hd-right {
	height: 6.25rem;
	display: flex;
	justify-content: flex-end;
	flex: 1;
	margin-inline-end: 1.25rem;
	padding-inline-end: 1.25rem;
	position: relative;
}

@media screen and (max-width: 1170px) {
	.hd-right {
		height: 4.0625rem;
		width: 4.0625rem;
		padding: 0 !important;
		margin: 0;
		position: absolute;
		inset: 0.625rem 0.625rem auto auto;
	}
}

/* @media screen and (max-width: 1199px) {
	.hd-right {
		display: none;
	}
} */

.hd-right::before {
	content: "";
	background: rgba(13, 68, 75, 0.4);
	backdrop-filter: blur(0.3125rem);
	border-radius: 0 100vw 100vw 0;
	position: absolute;
	inset: 0;
}

@media screen and (max-width: 1170px) {
	.hd-right::before {
		border-radius: 100%;
	}
}

.hd-right ul {
	list-style: none;
	font-size: 0.85714rem;
}

@media screen and (max-width: 1170px) {
	.hd-right ul .gnavi__list {
		display: none;
	}
}

.hd-right-inner {
	justify-content: space-between;
}

.hd-button a {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.625rem;
	color: #fff;
	padding: 1rem 0;
	margin-left: 1.5rem;
	width: 16.25rem;
	border-radius: 100vh;
	text-align: center;
	position: relative;
	background: var(--color-main);
	line-height: 1.5;
}

@media screen and (max-width:1500px) {
	.hd-button a {
		padding: 1rem 1.5rem;
		margin-left: 1rem;
	}
}

.hd-button a:before {
	content: '';
	width: 1.25rem;
	height: auto;
	aspect-ratio: 1;
	transform: translateX(0);
	transition: 0.3s;
	background: url(./images/common/arrow_w_r.svg) no-repeat center / contain;
}

.hd-button a:hover::before {
	transform: translateX(0.1875rem);
}

.site-header.fixed {
	position: fixed;
	top: 0;
	z-index: 3;
	width: 100%;
	animation: hdfix 0.8s;
}

.site-header.fixed .site-title a {
	box-shadow: 0.125rem 0.125rem 0.75rem rgba(71, 22, 22, 0.05);
}

.site-header.fixed .hd-right {
	box-shadow: 0.125rem 0.125rem 0.75rem rgba(71, 22, 22, 0.05);
	border-radius: 100vh;
}

@keyframes hdfix {
	0% {
		opacity: 0;
		transform: translateY(-1.25rem);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

/* @media (min-width: 811px) {
	.site-header.fixed .site-branding img {
		scale: 0.8;
		transform-origin: top left;
	}
} */

/*固定エントリーボタン*/
.fixed-btn {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	position: fixed;
	top: 26%;
	right: 0 !important;
	z-index: 2;
}

/* @media (min-width: 1200px) {
	.fixed-btn {
		display: none;
	}
} */

@media (max-width: 824px) {
	.fixed-btn {
		flex-direction: row;
		gap: 0;
		width: 100%;
		position: fixed;
		top: inherit;
		bottom: 0;
	}
}

.fixed-btn a {
	color: var(--blue);
	background: var(--color-accent);
	padding: 1rem;
	display: flex;
	justify-content: center;
	align-items: center;
	writing-mode: vertical-rl;
	border-radius: 0.625rem 0 0 0.625rem;
}

.fixed-btn a:nth-child(2) {
	color: #fff;
	background: var(--color-main);
	padding: 1rem;
	display: flex;
	justify-content: center;
	align-items: center;
	writing-mode: vertical-rl;
	border-radius: 0.625rem 0 0 0.625rem;
}

@media (max-width: 824px) {
	.fixed-btn a {
		writing-mode: horizontal-tb !important;
		border-radius: 0 !important;
		width: 50%;
		height: 2.8125rem;
		padding: 0 !important;
	}
}

.fixed-btn a span {
	padding-top: 0.5rem;
}

@media (max-width: 824px) {
	.fixed-btn a span {
		padding: 0 0 0 0.5rem;
	}
}

/* 新卒バナー */
.fixed-btn-new-graduate {
	position: fixed;
	bottom: 4.6875rem;
	right: 0;
	z-index: 2;
	width: clamp(12.5rem, 10.227rem + 9.697vw, 17.5rem);
	/* 10.625rem - 21.25rem */
	height: auto;
	opacity: 0;
	display: none;
	transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
	display: block;
}

.fixed-btn-new-graduate.show {
	opacity: 1;
}

.new-graduate .fixed-btn-new-graduate {
	display: none;
}

#closeBanner {
	display: none;
}

#closeBanner:checked~.fixed-btn-new-graduate {
	transform: translateX(9.375rem);
	opacity: 0;
	pointer-events: none;
}

#closeBanner:checked~.close-btn-label {
	display: none;
}

.close-btn-label {
	padding: 0;
	width: 1.5625rem;
	height: auto;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	position: absolute;
	top: -2%;
	left: -2%;
	background: white;
	color: black;
	border: none;
	cursor: pointer;
	border-radius: 50%;
	font-size: 0.8125rem;
	font-weight: bold;
	text-align: center;
	z-index: 999;
	transition: background 0.3s;
	box-shadow: 0 0.125rem 0.5rem 0 rgba(0, 0, 0, 0.15);
}

.close-btn-label:hover {
	background: var(--color-main);
	color: white;
}

@media (max-width: 1200px) {
	body:not(.home) .fixed-btn-new-graduate {
		display: none;
	}
}

@media (max-width: 824px) {
	.fixed-btn-new-graduate {
		bottom: 6.875rem;
	}
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
/*footer_募集要項*/
.footer-recruit {
	background: url(./images/common/footer_bg.webp) no-repeat center / cover;
	padding-block: clamp(3.75rem, 3.182rem + 2.424vw, 5rem) clamp(5rem, 2.727rem + 9.697vw, 10rem);
}

.footer-recruit__txt {
	color: #fff;
	font-weight: 700;
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
}

.footer-recruit__ttl .sbttl {
	color: #fff;
}

.footer-recruit__ttl .sbttl::before {
	mask: url(./images/common/ttl_line.svg) no-repeat center / contain;
	background: #fff;
}

.footer-recruit__btn {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2.8125rem 2.5rem;
	margin-block-start: clamp(1.875rem, 1.023rem + 3.636vw, 3.75rem);
}

@media(max-width: 824px) {
	.footer-recruit__btn {
		gap: 1.875rem 0.625rem;
		margin-inline: auto;
	}
}

.footer-recruit__btn>a {
	background: url(./images/common/arrow_paint.webp) no-repeat right bottom / 3.75rem #fff;
	border-radius: 0.625rem 0.625rem 0 0.625rem;
	color: var(--blue);
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1.875rem 0.625rem 1.5625rem;
	position: relative;
	box-shadow: 0 0.625rem 1.875rem rgba(0, 0, 0, 0.1);
	width: calc(100% / 2 - 2.5rem / 2);
	max-width: 25rem;
}

@media(max-width: 824px) {

	.footer-recruit__btn>a {
		background-size: 1.875rem;
		padding: 1.25rem 0.625rem 0.9375rem;
		width: calc(100% / 2 - 0.625rem / 2);
	}

}

.footer-recruit__btn>a span.application {
	background: var(--color-accent);
	border-radius: 6.25rem;
	color: var(--blue);
	font-size: clamp(0.75rem, 0.693rem + 0.242vw, 0.875rem);
	font-weight: 700;
	text-align: center;
	line-height: 1;
	padding: 0.313rem 1.25rem;
	width: fit-content;
	margin-inline: auto;
	position: absolute;
	inset: auto 0 calc(100% - 1em);
}

.footer-recruit__btn>a.stopped {
	pointer-events: none;
}

.footer-recruit__btn>a.stopped span.application {
	background: #c10e58;
	border-radius: 6.25rem;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
	padding: 0.313rem 1.25rem;
	width: fit-content;
	margin-inline: auto;
	position: absolute;
	inset: auto 0 calc(100% - 1em);
}

.footer-recruit__btn>a span.status {
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	display: block;
	border-block-end: 1px solid var(--blue);
	margin-block-end: 0.625rem;
	padding-block-end: 0.625rem;
	width: fit-content;
}

/*footer_フッターメニュー*/
.f-menu-wrapper {
	background-image: none;
	padding: clamp(3.75rem, 2.045rem + 7.273vw, 7.5rem) 0;
}

@media screen and (max-width: 824px) {
	.f-menu-wrapper {
		display: none;
	}
}

.f-menu-wrapper .content {
	gap: 0 2.5rem !important;
	padding: 0 2rem;
}

.f-menu-wrapper .category {
	margin-bottom: 2rem;
}

@media screen and (max-width: 824px) {
	.f-menu-wrapper .category {
		margin-bottom: 1.5rem;
	}
}

.f-menu-wrapper .category>a {
	font-size: clamp(1rem, 0.914rem + 0.38vw, 1.2rem);
	font-weight: 700;
}

.f-menu-wrapper a {
	display: block;
	color: var(--blue);
	line-height: 2.2;
	font-size: clamp(0.85rem, 0.786rem + 0.29vw, 1rem);
	font-weight: 500;
}

/*最下部フッター*/
.footer-info {
	background-color: var(--dark-beige);
	padding-block-start: 6.25rem;
	position: relative;
}

@media (max-width: 824px) {
	.footer-info {
		padding-block-start: 2.5rem;
	}
}

.footer-info::before {
	content: "";
	mask: url(./images/common/frame_wave.webp) no-repeat center bottom / 100% 100%;
	background-color: var(--dark-beige);
	height: 1.125rem;
	position: absolute;
	scale: -1 1;
	inset: auto 0 100%;
}

.footer-info__container {
	justify-content: space-between;
}

@media screen and (max-width: 824px) {
	.footer-info__container {
		gap: 2.5rem;
	}
}

@media screen and (max-width: 824px) {
	.footer-info__left {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
}

.footer-info__left .site-title img {
	width: 24.75rem;
	aspect-ratio: 396 / 65;
}

@media screen and (max-width: 824px) {
	.footer-info__left .site-title img {
		width: 18.75rem;
	}

	.footer-info__left .site-title {
		text-align: center;
	}
}

@media (min-width: 825px) {
	.footer-info__right {
		width: 50%;
	}
}

.footer-info__address {
	margin-block-start: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.footer-info__btn {
	display: flex;
	gap: 0.625rem;
	margin-block-start: clamp(0.938rem, 0.511rem + 1.818vw, 1.875rem);
}

@media (max-width: 510px) {

	.footer-info__btn {
		flex-direction: column;
		align-items: center;
	}
}

.footer-info__btn .btn {
	margin-block-start: 0;
}

.footer-info__btn .btn a {
	height: 3.75rem;
	width: 15rem;
}

.footer-schedule {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 0.3125rem;
	overflow-x: auto;
	display: block;
}

.footer-schedule th,
.footer-schedule td {
	padding: 0.8125rem 1rem;
	text-align: center;
	font-size: clamp(0.85rem, 0.786rem + 0.29vw, 1rem);
	white-space: nowrap;
}

.footer-schedule th {
	background-color: var(--color-main);
	color: #fff;
	width: calc(100% / 8);
}

.footer-schedule td {
	background-color: #fff;
	color: var(--blue);
	border: 0;
}

.footer-schedule tr td:nth-of-type(1) {
	color: var(--color-text);
}

.footer-schedule tbody tr:nth-of-type(1) {
	border-bottom: solid 1px var(--blue);
}

.footer-schedule+p {
	font-size: 0.85rem;
}

.footer-schedule__triangle {
	font-size: 0.875rem;
	margin-block-start: 0.9375rem;
	line-height: 1.6;
}

.footer-schedule__attention {
	font-size: 0.875rem;
	color: #8b8a7d;
	margin-block-start: 0.3125rem;
	line-height: 1.6;
}

.pagetop-wrapper {
	position: fixed;
	right: 8%;
	bottom: 1.25rem;
	z-index: 2;
}

@media screen and (max-width: 824px) {
	.pagetop-wrapper {
		bottom: 3.75rem;
	}
}

@media screen and (max-width: 510px) {
	.pagetop-wrapper {
		right: 5%;
	}

	.single-recruit .pagetop-wrapper {
		bottom: 2.5rem;
	}
}

.pagetop-wrapper a {
	color: var(--color-main);
	font-weight: 400;
	font-size: 0.85rem;
}

.pagetop-wrapper img {
	width: 1.25rem;
	margin-bottom: 0.3125rem;
}

.copyright {
	background-color: #fff;
	padding: 1rem 0;
	margin: 7.5rem 0 0 0;
	font-size: 0.75rem;
	text-align: center;
	line-height: 1;
	position: relative;
	z-index: 0;
}

.copyright::before {
	content: "";
	background: url(./images/common/frame_wave.webp) no-repeat center bottom / 100% 100%;
	height: 1.125rem;
	position: absolute;
	inset: auto 0 100%;
}

@media screen and (max-width: 824px) {
	.copyright {
		margin: 5rem 0 3.5rem 0;
	}
}

@media screen and (max-width: 510px) {
	.copyright {
		position: relative;
		right: 0;
		bottom: 0;
		font-size: 0.6875rem;
		line-height: 1.6;
	}
}

/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
	text-decoration: none;
	transition: 0.3s;
}

@media (hover: hover) {

	a:hover,
	a:active {
		opacity: 0.7;
	}
}

a:hover,
a:active {
	outline: 0;
}

a img {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

a:hover img {
	opacity: 1;
}

@keyframes flash {
	0% {
		opacity: 0.5;
	}

	100% {
		opacity: 1;
	}
}

.expansion-thumb {
	overflow: hidden;
}

.expansion-thumb img {
	width: 100%;
	transition: all 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.expansion-thumb a:hover img {
	transform: scale3d(1.1, 1.1, 1);
	animation: none;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
header .drawer-nav .drawer-nav-list {
	display: flex;
	justify-content: center;
	gap: 2rem;
}

.gnavi__lists {
	display: flex;
}

.gnavi__list {
	position: relative;
}

.gnavi__lists>li:not([class]) {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.gnavi__list:hover a {
	color: var(--color-accent);
}

.gnavi__list>a {
	white-space: nowrap;
	color: #fff;
	padding: 0 1.5rem;
	display: flex;
	height: 100%;
	align-items: center;
}

@media screen and (max-width:1500px) {
	.gnavi__list>a {
		padding: 0 0.75rem;
	}
}

@media screen and (max-width:1300px) {
	.gnavi__list>a {
		font-size: 1rem;
	}
}

.gnavi__list>a:hover {
	opacity: 1;
}

.dropdown__lists {
	visibility: hidden;
	opacity: 0;
	transition: all .2s;
	position: absolute;
	top: calc(100% - 0.625rem);
	left: 0.375rem;
	display: flex;
	flex-direction: column;
	width: 16.25rem;
	padding: 0 1rem;
	margin-left: 0;
	background-color: var(--color-accent);
	border-radius: 0.625rem;
	box-shadow: 0.125rem 0.125rem 0.75rem rgba(71, 22, 22, 0.05);
}

.gnavi__list:hover .dropdown__lists,
.gnavi__list:focus .dropdown__lists {
	visibility: visible;
	opacity: 1;
	position: absolute;
	transition: all 0.3s ease-in-out;
}

.dropdown__list {
	transition: all .3s;
	position: relative;
}

.dropdown__list a {
	color: var(--blue) !important;
	height: 3.75rem;
	padding: 0 0.3125rem;
	position: relative;
	line-height: 1.4;
	padding-inline-end: 1.875rem;
}

.dropdown__list a::after {
	content: "";
	position: absolute;
	right: 0.3125rem;
	top: 50%;
	transform: translateY(-50%);
	background: url(./images/common/menu-yajirushi.svg) no-repeat center / contain;
	width: 0.3125rem;
	height: 0.625rem;
}

.dropdown__list:not(:first-child)::before {
	content: "";
	width: 100%;
	height: 1px;
	background-color: var(--blue);
	position: absolute;
	top: 0;
	left: 0;
}

.dropdown__list:hover {
	color: pink;
}

.dropdown__list a {
	display: flex;
	justify-content: left;
	align-items: center;
	text-decoration: none;
	position: relative;
}

.dropdown__list a::before {
	content: '';
	display: block;
	width: 0.375rem;
	height: 0.375rem;
	border-top: 0.125rem solid var(--blue);
	border-left: 0.125rem solid var(--blue);
	transform: rotate(135deg);
	position: absolute;
	right: 0.9375rem;
	top: calc(50% - 0.3125rem);
}

.sp-menu-wrapper.row {
	display: flex;
	align-items: center;
	justify-content: right;
}

.gm,
.sp-menu {
	display: none;
}

.menu-trigger {
	color: #fff;
	position: relative;
	z-index: 100001;
	width: 5rem;
	height: 5rem;
	padding: 0.75rem 1.125rem 0.9375rem 1.125rem;
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
}

@media screen and (max-width: 1170px) {
	.menu-trigger {
		width: 4.0625rem;
		height: 4.0625rem;
		padding: 0.5rem 0.875rem 0.9375rem 0.875rem;
	}
}

.menu-trigger span {
	display: block;
	font-size: 0.875rem;
	color: var(--color-accent);
	font-family: "Damion", cursive;
	font-weight: 400;
	width: 100%;
}

@media screen and (max-width: 1170px) {
	.menu-trigger span {
		margin: 0.5625rem 0 0;
		font-size: 0.75rem;
	}
}

.drawer-hamburger-icon {
	background: var(--color-accent);
	margin-top: 0;
	border-radius: 0.625rem;
	height: 0.1875rem;
	transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	content: "";
	display: block;
	position: relative;
	border-radius: 0.625rem;
	height: 0.1875rem;
	background: var(--color-accent);
	transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.drawer-hamburger-icon:before {
	top: -0.75rem;
}

.drawer-hamburger-icon:after {
	top: 0.5625rem;
}

.active .drawer-hamburger-icon {
	background: transparent;
}

.active .drawer-hamburger-icon::before {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 0;
}

.active .drawer-hamburger-icon::after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	top: -0.125rem;
}

.menu-trigger.active span {
	color: #fff;
}

.sp-navigation {
	padding: 0 0 0 1.5rem;
}

.sp-menu {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100vh;
	background: rgb(0 194 219 / 90%);
	backdrop-filter: blur(0.3125rem);
	list-style: none;
	z-index: 100000;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	text-align: left;
	z-index: 10;
}

.sp-menu-inner {
	display: flex;
}

.drawer-dropdown-menu {
	display: none;
	padding-left: 1.25rem;
	transition: max-height 0.3s ease-in-out;
}

.menu-toggle {
	display: none;
}

.menu-label {
	font-size: 1rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	font-weight: bold;
	position: relative;
}

.menu-label::after {
	content: '＋';
	margin-left: 0.5rem;
	font-size: 1.125rem;
	transition: transform 0.3s;
}

.menu-toggle:checked+.menu-label::after {
	content: '−';
}

.menu-toggle:checked+.menu-label+.drawer-dropdown-menu {
	display: block;
	margin: 0.5rem 0 0 0;
}

.sp-menu .sp-menu-list {
	width: 100%;
	height: 100vh;
	padding: 11rem 9rem 8rem 9rem;
	overscroll-behavior-y: contain;
	overflow-y: auto;
}

.sp-menu .sp-menu-list .row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 4rem;
}

@media screen and (max-width:900px) {
	.sp-menu .sp-menu-list {
		padding: 9rem 1.5rem 9rem 1.5rem;
	}

	.sp-menu .sp-menu-list .row {
		grid-template-columns: 1fr;
	}
}

@media screen and (max-width:510px) {
	.sp-menu .sp-menu-list {
		padding: 7rem 1.5rem 11rem 1.5rem;
	}
}

.sp-menu li.drawer-dropdown {
	color: #fff;
	padding: 0.5rem 1rem 1.5rem 1rem;
	margin-bottom: 1rem;
	border-bottom: solid 0.0312rem #fff;
}

@media screen and (max-width:824px) {
	.sp-menu li.drawer-dropdown {
		padding: 0.5rem 1rem 1rem 1rem;
		margin-bottom: 0.5rem;
	}
}

.sp-menu li.drawer-dropdown>a {
	color: #fff;
	display: block;
}

.sp-menu li.drawer-dropdown-small {
	padding: 0.5rem 1rem 1rem 1rem;
	border-bottom: solid 0.0312rem #fff;
	margin-bottom: 0.5rem;
}

.sp-menu li.drawer-dropdown-small a {
	color: #fff;
	font-size: 0.85rem;
	display: block;
}

.sp-menu li.drawer-dropdown li {
	padding: 0.5em 0;
}

.sp-menu li.drawer-dropdown li a {
	color: #fff;
	display: block;
}

.sp-menu__btn a:first-child {
	background: var(--blue);
	color: var(--color-accent);
}

.sp-menu__btn a:first-child:before {
	mask: url(./images/common/arrow_w_r.svg) no-repeat center / contain;
	background-color: var(--color-accent);
}

/*--------------------------------------------------------------
## トップページ
--------------------------------------------------------------*/
/*シェイプ表示アニメーション*/
@keyframes fadeIn {
	0% {
		opacity: 0;
		/* 初期状態: 完全に透明 */
	}

	100% {
		opacity: 1;
		/* 最終状態: 完全に表示 */
	}
}

/*メインビジュアル*/
.mv {
	background: url(./images/common/footer_bg.webp) no-repeat center / cover;
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 50rem;
	position: relative;
	z-index: 0;
}

@media (max-width: 824px) {
	.mv {
		height: auto;
	}
}

.mv::after {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
	z-index: -1;
}

.mv__inner {
	display: flex;
	gap: 4vw;
	justify-content: center;
	padding-block-start: 10rem;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 0;
}

@media (max-width: 824px) {
	.mv__inner {
		padding-block-start: 6rem;
		flex-direction: column;
		justify-content: normal;
	}
}

.mv__inner::before {
	content: "";
	background: url(./images/top/mv_leaf_01.webp) no-repeat top left / contain;
	width: 12.25rem;
	height: auto;
	aspect-ratio: 196 / 697;
	position: absolute;
	inset: 9.375rem auto auto 0;
}

@media (max-width: 824px) {
	.mv__inner::before {
		width: 4.375rem;
		inset-block-start: 11.25rem;
	}
}

.mv__inner::after {
	content: "";
	background: url(./images/top/mv_leaf_02.webp) no-repeat top right / contain;
	width: 18.3125rem;
	height: auto;
	aspect-ratio: 293 / 839;
	position: absolute;
	inset: 0.1875rem 0 auto auto;
}

@media (max-width: 824px) {
	.mv__inner::after {
		width: 6.25rem;
	}
}

.mv h1 img {
	aspect-ratio: 306/167;
	width: 38.25rem;
	height: auto;
}

@media (max-width: 824px) {
	.mv h1 img {
		max-width: 80%;
	}
}

.mv-img img {
	aspect-ratio: 276/622;
	width: 17.25rem;
	height: auto;
}

@media (max-width: 824px) {
	.mv-img {
		max-width: 60%;
	}

	.mv-img.-first {
		margin-inline-start: auto;
	}

	.mv-img.-second {
		margin-block-end: -1.875rem;
	}

	.mv-img img {
		aspect-ratio: 552/240;
		width: 34.5rem;
	}
}

.mv-catch {
	margin-block-start: 2.5rem;
}

@media (max-width: 824px) {
	.mv-catch {
		order: -1;
		margin-block-start: 0;
		margin-block-end: 1.25rem;
	}
}

.mv-catch h1 {
	text-align: center;
}

.mv-btn {
	margin-block-start: 2.5rem;
}

@media (max-width: 824px) {

	.mv-btn {
		margin-block-start: 1.25rem;
	}

	.mv-btn a {
		max-width: 12.5rem;
		font-size: 0.875rem;
		height: 3.125rem;
	}
}

/* top_共通パーツ */
.top-links {
	display: flex;
	gap: 2.1875rem;
	flex-direction: column;
}

@media (max-width:824px) {
	.top-links {
		gap: 1.25rem;
	}
}

.top-links a {
	background: url(./images/common/paint_btn_bg.webp) no-repeat center right / auto 100% #fff;
	border-radius: 6.25rem;
	color: var(--blue);
	font-size: clamp(0.875rem, 0.648rem + 0.97vw, 1.375rem);
	font-weight: 700;
	text-shadow: 0 0 0.625rem #FFFFFF, 0 0 0.625rem #FFFFFF, 0 0 0.625rem #FFFFFF, 0 0 0.625rem #FFFFFF, 0 0 0.625rem #FFFFFF, 0 0 1.25rem #FFFFFF;
	display: flex;
	align-items: center;
	padding: 0 2.5rem;
	height: 7.5rem;
	position: relative;
	line-height: 1.6;
	box-shadow: 0 0.625rem 1.875rem rgba(0, 0, 0, 0.1);
	max-width: 30rem;
	width: 100%;
}

.top-links a .label {
	background-color: var(--color-main);
	border-radius: 6.25rem;
	color: #fff;
	font-size: 0.875rem;
	line-height: 1.6;
	position: absolute;
	padding: 0.25rem 0.75rem;
	inset: -1rem auto auto 2.5rem;
	text-shadow: none;
}

@media (max-width:824px) {
	.top-links a {
		height: 4.375rem;
		padding: 0 1.25rem;
		line-height: 1.4;
	}

	.top-links a .label {
		font-size: 0.75rem;
		line-height: 1.4;
		padding: 0.25rem 0.5rem;
		inset: -0.9em auto auto 0;
		text-shadow: none;
		letter-spacing: 0;
	}
}

/*top_メッセージ*/
.top-message__content {
	gap: 6.67%;
}

@media (max-width: 824px) {
	.top-message__content {
		gap: 1.875rem;
		align-items: center;
	}
}

.top-message__column_left {
	display: flex;
	gap: 3.75rem;
	flex-direction: column;
	flex-shrink: 0;
	max-width: 34.375rem;
	width: 50%;
}

@media (min-width: 825px) {
	.top-message__column_left {
		order: -1;
	}
}

@media (max-width: 824px) {
	.top-message__column_left {
		justify-content: space-between;
		flex-direction: row;
		gap: 0;
		width: 100%;
		max-width: 100%;
	}
}

.top-message__column_left img {
	aspect-ratio: 480/341;
	height: auto;
}

.top-message__column_left img:first-child {
	max-width: 30rem;
}

.top-message__column_left img:nth-child(2) {
	max-width: 22.5rem;
	margin-inline-start: auto;
}

@media (max-width: 824px) {
	.top-message__column_left img {
		width: 49%;
	}
}

.top-message__column_right {
	flex: 1;
}

.top-message__btn {
	margin-block-start: 5rem;
}

@media (max-width:824px) {
	.top-message__btn {
		margin-block-start: 2.5rem;
		gap: 2.5rem;
	}
}

.top-message__btn a {
	background: url(./images/top/message_btn_bg.webp) no-repeat center / cover;
	border-radius: 100vw;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	box-shadow: 0 0.625rem 1.875rem rgba(0, 0, 0, 0.1);
	margin-inline: auto;
	height: 14.375rem;
	max-width: 62.5rem;
	line-height: 1.7;
	letter-spacing: 0.1em;
	text-align: center;
	position: relative;
	z-index: 0;
	overflow: hidden;
}

@media (max-width: 824px) {
	.top-message__btn a {
		height: 8.75rem;
	}
}

.top-message__btn a::before {
	content: "";
	border: 0.125rem solid #fff;
	border-radius: 100vw;
	position: absolute;
	inset: 0.5rem;
}

@media (max-width: 824px) {
	.top-message__btn a::before {
		inset: 0.25rem;
	}
}

.top-message__btn a::after {
	content: "";
	background: url(./images/top/message_btn_leaf_01.webp) no-repeat top left / 10.625rem, url(./images/top/message_btn_leaf_02.webp) no-repeat right bottom / 8.4375rem;
	position: absolute;
	inset: 0;
}

@media (max-width: 824px) {
	.top-message__btn a::after {
		background-size: 2.8125rem, 2.5rem;
	}
}

.top-message__btn a:hover {
	box-shadow: none;
}

.top-message__btn a .head {
	font-size: clamp(1rem, 0.545rem + 1.939vw, 2rem);
	font-weight: 900;
}

.top-message__btn a .head::first-letter {
	color: var(--color-accent);
}

@media (max-width: 824px) {
	.top-message__btn a .txt {
		letter-spacing: 0.05em;
		line-height: 1.4;
		font-size: 0.75rem;
	}
}

.top-message__name {
	font-weight: 700;
	line-height: 1.6;
	margin-block-start: 1.875rem;
}

.top-message__name .name {
	font-size: clamp(1rem, 0.830rem + 0.727vw, 1.375rem);
}

/*top_医院のこと*/
.top-about {
	margin-block-start: -7.5rem;
	padding-block-start: 16.25rem;
}

@media (max-width: 824px) {
	.top-about {
		margin-block-start: -3.75rem;
		padding-block-start: 7.5rem;
	}
}

.top-about__wrapper {
	gap: 1.875rem;
}

.top-about__column_right {
	flex-shrink: 0;
}

@media (max-width: 824px) {
	.top-about__column_left {
		display: flex;
		flex-direction: column;
	}

	.top-about__column_left p {
		margin-block-start: 1.875rem;
		order: 1;
	}
}

.top-about__img {
	margin-block-start: 3.75rem;
	text-align: center;
}

.top-about__img img {
	aspect-ratio: 689/535;
	width: 43.0625rem;
	height: auto;
}

@media (max-width: 824px) {
	.top-about__img {
		margin-block-start: 0;
	}

	.top-about__img img {
		min-width: 15.625rem;
		max-width: 60%;
	}
}

.top-about__btn li:nth-child(2) a .label {
	letter-spacing: 0;
}

@media (max-width: 824px) and (min-width: 511px) {
	.top-about__wrapper {
		gap: 3.125rem;
	}

	.top-about__btn {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 1.75rem 2%;
		margin-inline: -3%;
	}

	.top-about__btn li:nth-child(2) a .label {
		inset-block-start: -2em;
	}
}


/*top_院長紹介*/
@media (max-width: 824px) {
	.top-director__wrapper {
		display: flex;
		flex-direction: column;
	}

	.top-director__ttl {
		order: -2;
	}
}

.top-director__sign {
	font-weight: 700;
	margin-block-start: 1.25rem;
	display: flex;
	gap: 0.9375rem;
	justify-content: center;
	align-items: flex-end;
}

@media (max-width: 824px) {
	.top-director__sign {
		flex-direction: column;
		align-items: normal;
	}
}

@media (max-width: 510px) {
	.top-director__sign {
		flex: 1;
	}
}

.top-director__sign-jpb {
	line-height: 1;
}

.top-director__sign-name {
	font-size: clamp(1rem, 0.830rem + 0.727vw, 1.375rem);
	line-height: 1;
}

.top-director__sign-spell {
	color: var(--color-main);
	font-size: clamp(1rem, 0.830rem + 0.727vw, 1.375rem);
	font-family: "Damion", cursive;
	font-weight: 400;
	line-height: 1;
}

.top-director__content {
	gap: 6.67%;
}

@media (max-width: 824px) {
	.top-director__content {
		display: contents;
	}
}

.top-director__column_left {
	order: -1;
	flex-shrink: 0;
	max-width: 32.0625rem;
	width: 45%;
}

@media (max-width: 824px) {
	.top-director__column_left {
		display: flex;
		justify-content: center;
		gap: 1.25rem;
		width: 100%;
		max-width: 100%;
		margin-block-end: 1.875rem;
	}
}

.top-director__column_right {
	flex: 1;
}

@media (max-width: 824px) {
	.top-director__column_right {
		display: contents;
	}
}

.top-director__img img {
	aspect-ratio: 1041/737;
	width: 32.0625rem;
	height: auto;
}

@media (max-width: 824px) {
	.top-director__img {
		min-width: 12.5rem;
		max-width: 40%;
	}
}

.top-director__btn {
	flex-direction: row;
	justify-content: center;
	gap: 3.33%;
	margin-block-start: 5rem;
}

.top-director__btn a:nth-child(2) .label {
	letter-spacing: 0;
	font-size: clamp(0.75rem, 0.722rem + 0.121vw, 0.813rem);
}

@media (max-width: 824px) and (min-width: 511px) {
	.top-about__wrapper {
		gap: 3.125rem;
	}

	.top-director__btn {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 1.75rem 2%;
		margin-inline: -3%;
	}

	.top-director__btn a .label {
		inset-block-start: -2em;
	}
}

@media (max-width: 824px) {
	.top-director__btn {
		margin-block-start: 3.75rem;
	}

	.top-director__btn a:nth-child(2) .label {
		inset-block-start: -2em;
	}
}

@media (max-width: 510px) {
	.top-director__btn {
		margin-block-start: 2.5rem;
	}

	.top-director__btn {
		flex-direction: column;
		gap: 2.5rem;
	}
}

/*top_インタビュー*/
.top-interview__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 6%;
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.top-interview__items {
		grid-template-columns: repeat(2, 1fr);
		margin-block-start: 2.5rem;
		gap: 10vw 5vw;
	}

	.top-interview__item:nth-child(3) {
		display: none;
	}
}

.top-interview__item a {
	font-weight: inherit;
}

.top-interview__item h3 {
	color: var(--color-text);
	font-size: clamp(1rem, 0.956rem + 0.188vw, 1.125rem);
	line-height: 1.7;
	margin-block-start: 1.875rem;
}

@media (max-width: 824px) {
	.top-interview__item h3 {
		margin-block-start: 1.25rem;
		letter-spacing: 0.05em;
		margin-block-start: 0.9375rem;
		font-size: 0.875rem;
	}
}

.top-interview__item .txt {
	color: var(--color-main);
	font-size: 0.875rem;
	margin-block-start: 2.5rem;
	display: flex;
	gap: 1em;
	line-height: 1.7;
	padding-inline-end: 3.25rem;
	position: relative;
}

@media (max-width: 824px) {
	.top-interview__item .txt {
		font-size: 0.75rem;
		flex-direction: column;
		margin-block-start: 1.25rem;
		padding-inline-end: 1.875rem;
		gap: 0.3125rem;
	}
}

.top-interview__item .txt::after {
	content: "";
	background: url(./images/common/arrow_circle.webp) no-repeat center / contain;
	border-radius: 100%;
	aspect-ratio: 1;
	width: fit-content;
	height: 2.625rem;
	position: absolute;
	inset: auto 0 -0.5rem auto;
}

@media (max-width: 824px) {
	.top-interview__item .txt::after {
		inset-block-end: 0;
		height: 1.5625rem;
	}
}

.top-interview__item .txt--job {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	padding: 0 0.9375rem;
	width: fit-content;
}

@media (max-width: 824px) {
	.top-interview__item .txt--job {
		padding: 0 0.5rem;
	}
}

.top-interview__item .txt--profile {
	color: var(--color-text);
}

.top-interview__item img {
	aspect-ratio: 3/4;
	object-fit: cover;
}

@media (max-width:824px) {
	.top-interview__item .img {
		width: 90%;
		margin-inline: auto;
	}
}

/*top_はたらく環境*/
.top-environment {
	padding-block: clamp(5rem, 2.727rem + 9.697vw, 10rem) 0;
	position: relative;
}

.top-environment__items {
	display: flex;
	flex-wrap: wrap;
	gap: 3.75rem 2.5rem;
	justify-content: center;
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.top-environment__items {
		flex-direction: column;
		gap: 0.625rem;
		margin-block-start: 2.5rem;
	}
}

.top-environment__items a {
	background: url(./images/common/arrow_paint.webp) no-repeat right bottom / 3.75rem #fff;
	border: 0.1875rem solid var(--color-main);
	display: flex;
	flex-direction: column;
	width: calc(100% / 3 - 5rem / 3);
}

@media (max-width: 824px) {
	.top-environment__items a {
		background-size: 1.875rem;
		flex-direction: row;
		width: 100%;
	}

	.top-environment__items a:nth-child(5) img {
		object-position: 20%;
	}
}

.top-environment__img {
	position: relative;
}

@media (max-width: 824px) {
	.top-environment__img {
		width: 6.25rem;
		flex-shrink: 0;
	}

	.top-environment__img img {
		object-fit: cover;
		min-height: 100%;
	}
}

.top-environment__img::after {
	content: "";
	background: url(./images/common/frame_wave.webp) no-repeat center bottom / 100% 100%;
	height: 1.125rem;
	position: absolute;
	inset: auto 0 -1px;
	scale: -1 1;
}

@media (max-width: 824px) {
	.top-environment__img::after {
		background-image: url(./images/common/frame_wave_vertical.webp);
		inset: 0 0 0 auto;
		scale: 1 -1;
		height: auto;
		width: 0.625rem;
	}
}

.top-environment__txtwrap {
	font-weight: 700;
	display: flex;
	gap: 0.9375rem;
	flex-direction: column;
	align-items: center;
	flex: 1;
	justify-content: center;
	padding: 2.8125rem 0.625rem;
	text-align: center;
}

@media (max-width: 824px) {
	.top-environment__txtwrap {
		align-items: normal;
		gap: 0.3125rem;
		padding: 0.9375rem 0.625rem 0.9375rem 0.9375rem;
		width: 80%;
		text-align: left;
	}
}

.top-environment__head {
	color: var(--blue);
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	letter-spacing: 0.1em;
}

.top-environment__txt {
	color: var(--color-text);
	line-height: 1.7;
}

@media (max-width: 824px) {
	.top-environment__txt {
		font-weight: 500;
		line-height: 1.6;
	}
}


/*応募の前に*/
.top-before-applying {
	padding-block: 12.5rem;
	position: relative;
	z-index: 0;
}

@media (max-width:824px) {
	.top-before-applying {
		padding-block: 6.25rem;
	}
}


.top-before-applying__ttl {
	gap: 3.75rem;
}

@media (max-width:824px) {
	.top-before-applying__ttl {
		gap: 1.875rem;
	}
}

.top-before-applying__items {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5%;
}

@media (max-width:824px) {
	.top-before-applying__items {
		grid-template-columns: 1fr;
	}
}

.top-before-applying__items>a {
	color: #fff;
	font-weight: 700;
	flex: 1;
	height: 23.75rem;
	text-align: center;
	padding: 0.5rem;
	position: relative;
	z-index: 0;
}

@media (max-width:824px) {
	.top-before-applying__items>a {
		height: 10rem;
		padding: 0.25rem;
	}
}

.top-before-applying__items>a:first-child {
	background: url(./images/top/before-applying_img_01.webp) no-repeat center / cover;
}

.top-before-applying__items>a:first-child::before {
	content: "";
	background-color: var(--color-main);
	opacity: 0.8;
	position: absolute;
	inset: 0;
	z-index: -2;
}

.top-before-applying__items>a:first-child::after {
	content: "";
	background: url(./images/top/before-applying_leaf_g_01.webp) no-repeat right top / 8.0625rem, url(./images/top/before-applying_leaf_g_02.webp) no-repeat left bottom / 6.5625rem;
	position: absolute;
	inset: 0;
	z-index: 1;
}

.top-before-applying__items>a:nth-child(2) {
	background: url(./images/top/before-applying_img_02.webp) no-repeat center / cover;
}

.top-before-applying__items>a:nth-child(2)::before {
	content: "";
	background-color: var(--blue);
	opacity: 0.8;
	position: absolute;
	inset: 0;
	z-index: -2;
}

.top-before-applying__items>a:nth-child(2)::after {
	content: "";
	background: url(./images/top/before-applying_leaf_w_01.webp) no-repeat right top / 8.0625rem, url(./images/top/before-applying_leaf_w_02.webp) no-repeat left bottom / 6.5625rem;
	position: absolute;
	inset: 0;
	z-index: 1;
}

@media (max-width:824px) {

	.top-before-applying__items>a:first-child::after,
	.top-before-applying__items>a:nth-child(2)::after {
		background-size: 3.125rem, 2.5rem;
	}
}

.top-before-applying__item-inner {
	display: flex;
	gap: 1.25rem;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	border: 0.125rem solid #fff;
	position: relative;
}

@media (max-width:824px) {
	.top-before-applying__item-inner {
		gap: 0.625rem;
	}
}

.top-before-applying__hukidashi {
	background: url(./images/common/hukidashi.svg) no-repeat center / cover;
	display: flex;
	justify-content: center;
	padding-block-start: 1.375rem;
	width: 7.875rem;
	height: auto;
	aspect-ratio: 126/84;
	position: absolute;
	inset: 2.375rem auto auto 2.9375rem;
}

@media (max-width:824px) {
	.top-before-applying__hukidashi {
		padding-block-start: 0.9375rem;
		width: 5rem;
		inset: -1.125rem auto auto -1.25rem;
	}
}

.top-before-applying__hukidashi p {
	color: var(--color-main);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 1.625rem;
	line-height: 1;
	transform: rotate(-10deg);
}

@media (max-width:824px) {
	.top-before-applying__hukidashi p {
		font-size: 1.125rem;
	}
}

.top-before-applying__items>a:nth-child(2) .top-before-applying__hukidashi p {
	color: var(--blue);
}

.top-before-applying__sbtxt {
	line-height: 1.5;
}

.top-before-applying__maintxt {
	font-weight: 900;
	font-size: clamp(1rem, 0.545rem + 1.939vw, 2rem);
	line-height: 1.6;
	letter-spacing: 0.1em;
}



/*--------------------------------------------------------------
## 下層ページ共通ここから
--------------------------------------------------------------*/
.page-layout {
	margin: 5rem 0;
}

@media screen and (max-width:824px) {
	.page-layout {
		margin: 4rem 0;
	}
}

.page-layout-min {
	margin-top: 6rem;
}

@media screen and (max-width:824px) {
	.page-layout-min {
		margin-top: 4rem;
	}
}

.page .entry-header,
.archive .entry-header,
.single .entry-header,
.error404 .entry-header {
	height: clamp(15rem, 8.182rem + 29.091vw, 30rem);
	background: url(./images/common/page-header.webp) center / cover no-repeat;
	position: relative;
}

.entry-header::after {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
}

.entry-header__inner::before {
	content: "";
	background: url(./images/top/mv_leaf_01.webp) no-repeat bottom left / 100%;
	width: 12.25rem;
	max-width: 20%;
	height: auto;
	aspect-ratio: 196 / 254;
	position: absolute;
	inset: auto auto 0 0;
	z-index: 1;
}

.entry-header__inner::after {
	content: "";
	background: url(./images/top/mv_leaf_02.webp) no-repeat bottom right / 100%;
	width: 18.3125rem;
	max-width: 20%;
	height: auto;
	aspect-ratio: 293 / 198;
	position: absolute;
	inset: auto 0 1.25rem auto;
	z-index: 1;
}

.entry-title__wrap {
	text-align: center;
	margin: auto;
	width: fit-content;
	height: fit-content;
	position: absolute;
	inset: 0;
	transform: translateY(0.625rem);
}

.page h1.entry-title,
.archive h1.entry-title,
.single h1.entry-title,
.error404 h1.entry-title {
	font-size: clamp(1.25rem, 0.795rem + 1.939vw, 2.25rem);
	font-weight: 900;
	margin: 0 auto;
	padding: 0 2em;
	text-align: center;
	color: var(--white);
	filter: drop-shadow(0 0 1.875rem #0096C4);
}

@media screen and (max-width:824px) {
	.entry-subtitle {
		font-size: 1.25rem;
	}
}

.entry-subtitle {
	color: var(--color-accent);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 2.5rem;
	margin-block-start: 0.625rem;
	line-height: 1;
	text-transform: capitalize;
}

@media screen and (max-width:824px) {
	.entry-subtitle {
		font-size: 1.25rem;
	}
}

.index-wrapper {
	margin: 5rem auto auto auto;
}

@media screen and (max-width: 824px) {
	.index-wrapper {
		margin: 2.5rem auto 0 auto;
	}
}

.index-wrapper>div {
	color: var(--thin-brown02);
	margin-bottom: 0.5em;
}

.index {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: clamp(0.625rem, 0.341rem + 1.212vw, 1.25rem);
}

.index li a {
	background: var(--color-main);
	color: #fff;
	border-radius: 6.25rem;
	padding: 0.8rem 3.5rem 0.8em 2rem;
	display: flex;
	align-items: center;
	line-height: 1.5;
	position: relative;
	box-shadow: 0 0.625rem 1.25rem rgba(0, 0, 0, 0.1);
}

@media screen and (max-width: 824px) {
	.index li a {
		font-size: 0.875rem;
		padding: 0.5rem 2.1875rem 0.5rem 0.9375rem;
	}
}

.index li a:before {
	content: "";
	background: url(./images/common/arrow_anchor.svg) no-repeat center / contain;
	border-radius: 100%;
	height: 1.875rem;
	width: auto;
	aspect-ratio: 1;
	margin-block: auto;
	position: absolute;
	inset: 0 0.625rem 0 auto;
}

@media screen and (max-width: 824px) {
	.index li a:before {
		height: 1.25rem;
	}
}

.index li a:hover {
	box-shadow: none;
}

@media screen and (max-width: 824px) {
	.index {
		flex-direction: row;
		justify-content: flex-start;
	}
}

h2.headline.line {
	position: relative;
	border-bottom: solid 0.0312rem var(--thin-brown02);
	padding-bottom: 1em;
	margin-bottom: 1.25em;
}

h2.headline.line::before,
h3.headline.line::before,
.interview-qa h3.headline::before {
	content: "";
	width: 2.5rem;
	height: 0.3125rem;
	background: var(--thin-brown01);
	display: block;
	position: absolute;
	bottom: -0.1562rem;
}

@media screen and (max-width: 824px) {

	h2.headline.line::before,
	h3.headline.line::before,
	.interview-qa h3.headline::before {
		width: 1.875rem;
		height: 0.25rem;
		bottom: -0.125rem;
	}
}

h2.headline-large.line {
	padding-bottom: 1em;
}

h3.headline.line,
.interview-qa h3.headline {
	position: relative;
	border-bottom: solid 0.0312rem var(--thin-brown02);
	padding-bottom: 1em;
	margin-bottom: 1em;
}

.back-white {
	background: #FFF;
	box-shadow: 0 0 0 100vmax #FFF;
	clip-path: inset(0 -100vmax);
	padding: 7rem 0;
}

.back-pink {
	background: var(--base-thin-pink);
	box-shadow: 0 0 0 100vmax var(--base-thin-pink);
	clip-path: inset(0 -100vmax);
	padding: 7rem 0;
}

@media screen and (max-width: 824px) {

	.back-white,
	.back-pink {
		padding: 4rem 0;
	}
}

/*--------------------------------------------------------------
下層ページ共通レイアウト
--------------------------------------------------------------*/
.story-darkback {
	background: var(--base-thin-pink);
	padding: 3rem 4rem;
	margin-top: 4rem;
	border-radius: clamp(0.625rem, -2.114rem + 5.32vw, 1.875rem);
	gap: 1rem 3rem;
}

@media screen and (max-width: 824px) {
	.story-darkback {
		margin-top: 2.5rem;
		padding: 2.5rem 2rem;
	}
}

.story-darkback .txt {
	flex: 2;
}

.story-darkback .img {
	flex: 1.25;
	margin-top: -5rem;
}

@media screen and (max-width: 824px) {
	.story-darkback .img {
		margin-top: 0;
	}
}

.story-darkback .img img {
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
}

.story-darkback h3 {
	position: relative;
	margin-left: 6rem;
}

@media screen and (max-width: 510px) {
	.story-darkback h3 {
		margin-left: 4rem;
	}
}

.story-darkback h3::before {
	content: "";
	position: absolute;
	left: -5.8125rem;
	background: url(./images/page/director-icon.png) no-repeat;
	background-size: contain;
	width: 4.375rem;
	height: 4.375rem;
	top: 50%;
	transform: translatey(-50%);
}

@media screen and (max-width: 510px) {
	.story-darkback h3::before {
		left: -4.0625rem;
		width: 3.125rem;
		height: 3.125rem;
	}
}

.story-darkback .small-hl {
	font-size: clamp(1rem, 0.562rem + 0.85vw, 1.2rem);
}

/*吹き出し*/
.bubble-wrap {
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem 2rem;
	margin: clamp(2rem, -2.383rem + 8.51vw, 4rem);
}

@media screen and (max-width: 824px) {
	.bubble-wrap {
		flex-direction: column;
	}
}

.bubble-wrap .img {
	width: 8rem;
	text-align: center;
}

@media screen and (max-width: 824px) {
	.bubble-wrap .img {
		width: 6.25rem;
		order: 1;
	}
}

.bubble-wrap .bubble {
	background: var(--pink);
	text-align: left;
	padding: 1.5rem 2rem;
	border-radius: 0.5rem;
	position: relative;
	width: calc(100% - 8rem - 2rem);
	margin: 1rem 0;
}

@media screen and (max-width: 824px) {
	.bubble-wrap .bubble {
		width: 100%;
		font-size: 0.875rem;
		padding: 1rem;
		order: 0;
	}
}

.bubble-wrap .bubble::before {
	content: "";
	display: block;
	width: 1.25rem;
	height: 1.25rem;
	border: 0.625rem solid transparent;
	border-right: 0.625rem solid var(--main-color);
	position: absolute;
	top: 50%;
	left: -1.3125rem;
	transform: translateY(-50%);
}

@media screen and (max-width: 824px) {
	.bubble-wrap .bubble::before {
		bottom: auto;
		top: 100%;
		left: 50%;
		transform: rotate(-90deg) translateY(-50%);
		text-align: center;
	}
}

.bubble-wrap .bubble::after {
	content: "";
	display: block;
	width: 1.25rem;
	height: 1.25rem;
	border: 0.625rem solid transparent;
	border-right: 0.625rem solid var(--pink);
	position: absolute;
	top: 50%;
	left: -1.2188rem;
	transform: translateY(-50%);
}

@media screen and (max-width: 824px) {
	.bubble-wrap .bubble::after {
		bottom: calc(100% - 1px);
		top: calc(100% - 0.125rem);
		left: 50%;
		transform: rotate(-90deg) translateY(-50%);
	}
}

.bubble-wrap .bubble a {
	text-decoration: underline;
}

/*白吹き出し*/
.bubble-wrap .bubble.bubble-wht {
	background: var(--white);
}

.bubble-wrap .bubble.bubble-wht::before {
	border-right: 0.625rem solid var(--white);
}

.bubble-wrap .bubble.bubble-wht::after {
	border-right: 0.625rem solid var(--white);
}

.point-blue {
	color: var(--blue);
	font-weight: bold;
}

/*--------------------------------------------------------------
クリニックについて
--------------------------------------------------------------*/
.about-philosophy {
	position: relative;
	z-index: 1;
}

.about-philosophy .l-row__txtimg {
	align-items: center;
}

@media (min-width: 825px) {
	.about-philosophy .img {
		order: -1;
	}
}

.about-policy {
	margin-block-start: -7.5rem;
	padding-block: 16.25rem 21.875rem;
}

@media (max-width: 824px) {
	.about-policy {
		margin-block-start: -3.75rem;
		padding-block: 9rem 5rem;
	}
}

.about-policy .l-row__txtimg {
	align-items: center;
}

@media (min-width:825px) {
	.about-policy .img {
		order: -1;
	}
}

.about-policy .c-list_disc {
	color: var(--blue);
	font-weight: 700;
	margin-block-end: 2.5rem;
}

@media (max-width:824px) {
	.about-policy .c-list_disc {
		margin-block-end: 1.25rem;
	}
}

.about-vision .l-row__txtimg {
	align-items: center;
}

.about-vision .l-row__txtimg+.l-row__txtimg {
	margin-block-start: 5rem;
}

@media (max-width:824px) {
	.about-vision .l-row__txtimg+.l-row__txtimg {
		margin-block-start: 2.5rem;
	}
}

/*--------------------------------------------------------------
大事にしていること
--------------------------------------------------------------*/
.important-kw {
	position: relative;
	z-index: 1;
}

.important-kw h2 {
	color: var(--color-txt);
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	font-weight: 500;
	letter-spacing: 0.05em;
}

.important-kw ul {
	color: var(--color-main);
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	text-align: center;
	letter-spacing: 0.1em;
	display: flex;
	justify-content: center;
	gap: 0 clamp(0.625rem, -0.511rem + 4.848vw, 3.125rem);
	margin-block: clamp(1.875rem, 0.455rem + 6.061vw, 5rem);
}

.important-kw ul li {
	width: 12.5rem;
	height: auto;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 33%;
}

.important-kw__items {
	display: flex;
	flex-direction: column;
	gap: 6.25rem;
	margin-block-start: 10rem;
}

@media (max-width: 824px) {
	.important-kw__items {
		margin-block-start: 2.5rem;
		gap: 3.75rem;
	}
}

.important-kw__item h3 {
	margin-block-end: 0.9375rem;
}

@media (min-width:825px) {
	.important-kw__item h3 img {
		margin: -1.5625rem 0 0 -1.5625rem;
	}
}

@media (max-width: 824px) {
	.important-kw__item h3 {
		text-align: center;
	}

	.important-kw__item h3 img {
		margin-inline-start: -2.5rem;
		height: 5rem;
	}
}

.important-skill {
	margin-block-start: -7.5rem;
	padding-block: 16.25rem 14.375rem;
	position: relative;
}

@media (max-width: 824px) {
	.important-skill {
		margin-block-start: -3.75rem;
		padding-block: 9rem 5rem;
	}
}

.important-skill::before {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
}

.important-skill__sec+.important-skill__sec {
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.important-skill__sec+.important-skill__sec {
		margin-block-start: 3.75rem;
	}
}

.important-skill__items {
	display: flex;
	flex-wrap: wrap;
	gap: 3.75rem 2.5rem;
	justify-content: center;
	counter-reset: number 0;
}

@media (max-width: 824px) {
	.important-skill__items {
		flex-direction: column;
		gap: 1.5625rem;
	}
}

.important-skill__item {
	background-color: #fff;
	display: flex;
	flex-direction: column;
	width: calc(100% / 3 - 5rem / 3);
	position: relative;
}

.important-skill__item::before {
	content: counter(number, decimal-leading-zero);
	counter-increment: number 1;
	color: var(--color-main);
	background: url(./images/common/circle.svg) no-repeat center / contain;
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 54/53;
	width: fit-content;
	height: 3.3125rem;
	line-height: 1;
	padding-block-end: 0.4375rem;
	margin-inline: auto;
	position: absolute;
	inset: -1.5625rem 0 auto;
	z-index: 1;
}

.important-skill__sec.-mind .important-skill__item::before {
	color: var(--blue);
}

@media (max-width: 824px) {
	.important-skill__item {
		flex-direction: row;
		width: 100%;
	}

	.important-skill__item::before {
		height: 2.1875rem;
		font-size: 1.5rem;
		margin-inline: 0;
		inset: -0.625rem auto auto -0.625rem;
	}
}

.important-skill__img {
	position: relative;
}

@media (max-width: 824px) {
	.important-skill__img {
		width: 6.25rem;
		flex-shrink: 0;
	}

	.important-skill__img img {
		object-fit: cover;
		min-height: 100%;
	}

	.important-skill__sec.-mind .important-skill__item:nth-child(3) .important-skill__img img {
		object-position: 34%;
	}
}

.important-skill__img::after {
	content: "";
	background: url(./images/common/frame_wave.webp) no-repeat center bottom / 100% 100%;
	height: 1.125rem;
	position: absolute;
	inset: auto 0 -1px;
	scale: -1 1;
}

@media (max-width: 824px) {
	.important-skill__img::after {
		background-image: url(./images/common/frame_wave_vertical.webp);
		inset: 0 0 0 auto;
		scale: 1 -1;
		height: auto;
		width: 0.625rem;
	}
}

.important-skill__txtwrap {
	display: flex;
	gap: 0.9375rem;
	flex-direction: column;
	align-items: center;
	flex: 1;
	padding: 2.5rem 10%;
}

@media (max-width: 824px) {
	.important-skill__txtwrap {
		align-items: normal;
		gap: 0.3125rem;
		padding: 1.25rem 0.625rem 1.25rem 0.9375rem;
		width: 80%;
	}
}

.important-skill__head {
	color: var(--color-main);
	font-weight: 700;
	font-size: clamp(1rem, 0.943rem + 0.242vw, 1.125rem);
	text-align: center;
	line-height: 1.7;
}

.important-skill__sec.-mind .important-skill__head {
	color: var(--blue);
}

@media (max-width: 824px) {
	.important-skill__head {
		line-height: 1.6;
		text-align: left;
	}
}

.important-skill__txt {
	line-height: 1.7;
}

@media (max-width: 824px) {
	.important-skill__txt {
		line-height: 1.6;
	}
}



/*--------------------------------------------------------------
1ページでわかる
--------------------------------------------------------------*/
.onepage-medical__items {
	display: flex;
	flex-direction: column;
	gap: 6.25rem;
}

@media (max-width: 824px) {
	.onepage-medical__items {
		gap: 3.75rem;
	}
}

.onepage-medical__item {
	align-items: center;
}

@media (min-width: 825px) {
	.onepage-medical__item .img {
		order: -1;
	}
}

.onepage-number__sec+.onepage-number__sec {
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.onepage-number__sec+.onepage-number__sec {
		margin-block-start: 3.75rem;
	}
}

.onepage-number__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3%;
}

@media (max-width: 824px) {
	.onepage-number__items {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0.625rem;
	}
}

.onepage-number__item {
	background-color: #e7f9fc;
	display: flex;
	gap: 0.9375rem;
	flex-direction: column;
	align-items: center;
	padding: 2.5rem 10%;
}

@media (max-width: 824px) {
	.onepage-number__item {
		display: grid;
		gap: 0;
		grid-template-columns: auto 5.625rem;
		padding: 1.875rem 1.25rem;
	}
}

.onepage-number__head {
	color: var(--blue);
	font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-align: center;
	line-height: 1.6;
}

@media (max-width: 824px) {
	.onepage-number__head {
		grid-area: 1 / 1 / 2 / 2;
		text-align: left;
	}
}

.onepage-number__number {
	color: var(--blue);
	font-size: clamp(1.5rem, 0.080rem + 6.061vw, 4.625rem);
	font-weight: 900;
	line-height: 1.1;
}

.onepage-number__number span {
	font-size: clamp(1.125rem, 0.727rem + 1.697vw, 2rem);
}

@media (max-width: 824px) {
	.onepage-number__number {
		grid-area: 2 / 1 / 3 / 2;
	}
}

.onepage-number__img {
	padding-block: 1.25rem;
}

@media (max-width: 824px) {
	.onepage-number__img {
		padding-block: 0;
		display: flex;
		align-items: center;
		justify-content: center;
		grid-area: 1 / 2 / 3 / 3;
	}

	.onepage-number__img img {
		height: 3.4375rem;

	}
}

.onepage-number__txt {
	border-block-start: 1px solid var(--blue);
	padding-block-start: 1.25rem;
	width: 100%;
	line-height: 1.7;
}

@media (max-width: 824px) {
	.onepage-number__txt {
		grid-area: 3 / 1 / 4 / 3;
		margin-block-start: 0.9375rem;
	}
}

@media (max-width: 824px) {
	.onepage-number__sec.-staff .onepage-number__item:nth-child(3) {
		grid-template-columns: auto 9.375rem;
	}

	.onepage-number__sec.-staff .onepage-number__item:nth-child(3) .onepage-number__head {
		grid-area: 1 / 1 / 2 / 2;
	}

	.onepage-number__sec.-staff .onepage-number__item:nth-child(3) .onepage-number__img {
		grid-area: 1 / 2 / 2 / 3;
	}

	.onepage-number__sec.-staff .onepage-number__item:nth-child(3) .onepage-number__img img {
		height: 9.375rem;
	}
}

.onepage-number__sec.-work .onepage-number__item:first-child .onepage-number__number {
	font-size: clamp(1.5rem, 0.591rem + 3.879vw, 3.5rem);
}

.onepage-number__sec.-work .onepage-number__item:first-child .onepage-number__number span {
	font-size: clamp(0.875rem, 0.591rem + 1.212vw, 1.5rem);
}

/*--------------------------------------------------------------
院長プロフィール
--------------------------------------------------------------*/
.profile-profile {
	position: relative;
	z-index: 1;
}

.profile-profile__content {
	display: flex;
	gap: clamp(1.875rem, 0.455rem + 6.061vw, 5rem);
	align-items: center;
	margin-inline: 5%;
}

@media (max-width: 824px) {
	.profile-profile__content {
		flex-direction: column;
		margin-inline: 0
	}
}

.profile-profile__img {
	flex-shrink: 0;
}

.profile-profile__img img {
	width: 25rem;
	height: auto;
	aspect-ratio: 400/533;
}

.profile-profile__list_01,
.profile-profile__list_02 {
	line-height: 1.7;
}

.profile-profile__list_01 dt,
.profile-profile__list_02 dt {
	color: var(--blue);
	padding-inline-start: 1.3em;
	position: relative;
}

.profile-profile__list_01 dt:before,
.profile-profile__list_02 dt:before {
	content: "●";
	color: var(--color-main);
	position: absolute;
	inset-inline-start: 0;
}

.profile-profile__list_01 {
	flex: 1;
}

.profile-profile dd {
	margin: 0;
}

@media screen and (max-width: 824px) {
	.profile-profile__img {
		max-width: 40%;
		min-width: 9.375rem;
		margin-inline: auto;
	}
}

.profile-profile__list_01 dl {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

@media screen and (max-width: 824px) {
	.profile-profile__list_01 dl {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 0.9375rem;
	}
}

.profile-profile__list_01 dl>div {
	display: flex;
}

@media screen and (max-width: 824px) {
	.profile-profile__list_01 dl>div {
		flex-direction: column;
		gap: 0.3125rem;
		border-block-end: 1px solid #BDCCD3;
		padding-block-end: 0.9375rem;
	}
}

.profile-profile__list_01 dt {
	flex-shrink: 0;
	width: 12.5rem;
}

@media screen and (max-width: 824px) {
	.profile-profile__list_01 dt {
		padding-inline-end: 0;
		width: 100%;
	}
}

.profile-profile__list dd {
	flex: 1;
	margin: 0;
}

.profile-profile__list_02 {
	margin-block-start: clamp(2.5rem, 1.364rem + 4.848vw, 5rem);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2.5rem 3.33%;
}

@media (max-width: 824px) {
	.profile-profile__list_02 {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}
}

.profile-profile__list_02>div {
	background: url(./images/common/bg_wood.webp) no-repeat top center / cover;
	padding: clamp(1.875rem, 1.591rem + 1.212vw, 2.5rem) clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
	border: 0.125rem solid #E4DEDC;
}

.profile-profile__list_02>div:last-child img {
	display: block;
	margin-inline: auto;
	height: auto;
}

@media (min-width: 825px) {
	.profile-profile__list_02>div:last-child {
		grid-area: 5 / 1 / 6 / 3;
	}

	.profile-profile__list_02>div:last-child img {
		aspect-ratio: 1094/167;
		width: 68.375rem;
		margin-block-start: 1.875rem;
	}
}

@media (max-width: 824px) {
	.profile-profile__list_02>div:last-child img {
		aspect-ratio: 469/386;
		width: 29.3125rem;
	}
}

.profile-profile__list_02 dt {
	margin-block-end: 0.9375rem;
}

.profile-profile__catch {
	margin-block-start: clamp(3.75rem, 2.045rem + 7.273vw, 7.5rem);
	line-height: 1.7;
	text-align: center;
	position: relative;
}

.profile-profile__catch::before,
.profile-profile__catch::after {
	content: "";
	background: url(./images/common/pic_palmtree.svg) no-repeat center / contain;
	aspect-ratio: 134/255;
	width: fit-content;
	max-width: 11.5%;
	height: 15.9375rem;
	margin-block: auto;
	position: absolute;
}

.profile-profile__catch::before {
	inset: 0 auto 0 0;
}

.profile-profile__catch::after {
	inset: 0 0 0 auto;
	scale: -1 1;
}

.profile-profile__catch-head {
	color: var(--blue);
	font-weight: 700;
	font-size: clamp(0.875rem, 0.705rem + 0.727vw, 1.25rem);
}

.profile-profile__catch-txt {
	font-size: clamp(1.125rem, 0.727rem + 1.697vw, 2rem);
}

.profile-profile__catch-txt mark {
	font-weight: 500;
}


/* スタッフから見た院長 */
.profile-staffcomment {
	margin-block-start: -7.5rem;
	padding-block: 16.25rem 21.875rem;
}

@media (max-width: 824px) {
	.profile-staffcomment {
		margin-block-start: -3.75rem;
		padding-block: 9rem 5rem;
	}
}

.profile-staffcomment__inner {
	max-width: 59.375rem;
}

.profile-staffcomment__sec {
	position: relative;
}

.profile-staffcomment__sec+.profile-staffcomment__sec {
	margin-block-start: 7.5rem;
}

@media (max-width: 824px) {
	.profile-staffcomment__sec+.profile-staffcomment__sec {
		margin-block-start: 3.75rem;
	}
}

.profile-staffcomment__sec h3 {
	color: var(--blue);
	font-size: clamp(1.25rem, 0.909rem + 1.455vw, 2rem);
	text-align: center;
	line-height: 1.6;
	letter-spacing: 0;
	position: absolute;
	inset: 5rem auto auto 0;
	width: 46%;
	z-index: 0;
}

.profile-staffcomment__sec:nth-of-type(2) h3 {
	inset: 5rem 0 auto auto;
}

.profile-staffcomment__sec h3::before {
	content: "";
	mask: url(./images/common/ttl_line.svg) no-repeat center / contain;
	background-color: #fff;
	aspect-ratio: 66 / 38;
	width: fit-content;
	height: 9.5625rem;
	margin: auto;
	position: absolute;
	inset: 0;
	z-index: -1;
}

@media (max-width: 824px) {
	.profile-staffcomment__sec h3 {
		margin-block-end: 1.875rem;
		position: relative;
		width: 100%;
		inset: auto !important;
	}

	.profile-staffcomment__sec h3::before {
		height: 4.6875rem;
	}
}

.profile-staffcomment__letters {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.profile-staffcomment__letter:nth-child(odd),
.profile-staffcomment__sec:nth-of-type(2) .profile-staffcomment__letter:nth-child(even) {
	align-self: flex-end;
	margin-inline: -2.5rem 0;
}

.profile-staffcomment__letter:nth-child(even),
.profile-staffcomment__sec:nth-of-type(2) .profile-staffcomment__letter:nth-child(odd) {
	align-self: flex-start;
	margin-inline: 0 -2.5rem;
}

.profile-staffcomment__letter:not(:first-child) {
	margin-block-start: -7.1875rem;
}

@media (max-width: 824px) {
	.profile-staffcomment__letter {
		margin-inline: 0 !important;
		max-width: 95%;
	}

	.profile-staffcomment__letter:not(:first-child) {
		margin-block-start: -2.5rem;
	}
}

.profile-staffcomment__letter img {
	aspect-ratio: 1030/622;
	width: 32.1875rem;
	height: auto;
}

.profile-staffcomment__img {
	text-align: center;
	position: absolute;
	inset: auto auto 0 0;
	width: 46%;
}

@media (max-width: 824px) {
	.profile-staffcomment__img {
		text-align: left;
		position: static;
		width: auto;
	}

	.profile-staffcomment__sec:nth-of-type(2) .profile-staffcomment__img {
		text-align: right;
	}
}

.profile-staffcomment__img img {
	aspect-ratio: 315/190;
	width: 19.6875rem;
	height: auto;
}

@media (max-width: 824px) {
	.profile-staffcomment__img img {
		width: 9.375rem;
	}
}


.profile-staffcomment__sec:nth-of-type(2) .profile-staffcomment__img {
	inset: auto 0 0 auto;
}

/* 院長これまでストーリー */
.profile-story__sec+.profile-story__sec {
	margin-block-start: 3.75rem;
}

@media (min-width: 825px) {

	.profile-story__sec h3,
	.profile-story__sec h3+p {
		padding-inline-start: 6.25rem;
		position: relative;
	}

	.profile-story__sec h3::before {
		content: "";
		background-color: var(--blue);
		height: 1px;
		width: 4.375rem;
		position: absolute;
		inset: 1em auto auto 0;
	}

	.profile-story__sec .txt {
		width: 60%;
	}
}

@media (max-width: 824px) {
	.profile-story__sec+.profile-story__sec {
		margin-block-start: 2.5rem;
	}
}


/*--------------------------------------------------------------
## 働きやすい理由
--------------------------------------------------------------*/
body.reason main {
	counter-reset: number 0;
}

.reason-sec h2::before {
	content: "Point" counter(number, decimal-leading-zero);
	counter-increment: number 1;
	background: url(./images/common/hukidashi.svg) no-repeat center / cover;
	color: var(--color-main);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 1.625rem;
	line-height: 1;
	transform: rotate(-10deg);
	display: flex;
	justify-content: center;
	margin-inline-start: -0.625rem;
	padding-block-start: 1.375rem;
	width: 7.875rem;
	height: auto;
	aspect-ratio: 126 / 84;
}

@media (max-width: 824px) {
	.reason-sec h2::before {
		font-size: 1.125rem;
		padding-block-start: 0.9375rem;
		width: 5rem;
	}
}

/*--------------------------------------------------------------
## 福利厚生
--------------------------------------------------------------*/
.welfare__lead mark {
	font-size: clamp(1.25rem, 0.909rem + 1.455vw, 2rem);
}

@media screen and (min-width: 825px) {
	.welfare__lead {
		margin-block-start: 6.25rem;
	}
}

@media screen and (max-width: 824px) {
	.welfare__lead {
		margin-block-start: 4rem;
	}
}

.welfare-welfare {
	counter-reset: number 0;
}

@media screen and (max-width: 824px) {
	.welfare-welfare .c-ttl__primary {
		margin-block-end: 0;
	}
}

@media screen and (min-width: 825px) {
	.welfare-welfare_item:nth-of-type(even) .img {
		order: -1;
	}
}

.welfare-welfare_item h2::before {
	content: "Welfare" counter(number, decimal-leading-zero);
	counter-increment: number 1;
	background: url(./images/common/hukidashi_blue.svg) no-repeat center / cover;
	color: var(--color-accent);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 1.625rem;
	line-height: 1;
	letter-spacing: 0;
	transform: rotate(-10deg);
	display: flex;
	justify-content: center;
	margin-inline-start: -0.625rem;
	padding-block-start: 1.375rem;
	width: 7.875rem;
	height: auto;
	aspect-ratio: 126 / 84;
}

@media (max-width: 824px) {
	.welfare-welfare_item h2::before {
		font-size: 1.125rem;
		padding-block-start: 0.9375rem;
		width: 5rem;
	}
}

.welfare-welfare_item+.welfare-welfare_item {
	margin-block-start: 6.25rem;
}

@media (max-width: 824px) {
	.welfare-welfare_item+.welfare-welfare_item {
		margin-block-start: 3.75rem;
	}
}

.welfare-point__item {
	gap: clamp(1.875rem, 1.023rem + 3.636vw, 3.75rem);
	align-items: center;
}

.welfare-point__item+.welfare-point__item {
	border-block-start: 1px solid var(--blue);
	margin-block-start: 2.5rem;
	padding-block-start: 2.5rem;
}

@media (min-width: 825px) {
	.welfare-point__item .txt {
		width: 58%;
	}
}


/*--------------------------------------------------------------
## お仕事紹介
--------------------------------------------------------------*/
/* 仕事コンテンツ全体 */
.work-ttl {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.625rem;
	margin-block-end: 3.75rem;
}

@media (max-width: 824px) {
	.work-ttl {
		margin-block-end: 1.875rem;
	}
}

.work-ttl h3 {
	color: var(--blue);
	font-size: clamp(1.25rem, 0.909rem + 1.455vw, 2rem);
	font-weight: 900;
	letter-spacing: 0.1em;
	line-height: 1.7;
}

.work-ttl__img img {
	aspect-ratio: 1;
	width: 3.75rem;
	height: auto;
}

@media (max-width: 824px) {
	.work-ttl__img img {
		width: 2.5rem;
	}
}

/*勤務時間*/
.work-time__items {
	display: flex;
	justify-content: center;
	gap: 2.5rem;
}

@media (max-width: 824px) {
	.work-time__items {
		flex-direction: column;
		gap: 1.25rem;
	}
}

.work-time__item:first-child {
	padding-inline-end: 2.5rem;
}

@media (min-width: 825px) {
	.work-time__item:first-child {
		padding-inline-end: 2.5rem;
		border-inline-end: 1px solid var(--blue);
	}
}

@media (max-width: 824px) {
	.work-time__item:first-child {
		padding-block-end: 1.25rem;
		border-block-end: 1px solid var(--blue);
	}
}

.work-time__item .time {
	color: var(--blue);
	font-weight: 900;
	font-size: 1.125rem;
}

@media (max-width: 824px) {
	.work-time__item .time {
		font-size: 0.875rem;
	}
}

.work-time__item .time .l {
	font-size: 2rem;
}

@media (max-width: 824px) {
	.work-time__item .time .l {
		font-size: 1.25rem;
	}
}

.work-time__item .note {
	font-size: 0.875rem;
}

@media (max-width: 824px) {
	.work-time__item .note {
		font-size: 0.75rem;
	}
}

.work-time__txt {
	text-align: center;
	margin-block-start: 2.5rem;
}

@media (max-width: 824px) {
	.work-time__txt {
		text-align: left;
	}
}

@media (max-width: 824px) {
	.work-ttl {
		margin-block-end: 1.875rem;
	}
}

/*仕事内容*/
.work-job__item {
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.work-job__item {
		margin-block-start: 2.5rem;
	}
}

.work-job__item h4.c-headtxt_obi {
	width: fit-content;
	padding-inline: 2.5rem;
	margin: 0 0 1.25rem;
	letter-spacing: 0.05em;
}

@media (max-width: 824px) {
	.work-job__item h4.c-headtxt_obi {
		margin-inline: auto;
	}
}

@media (min-width: 825px) {
	.work-job__item .img {
		order: -1;
	}
}

/* 必要なスキル */
@media (min-width: 825px) {
	.work-skill .work-ttl {
		flex-direction: row;
	}
}

.work-skill .l-row__txtimg {
	gap: clamp(1.875rem, 1.023rem + 3.636vw, 3.75rem);
}

@media (min-width: 825px) {
	.work-skill .l-row__txtimg .txt {
		width: 58%;
	}
}

/* 募集要項 */
.work-bg {
	position: relative;
	z-index: 1;
}

.work-recruit {
	margin-block-start: -7.5rem;
	padding-block-start: 16.25rem;
	z-index: 0;
}

@media (max-width: 824px) {
	.work-recruit {
		margin-block-start: -3.75rem;
		padding-block-start: 9rem;
	}
}

.work-recruit__table {
	border-spacing: 0.5rem;
	border-collapse: inherit;
}

@media (max-width: 824px) {
	.work-recruit__table {
		border-spacing: 0.25rem;
	}
}

.work-recruit__table th,
.work-recruit__table td {
	background-color: #fff;
	border: 0;
}

.work-recruit__table th {
	color: var(--blue);
	text-align: left;
}

/* キャリアパス */
.work-carrer::after {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
}

.work-carrer__items {
	display: flex;
	flex-direction: column;
	gap: 3.75rem;
	margin-block-start: 3.75rem;
}

.work-carrer__item {
	border-block-start: 1px solid var(--blue);
	padding-block-start: 3.75rem;
}

.work-carrer__head {
	color: var(--blue);
	font-weight: 900;
	font-size: 1.75rem;
	letter-spacing: 0.1em;
	margin-block-end: 2.5rem;
	text-align: center;
}

@media (min-width: 825px) {
	.work-carrer__txt {
		text-align: center;
	}
}

.work-carrer__head {
	line-height: 1.7;
}

.work-carrer__head .l {
	font-size: 2.5rem;
}

@media (max-width: 824px) {
	.work-carrer__head {
		font-size: 1rem;
		margin-block-end: 1.25rem;
	}

	.work-carrer__head .l {
		font-size: 1.5rem;
	}
}

.work-carrer .p-hukidashi {
	margin-block-start: 5rem;
}

.work-carrer .p-hukidashi__txt::after {
	display: none;
}

/* タブ切り替え */
.tab-label {
	display: block;
}

@media (max-width: 824px) {
	.tab-label {
		width: 100%;
	}
}

@media screen and (max-width: 510px) {
	.tab-label {
		font-size: 0.75rem !important;
	}
}

/*ラジオボタンを全て非表示に*/
input[name="tab-radio"] {
	display: none;
}

input[name="step-radio"] {
	display: none;
}

.tab-label {
	cursor: pointer !important;
	color: #fff !important;
	background-color: var(--color-main);
	border: 1px solid var(--color-main);
	border-block-end: 0;
	border-radius: clamp(0.5rem, 0.273rem + 0.97vw, 1rem) clamp(0.5rem, 0.273rem + 0.97vw, 1rem) 0 0;
	font-size: initial;
	font-weight: 50;
	display: flex;
	align-items: center;
	justify-content: center;
	letter-spacing: 0.05em;
	margin-inline: 0.5%;
	height: 5rem;
	transition: .3s;
}

@media screen and (max-width: 824px) {
	.tab-label {
		border-radius: 0;
		height: 3.75rem;
	}
}

/* .tab-label:hover {
	opacity: .7 !important;
} */

input:checked+h2>.tab-label {
	color: var(--color-accent) !important;
	background-color: var(--color-base);
	border-block-end-color: var(--color-base);
	font-weight: 700;
	transition: .3s;
}

.tab-panel {
	clear: both;
	display: none;
}

.oral-hypofunction {
	margin-top: 2rem;
}

.oral-hypofunction h5 {
	font-size: clamp(1rem, 0.562rem + 0.85vw, 1.2rem);
}

/*１日の流れ*/
.day-container {
	position: relative;
}

.day-container::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 8%;
	width: 0.125rem;
	height: 100%;
	background: var(--dark-pink);
	;
	z-index: -2;
}

.day-content.row.repeat-grow1-4>p {
	flex: 4;
	margin-bottom: 0;
}

.day-content-inner.row.repeat-grow4-1>p {
	flex: 4;
}

.day-content-inner.row.repeat-grow4-1>img {
	flex: 1;
}

.day-content {
	gap: 0 2rem;
	padding: clamp(2rem, 0.904rem + 2.13vw, 2.5rem);
	align-items: center;
	border-radius: 0.625rem;
}

.day-content:not(:last-child) {
	margin-bottom: 1.5rem;
}

.day-content:nth-of-type(odd) {
	background: var(--base-thin-pink);
}

.day-content:nth-of-type(even) {
	background: var(--base-pink);
}

.day-title {
	font-weight: bold;
	font-size: clamp(1rem, 0.562rem + 0.85vw, 1.2rem);
}

.day-title span {
	color: var(--thin-brown01);
	font-size: clamp(0.85rem, 0.521rem + 0.64vw, 1rem);
}

.day-content-inner {
	gap: 1rem 2rem;
	align-items: center;
}

/*教育方針*/
.education-section .repeat-grow1-1 {
	gap: 2rem 3rem;
}

.education-section h2.headline+p {
	margin-bottom: 4rem;
}

/*入職後の流れ*/
.stepup-content {
	display: flex;
	overflow-x: auto;
	white-space: nowrap;
	scroll-snap-type: x mandatory;
}

@media screen and (max-width: 824px) {
	.stepup-content img {
		min-width: 120%;
	}
}

@media screen and (max-width: 510px) {
	.stepup-content img {
		min-width: 340%;
		height: auto;
		flex-shrink: 0;
		scroll-snap-align: start;
		padding-right: 1rem;
	}
}

.tab_btn_area {
	border-block-end: 1px solid var(--color-main);
	display: flex;
	justify-content: center;
	gap: 1.25rem;
	max-width: 75rem;
	width: 90%;
	margin: clamp(5rem, 2.727rem + 9.697vw, 10rem) auto 0;
}

.tab_btn {
	cursor: pointer;
}

.tab-panel {
	display: none;
}

.tab-panel.active {
	display: block;
}

.tab_btn {
	width: 30rem;
	max-width: 49%;
	margin-block-end: -1px;
	text-align: center;
	line-height: 1.6;
	color: #fff !important;
	background-color: var(--color-main);
	border: 1px solid var(--color-main);
	border-block-end: 0;
	border-radius: clamp(0.5rem, 0.273rem + 0.97vw, 1rem) clamp(0.5rem, 0.273rem + 0.97vw, 1rem) 0 0;
	font-size: initial;
	font-weight: 50;
	display: flex;
	align-items: center;
	justify-content: center;
	letter-spacing: 0.05em;
	margin-inline: 0.5%;
	height: 5rem;
	transition: .3s;
	opacity: 0.7;
}

.tab_btn.active {
	color: var(--color-main) !important;
	background-color: var(--color-base);
	border-block-end-color: var(--color-base);
	font-weight: 700;
	transition: .3s;
	opacity: 1;
}

/* .tab_btn>h2 {
	width: 30rem;
	max-width: 49%;
	margin-block-end: -1px;
	text-align: center;
	line-height: 1.6;
} */

@media screen and (max-width: 510px) {
	.tab_btn_area {
		display: flex;
		gap: 0;
	}

	.tab_btn {
		margin-inline: 0;
		max-width: 50%;
		border-radius: 0;
		height: 3.75rem;
	}

	/* .tab_btn>h2 {
		max-width: 50%;
	} */
}

@media screen and (max-width: 510px) {
	.tab_btn {
		font-size: 0.75rem !important;
	}
}

/* .tab_btn:has(input#tab-da:checked)~.panel-da,
.tab_btn:has(input#tab-nt:checked)~.panel-nt {
	display: block;
} */

/*--------------------------------------------------------------
## 院内ギャラリー
--------------------------------------------------------------*/
.gallery .gallery-section h3 {
	margin-block-start: clamp(2.5rem, 1.364rem + 4.848vw, 5rem);
	text-align: center;
}

.gallery__lead+.gallery-section {
	padding-block-start: 6rem;
}

@media screen and (min-width: 825px) {
	.gallery__lead {
		margin-block-start: 6rem;
		text-align: center;
	}

	.gallery-section__lead {
		text-align: center;
	}
}

@media screen and (max-width: 824px) {
	.gallery__lead {
		margin-block-start: 4rem;
	}
}

.gallery .gallery-content {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1rem, 0.571rem + 1.9vw, 2rem);
	margin-block-start: clamp(2.5rem, 1.932rem + 2.424vw, 3.75rem);
}

@media screen and (max-width: 510px) {
	.gallery .gallery-content {
		grid-template-columns: repeat(2, 1fr);
	}
}

/*--------------------------------------------------------------
## よくある質問 
--------------------------------------------------------------*/
.faq-wrapper {
	gap: 0 3rem;
}

.faq .column-index .pc {
	position: sticky;
	top: 9.375rem;
	background: #E7F9FC;
	border-radius: 0.625rem;
	padding: 1rem 0.8rem;
	margin: 0;
	z-index: 2;
	display: flex;
	justify-content: center;
}

.faq .column-index .tb {
	font-size: 0.8125rem;
	margin-top: 0;
	padding: 0.5rem 0.625rem;
	width: 80%;
}

.faq .column-index.index li a {
	padding: 1rem 0rem 1rem 2rem;
}

@media screen and (max-width: 824px) {
	.faq .column-content {
		margin-block-start: 4rem;
	}

	.faq .index-wrapper.pc {
		display: none;
	}

	.faq .column-index {
		position: sticky;
		top: 5.625rem;
		z-index: 2;
	}
}

.faq-category+.faq-category {
	margin-block-start: clamp(5rem, 2.727rem + 9.697vw, 10rem);
}

.faq-block {
	margin-top: clamp(2.5rem, 1.932rem + 2.424vw, 3.75rem);
}

.faq .faq-item {
	gap: 1rem 3rem;
}

.faq-block h3 {
	margin-bottom: 3rem;
	font-size: clamp(1.25rem, 0.795rem + 1.939vw, 2.25rem);
}

.faq-block h4 {
	color: var(--blue);
	font-size: clamp(1rem, 0.786rem + 0.95vw, 1.5rem);
	margin-block-end: 1.25rem;
	text-indent: -2.25em;
	padding-left: 2.5em;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.faq-item+.faq-item {
	margin-top: clamp(2.5rem, 2.216rem + 1.212vw, 3.125rem);
}

.faq-item+.faq-item a {
	text-decoration: underline;
}

/*--------------------------------------------------------------
## 99の質問
--------------------------------------------------------------*/
.qa99-wrapper {
	gap: 0 3rem;
}

.qa99 .column-index .pc {
	position: sticky;
	top: 9.375rem;
	background: #E7F9FC;
	border-radius: 0.625rem;
	padding: 1rem 0.8rem;
	margin: 0;
	z-index: 2;
	display: flex;
	justify-content: center;
}

.qa99 .column-index .tb {
	font-size: 0.8125rem;
	margin-top: 0;
	padding: 0.5rem 0.625rem;
	width: 80%;
}

.qa99 .column-index.index li a {
	padding: 1rem 0rem 1rem 2rem;
}

@media screen and (max-width: 824px) {
	.qa99 .column-content {
		margin-block-start: 4rem;
	}

	.qa99 .index-wrapper.pc {
		display: none;
	}

	.qa99 .column-index {
		position: sticky;
		top: 5.625rem;
		z-index: 2;
	}
}

.qa99 .qa-item {
	margin-top: clamp(2.5rem, 2.216rem + 1.212vw, 3.125rem);
	gap: 1rem 3rem;
}

.qa99 .qa-item h4 {
	color: var(--blue);
	font-size: clamp(1rem, 0.786rem + 0.95vw, 1.5rem);
	margin-block-end: 1.25rem;
	text-indent: -2.25em;
	padding-left: 2.5em;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.qa99 .qa-img {
	margin-block-start: 1.25rem;
}

.qa99 .qa-img img {
	width: 27.5rem;
	height: auto;
	aspect-ratio: 440/292;
}

@media screen and (max-width:824px) {
	.qa99 .qa-img {
		text-align: center;
	}
}

#faq-toc li a {
	position: relative;
	padding: 0.5rem 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	letter-spacing: 0;
}

#faq-toc li a:before {
	content: "";
	background: url(./images/common/arrow_anchor_blue.svg) no-repeat center / contain;
	height: 1.625rem;
	width: auto;
	aspect-ratio: 1;
}


/*--------------------------------------------------------------
##マッチング率診断
--------------------------------------------------------------*/
.wp-block-greentreelabs-post-snippets-block div h2 {
	font-size: 1.2rem;
	color: var(--color-main);
	margin: 3rem 0 2rem 0;
	font-size: 1.5rem;
	letter-spacing: 0.05em;
}

@media screen and (max-width:530px) {
	.wp-block-greentreelabs-post-snippets-block div h2 {
		font-size: 1.2rem;
	}
}

.wp-block-greentreelabs-post-snippets-block div h2 span {
	color: var(--main-color);
}

.wp-block-greentreelabs-post-snippets-block form>div .q_wrap>div {
	transition: all 0.3s ease-in-out;
}

.wp-block-greentreelabs-post-snippets-block form>div .q_wrap {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}

@media screen and (max-width:1260px) {
	.wp-block-greentreelabs-post-snippets-block form>div .q_wrap {
		grid-template-columns: repeat(2, 1fr);
		gap: 0.5rem;
	}
}

@media screen and (max-width:530px) {
	.wp-block-greentreelabs-post-snippets-block form>div .q_wrap {
		grid-template-columns: repeat(1, 1fr);
	}
}

.wp-block-greentreelabs-post-snippets-block form>div .q_wrap>div label {
	display: block;
	height: 3.75rem;
	padding: 0 1.5rem;
	line-height: 3.75rem;
	background: #E7F9FC;
	white-space: nowrap;
}

@media screen and (max-width:530px) {
	.wp-block-greentreelabs-post-snippets-block form>div .q_wrap>div label {
		font-size: 0.85rem;
		padding: 0 1rem;
	}
}

.wp-block-greentreelabs-post-snippets-block form>div .q_wrap>div label input {
	margin-right: 1rem;
}

.wp-block-greentreelabs-post-snippets-block form button#resultbtn {
	color: var(--blue);
	background: var(--color-accent);
	display: inline-block;
	font-size: clamp(1rem, 0.914rem + 0.38vw, 1.2rem);
	font-weight: bold;
	border-radius: 100vh;
	padding: 1.25em 5vw;
	margin: 4rem auto 0 auto;
	position: relative;
	transition: 0.3s ease-in-out;
	display: block;
	max-width: 18.75rem;
	width: 100%
}

.wp-block-greentreelabs-post-snippets-block form div.resource {
	background: #E7F9FC;
	padding: clamp(2.5rem, 1.404rem + 2.13vw, 3rem);
	margin-top: 3.3125rem;
	border-radius: clamp(0.625rem, -2.114rem + 5.32vw, 1.875rem);
}

.wp-block-greentreelabs-post-snippets-block form div.resource p#goukei {
	color: var(--blue);
	font-size: 1.5rem;
	line-height: 1.8;
	margin: 0 0 1rem;
	font-weight: 600;
}

@media screen and (max-width:530px) {
	.wp-block-greentreelabs-post-snippets-block form div.resource p#goukei {
		font-size: 1rem;
	}
}

.wp-block-greentreelabs-post-snippets-block form div.resource p#goukei span {
	font-size: 3rem;
}

.wp-block-greentreelabs-post-snippets-block form div.resource .btn-wrapper {
	justify-content: center;
}

.wp-block-greentreelabs-post-snippets-block form div.resource .btn {
	display: flex;
	justify-content: center;
	gap: 1rem;
}

@media screen and (max-width:530px) {
	.wp-block-greentreelabs-post-snippets-block form div.resource .main-btn {
		flex-direction: column;
	}
}

.wp-block-greentreelabs-post-snippets-block form div.resource .main-btn:nth-of-type(2) {
	margin-top: 0;
}

.wp-block-greentreelabs-post-snippets-block form div.resource .main-btn a {
	width: 19.375rem;
}

@media screen and (max-width:824px) {
	.wp-block-greentreelabs-post-snippets-block form div.resource .main-btn a {
		width: 100%;
	}
}

.wp-block-greentreelabs-post-snippets-block form div.resource .main-btn a:hover {
	opacity: 0.7;
}

#acMenu dt {
	display: block;
	width: 12.5rem;
	height: 3.125rem;
	line-height: 3.125rem;
	text-align: center;
	cursor: pointer;
}

#acMenu dd {
	background: #f2f2f2;
	width: 12.5rem;
	text-align: center;
	display: none;
}

.mach_txt,
.resource {
	display: none;
}

.error_txt {
	display: none;
	color: #f00;
}

/*--------------------------------------------------------------
##見学
--------------------------------------------------------------*/
.visitor-visit .l-row__txtimg {
	align-items: center;
}

@media (min-width: 825px) {
	.visitor-visit .l-row__txtimg .img {
		order: -1;
	}
}

.visitor-visit__list {
	margin-block-start: clamp(2.5rem, 1.364rem + 4.848vw, 5rem);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 3.33%;
}

@media (max-width: 824px) {
	.visitor-visit__list {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}
}


.visitor-visit__list>div {
	background: #E7F9FC;
	padding: clamp(1.875rem, 1.591rem + 1.212vw, 2.5rem) clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
	position: relative;
}

.visitor-visit__list>div::before {
	content: "";
	border: 1px solid var(--color-main);
	position: absolute;
	inset: 0.5rem;
}


@media (min-width: 825px) {
	.visitor-visit__list>div:last-child {
		grid-area: 2 / 1 / 3 / 3;
	}
}

.visitor-visit__list dt {
	color: var(--blue);
	padding-inline-start: 1.3em;
	position: relative;
	margin-block-end: 0.9375rem;
}

.visitor-visit__list dt:before {
	content: "●";
	color: var(--color-main);
	position: absolute;
	inset-inline-start: 0;
}

.visitor-visit__list dd {
	margin-block-end: 0;
}

.visitor-visit__list .head {
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	font-weight: 700;
}

/*採用までの流れ*/
.visitor-flow {
	padding-block-end: 14.375rem;
}

@media (max-width: 824px) {
	.visitor-flow {
		padding-block-end: 5rem;
	}
}

.visitor-flow::after {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
}

.visitor-flow__steps {
	display: flex;
	flex-direction: column;
	gap: 6.25rem;
	counter-reset: number 0;
}

@media (max-width: 824px) {
	.visitor-flow__steps {
		gap: 5rem;
	}
}

.visitor-flow__step {
	display: flex;
	align-items: center;
	position: relative;
}

@media (max-width: 824px) {
	.visitor-flow__step {
		flex-direction: column;
		gap: 1.25rem;
		margin-block-start: 1.25rem;
	}
}

.visitor-flow__step+*::before {
	content: "";
	background: url(./images/common/arrow_paint.webp) no-repeat center / contain;
	aspect-ratio: 1;
	width: 3.75rem;
	height: auto;
	margin-inline: auto;
	position: absolute;
	inset: auto 0 calc(100% + 1.875rem);
	rotate: 45deg;
}

@media (max-width: 824px) {
	.visitor-flow__step+*::before {
		width: 1.875rem;
		inset-block-end: calc(100% + 3.125rem);
	}
}

.visitor-flow__step-head {
	color: var(--blue);
	flex-shrink: 0;
	font-weight: 900;
	font-size: clamp(1.125rem, 0.841rem + 1.212vw, 1.75rem);
	width: 24%;
	position: relative;
}

@media (max-width: 824px) {
	.visitor-flow__step-head {
		width: fit-content;
		text-align: center;
	}
}

.visitor-flow__step-head::before {
	content: "Step" counter(number, decimal-leading-zero);
	counter-increment: number 1;
	background: url(./images/common/hukidashi.svg) no-repeat center / cover;
	color: var(--color-main);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 1.625rem;
	line-height: 1;
	transform: rotate(-10deg);
	display: flex;
	justify-content: center;
	margin-inline-start: -0.625rem;
	padding-block-start: 1.375rem;
	width: 7.875rem;
	height: auto;
	aspect-ratio: 126 / 84;
	position: absolute;
	inset: auto auto 100% -3.75rem;
}

@media (max-width: 824px) {
	.visitor-flow__step-head::before {
		font-size: 1.125rem;
		padding-block-start: 0.9375rem;
		width: 5rem;
		inset: auto auto calc(100% - 0.9375rem) -3.75rem;
	}
}

.visitor-flow__step-txt {
	flex: 1;
}

@media (min-width: 825px) {
	.visitor-flow__step-txt {
		padding: 1.25rem 0 1.25rem 2.5rem;
		border-inline-start: 1px solid var(--blue);
	}
}

.visitor-flow__step .btn {
	justify-content: normal;
	margin-block-start: 1.25rem;
}

/* Webカジュアル面談 */
.online-section {
	padding-block: 1.875rem 20.625rem;
}

@media (max-width: 824px) {
	.online-section {
		padding-block: 1.875rem 10rem;
	}
}

/* 見学申し込みフォーム */
.entry-tel .tel,
.entry-tel .tel a {
	font-size: 2rem;
}

@media (max-width: 824px) {
	.entry-tel .tel,
	.entry-tel .tel a {
		font-size: 1.25rem;
	}
	
}

.entry-form::before {
	content: "";
	mask: url(./images/common/frame_beach.svg) no-repeat center bottom / 100% 100%;
	background-color: #fff;
	width: 100%;
	height: auto;
	aspect-ratio: 144 / 17;
	position: absolute;
	inset: auto 0 -1px;
}

.entry-form-wrapper {
	padding-block-start: 1.875rem;
}

@media (max-width:824px) {
	.entry-form-wrapper {
		padding-block-start: 1.875rem;
	}
}


/*--------------------------------------------------------------
##お問い合わせ
--------------------------------------------------------------*/
.contact .tel a {
	font-size: 2rem;
	text-decoration: underline;
}

.mail-contact-section form p {
	margin: 1em 0 1.5em 0;
}

/*--------------------------------------------------------------
##新卒衛生士ページ
--------------------------------------------------------------*/
.newgraduate_reason {
	position: relative;
	z-index: 1;
}

.newgraduate_reason .c-headtxt_round {
	margin-block-end: 5rem;
}

@media (max-width: 824px) {
	.newgraduate_reason .c-headtxt_round {
		margin-block-end: 2.5rem;
	}
}

.newgraduate_reason .c-headtxt_round .mainttl {
	font-size: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

.newgraduate_reason__items {
	display: flex;
	flex-direction: column;
	gap: 6.25rem;
	counter-reset: number 0;
}

@media (max-width: 824px) {
	.newgraduate_reason__items {
		gap: 2.5rem;
	}
}

.newgraduate_reason__item .more-btn,
.newgraduate_about .more-btn,
.newgraduate_work .more-btn {
	margin-block-start: 2.5rem;
	justify-content: normal;
}

@media (min-width: 825px) {

	.newgraduate_reason__item:nth-child(even) .img,
	.newgraduate_about .img {
		order: -1;
	}
}

@media (max-width: 824px) {
	.newgraduate_reason__item {
		gap: 0;
	}
}

.newgraduate_reason__item h3::before {
	content: "Point" counter(number, decimal-leading-zero);
	counter-increment: number 1;
	background: url(./images/common/hukidashi.svg) no-repeat center / cover;
	color: var(--color-main);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 1.625rem;
	line-height: 1;
	transform: rotate(-10deg);
	display: flex;
	justify-content: center;
	margin-inline-start: -0.625rem;
	padding-block-start: 1.375rem;
	width: 7.875rem;
	height: auto;
	aspect-ratio: 126 / 84;
}

@media (max-width: 824px) {
	.newgraduate_reason__item h3::before {
		font-size: 1.125rem;
		padding-block-start: 0.9375rem;
		width: 5rem;
	}
}

@media (max-width: 824px) {
	.newgraduate_reason__item .txt {
		display: contents;
	}

	.newgraduate_reason__item .img {
		margin-block-start: 1.875rem;
	}

	.newgraduate_reason__item .btn {
		order: 1;
	}
}

.newgraduate_about__wrapper {
	margin-block-start: -7.5rem;
	padding-block-start: 18rem;
}

@media (max-width: 824px) {
	.newgraduate_about__wrapper {
		margin-block-start: -3.75rem;
		padding-block-start: 9rem;
	}
}

@media (max-width: 824px) {

	.newgraduate_about .l-row__txtimg,
	.newgraduate_work .l-row__txtimg {
		gap: 0;
	}

	.newgraduate_about .txt,
	.newgraduate_work .txt {
		display: contents;
	}

	.newgraduate_about .img,
	.newgraduate_work .img {
		margin-block-start: 1.875rem;
	}

	.newgraduate_about .btn,
	.newgraduate_work .btn {
		order: 1;
	}
}

.newgraduate_work {
	margin-block-start: 6.25rem;
}


.newgraduate_interview__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 6%;
	margin-block-start: 5rem;
}

@media (max-width: 824px) {
	.newgraduate_interview__items {
		grid-template-columns: repeat(2, 1fr);
		margin-block-start: 2.5rem;
		gap: 10vw 5vw;
	}

	.newgraduate_interview__item:nth-child(3) {
		display: none;
	}
}

.newgraduate_interview__item a {
	font-weight: inherit;
}

.newgraduate_interview__item h3 {
	color: var(--color-text);
	font-size: clamp(1rem, 0.956rem + 0.188vw, 1.125rem);
	line-height: 1.7;
	margin-block-start: 1.875rem;
}

@media (max-width: 824px) {
	.newgraduate_interview__item h3 {
		margin-block-start: 1.25rem;
		letter-spacing: 0.05em;
		margin-block-start: 0.9375rem;
		font-size: 0.875rem;
	}
}

.newgraduate_interview__item .txt {
	color: var(--color-main);
	font-size: 0.875rem;
	margin-block-start: 2.5rem;
	display: flex;
	gap: 1em;
	line-height: 1.7;
	padding-inline-end: 3.25rem;
	position: relative;
}

@media (max-width: 824px) {
	.newgraduate_interview__item .txt {
		font-size: 0.75rem;
		flex-direction: column;
		margin-block-start: 1.25rem;
		gap: 0.3125rem;
	}
}

.newgraduate_interview__item .txt::after {
	content: "";
	background: url(./images/common/arrow_circle.webp) no-repeat center / contain;
	border-radius: 100%;
	aspect-ratio: 1;
	width: fit-content;
	height: 2.625rem;
	position: absolute;
	inset: auto 0 -0.5rem auto;
}

@media (max-width: 824px) {
	.newgraduate_interview__item .txt::after {
		inset-block-end: 0;
		height: 1.5625rem;
	}
}

.newgraduate_interview__item .txt--job {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	padding: 0 0.9375rem;
	width: fit-content;
}

@media (max-width: 824px) {
	.newgraduate_interview__item .txt--job {
		padding: 0 0.5rem;
	}
}

.newgraduate_interview__item .txt--profile {
	color: var(--color-text);
}

.newgraduate_interview__item img {
	aspect-ratio: 3/4;
	object-fit: cover;
}

@media (max-width:824px) {
	.newgraduate_interview__item .img {
		width: 90%;
		margin-inline: auto;
	}
}

.newgraduate-faq {
	padding-block: 1.875rem 20.625rem;
}

@media (max-width: 824px) {
	.newgraduate-faq {
		padding-block: 1.875rem 10rem;
	}
}


.newgraduate_faq__img {
	text-align: center;
}

.newgraduate_faq__img img {
	aspect-ratio: 780/486;
	width: 48.75rem;
	height: auto;
}

.newgraduate_faq__lead {
	margin-block-start: 5rem;
	text-align: center;
}

@media (max-width: 824px) {
	.newgraduate_faq__lead {
		margin-block-start: 2.5rem;
		text-align: center;
	}
}

.newgraduate-beforeapplying {
	padding-block: 1.875rem 20.625rem;
}

@media (max-width: 824px) {
	.newgraduate-beforeapplying {
		padding-block: 1.875rem 10rem;
	}
}

.newgraduate-beforeapplying h2 {
	font-size: clamp(1.125rem, 0.727rem + 1.697vw, 2rem);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: clamp(1.875rem, 0.739rem + 4.848vw, 4.375rem);
	text-align: center;
	margin-block-end: 2.5rem;
}

.newgraduate-beforeapplying h2::before,
.newgraduate-beforeapplying h2::after {
	content: "";
	background-color: var(--color-main);
	height: 2.5rem;
	width: 1px;
	transform: rotate(-30deg);
}

.newgraduate-beforeapplying h2::after {
	transform: scale(-1, 1) rotate(-30deg);
}

.newgraduate-beforeapplying__btn {
	display: flex;
	justify-content: center;
}

.newgraduate-beforeapplying__btn a {
	background: url(./images/new-graduate/beforeapplying_btn_bg.webp) no-repeat center / cover;
	border-radius: 6.25rem;
	color: #fff;
	font-size: clamp(1rem, 0.824rem + 0.751vw, 1.5rem);
	display: flex;
	gap: 0.625rem;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	text-align: center;
	letter-spacing: 0.15em;
	width: 60rem;
	height: 12.5rem;
	position: relative;
	z-index: 0;
	overflow: hidden;
}

.newgraduate-beforeapplying__btn a>* {
	line-height: 1.6;
}

.newgraduate-beforeapplying__btn a .s {
	font-size: clamp(0.75rem, 0.636rem + 0.485vw, 1rem);
	letter-spacing: 0.05em;
}

@media (max-width: 824px) {
	.newgraduate-beforeapplying__btn a {
		border-radius: 1.25rem;
		height: 12.5rem;
	}
}

.newgraduate-beforeapplying__btn a::before {
	content: "";
	background-color: var(--color-main);
	opacity: 0.8;
	position: absolute;
	inset: 0;
	z-index: -1;
}

.newgraduate-beforeapplying__btn a::after {
	content: "";
	background: url(./images/common/arrow_n_r.svg) no-repeat center #fff;
	border-radius: 100%;
	height: 4.125rem;
	width: auto;
	aspect-ratio: 1;
	margin-block: auto;
	position: absolute;
	inset: 0 2.5rem 0 auto;
	transition: 0.3s;
}

@media (max-width: 824px) {
	.newgraduate-beforeapplying__btn a::after {
		height: 2.5rem;
		inset: 0 1rem 0 auto;
	}
}

.newgraduate-beforeapplying__btn a:hover::after {
	transform: translateX(0.1875rem);
}

.newgraduate-entry {
	padding-block-start: 1.875rem;
}

.newgraduate-entry::after {
	content: "";
	background: url(./images/common/symbol_w.svg) no-repeat center / contain;
	width: 29.8125rem;
	height: auto;
	aspect-ratio: 477 / 482;
	position: absolute;
	inset: -18.75rem -11.875rem auto auto;
	z-index: -1;
}

@media (max-width:824px) {
	.newgraduate-entry::after {
		inset: -6rem -4rem auto auto;
		width: 15.625rem;
	}
}

@media (min-width: 825px) {
	.newgraduate-entry__lead {
		text-align: center;
	}
}

.newgraduate-entry__items {
	display: flex;
	justify-content: center;
	gap: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
	margin-block-start: clamp(2.5rem, 1.364rem + 4.848vw, 5rem);
}

@media (max-width:510px) {
	.newgraduate-entry__items {
		flex-direction: column;
	}
}

.newgraduate-entry__item {
	border-radius: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
	color: #fff;
	font-weight: 700;
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 18.75rem;
	overflow: hidden;
	position: relative;
	z-index: 0;
}

.newgraduate-entry__item::after {
	content: "";
	background: url(./images/common/arrow_n_r.svg) no-repeat center / 1.25rem #fff;
	border-radius: 100%;
	height: 4.125rem;
	width: auto;
	aspect-ratio: 1;
	margin-block: 1.875rem -1.25rem;
}

@media (max-width:510px) {
	.newgraduate-entry__item {
		padding: 1.875rem;
		height: auto;
	}

	.newgraduate-entry__item::after {
		background-size: 0.9375rem;
		height: 2.0625rem;
		margin-block: auto;
		position: absolute;
		inset: 0 auto 0 1.25rem;
	}
}

.newgraduate-entry__item:nth-child(odd):before {
	content: "";
	background-color: var(--color-main);
	opacity: 0.8;
	position: absolute;
	inset: 0;
	z-index: -1;
}

.newgraduate-entry__item:nth-child(even):before {
	content: "";
	background-color: var(--color-accent);
	opacity: 0.8;
	position: absolute;
	inset: 0;
	z-index: -1;
}

.newgraduate-entry__item:first-child {
	background: url(./images/new-graduate/entry_img_01.webp) no-repeat center / cover;
}

.newgraduate-entry__item:nth-child(2) {
	background: url(./images/new-graduate/entry_img_02.webp) no-repeat center / cover;
}

.newgraduate-entry__sbtxt {
	background-color: #fff;
	border-radius: 6.25rem;
	font-size: clamp(0.75rem, 0.693rem + 0.242vw, 0.875rem);
	color: var(--color-main);
	padding: 0 0.5rem;
	margin-block-end: 0.625rem;
}

.newgraduate-entry__maintxt {
	font-size: clamp(1.125rem, 0.993rem + 0.563vw, 1.5rem);
	line-height: 1.6;
}





.new-graduate .back-color {
	background: var(--base-thin-pink);
	padding: 7rem 0;
	position: relative;
}

@media screen and (max-width:824px) {
	.new-graduate .back-color {
		padding: 4rem 0;
	}
}

.new-graduate .point-section {
	position: relative;
	z-index: 1;
}

.new-graduate .point-section>h2 {
	margin-bottom: clamp(3rem, -5.766rem + 17.02vw, 7rem);
	position: relative;
}

.new-graduate .point-section>h2::before {
	content: "";
	background: url(./images/page/inclinip-hukidashi.svg) no-repeat;
	background-size: contain;
	position: absolute;
	top: calc(-1 * clamp(6.125rem, 4.732rem + 6.19vw, 9.375rem));
	left: 25%;
	width: clamp(6.75rem, -2.016rem + 17.02vw, 10.75rem);
	height: clamp(5.375rem, -1.747rem + 13.83vw, 8.625rem);
	z-index: 2;
}

@media screen and (max-width: 824px) {
	.new-graduate .point-section>h2::before {
		left: 26%;
		top: -6.25rem;
	}
}

@media screen and (max-width: 510px) {
	.new-graduate .point-section>h2::before {
		left: 20%;
	}
}

.new-graduate .point-item {
	background: var(--white);
	padding: 3rem clamp(2rem, -0.191rem + 4.26vw, 3rem) clamp(2rem, -0.191rem + 4.26vw, 3rem) clamp(2rem, -0.191rem + 4.26vw, 3rem);
	margin-top: 3rem;
	border-radius: clamp(0.625rem, -2.114rem + 5.32vw, 1.875rem);
	align-items: center;
	position: relative;
	gap: 1rem 3rem;
}

.new-graduate .point-item::before {
	content: "";
	position: absolute;
	top: -1.875rem;
	left: -1.5625rem;
	width: clamp(4.375rem, 3.759rem + 2.74vw, 5.813rem);
	height: clamp(4.375rem, 3.759rem + 2.74vw, 5.813rem);
}

@media screen and (max-width: 1024px) {
	.new-graduate .point-item::before {
		left: -1.25rem;
	}
}

.new-graduate .point-item:nth-of-type(1)::before {
	background: url(./images/page/new-point-num01.svg) no-repeat center / contain;
	;
}

.new-graduate .point-item:nth-of-type(2)::before {
	background: url(./images/page/new-point-num02.svg) no-repeat center / contain;
	;
}

.new-graduate .point-item:nth-of-type(3)::before {
	background: url(./images/page/new-point-num03.svg) no-repeat center / contain;
	;
}

.new-graduate .point-item h3 {
	font-size: clamp(1.2rem, 1.015rem + 0.82vw, 2rem);
}

/*おすすめステップ*/
.new-graduate .recommend-section.back-white {
	padding: 6rem 0 0 0;
}

.recommend-content {
	padding: 3rem clamp(2rem, -2.383rem + 8.51vw, 4rem);
	margin-top: 6rem;
	border-radius: clamp(0.625rem, -2.114rem + 5.32vw, 1.875rem);
	align-items: center;
	gap: 0 2rem !important;
}

.recommend-content.step01,
.recommend-content.step04 {
	background: var(--base-thin-pink);
}

.recommend-content.step02,
.recommend-content.step05 {
	background: var(--base-pink);
}

.recommend-content .num,
.recommend-content-interview .num {
	font-size: clamp(1rem, 0.624rem + 0.73vw, 1.5rem);
	font-family: "Judson", serif;
	display: inline-block;
	color: var(--white);
	background: var(--thin-brown01);
	border-radius: 100vh;
	padding: 0.2em 1em 0.25em 1em;
	margin-bottom: 0.5em;
}

.recommend-content p.lead {
	margin: 3rem 0;
}

@media screen and (max-width:824px) {
	.recommend-content p.lead {
		margin: 2rem 0;
	}
}

.recommend-content .img {
	position: relative;
	max-width: 50%;
	height: 32.5rem;
	flex: initial;
}

.recommend-content .img::before {
	position: absolute;
	content: "";
	width: 120%;
	height: 120%;
}

.recommend-content:nth-of-type(1) .img::before {
	background: url(./images/page/page-step01.png) no-repeat center / contain;
	bottom: 1.875rem;
}

.recommend-content:nth-of-type(2) .img::before {
	background: url(./images/page/page-step02.png) no-repeat center / contain;
	left: -20%;
	bottom: 1.875rem;
}

.recommend-content:nth-of-type(4) .img::before {
	background: url(./images/page/page-step04.png) no-repeat center / contain;
	top: -1.875rem;
}

.recommend-content:nth-of-type(5) .img::before {
	background: url(./images/page/page-step05.png) no-repeat center / contain;
	left: -20%;
	bottom: 1.875rem;
}

@media screen and (max-width:824px) {
	.recommend-content .img {
		height: auto;
		max-width: 100%;
	}

	.recommend-content .img::before {
		content: none;
	}

	.recommend-content .img img {
		margin-top: -6rem;
	}
}

.recommend-content-interview {
	margin-top: 6rem;
	margin-left: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	margin-right: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	padding: clamp(3rem, 1.071rem + 8.57vw, 7.5rem) clamp(1rem, -1.191rem + 4.26vw, 2rem) 0 clamp(1rem, -1.191rem + 4.26vw, 2rem);
	background: url(./images/page/interview-back.jpg) no-repeat center / cover;
	border: solid clamp(0.438rem, 0.33rem + 0.48vw, 0.688rem) var(--pink);
	border-radius: clamp(1.25rem, 10vw, 6.25rem);
}

.recommend-interview {
	align-items: end;
	gap: 0 3rem !important;
}

.recommend-interview li {
	position: relative;
}

.recommend-interview li .txt {
	text-align: left;
	background: var(--white);
	padding: 2em;
	border-radius: clamp(0.625rem, -0.06rem + 1.33vw, 0.938rem);
}

.recommend-interview li .txt h3 {
	margin-bottom: 1em;
}

.recommend-interview li .txt>div {
	font-size: clamp(0.85rem, 0.521rem + 0.64vw, 1rem);
	display: inline-block;
	color: var(--white);
	background: var(--dark-pink);
	border-radius: 100vh;
	padding: 0.1em 1em 0.2em 1em;
	margin-bottom: 0.5em;
}

.recommend-interview li .txt a {
	display: block;
	text-align: right;
}

.recommend-interview li .img {
	margin-top: -2rem;
}

.recommend-interview li .img img {
	max-width: 17.875rem;
	width: 100%;
	height: auto;
	margin-left: clamp(0rem, -15.34rem + 29.79vw, 7rem);
}

@media screen and (max-width:824px) {
	.recommend-interview li .img img {
		max-width: 11.25rem;
	}
}

.new-graduate .recruit-section {
	margin-top: 0;
	margin-bottom: 0;
	margin-left: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	margin-right: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	background: var(--pink);
	border-radius: clamp(1.25rem, 10vw, 6.25rem);
	padding: 10rem 2rem 7.5rem 2rem;
}

@media screen and (max-width: 824px) {
	.new-graduate .recruit-section {
		padding: 6rem 2rem 3.5rem 2rem;
	}
}

@media screen and (max-width: 824px) {
	.new-graduate .recruit-section .main-wrapper {
		width: 100%;
	}
}

.new-graduate .recruit-section>row {
	gap: 6rem 3rem;
}

.new-graduate .recruit-content {
	gap: 4.5rem 3rem;
}

.new-graduate .recruit-content>div {
	background: var(--white);
	text-align: center;
	border-radius: clamp(0.625rem, -0.06rem + 1.33vw, 0.938rem);
	padding: 4rem clamp(2rem, -2.383rem + 8.51vw, 4rem);
	position: relative;
}

.new-graduate .recruit-content>div::before {
	content: "";
	position: absolute;
	top: -4.375rem;
	left: 50%;
	transform: translatex(-50%);
	width: 8.625rem;
	height: 8.625rem;
}

@media screen and (max-width: 824px) {
	.new-graduate .recruit-content>div::before {
		top: -2.5rem;
		width: 5.625rem;
		height: 5.625rem;
	}
}

.new-graduate .recruit-content>div:nth-of-type(1)::before {
	background: url(./images/page/page-step-visit.svg) no-repeat center / contain;
}

.new-graduate .recruit-content>div:nth-of-type(2)::before {
	background: url(./images/page/page-step-recruit.svg) no-repeat center / contain;
}

.new-graduate .recruit-content .btn {
	margin-top: 2.5rem;
}

.new-graduate .recruit-content .btn span {
	color: rgba(258, 258, 258, 0.7);
	font-size: 1rem;
}

/*--------------------------------------------------------------
## インタビュー一覧
--------------------------------------------------------------*/
.archive .interview-list.row {
	gap: 5rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

@media screen and (max-width:1024px) {
	.archive .interview-list.row {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width:824px) {
	.archive .interview-list.row {
		gap: 2rem 1rem;
	}
}

.archive .interview-list h2.headline {
	color: var(--color-text);
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	line-height: 1.8;
	letter-spacing: 0.05em;
	margin-block-start: 1.875rem;
}

@media (max-width: 824px) {
	.archive .interview-list h2.headline {
		margin-block-start: 0.9375rem;
	}
}

.archive .interview-info .child {
	font-size: clamp(0.75rem, 0.639rem + 0.48vw, 1rem);
}

@media (max-width: 824px) {
	.archive .interview-list .photo img {
		display: block;
		width: 90%;
		margin-inline: auto;
		aspect-ratio: 3 / 4;
		object-fit: cover;
	}
}

.interview-info {
	color: var(--color-main);
	font-size: 0.875rem;
	font-weight: 500;
	display: flex;
	gap: 1em;
	line-height: 1.7;
	padding-inline-end: 3.25rem;
	position: relative;
}

@media screen and (max-width:824px) {
	.interview-info {
		font-size: 0.75rem;
		flex-direction: column;
		margin-block-start: 1.25rem;
		gap: 0.3125rem;
	}
}

a .interview-info {
	margin-block-start: 2.5rem;
}

@media screen and (max-width:824px) {
	a .interview-info {
		margin-block-start: 1.25rem;
	}
}

a .interview-info::after {
	content: "";
	background: url(./images/common/arrow_circle.webp) no-repeat center / contain;
	border-radius: 100%;
	aspect-ratio: 1;
	width: fit-content;
	height: 2.625rem;
	position: absolute;
	inset: auto 0 -0.5rem auto;
}

@media (max-width: 824px) {
	a .interview-info::after {
		inset-block-end: 0;
		height: 1.5625rem;
	}
}

.interview-info-item-name {
	background-color: var(--color-main);
	border-radius: 100vw;
	color: #fff;
	padding: 0 0.9375rem;
	width: fit-content;
}

@media screen and (max-width:824px) {
	.interview-info-item-name {
		padding: 0 0.5rem;
	}
}

/*--------------------------------------------------------------
## インタビュー詳細
--------------------------------------------------------------*/
.single-interview .site-content {
	margin-bottom: 5rem;
}

.single-interview .entry-header {
	display: none;
}

.single .interview-main .main-wrapper__narrow {
	gap: 3rem 5rem;
	padding: 8rem 0 15rem;
	align-items: center;
}

@media screen and (max-width: 824px) {
	.single .interview-main .main-wrapper__narrow {
		gap: 0;
		padding: 1rem 0 6rem;
	}
}

.single .interview-main h1 {
	color: var(--blue);
	font-size: clamp(1.125rem, 0.841rem + 1.212vw, 1.75rem);
	letter-spacing: 0.05em;
	margin-block-start: 1.25rem;
}

@media screen and (max-width: 824px) {
	.single .interview-main .txt {
		display: contents;
	}
}

.single .interview-main .photo {
	flex-shrink: 0;
	max-width: 40%;
}

.single .interview-info-item-name .name {
	font-size: 1.25rem;
	font-weight: 700;
}

.single .interview-info-item-name .job::before {
	content: "/";
	color: var(--color-main);
	margin-inline: 1em;
}

.interview-info-item-status {
	color: var(--color-text);
}

.interview-info .child {
	color: var(--white);
	background: var(--dark-blue);
	border-radius: 100vh;
	padding: 0.25rem 0.75rem 0.25rem 1rem;
	margin-right: 1rem;
}

.interview-info h1 {
	font-size: clamp(1.25rem, 1.136rem + 0.485vw, 1.5rem);
	margin-top: 2rem;
	letter-spacing: 0.05em;
}

.interview-join {
	display: flex;
	gap: 1.25rem;
	margin-block-start: 1.25rem;
}

.interview-join dt {
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	font-weight: 700;
	color: var(--color-main);
}

.interview-profile {
	background: var(--white);
	padding: 2rem 2rem;
	margin-top: 2.5rem;
	border-radius: clamp(1.25rem, 0.682rem + 2.424vw, 2.5rem);
}

@media screen and (max-width:824px) {
	.interview-profile {
		font-size: 0.85rem;
		margin-top: 1.25rem;
		padding: 2rem 1.25rem;
		order: 1;
	}
}

.interview-profile dl+dl {
	margin-block-start: 2.5em;
}

.interview-profile dt {
	font-size: clamp(0.875rem, 0.761rem + 0.485vw, 1.125rem);
	font-weight: 900;
	color: var(--color-main);
	margin-bottom: 0.625rem;
}

.interview-profile dd {
	font-size: clamp(0.875rem, 0.818rem + 0.242vw, 1rem);
	margin-block-end: 0;
}

.interview-profile dt.profile {
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: clamp(1.125rem, 0.955rem + 0.727vw, 1.5rem);
}

.single .interview-main .photo,
.single .interview-main .photo img {
	width: fit-content;
}

.single .interview-main .photo img {
	width: 25rem;
	max-width: 100%;
}

@media screen and (max-width:824px) {
	.single .interview-main .photo {
		width: 70%;
		margin: 1.25rem auto 0;
	}
}

.single .interview-qa {
	padding-block-start: 6.25rem
}

@media screen and (max-width:824px) {
	.single .interview-qa {
		padding-block-start: 1.875rem;
	}
}

.single .interview-qa .breadcrumb-list {
	margin-bottom: 4rem;
}

.single .interview-qa .interview-cont {
	list-style: none;
}

.interview-qa .interview-cont li+li {
	margin: 3.5rem 0 0;
	padding-block-start: 3.5rem;
	border-block-start: 1px solid var(--blue);
}

@media (max-width: 824px) {
	.interview-qa .interview-cont li+li {
		margin: 2rem 0 0;
		padding-block-start: 2rem;
	}
}

.single .interview-qa h3 {
	margin-block-end: 2.5rem;
}

@media (max-width: 824px) {
	.single .interview-qa h3 {
		margin-block-end: 1.25rem;
	}
}

.single .interview-item {
	background: #E7F9FC;
	border-radius: 2.5rem;
	padding: 4rem;
}

@media (max-width: 824px) {
	.single .interview-item {
		background: #E7F9FC;
		border-radius: 1.25rem;
		padding: 2rem 1.25rem;
	}
}

.single .interview-item+.interview-item {
	margin-block-start: 4rem;
}

@media (max-width: 824px) {
	.single .interview-item+.interview-item {
		margin-block-start: 2rem;
	}
}

/* 院長を一言で言うと */
.interview-hitokoto h2 {
	color: var(--blue);
	font-size: 1.75rem;
	text-align: center;
}

@media (max-width: 824px) {
	.interview-hitokoto h2 {
		font-size: 1.125rem;
	}

}

.interview-hitokoto__comment {
	display: flex;
	gap: 3.125rem;
	align-items: center;
	justify-content: center;
	margin-block-start: 2.5rem;
	margin-inline: auto;
	width: 100%;
	max-width: 65.625rem;
}

@media (max-width: 824px) {
	.interview-hitokoto__comment {
		flex-direction: column;
		align-items: center;
		gap: 1.5rem;
		margin-block-start: 1.25rem;
	}
}

.interview-hitokoto__comment .img {
	flex-shrink: 0;
}

@media (max-width: 824px) {
	.interview-hitokoto__comment .img {
		width: 5rem;
		order: 1;
	}
}

.interview-hitokoto__comment .img img {
	width: 9.375rem;
	height: auto;
	aspect-ratio: 1;
}

.interview-hitokoto__comment .txt {
	background-color: var(--color-main);
	border-radius: 1.25rem;
	color: #fff;
	padding: 1.25rem 2.5rem;
	width: fit-content;
	position: relative;
}

@media (max-width: 824px) {
	.interview-hitokoto__comment .txt {
		border-radius: 0.625rem;
		padding: 0.5rem 1.25rem;
	}
}

.interview-hitokoto__comment .txt p {
	font-weight: 900;
	font-size: 1.25rem;
}

@media (max-width: 824px) {
	.interview-hitokoto__comment .txt p {
		font-size: 1rem;
	}
}

.interview-hitokoto__comment .txt::after {
	content: "";
	background-color: var(--color-main);
	clip-path: polygon(0 49%, 100% 100%, 100% 0);
	height: 1.75rem;
	aspect-ratio: 32 / 34;
	margin-block: auto;
	position: absolute;
	inset: 0 99% 0 auto;
}

@media (max-width: 824px) {
	.interview-hitokoto__comment .txt::after {
		height: 1.25rem;
		margin-inline: auto;
		inset: calc(100% - 0.125rem) 0 auto;
		transform: rotate(-90deg);
	}
}

/*レーダーチャート*/
.chart_graph__wrap {
	background-color: #fff;
	border-radius: 2.5rem;
	padding: 5rem 2.5rem 2.5rem;
	margin-block-start: -4.6875rem;
}

@media (max-width: 824px) {
	.chart_graph__wrap {
		border-radius: 1.25rem;
		padding: 3.125rem 0.625rem 0.625rem;
		margin-block-start: -2.5rem;
	}
}

.chart_graph {
	padding-top: 7.5rem;
	padding-bottom: 5.625rem;
	width: 25rem;
	height: auto;
	aspect-ratio: 1;
	margin: 0 auto;
	position: relative;
}

.radar_item_wrap {
	width: 25rem;
	height: 25rem;
	position: absolute;
}

@media (max-width: 824px) {
	.chart_graph {
		padding-top: 5.3125rem;
		padding-bottom: 5.3125rem;
		width: 10rem;
	}

	.radar_item_wrap {
		width: 10rem;
		height: 10rem;
	}
}

.chart_graph .radar_item {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: max-content;
}

.chart_graph .radar_item .item_name {
	font-size: 1rem;
	color: var(--blue);
}

.chart_graph .radar_item .item_value {
	font-size: 1.375rem;
	color: #162F56;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 600;
	background-color: #E7F9FC;
	border-radius: 50%;
	width: 3.125rem;
	height: 3.125rem;
}

.chart_graph .radar_item.no1 {
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
}

.chart_graph .radar_item.no2 {
	position: absolute;
	left: 100%;
	top: 7.875rem;
	align-items: flex-start;
}

.chart_graph .radar_item.no3 {
	position: absolute;
	top: 92%;
	right: 1.375rem;
	flex-direction: column-reverse;
}

.chart_graph .radar_item.no4 {
	position: absolute;
	top: 92%;
	left: 1.375rem;
	flex-direction: column-reverse;
}

.chart_graph .radar_item.no5 {
	position: absolute;
	top: 7.875rem;
	right: 100%;
	align-items: flex-end;
}

@media (max-width: 824px) {
	.chart_graph .radar_item {
		width: 4.6875rem;
	}

	.chart_graph .radar_item .item_name {
		font-size: 0.75rem;
	}

	.chart_graph .radar_item .item_value {
		font-size: 1rem;
		width: 1.875rem;
		height: 1.875rem;
	}

	.chart_graph .radar_item.no1 {
		bottom: 10.3125rem;
	}

	.chart_graph .radar_item.no2 {
		right: -5.125rem;
		top: 2.8125rem;
	}

	.chart_graph .radar_item.no3 {
		bottom: inherit;
		top: 9.6875rem;
		right: -0.625rem;
	}

	.chart_graph .radar_item.no4 {
		bottom: inherit;
		top: 9.6875rem;
		left: -0.625rem;
	}

	.chart_graph .radar_item.no5 {
		top: 2.8125rem;
		left: -4.875rem;
	}
}

.chart_graph__txt {
	background: rgb(231, 249, 252);
	border-radius: 2.5rem;
	margin-block-start: 2.5rem;
	padding: 2.5rem;
}

@media (max-width: 824px) {
	.chart_graph__txt {
		border-radius: 1rem;
		margin-block-start: 1.25rem;
		padding: 2rem 1.25rem;
	}
}

.chart_graph__txt dt {
	color: var(--blue);
	font-size: 1.125rem;
	margin-block-end: 0.3125rem;
	padding-inline-start: 1.3em;
	position: relative;
}

@media (max-width: 824px) {
	.chart_graph__txt dt {
		font-size: 1rem;
	}
}

.chart_graph__txt dt::before {
	content: "●";
	color: var(--color-main);
	position: absolute;
	inset-inline-start: 0;
}

.chart_graph__txt>div:last-child dd {
	margin-block-end: 0;
}

/*ページ送り*/
.interview-navigation {
	display: flex;
	justify-content: space-between;
	gap: 1rem 2rem;
	align-items: center;
	margin-bottom: 0.625rem;
	margin: 4rem 0 2rem 0;
}

@media screen and (max-width:824px) {
	.interview-navigation {
		flex-direction: column;
	}
}

.interview-navigation .btn {
	margin: 0;
}

@media screen and (max-width:824px) {
	.interview-navigation .btn {
		width: 100%;
	}
}

.interview-navigation .btn .tag {
	background-color: white;
	color: var(--color-main);
	font-family: "Lato", "Zen Kaku Gothic New", sans-serif;
	font-size: clamp(0.85rem, 0.521rem + 0.64vw, 1rem);
	padding: 0.125rem 0.625rem 0.3125rem 0.625rem;
	border-radius: 100vh;
	margin-right: 0.3125rem;
}

.interview-navigation .prev {
	margin-right: auto;
}

.interview-navigation .prev a:before {
	transform: rotate(180deg);
}

.interview-navigation .prev a:hover::before {
	transform: translateX(-0.1875rem) rotate(180deg);
}

.interview-navigation .next {
	position: relative;
	margin-left: auto;
}

.interview-navigation .next:after {
	mask: url(./images/common/arrow_w_r.svg) no-repeat center / contain;
	background-color: var(--blue);
	content: '';
	margin-block: auto;
	position: absolute;
	inset: 0 1em 0 auto;
	width: auto;
	height: 0.75rem;
	aspect-ratio: 1;
	transition: 0.3s;
}

.interview-navigation .next:hover:after {
	right: 0.75em !important;
	transition: right 0.3s ease-in-out;
}

.interview-navigation .next a:before {
	content: none;
}

.interview-navigation .interview-back {
	text-align: center;
	margin-top: 0.625rem;
}

.interview-back {
	margin-block-end: 2.5rem;
}

.interview-back a {
	font-weight: bold;
	text-decoration: underline;
}

/* 院長から見たN.Rさんの姿 */
.interview-director {
	background-color: var(--dark-beige);
	border-radius: 2.5rem;
	margin-block-start: 12.5rem;
	padding: 5rem 2.5rem 2.5rem;
	position: relative;
}

@media (max-width: 824px) {
	.interview-director {
		border-radius: 1.25rem;
		margin-block-start: 7.5rem;
		padding: 1.875rem 0.625rem 0.625rem;
	}
}

.interview-director::before {
	content: "";
	background: url(./images/common/director_box_img.webp) no-repeat top center / cover;
	width: fit-content;
	height: 8.75rem;
	aspect-ratio: 20/14;
	margin-inline: auto;
	position: absolute;
	inset: auto 0 100% 0;
}

@media (max-width: 824px) {
	.interview-director::before {
		height: 5.25rem;
	}
}

.interview-director dl {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.9375rem;
}

@media (min-width: 825px) {
	.interview-director dl>div:nth-child(3) {
		grid-area: 2 / 1 / 3 / 3;
	}

	.interview-director dl>div:nth-child(4) {
		grid-area: 3 / 1 / 4 / 3;
	}

	.interview-director dl>div:nth-child(5) {
		grid-area: 4 / 1 / 5 / 3;
	}
}

@media (max-width: 824px) {
	.interview-director dl {
		grid-template-columns: 1fr;
		gap: 0.625rem;
	}
}

.interview-director dl>div {
	background: #fff;
	border-radius: 1.25rem;
	padding: 2rem;
}

@media (max-width: 824px) {
	.interview-director dl>div {
		border-radius: 1rem;
		padding: 1.25rem;
	}
}

.interview-director dt {
	color: var(--blue);
	margin-block-end: 0.9375rem;
	padding-inline-start: 1.3em;
	position: relative;
}

.interview-director dt:before {
	content: "●";
	color: var(--color-main);
	position: absolute;
	inset-inline-start: 0;
}

.interview-director dd {
	margin-block-end: 0;
}

/* ある1日 */
.interview-schedule__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 5rem 1.875rem;
}

@media (max-width: 824px) {
	.interview-schedule__items {
		grid-template-columns: 1fr;
		gap: 0.9375rem;
	}
}

.interview-schedule__item {
	background: #fff;
	border: 0.125rem solid var(--color-main);
	padding: 1.25rem 0.625rem;
	display: flex;
	flex-direction: column;
	gap: 0.3125rem;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
}

.interview-schedule__item.-blue {
	background: var(--color-main);
	color: #fff;
}

.interview-schedule__item.-blue .time,
.interview-schedule__item:last-child .time {
	color: #fff;
}

.interview-schedule__item.-yellow {
	background: var(--color-accent);
	border-color: var(--color-accent);
}

.interview-schedule__item.-space {
	visibility: hidden;
}

@media (max-width: 824px) {
	.interview-schedule__item.-space {
		display: none;
	}
}

@media (max-width: 824px) {
	.interview-schedule__item {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: normal;
		padding: 0.625rem;
		gap: 0.3125rem 0.9375rem;
		text-align: left;
	}
}

.interview-schedule__item::after {
	content: "";
	background-color: var(--color-main);
	width: 2.0625rem;
	height: 0.1875rem;
	margin-block: auto;
	position: absolute;
	inset: 0 auto 0 100%;
}

.interview-schedule__item:has(+ .interview-schedule__item.-space):after {
	display: none;
}

@media (max-width: 824px) {
	.interview-schedule__item::after {
		width: 0.1875rem;
		height: 1.125rem;
		margin: 0 auto;
		inset: 100% 0 auto;
	}
}

@media (min-width: 825px) {
	.interview-schedule__item:nth-child(-n + 3) {
		order: 0;
	}

	.interview-schedule__item:nth-child(6) {
		order: 1;
	}

	.interview-schedule__item:nth-child(5) {
		order: 2;
	}

	.interview-schedule__item:nth-child(4) {
		order: 3;
	}

	.interview-schedule__item:nth-child(n+7):nth-child(-n+9) {
		order: 4;
	}

	.interview-schedule__item:nth-child(12) {
		order: 5;
	}

	.interview-schedule__item:nth-child(11) {
		order: 6;
	}

	.interview-schedule__item:nth-child(10) {
		order: 7;
	}

	.interview-schedule__item:nth-child(n+13):nth-child(-n+15) {
		order: 8;
	}

	.interview-schedule__item:nth-child(18) {
		order: 9;
	}

	.interview-schedule__item:nth-child(17) {
		order: 10;
	}

	.interview-schedule__item:nth-child(16) {
		order: 11;
	}

	.interview-schedule__item:nth-child(4)::after,
	.interview-schedule__item:nth-child(5)::after,
	.interview-schedule__item:nth-child(10)::after,
	.interview-schedule__item:nth-child(11)::after,
	.interview-schedule__item:nth-child(16)::after,
	.interview-schedule__item:nth-child(17)::after {
		inset: 0 100% 0 auto;
	}

	.interview-schedule__item:nth-child(3n)::after {
		width: 0.1875rem;
		height: 5.1875rem;
		margin: 0 auto;
		inset: 100% 0 auto;
	}
}

.interview-schedule__item:last-child::after {
	display: none;
}

.interview-schedule .time {
	color: var(--color-main);
	font-family: "Damion", cursive;
	font-weight: 400;
	font-size: 2.5rem;
	line-height: 1;
}

@media (max-width: 824px) {
	.interview-schedule .time {
		font-size: 1.5rem;
	}

}

.interview-schedule .txt {
	font-weight: 700;
}

.interview-schedule .sbtxt {
	font-size: 0.75rem;
	line-height: 1.6;
}

@media (max-width: 824px) {
	.interview-schedule .sbtxt {
		width: 100%;
	}
}


/*--------------------------------------------------------------
## 募集要項一覧
--------------------------------------------------------------*/
.recruit-lastupdated {
	margin-block-start: 1.25rem;
	text-align: right;
	font-size: 0.75rem;
}

.post-type-archive-recruit .recruit-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 3rem;
	gap: 1rem 4rem;
}

@media screen and (max-width:824px) {
	.post-type-archive-recruit .recruit-list {
		margin-top: 2rem;
		grid-template-columns: repeat(1, 1fr);
	}
}

.post-type-archive-recruit .recruit-list li {
	padding: 2rem;
	background: #E7F9FC;
	position: relative;
	transition: all 0.3s ease-in-out;
}

.post-type-archive-recruit .recruit-list li:hover {
	transition: all 0.3s ease-in-out;
	opacity: 0.7;
}

.post-type-archive-recruit .recruit-list li::before {
	content: "";
	background: url(./images/common/arrow_circle.webp) no-repeat center / contain;
	aspect-ratio: 1;
	width: fit-content;
	height: 1.875rem;
	margin-block: auto;
	position: absolute;
	inset: 0 auto 0 1.25rem;
	transition: 0.3s;
}

.post-type-archive-recruit .recruit-list li:hover::before {
	left: 1.5rem;
	transition: left 0.3s ease-in-out;
}

.post-type-archive-recruit h3.recruit_title {
	color: var(--blue);
	position: relative;
	margin-left: 2.5rem;
}

@media screen and (min-width: 511px) {
	.no_recruit_post {
		text-align: center;
	}
}

/*--------------------------------------------------------------
## 募集要項詳細
--------------------------------------------------------------*/
@media screen and (max-width: 510px) {
	.recruit-wrapper {
		margin: 3.125rem auto 0;
	}
}

.index .entry a {
	color: #fff;
	background: var(--text-color);
}

.index .entry a::before {
	background: url(./images/common/index-yajirushi-wt.svg) no-repeat center / contain;
}

.recruit-table th,
th {
	font-weight: 600;
	background: var(--color-main);
	color: var(--white);
	width: 30%;
	border: solid 0.0437rem #fff;
	vertical-align: top;
}

.recruit-table td,
td {
	background: #e7f9fc;
	border: solid 0.0437rem var(--color-main);
}

@media screen and (max-width: 510px) {

	.recruit-table th,
	th,
	.recruit-table td,
	td {
		padding: 0.625rem;
	}
}

.single-recruit .lead small {
	display: block;
	line-height: 2;
}

.single-recruit .lead small,
.single-recruit .lead small a {
	font-size: 1rem;
}

@media screen and (max-width: 824px) {

	.single-recruit .lead small,
	.single-recruit .lead small a {
		font-size: 0.75rem;
	}
}

#entry-form {
	text-align: center;
	margin-top: 8rem;
}

@media screen and (max-width: 824px) {
	#entry-form {
		margin-top: 6rem;
	}
}

.entry-form p {
	margin: 0 0 0.625rem;
}

.entry-form label {
	display: inline-block;
	text-align: left;
	line-height: 1.8;
	max-width: 31.25rem;
	width: 100%;
	margin-bottom: 1rem;
}

.entry-form label .must {
	color: #c10e58;
	font-size: 0.875rem;
	font-weight: 500;
}

.entry-form .check-web {
	margin-top: 2rem;
	text-align: center;
}

.entry-form .check-web .radio {
	margin-top: 1rem;
}

.entry-submit {
	margin: 4rem auto 0;
	position: relative;
}

.entry-submit input[type="submit"] {
	width: 100%;
	height: 100%;
	color: var(--blue);
	background: var(--color-accent);
	border: solid 0.1562rem var(--color-accent);
	border-radius: 100vh;
	padding: 1.25em 4.5vw;
	width: 17.5rem;
	margin: 0 auto;
	font-weight: bold;
}

.entry-submit input[type="submit"]:focus,
.entry-submit input[type="submit"]:active {
	outline: none;
}

.around-link-wrap {
	margin: 3rem 0 0;
}

.entry-form {
	margin-top: 1.5rem;
}

.entry-form form {
	margin-block-start: 3.75rem;
}

/*--------------------------------------------------------------
## プライバシーポリシー
--------------------------------------------------------------*/
.privacy-policy h2 {
	font-size: 2rem;
	margin-bottom: 1.5rem;
}

.privacy-policy section+section {
	margin-block-start: 5rem;
}

@media screen and (max-width: 824px) {
	.privacy-policy h2 {
		font-size: 1.2rem;
		margin-bottom: 1.2rem;
	}

	.privacy-policy section+section {
		margin-block-start: 2.5rem;
	}
}

/*--------------------------------------------------------------
## 404ページ
--------------------------------------------------------------*/
.notfound-list li {
	line-height: 2.5em;
}

.notfound-list a {
	color: var(--blue);
}

.notfound-list:nth-of-type(1)>li>a:nth-of-type(1) {
	color: var(--blue);
	font-size: clamp(1rem, 0.562rem + 0.85vw, 1.2rem);
}

.notfound-list:nth-of-type(1)>li {
	margin: clamp(1.5rem, 0.404rem + 2.13vw, 2rem) 0;
}

.notfound-list:not(:first-child) {
	margin: 1rem 0;
}

.notfound-list+h3 {
	margin-top: 4rem;
}

.search-form-wrapper input[type="search"] {
	width: 80%;
}

.search-form-wrapper input[type="submit"] {
	display: inline-block;
	width: 3.75rem;
	height: 1.5625rem;
}

/* 投稿一覧と応募完了を消す */
.page-item-7,
.page-item-121 {
	display: none;
}

/*--------------------------------------------------------------
# カテゴリ別親ページ
--------------------------------------------------------------*/
.related-pages-wrapper {
	background: #E7F9FC;
	padding: 6rem 0;
	margin-top: 0;
	margin-bottom: clamp(3.75rem, 2.045rem + 7.273vw, 7.5rem);
	;
	margin-left: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	margin-right: clamp(1rem, -0.364rem + 5.82vw, 4rem);
	border-radius: 2.5rem;
	position: relative;
}

.related-pages-wrapper::before {
	content: "";
	background: url(./images/common/leaf_03.webp) no-repeat center / contain;
	aspect-ratio: 290/272;
	width: 15.625rem;
	max-width: 19%;
	height: auto;
	position: absolute;
	inset: -1.25rem auto auto -4.41%;
}

@media screen and (max-width: 824px) {
	.related-pages-wrapper::before {
		inset-block-start: -0.625rem;
	}
}

.related-pages-wrapper::after {
	content: "";
	background: url(./images/common/leaf_04.webp) no-repeat center / contain;
	aspect-ratio: 372/230;
	width: 21.875rem;
	max-width: 26%;
	height: auto;
	position: absolute;
	inset: -2.375rem -5.59% auto auto;
}

@media screen and (max-width: 824px) {
	.related-pages-wrapper::after {
		inset-block-start: -1.125rem;
	}
}

@media screen and (max-width: 824px) {
	.related-pages-wrapper {
		padding: 2.5rem 0;
	}
}

.child-page-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem 2.5rem;
}

@media screen and (max-width: 1024px) {
	.child-page-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem 0.8rem;
	}
}

.child-page-list li a {
	background: url(./images/common/arrow_paint.webp) no-repeat right bottom / 3.75rem #fff;
	border: 0.1875rem solid var(--color-main);
	font-size: 1rem;
	line-height: 1.5;
	color: var(--color-txt);
	font-weight: 500;
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
}

@media (max-width: 824px) {
	.child-page-list li a {
		background-size: 1.5rem;
	}
}

.child-page-list li a .img {
	position: relative;
}

.child-page-list li a .img::after {
	content: "";
	background: url(./images/common/frame_wave.webp) no-repeat center bottom / 100% 100%;
	height: 1.125rem;
	position: absolute;
	inset: auto 0 -1px;
	scale: -1 1;
}

@media (max-width: 824px) {
	.child-page-list li a .img::after {
		height: 0.3125rem;
	}
}

.child-page-list li a .txt {
	font-size: clamp(0.813rem, 0.670rem + 0.606vw, 1.125rem);
	color: var(--blue);
	padding: 1.25rem;
	line-height: 1.6;
	flex: 1;
	display: flex;
	align-items: center;
}

@media (max-width: 824px) {
	.child-page-list li a .txt {
		padding: 0.625rem 0.5rem;
		letter-spacing: 0;
	}
}


/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
/* Older / Newer Posts Navigation (always hidden) */
.infinite-scroll.neverending .site-footer {
	/* Theme Footer (when set to scrolling) */
	display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

embed,
iframe,
object {
	max-width: 100%;
}

/*--------------------------------------------------------------
## フォームへのボタン
--------------------------------------------------------------*/
.fix-btn2 {
	position: static;
	display: none;
}

.fix-btn2 a {
	display: block;
	color: #fff;
	font-size: 1.2rem;
	padding: 1.125rem 0.625rem;
	margin: 0;
	width: 100%;
	text-align: center;
	box-shadow: 0 0.1875rem 0.375rem rgba(0, 0, 0, 0.16);
	position: relative;
	background: #212121;
}

@media screen and (max-width: 510px) {
	.fix-btn2 {
		display: block;
		position: fixed;
		left: 0;
		bottom: 0;
		z-index: 3;
		width: 100%;
	}

	.fix-btn {
		display: none;
	}
}

/*編集用コメントの非表示*/
.comment {
	display: none;
}

/*リキャプチャ非表示*/
.grecaptcha-badge {
	visibility: hidden;
}