@charset "UTF-8";
/*
Version: 1.0.0
Creation Date: 2026.1.17
Last Updated: 2026.2.20
*/


/* import
------------------------------------------------------------ */
@import "https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css";
@import "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/7.0.1/css/all.min.css";
@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap";
@import "https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,500;0,600;0,700;1,500;1,600;1,700&display=swap";


/* set
------------------------------------------------------------ */
:root {
--design-width: 1366;
--font-size-base: clamp(8.75px, calc(10 * 100vw / var(--design-width)), 11.25px);
--font-base: 'Noto Sans JP', sans-serif;
--font-en: 'Poppins', sans-serif;
--color-bg: #e8e8e8;
--color-text: #000;
--color-primary: #313d8a;
--color-primary-light: #475499;
--color-secondary: #f39800;
--color-sky: #408fb9;
--color-gray: #727171;
--color-line: #c9caca;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
font-size: var(--font-size-base);
overflow-x: hidden;
scroll-behavior: smooth;
}
body {
-webkit-text-size-adjust: 100%;
background: var(--color-bg);
font-family: var(--font-base);
color: var(--color-text);
font-size: 1.6rem;
font-weight: 500;
line-height: 1.2;
overflow-x: hidden;
}
ul,ol {
list-style: none;
}
img {
vertical-align: middle;
max-width: 100%;
height: auto;
}
table {
width: 100%;
border-collapse: collapse;
}
a {
color: inherit;
text-decoration: none;
word-break: break-all;
}
:hover {
transition: .3s;
}
.opa a:hover {
opacity: .7;
}
.smd,.smp {
display: none;
}
.pc {
display: block;
}


/* common
------------------------------------------------------------ */
/* font */
.NOTO {  /* Noto Sans JP */
font-family: var(--font-base);
}
.EN { /* Poppins */
font-family: var(--font-en);
}
em {
font-style: normal;
display: inline-block;
transform: skew(-8deg);
}
time {
color: var(--color-gray);
}
sup {font-size: 70%;}
small {font-size: 80%;}
.l {font-weight: 400;}
.m {font-weight: 500;}
.sb {font-weight: 600;}
.b {font-weight: 700;}
.eb {font-weight: 800;}
.h {font-weight: 900;}
.lh1 {line-height: 1;}
.lh12 {line-height: 1.2;}
.lh13 {line-height: 1.3;}
.lh14 {line-height: 1.4;}
.lh15 {line-height: 1.5;}
.lh16 {line-height: 1.6;}
.lh17 {line-height: 1.7;}
.lh18 {line-height: 1.8;}
.lh19 {line-height: 1.9;}
.lh20 {line-height: 2;}
.lh21 {line-height: 2.1;}
.lh22 {line-height: 2.2;}
.lh23 {line-height: 2.3;}
.lh24 {line-height: 2.4;}
.lh25 {line-height: 2.5;}
.lh26 {line-height: 2.6;}
.ls01 {letter-spacing: .01em;}
.ls02 {letter-spacing: .02em;}
.ls03 {letter-spacing: .03em;}
.ls05 {letter-spacing: .05em;}
.ls06 {letter-spacing: .06em;}
.ls07 {letter-spacing: .07em;}
.ls08 {letter-spacing: .08em;}
.ls09 {letter-spacing: .09em;}
.ls10 {letter-spacing: .1em;}
.ls11 {letter-spacing: .11em;}
.ls12 {letter-spacing: .12em;}
.ls13 {letter-spacing: .13em;}
.ls14 {letter-spacing: .14em;}
.ls15 {letter-spacing: .15em;}
.ls16 {letter-spacing: .16em;}
.ls17 {letter-spacing: .17em;}
.ls18 {letter-spacing: .18em;}
.ls19 {letter-spacing: .19em;}
.ls20 {letter-spacing: .2em;}
.-ls {letter-spacing: 0;}
.ilc {font-style: italic;}
.nml {font-style: normal;}
.f10 {font-size: 1rem;}
.f11 {font-size: 1.1rem;}
.f12 {font-size: 1.2rem;}
.f13 {font-size: 1.3rem;}
.f14 {font-size: 1.4rem;}
.f15 {font-size: 1.5rem;}
.f16 {font-size: 1.6rem;}
.f17 {font-size: 1.7rem;}
.f18 {font-size: 1.8rem;}
.f19 {font-size: 1.9rem;}
.f20 {font-size: 2rem;}
.f21 {font-size: 2.1rem;}
.f22 {font-size: 2.2rem;}
.f23 {font-size: 2.3rem;}
.f24 {font-size: 2.4rem;}
.f25 {font-size: 2.5rem;}
.f26 {font-size: 2.6rem;}
.f27 {font-size: 2.7rem;}
.f28 {font-size: 2.8rem;}
.f29 {font-size: 2.9rem;}
.f30 {font-size: 3rem;}
.f31 {font-size: 3.1rem;}
.f32 {font-size: 3.2rem;}
.f33 {font-size: 3.3rem;}
.f34 {font-size: 3.4rem;}
.f35 {font-size: 3.5rem;}
.f36 {font-size: 3.6rem;}
.f37 {font-size: 3.7rem;}
.f38 {font-size: 3.8rem;}
.f39 {font-size: 3.9rem;}
.f40 {font-size: 4rem;}
.f41 {font-size: 4.1rem;}
.f52 {font-size: 5.2rem;}
.v-rl {
writing-mode: vertical-rl;
}
.h-tb {
writing-mode: horizontal-tb;
}
.nowrap {
white-space: nowrap;
}
.stroke,
.stroke_wht {
font-size: 8.78vw;
color: transparent;
-webkit-text-stroke: 1px var(--color-primary);
}
.stroke_wht {
-webkit-text-stroke: 1px #FFF;
}

/* layout */
main {
width: 100%;
display: block;
position: relative;
}
article {
width: 100%;
position: relative;
}
section {
width: 87.85%;
margin: 0 auto;
position: relative;
z-index: 1;
}
.narrow {
width: 85.83%;
margin: 0 auto;
padding: 4vw 8vw;
}

/* margin */
.mb5 {margin-bottom: .5rem;}
.mb10 {margin-bottom: 1rem;}
.mb15 {margin-bottom: 1.5rem;}
.mb20 {margin-bottom: 2rem;}
.mb25 {margin-bottom: 2.5rem;}
.mb30 {margin-bottom: 3rem;}
.mb40 {margin-bottom: 4rem;}
.mb50 {margin-bottom: 5rem;}
.mb60 {margin-bottom: 6rem;}
.mb70 {margin-bottom: 7rem;}
.mb80 {margin-bottom: 8rem;}
.mb90 {margin-bottom: 9rem;}
.mb100 {margin-bottom: 10rem;}

/* style */
.none {
display: none;
}
.center {
text-align: center;
}
.left {
text-align: left;
}
.right {
text-align: right;
}
.block {
display: block;
}
.max img {
width: 100vw;
}
.flex {
display: flex;
}
.grid {
display: grid;
}
.round {
border-radius: 3rem;
}
.hvr a {
text-decoration: underline;
}
.hvr a:hover {
text-decoration: none;
}

/* color */
.primary {
color: var(--color-primary);
}
.secondary {
color: var(--color-secondary);
}
.sky,
.hvr_sky a:hover {
color: var(--color-sky);
}
.gray {
color: var(--color-gray);
}
.blk {
color: var(--color-text);
}
.wht {
color: #FFF;
}

/* background */
.bg_primary {
background: var(--color-primary);
color: #FFF;
}
.bg_light {
background: var(--color-primary-light);
}
.bg_secondary {
background: var(--color-secondary);
}
.bg_sky {
background: var(--color-sky);
}
.bg_blk {
background: var(--color-text);
}
.bg_wht {
background: #FFF;
}
.bg {
background: var(--color-bg);
}

#about::after {
content: "";
background: url("img/line_01.svg") no-repeat center/contain;
width: 37.12vw;
aspect-ratio: 507 / 536;
position: absolute;
bottom: -19.55vw;
left: -11.57vw;
}
#kv::before {
content: "";
background: url("img/line_02.svg") no-repeat center/contain;
width: 22.55vw;
aspect-ratio: 308 / 308;
position: absolute;
bottom: -16.98vw;
right: 18.08vw;
z-index: 1;
}
footer::before {
content: "";
background: url("img/line_03.svg") no-repeat center/contain;
width: 31.92vw;
aspect-ratio: 436 / 536;
position: absolute;
top: -17.57vw;
left: -11.57vw;
}
.single + footer::before {
z-index: 1;
}
.development + footer::before,
.interview + footer::before {
display: none;
}
footer::after,
.advantage::after,
.entry article.bg_primary::after {
content: "";
background: url("img/line_04.svg") no-repeat center/contain;
width: 24.82vw;
aspect-ratio: 339 / 430;
position: absolute;
top: -22.77vw;
right: -7.83vw;
}
.home + footer::after,
.single + footer::after {
top: -150%;
}
.advantage::after {
top: -5vw;
}
.entry article.bg_primary::after {
top: 30%;
}
.work article.bg_primary::before,
#development::after,
#welfare::after,
.interview #ttl::after,
.question.q3::before,
#recruitment::before,
.entry article.bg_primary::before {
content: "";
background: url("img/line_05.svg") no-repeat center/contain;
width: 36.68vw;
aspect-ratio: 501 / 549;
position: absolute;
top: -19.55vw;
left: -20.2vw;
}
.work article.bg_primary::before {
top: -19.55vw;
}
#development::after,
#welfare::after {
top: -6.7vw;
z-index: -1;
}
.interview #ttl::after {
top: 130%;
}
.question.q3::before {
top: -2.56vw;
left: -24.3vw;
}
#recruitment::before {
top: -6.37vw;
}
.entry article.bg_primary::before {
top: -5.5vw;
}
#ttl:has(.max)::before,
#recruitment::after,
.entry + footer::after {
content: "";
background: url("img/line_06.svg") no-repeat center/contain;
width: 34.77vw;
aspect-ratio: 475 / 668;
position: absolute;
top: 12.15vw;
right: -20.64vw;
z-index: -1;
}
#recruitment::after {
top: 50%;
right: -16.47vw;
}
.entry + footer::after {
top: -100%;
right: -15.96vw;
z-index: 0;
}
#ttl:not(:has(.max))::before,
.work article.bg_primary::after,
.development #ttl::before,
.welfare #ttl::before,
.interview #ttl::before,
.staff #ttl::before {
content: "";
background: url("img/line_07.svg") no-repeat center/contain;
width: 40.78vw;
aspect-ratio: 557 / 527;
position: absolute;
top: 11.27vw;
right: -25.4vw;
z-index: 1;
}
.recruitment #ttl:not(:has(.max))::before {
top: 5.2vw;
right: -31.11vw;
}
.work article.bg_primary::after {
top: 8.42vw;
right: -31.48vw;
z-index: 0;
}
.development #ttl::before,
.welfare #ttl::before {
top: 240%;
right: -31.26vw;
z-index: 0;
}
.interview #ttl::before {
top: 19.62vw;
right: -31.48vw;
z-index: -1;
}
.staff #ttl::before {
top: 23.87vw;
z-index: -1;
}
.work + footer::after {
content: "";
background: url("img/line_08.svg") no-repeat center/contain;
width: 31.92vw;
aspect-ratio: 436 / 536;
position: absolute;
top: -17.57vw;
left: -11.57vw;
}

/* WP */
.no-width-limit .wp-block-column {
width: auto !important;
max-width: none !important;
flex-basis: auto !important;
flex-grow: 0 !important;
}
.grecaptcha-badge {
visibility: hidden;
}
#autozip {
display: none !important;
}
.wp-block-list {
list-style: initial;
margin: revert;
padding: revert;
}
ol.wp-block-list {
list-style-type: decimal;
}
.wp-block-embed iframe {
width: 100%;
height: auto;
aspect-ratio: 16 / 9;
}


/* header
------------------------------------------------------------ */
header {
width: 100%;
position: absolute;
top: 0;
left: 0;
z-index: 3;
}
header p.EN {
clip-path: polygon(0 0,100% 0,calc(100% - 2.5vw) 100%,0 100%);
font-size: 1.8rem;
line-height: 2;
padding: 0 5rem 0 6%;
display: inline-block;
}
header article {
margin: 2rem 0;
padding: 2rem 0;
}
header article::before {
content: "";
background: #FFF;
width: 100%;
height: 100%;
border-radius: 0 100vh 100vh 0;
position: absolute;
top: 0;
left: -4%;
}
header section {
display: flex;
justify-content: space-between;
align-items: center;
gap: 5rem;
}
header h1 {
max-width: 26.67%;
}
header nav {
flex: 1;
}
header nav ul {
display: flex;
justify-content: center;
gap: 5rem;
}
header nav ul li {
overflow: hidden;
}
header nav ul li a {
letter-spacing: .05em;
height: 1.2em;
display: block;
position: relative;
}
header nav ul li a span {
display: block;
transition: transform .3s ease;
}
header nav ul li a span:first-child {
transform: translateY(0);
}
header nav ul li a span:last-child {
position: absolute;
top: 0;
left: 0;
transform: translateY(100%);
}
header nav ul li a:hover span:first-child {
transform: translateY(-100%);
}
header nav ul li a:hover span:last-child {
color: var(--color-primary);
transform: translateY(0);
}

header nav.active {
background: #FFF;
display: block;
padding: 6rem 6rem 8rem;
outline: 1px solid var(--color-primary);
outline-offset: -2rem;
border-radius: 1rem;
position: fixed;
top: 1rem;
right: 1rem;
z-index: 3;
animation: pulse .4s ease;
}
header nav.active ul {
display: block;
}
header nav.active li.none {
display: block;
}
header nav.active li {
font-size: 1.8rem;
margin-top: 3rem;
}

/* Triple Menu */
#triple {
display: none;
background: #FFF;
width: 6rem;
height: 6rem;
padding: 2rem 1.4rem 0;
border-radius: 50%;
cursor: pointer;
position: fixed;
top: 1rem;
right: 1rem;
z-index: 4;
}
#triple span {
background: var(--color-primary);
width: 100%;
height: 1px;
margin: 0 auto .8rem;
display: block;
transition: all .2s ease-in-out;
}
#triple span:last-child {
margin-bottom: 0;
}
#triple.open span:nth-child(1) {
transform: translateY(.9rem) rotate(-225deg);
}
#triple.open span:nth-child(2) {
transform: scaleX(0);
}
#triple.open span:nth-child(3) {
transform: translateY(-.9rem) rotate(225deg);
}
#triple.show {
display: block;
animation: pulse .4s ease;
}


/* footer
------------------------------------------------------------ */
footer {
padding-top: 4vw;
position: relative;
}
footer section {
letter-spacing: .05em;
}
footer p.EN {
font-size: 2rem;
letter-spacing: .1em;
padding: 2rem 0;
}
footer nav > ul {
margin-top: 2rem;
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 4rem;
}
footer nav ul a:hover {
color: var(--color-sky);
}
footer nav > ul > li:not(:first-child) {
padding-left: 3rem;
border-left: 1px solid #FFF;
}
footer nav ul ul {
margin-top: 2rem;
}
footer nav ul ul li {
font-size: 1.4rem;
font-weight: 400;
margin-bottom: .5em;
}
footer nav ul ul li::before {
content: "・";
}
footer hr {
margin: 3rem 0;
border: none;
border-bottom: 1px solid #FFF;
}
footer address {
font-style: normal;
display: flex;
justify-content: space-between;
gap: 3rem;
}
footer dl {
margin-bottom: 2rem;
display: flex;
align-items: center;
flex: 1;
gap: 3rem;
}
footer dt {
white-space: nowrap;
}
footer dd {
font-size: 1.5rem;
font-weight: 400;
line-height: 1.8;
flex: 1;
}
footer p.bg_blk {
font-size: 1.4rem;
font-weight: 300;
padding: 1.5rem;
}

/* #pagetop */
#pagetop {
display: none;
position: fixed;
right: 1rem;
bottom: 1rem;
z-index: 1;
animation: pulse .4s ease;
}
#pagetop a {
background: #FFF;
width: 6rem;
height: 6rem;
display: block;
border-radius: 50%;
text-indent: 100%;
white-space: nowrap;
overflow: hidden;
position: relative;
}
#pagetop a::before {
content: "";
width: 2rem;
height: 2rem;
margin: 0 auto;
display: block;
border-top: 1px solid var(--color-primary);
border-right: 1px solid var(--color-primary);
transform: rotate(-45deg);
position: absolute;
top: 2.5rem;
right: 2rem;
}


/* main
------------------------------------------------------------ */
/* #ttl */
#ttl:has(.max) {
margin-bottom: 5vw;
}
#ttl:has(.max) section {
position: absolute;
left: 50%;
bottom: -5vw;
transform: translateX(-50%);
}
#ttl:not(.max) section {
padding-top: 20rem;
z-index: 2;
}
#ttl h1 {
font-size: 8.78vw;
padding-left: 2rem;
}
#ttl:not(:has(.max)) .go_entry {
bottom: -6vw;
}
.work #ttl:not(.max)::before {
display: none;
}

#breadcrumb {
padding: 0 2rem 2rem;
}

.arw {
margin-bottom: 4rem;
}
.arw > * {
padding-bottom: 3rem;
position: relative;
}
.arw > *::before,
.arw > *::after {
content: "";
background: var(--color-primary);
width: 3rem;
height: 1px;
position: absolute;
bottom: 0;
}
.arw > *::before {
left: 50%;
transform: rotate(-35deg);
transform-origin: left center;
}
.arw > *::after {
right: 50%;
transform: rotate(35deg);
transform-origin: right center;
}

.line {
margin-bottom: 4rem;
}
.line > * {
padding-bottom: 1.2rem;
position: relative;
}
.line > *::before {
content: "";
background: var(--color-primary);
width: 100%;
height: 5px;
position: absolute;
bottom: 0;
left: 0;
}

.up {
margin: calc(-4vw - 1em) auto 4vw;
}
:has(> .up) {
scroll-margin-top: calc(4vw + 1em);
display: flow-root;
}

/* .go_entry */
.go_entry {
max-width: 17vw;
position: absolute;
bottom: 6vw;
right: 0;
}
.go_entry a img {
transition: .5s;
}
.go_entry a:hover img {
transform: scale(1.1);
transition: .5s;
}

/* .more */
.more a {
background: url("img/more_w.svg") no-repeat right .5em center;
background-color: var(--color-primary-light);
color: #FFF;
letter-spacing: .05em;
white-space: nowrap;
text-align: center;
padding: .8em 2.5em;
display: inline-block;
border-radius: 100vh;
border: solid 1px var(--color-primary-light);
}
.more a:hover,
.more.reverse a {
background: url("img/more_p.svg") no-repeat right .5em center;
background-color: #FFF;
color: var(--color-primary);
}
.more.reverse a {
border: solid 1px #FFF;
}
.more.reverse a:hover {
background: url("img/more_w.svg") no-repeat right .5em center;
background-color: var(--color-primary-light);
color: #FFF;
}

/* .home
----------------------------------- */
/* #kv */
#kv section {
position: absolute;
left: 50%;
bottom: -5vw;
transform: translateX(-50%);
z-index: 1;
}
#kv h2 {
font-size: 8.05vw;
color: #FFF;
}
#kv p.stroke_wht {
font-size: 9.52vw;
-webkit-text-stroke: 1.6px #FFF;
white-space: nowrap;
}

#kv div.max {
position: relative;
z-index: 1;
}
#kv .go_entry {
top: 4vw;
bottom: auto;
}

/* #about */
#about {
padding: 5vw 0 8vw;
}
#about figure.flex {
align-items: flex-end;
}
#about figure.flex figcaption {
flex: 0 0 50%;
padding: 0 0 8vw 1em;
}
#about figure.flex > div {
flex: 0 0 55%;
margin-right: -5%;
}

#about::before {
content: "";
background: url("img/bg_logo.svg") no-repeat center/contain;
width: 22.33vw;
aspect-ratio: 305 / 398;
position: absolute;
top: 5vw;
right: -1.8vw;
}

/* #news */
#news.flex {
align-items: center;
gap: 5vw;
margin: -11vw auto 5vw;
padding: 3vw 5vw;
}
.news-list {
flex: 1;
}
.news-list li:not(:last-child) {
border-bottom: solid 1px var(--color-line);
}
.news-list a {
display: flex;
padding: 1.5em 0;
}
.news-list time {
flex: 0 0 6em;
}
.news-list p {
flex: 1;
color: var(--color-primary);
line-height: 1.6;
padding-left: 1em;
border-left: solid 1px var(--color-line);
}
.news-list a:hover p {
color: var(--color-secondary);
transition: .3s;
}

/* .summary */
.summary {
display: flex;
gap: 2em;
position: relative;
z-index: 1;
}
.summary > div {
flex: 0 0 51%;
}
.summary > div img {
border-radius: 0 2rem 2rem 0;
}
.summary figcaption {
flex: 1 1 49%;
padding: 0 1em;
}
.summary figcaption div {
max-width: 86%;
}

.summary.replace > div img {
border-radius: 2rem 0 0 2rem;
}
.summary.replace figcaption {
order: -1;
}
.summary.replace figcaption > div {
margin-left: auto;
}

.summary.v2 > div {
flex: 0 0 45%;
}
.summary.v2 figcaption {
flex: 1 1 55%;
padding: 0;
}
.summary.v2 figcaption > div {
max-width: calc(87.85% - 4vw);
}

/* #work */
#work {
padding: 3vw 0 8vw;
color: #FFF;
}
#work::before {
content: "";
background: url("img/home_work_bg.jpg") no-repeat center/cover;
width: 100%;
height: calc(100% - 13vw);
position: absolute;
left: 0;
bottom: 0;
z-index: -1;
}

/* #interview */
#interview {
padding: 11vw 0;
}

/* #job-info */
#job-info section {
padding: 5vw 0;
}
#job-info ul.flex {
position: relative;
z-index: 1;
}
#job-info section ul.flex {
justify-content: center;
gap: 5vw;
}
#job-info section ul.flex li {
padding: 4rem 7rem;
}
#job-info section ul.flex li figure {
min-height: 9rem;
margin-bottom: 1rem;
display: flex;
justify-content: center;
align-items: center;
}

/* .category
----------------------------------- */
div#news {
margin-bottom: 5rem;
padding: 3vw 8vw;
}
div#news .news-list a {
padding: 2.5em 0;
position: relative;
}
div#news .news-list li a::before,
div#news .news-list li a::after {
content: "";
background: var(--color-primary);
width: 8px;
height: 2px;
position: absolute;
top: calc(50% - 1px);
right: 2rem;
transform-origin: calc(100% - 1px) 50%;
}
div#news .news-list li a:hover::before,
div#news .news-list li a:hover::after {
background: var(--color-secondary);
}
div#news .news-list li a::before {
transform: rotate(47deg);
}
div#news .news-list li a::after {
transform: rotate(-47deg);
}
div#news .news-list p {
padding-right: 3rem;
}

/* .single
----------------------------------- */
#post {
margin-bottom: 8rem;
padding: 5vw 8vw;
}
.post {
margin: 2vw auto 4vw;
padding: 2vw 0;
border-top: solid 1px var(--color-line);
}
#post .more a {
padding: .8em 4em;
}

/* #post s_link */
#post_link,
#posts_link {
margin: 5rem auto 8rem;
display: flex;
flex-wrap: wrap;
justify-content: center;
}
#post_link li a,
#posts_link li a,
#posts_link li.active {
background: #FFF;
color: var(--color-primary);
width: 4rem;
height: 4rem;
margin: .5rem;
display: flex;
justify-content: center;
align-items: center;
border: 1px solid var(--color-primary);
}
#posts_link li a:hover,
#posts_link li.active {
background: var(--color-primary);
color: #FFF;
opacity: 1;
}
#post_link li a,
#posts_link li.prev a,
#posts_link li.next a {
background: none !important;
width: auto !important;
border: none !important;
}
#post_link li a:hover,
#posts_link li.prev a:hover,
#posts_link li.next a:hover {
color: #999;
}
#post_link li.more a {
background: url("img/more_w.svg") no-repeat right .5em center !important;
background-color: var(--color-primary-light) !important;
color: #FFF;
height: auto;
border: solid 1px var(--color-primary-light) !important;
}
#post_link li.more a:hover {
background: url("img/more_p.svg") no-repeat right .5em center !important;
background-color: #FFF !important;
color: var(--color-primary) !important;
}

/* .work
----------------------------------- */
.work article.bg_primary {
background: url("img/work_bg.jpg") no-repeat center/cover;
margin-bottom: 18rem;
padding: 5rem 0 2rem;
}
.work .summary.replace h2 em {
padding-top: 10vw;
}
.work .summary.replace h2 span {
position: absolute;
top: 0;
left: 7%;
}

/* .development
----------------------------------- */
#development {
margin-bottom: 8rem;
}
#development::before {
content: "";
background: #FFF;
width: 87.85%;
height: calc(100% - 6vw);
position: absolute;
top: 6vw;
left: 50%;
transform: translateX(-50%);
}
#development section {
padding: 0 4vw 4vw;
}
#development h3.line {
margin-bottom: 8rem;
}
#development ol.flex {
flex-wrap: wrap;
}
#development ol.flex > li {
background: var(--color-primary);
color: #FFF;
letter-spacing: .03em;
padding: 4vw 2.5vw;
display: flex;
flex-direction: column;
flex-basis: 25%;
position: relative;
}
#development ol.flex > li:nth-child(1) {
background: rgba(49,61,138,.15);
color: var(--color-primary);
}
#development ol.flex > li:nth-child(2) {
background: rgba(49,61,138,.25);
color: var(--color-primary);
}
#development ol.flex > li:nth-child(3) {
background: rgba(49,61,138,.5);
}
#development ol.flex li h1 {
font-size: 2.9rem;
font-weight: 500;
text-align: center;
}
#development ol.flex li h1 span {
font-size: 3.2rem;
line-height: 1.3;
text-align: left;
height: 3em;
margin: .3em auto;
display: inline-block;
}
#development ol.flex li h2 {
font-size: 2.6rem;
text-align: center;
margin-bottom: .8em;
padding: .5em;
border-top: 3px solid;
border-bottom: 3px solid;
}
#development ol.flex li h3 {
font-size: 2rem;
line-height: 1.6;
min-height: 3em;
margin-bottom: 1em;
display: flex;
align-items: center;
}
#development ol.flex li p {
line-height: 1.6;
font-weight: 400;
min-height: 6em;
margin-bottom: 1em;
}
#development ol.flex li ul.bg_wht.disc {
color: var(--color-primary);
font-size: 1.5rem;
margin-bottom: 1em;
padding: 1em .5em;
}
#development ol.flex li ul.bg_wht.disc li::before {
content: "●";
}
#development ol.flex li div:has(h4) {
margin-top: auto;
}
#development ol.flex li h4 {
font-size: 2rem;
margin-bottom: .5em;
}
#development ol.flex li div ul.disc {
font-size: 1.7rem;
min-height: 7em;
}
#development ol.flex li >*:not(figure) {
position: relative;
z-index: 1;
}
#development ol.flex li figure {
width: 150%;
position: absolute;
right: -50%;
bottom: 0;
}

#training section {
margin-bottom: 12rem;
}
#training .summary.v2 figcaption > div {
max-width: 100%;
}
#training .summary.v2 .bg_primary {
padding: 3rem 0 6rem;
position: relative;
}
#training .summary.v2 .bg_primary::before {
content: "";
background: var(--color-primary);
width: 300%;
height: 150%;
position: absolute;
top: 0;
left: -150%;
z-index: -1;
}

.card--outlined {
flex-wrap: wrap;
gap: 3rem;
}
.card--outlined li {
background: #FFF;
margin-bottom: 3rem;
padding: 3rem;
border: .5rem solid var(--color-primary);
border-radius: 3rem;
}
.card--outlined li h1 {
color: var(--color-primary);
font-size: 2.7rem;
letter-spacing: .05em;
white-space: nowrap;
text-align: center;
margin-bottom: .5em;
}
.card--outlined li h1 span {
display: inline-block;
}
.card--outlined li h1 small {
font-size: 2rem;
font-weight: 500;
margin-top: .5em;
padding: .5em 2em;
display: block;
border-top: .5rem solid var(--color-primary);
}
.card--outlined li p {
font-weight: 400;
letter-spacing: .03em;
line-height: 1.7;
}
.card--outlined.flex li {
flex-basis: calc((100% - 6rem) / 3);
}
.card--outlined li.flex {
align-items: center;
gap: 3rem; 
}
.card--outlined li.flex h1 {
align-self: stretch;
text-align: center;
min-width: 10em;
margin-bottom: 0;
padding-right: 3rem;
display: flex;
justify-content: center;
align-items: center;
border-right: .5rem solid var(--color-primary);
}
.card--outlined li.flex h1 span.bg_primary {
font-size: 1.8rem;
margin-top: 1rem;
padding: .5em 1.5em;
display: block;
border-radius: 50vh;
}
.card--outlined li.flex p {
padding: .5em 0;
}
.card--outlined li.flex div.flex {
align-items: center;
gap: 3rem; 
}

/* .welfare
----------------------------------- */
#welfare {
margin-bottom: 20rem;
}
#welfare::before {
content: "";
background: #FFF;
width: 87.85%;
height: calc(100% - 6vw);
position: absolute;
top: 6vw;
left: 50%;
transform: translateX(-50%);
}
#welfare section {
padding: 0 4vw 4vw;
}

.bg {
padding: 4rem;
}
.bg h3 {
margin: -6rem 0 3rem;
flex-wrap: wrap;
align-items: flex-end;
gap: 2rem;
}
.bg div.flex {
flex-wrap: wrap;
gap: 2rem;
}
.bg div.flex ul {
flex-basis: calc((100% - 2rem) / 2);
}

.card--flat {
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 3rem;
}
.card--flat li.card--tall {
grid-column: 1;
grid-row: 1 / span 2;
}
.card--flat li {
background: #FFF;
text-align: center;
padding: 3rem 2rem;
}
.card--flat h4 {
color: var(--color-primary);
font-size: 2.5rem;
letter-spacing: .05em;
white-space: nowrap;
margin-bottom: .5em;
padding-bottom: .5em;
border-bottom: .1rem solid var(--color-primary);
}
.card--flat p {
font-weight: 700;
line-height: 1.7;
}
.card--flat p.m {
font-weight: 500;
}
.card--flat p.add {
padding: 1.5em 0;
}

/* .interview
----------------------------------- */
.interview {
padding-bottom: 12rem;
}
.card--staff {
margin: 9rem auto 6rem;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 6vw;
}
.card--staff.col-2 {
grid-template-columns: repeat(2, 26%);
justify-content: center;
gap: 12vw;
}
.card--staff li.flex {
flex-direction: column;
margin-bottom: 6rem;
padding-top: 6vw;
position: relative;
}
.card--staff h2 {
color: var(--color-primary);
font-size: 2.2rem;
position: absolute;
top: 0;
left: 1.5vw;
}
.card--staff h2 span.stroke {
font-size: 8.57vw;
line-height: 1;
margin-left: -1.5vw;
display: block;
}
.card--staff h3 {
position: absolute;
top: 0;
right: -2vw;
}
.card--staff h3 span {
background: #FFF;
color: var(--color-primary);
font-size: 2.2rem;
letter-spacing: .08em;
white-space: nowrap;
margin-left: 1rem;
padding: 1em .5em;
display: inline-block;
}
.card--staff h3 span:nth-of-type(2) {
margin-top: 2em;
}
.card--staff h3 span:nth-of-type(3) {
margin-top: 4em;
}
.card--staff figcaption {
padding: 3rem 0;
}
.card--staff h4 {
color: var(--color-primary);
font-size: 2.5rem;
font-weight: 500;
letter-spacing: .05em;
margin-bottom: 1rem;
}
.card--staff h4 small {
font-size: 1.8rem;
margin: 0 1rem;
}
.card--staff figcaption p {
font-size: 1.7rem;
line-height: 1.7;
letter-spacing: .05em;
}
.card--staff .more {
margin-top: auto;
}

.interview ul.flex {
justify-content: center;
gap: 8rem;
}

/* .staff
----------------------------------- */
.staff {
padding-bottom: 12rem;
}

.profile {
padding-bottom: 12rem;
}
.profile figure.flex {
gap: 5vw;
}
.profile figure.flex > div {
flex: 0 0 51%;
}
.profile figure.flex > div img {
border-radius: 3rem;
}
.profile figure.flex figcaption {
flex: 1 1 49%;
}
.profile figure.flex .bg_primary {
padding: 3rem 0 6rem;
position: relative;
}
.profile figure.flex .bg_primary::before {
content: "";
background: var(--color-primary);
width: 300%;
height: 100%;
position: absolute;
bottom: 0;
left: -150%;
z-index: -1;
}
.profile figure.flex figcaption h2 {
display: flex;
align-items: center;
}
.profile figure.flex figcaption h2 span {
padding-left: 1rem;
}
.profile figure.flex figcaption h4 small {
margin: 0 1rem;
}

.advantage section {
max-width: 860px;
padding-bottom: 12rem;
}

.question {
padding-bottom: 12rem;
}
.question.bg_wht {
margin-bottom: 12rem;
padding: 6rem 0;
}

.schedule section {
max-width: 860px;
padding-bottom: 12rem;
}
ol.flow {
margin-top: 8rem;
position: relative;
z-index: 1;
}
ol.flow::before {
content: "";
background: var(--color-primary);
width: 1rem;
height: calc(100% - 9em);
position: absolute;
top: 6.5rem;
left: 6.5rem;
transform: translateX(-50%);
z-index: -1;
}
ol.flow li {
min-height: 10em;
position: relative;
}
ol.flow li time {
background: #FFF;
font-size: 2.3rem;
color: var(--color-primary);
width: 13rem;
height: 13rem;
display: flex;
justify-content: center;
align-items: center;
border: .5rem solid var(--color-primary);
border-radius: 50%;
position: absolute;
top: 0;
left: 0;
z-index: 1;
}
ol.flow li p {
background: var(--color-primary);
font-size: 2.3rem;
color: #FFF;
width: 100%;
height: 9rem;
padding: 1em 1em 1em 5.5em;
display: flex;
align-items: center;
border-radius: 100vh;
position: absolute;
top: 1em;
left: 1em;
}

.to-you {
margin-bottom: 18rem;
}
.to-you::before {
content: "";
background: var(--color-primary);
width: 97%;
height: calc(100% - 1vw);
border-radius: 0 100vh 100vh 0;
position: absolute;
top: 5vw;
left: 0;
z-index: -1;
}
.to-you section {
color: #FFF;
text-align: center;
max-width: 600px;
}
.to-you h2 {
font-size: 7.83vw;
}

/* .recruitment
----------------------------------- */
.recruitment .summary {
padding-bottom: 2.5rem;
}
.recruitment .summary::before {
content: "";
background: var(--color-primary);
width: 100%;
height: calc(100% - 10rem);
position: absolute;
left: 0;
bottom: 0;
z-index: -1;
}
.recruitment .summary figcaption {
padding-top: 4rem;
}
ul.disc li {
padding: 0 0 .5em 1em;
position: relative;
}
ul.disc li::before {
content: "・";
position: absolute;
top: 0;
left: 0;
}
#recruitment {
padding: 8rem 0;
}
#recruitment ul.more {
margin-top: 6rem;
justify-content: center;
gap: 2rem;
}
#recruitment ul.more a,
#recruitment ul.more .active a:hover {
background: #FFF;
color: var(--color-primary);
padding: .8em 5em;
border: solid 3px var(--color-primary);
}
#recruitment ul.more a:hover,
#recruitment ul.more .active a {
background: var(--color-primary);
color: #FFF;
}

.tbl th {
color: var(--color-primary);
font-weight: 500;
white-space: nowrap;
text-align: left;
padding: .8em .3em;
border-bottom: solid 1px var(--color-primary);
}
.tbl td {
font-weight: 400;
padding: .8em 0 .8em 2em;
border-bottom: solid 1px var(--color-line);
}
.tbl tr:last-child > * {
border-bottom: none;
}
.tbl a {
color: var(--color-primary);
font-weight: 700;
text-decoration: underline;
}
.tbl a:hover {
text-decoration: none;
}

/* .entry
----------------------------------- */
.fa-phone {
background: #FFF;
color: var(--color-primary);
font-size: 2.4rem;
text-align: center;
line-height: 3.6rem;
width: 3.6rem;
height: 3.6rem;
border-radius: 50%;
}
.entry article.bg_primary {
padding: 4rem 0 8rem;
}





@media (max-width: 1024px) {

/* set
------------------------------------------------------------ */
.nonpc {
display: none;
}

}


@media (max-width: 1023px) {

/* set
------------------------------------------------------------ */
.pc {
display: none;
}
.smd,.smd-block {
display: block;
}

/* common
------------------------------------------------------------ */
/* layout */
section {
width: 92%;
}
.narrow {
width: 100%;
padding: 5vw;
}

/* footer
------------------------------------------------------------ */
footer dl {
display: block;
}

/* main
------------------------------------------------------------ */
/* #ttl */
#ttl div.max img {
aspect-ratio: 2 / 1;
object-fit: cover;
}

/* .home
----------------------------------- */
/* #about */
#about figure.flex figcaption {
padding:  3rem 0 0;
}
#about figure.flex > div {
max-width: 50%;
margin-left: auto;
}

/* #news */
#news.flex > div {
display: flex;
justify-content: space-between;
align-items: center;
gap: 3rem;
}

/* .summary */
.summary {
gap: 1em;
}
.summary > div {
flex: 0 0 40% !important;
}
.summary figcaption {
flex: 1 1 60% !important;
padding: 0 .5em;
}
.summary figcaption div,
.summary.v2 figcaption > div {
max-width: 94%;
}

/* .category
----------------------------------- */
div#news {
padding: 3vw 5vw;
}
div#news .news-list a {
padding: 1.5em 0;
}
div#news .news-list li a::before,
div#news .news-list li a::after {
right: 0;
}

/* .single
----------------------------------- */
#post {
padding: 5vw;
}

/* .development
----------------------------------- */
#development::before {
width: 100%;
}
#development section {
padding: 0 0 4vw;
}
#development ol.flex > li {
padding: 2.5vw;
flex-basis: 50%;
}
#development ol.flex li figure {
width: 100%;
right: -25%;
bottom: -5%;
}

.card--outlined {
gap: 2rem;
}
.card--outlined li {
margin-bottom: 2rem;
padding: 3rem 2rem;
border-radius: 2rem;
}
.card--outlined li h1 small {
padding: .5em 1em;
}

/* .welfare
----------------------------------- */
#welfare {
margin-bottom: 10rem;
}
#welfare::before {
width: 100%;
}
#welfare section {
padding: 0 0 4vw;
}

.bg {
padding: 2rem;
}

.card--flat {
gap: 2rem;
}
.card--flat li {
padding: 2rem 1rem;
}
.card--flat li p br {
display: none;
}

/* .interview
----------------------------------- */
.card--staff.col-2 {
grid-template-columns: repeat(2, 36%);
}
.card--staff h3 {
right: -3vw;
}
.card--staff h3 span {
font-size: 1.6rem;
}

}


@media (max-width: 540px) {

/* set
------------------------------------------------------------ */
html {
font-size: calc(var(--font-size-base) * .8);
}
body {
font-size: 2rem;
}
.smd,
.smp-none {
display: none;
}
.smp,.smp-block {
display: block;
}
br.smp {
font-size: 0;
}

/* common
------------------------------------------------------------ */
/* font */
.lh21 {line-height: 2;}
.lh22 {line-height: 2;}
.lh23 {line-height: 2;}
.lh24 {line-height: 2;}
.lh25 {line-height: 2;}
.lh26 {line-height: 2;}
.f10 {font-size: 1.4rem;}
.f11 {font-size: 1.5rem;}
.f12 {font-size: 1.6rem;}
.f13 {font-size: 1.7rem;}
.f14 {font-size: 1.8rem;}
.f15 {font-size: 1.9rem;}
.f16 {font-size: 2rem;}
.f17 {font-size: 2rem;}
.f18 {font-size: 2rem;}
.f19 {font-size: 2rem;}

/* style */
.smp-center {
text-align: center;
}
.smp-left {
text-align: left;
}
.round {
border-radius: 2rem;
}

/* WP */
.is-layout-flex.smp-block {
display: block !important;
}

/* header
------------------------------------------------------------ */
header p.EN {
font-size: 1.3rem;
}
header article {
margin: 1rem 0;
padding: 1rem 0;
}
header article::before {
width: 65%;
}
header h1 {
max-width: 50%;
}
header nav {
display: none;
}

header nav.active li {
font-size: 2.1rem;
}

/* Triple Menu */
#triple {
display: block;
}

/* footer
------------------------------------------------------------ */
footer {
padding-top: 6rem;
}
footer h1 img {
max-width: 70%;
}
footer nav > ul {
justify-content: space-between;
gap: 2rem;
}
footer nav > ul > li {
flex-basis: calc(50% - 1rem);
padding-left: 0 !important;
border-left: none !important;
}
footer nav ul ul li {
font-size: 1.6rem;
}
footer address {
flex-direction: column;
gap: 1rem;
}
footer dd {
font-size: 1.7rem;
}
footer p.bg_blk {
text-align: left;
}

/* main
------------------------------------------------------------ */
/* #ttl */
#ttl:not(.max) section {
padding-top: 12rem;
}
#ttl h1 {
padding-left: 0;
}

#breadcrumb {
padding: 0 0 2rem;
}

/* .go_entry */
.go_entry {
max-width: 20vw;
}

/* .home
----------------------------------- */
/* #kv */
#kv div.max img {
aspect-ratio: 1 / 1;
object-fit: cover;
}
#kv .go_entry {
top: -4vw;
}

/* #news */
#news.flex {
padding-bottom: 8rem;
}
#news.flex h2 {
margin-bottom: 2rem;
}
#news.flex .more {
position: absolute;
left: 50%;
bottom: 2rem;
transform: translateX(-50%);
}
.news-list {
margin-bottom: 3rem;
}
.news-list a {
display: block;
padding: 1em 0;
}
.news-list p {
padding: .5rem 0 0;
border-left: none;
}

/* .summary */
.summary {
display: block;
}
.summary > div {
max-width: 86%;
margin-bottom: 2rem;
}
.summary figcaption {
padding: 0;
}
.summary figcaption div {
margin: 0 auto;
}

.summary.replace > div {
margin-left: auto;
}

/* #work */
#work .summary .stroke {
-webkit-text-stroke: 1px #FFF;
margin-bottom: 0;
}

/* #job-info */
#job-info section {
padding: 8rem 5%;
}
#job-info section ul.flex {
flex-direction: column;
}

/* .work
----------------------------------- */
.work .summary.replace h2 em {
padding-top: 0;
}
.work .summary.replace h2 span {
position: static;
}

/* .development
----------------------------------- */
#development ol.flex {
display: block;
width: 90%;
margin: 0 auto 3rem;
}
#development ol.flex > li {
padding: 4rem 2rem;
display: block;
}
#development ol.flex li h1 span {
height: auto;
margin: .3em auto 1em;
}
#development ol.flex li h1 span br,
#development ol.flex li h3 br {
display: none;
}
#development ol.flex li h3,
#development ol.flex li p,
#development ol.flex li div ul.disc {
min-height: auto;
}
#development ol.flex li h3 {
font-size: 2.3rem;
}
#development ol.flex li ul.bg_wht.disc {
font-size: 1.8rem;
padding: 1em;
}
#development ol.flex li div ul.disc {
font-size: 2rem;
}
#development ol.flex li figure {
position: static;
}

#training .summary h2 {
margin-bottom: 3rem;
padding: 0 4%;
}

.card--outlined {
display: block;
width: 90%;
margin: 0 auto;
}
.card--outlined li.flex {
display: block; 
}
.card--outlined li.flex h1 {
min-width: auto;
margin-bottom: .5em;
padding-right: 0;
border-right: none;
}
.card--outlined li.flex div.flex {
display: block;
}

/* .welfare
----------------------------------- */
.card--flat {
grid-template-columns: 1fr;
}
.card--flat li {
padding: 2rem;
}
.card--flat li p br {
display: block;
}

/* .interview
----------------------------------- */
.card--staff {
width: 80%;
margin: 6rem auto;
grid-template-columns: 1fr;
}
.card--staff.col-2 {
grid-template-columns: 1fr;
}
.card--staff li.flex figure > div img {
aspect-ratio: 3 / 4;
object-fit: cover;
}
.card--staff h2 {
font-size: 3rem;
}
.card--staff h2 span.stroke {
font-size: 16vw;
}
.card--staff h3 {
top: -5vw;
right: -5vw;
}
.card--staff h3 span {
font-size: 2.2rem;
}
.card--staff h4 {
font-size: 2.8rem;
}
.card--staff h4 small {
font-size: 2.1rem;
}
.card--staff figcaption p {
font-size: 2rem;
}

.interview ul.flex {
width: 80%;
margin: 0 auto;
flex-direction: column;
}

/* .staff
----------------------------------- */
.profile figure.flex {
flex-direction: column;
}
.profile figure.flex > div {
width: 80%;
margin: 0 auto;
}
.profile figure.flex figcaption h2 {
position: absolute;
top: -4rem;
left: 2rem;
}
.profile figure.flex figcaption h2 span {
font-size: 16vw;
}

.question h2 {
font-size: 2.6rem;
}

ol.flow::before {
height: calc(100% - 12rem);
top: 5rem;
left: 5rem;
}
ol.flow li {
min-height: 6.5em;
}
ol.flow li time {
width: 10rem;
height: 10rem;
}
ol.flow li p {
height: 8rem;
padding: 1em 1em 1em 5em;
top: 1rem;
left: 0;
}

.to-you::before {
width: 100%;
height: 130%;
border-radius: 0;
top: -10%;
}

/* .recruitment
----------------------------------- */
.recruitment .summary h3 {
color: #FFF;
margin-bottom: 3rem;
}
#recruitment ul.more a,
#recruitment ul.more .active a:hover {
padding: .8em 2.5em;
}

.tbl th {
padding: .8em .3em 0;
display: block;
border-bottom: none;
}
.tbl td {
padding: .3em .3em .8em;
display: block;
}

}