@charset "UTF-8";
/*
Theme Name:  髙松建設株式会社
Template: twentynineteen
Author:  髙松建設株式会社
Author URI:
Description:
Version: 1.0.0
Updated: 2026-03-06
*/

/* Color Scheme
-----------------------------------------------------

	=THEME COLOR = #007365

-----------------------------------------------------
*/

@import url(reset.css);
@import url(wp-customize.css);

@font-face {
    font-family: 'Brother-1816';
    font-style: normal;
    font-weight: normal;
    src: local('Brother-1816'), url('assets/fonts/Brother-1816-Regular.woff2') format('woff2');
}

@font-face {
    font-family: 'Brother-1816 Medium';
    font-style: normal;
    font-weight: normal;
    src: local('Brother-1816 Medium'), url('assets/fonts/Brother-1816-Medium.woff2') format('woff2');
}

@font-face {
    font-family: 'Brother-1816 Bold';
    font-style: normal;
    font-weight: normal;
    src: local('Brother-1816 Bold'), url('assets/fonts/Brother-1816-Bold.woff2') format('woff2');
}

@font-face {
    font-family: 'Brother-1816 Black';
    font-style: normal;
    font-weight: normal;
    src: local('Brother-1816 Black'), url('assets/fonts/Brother-1816-Black.woff2') format('woff2');
}

/* CSS Variable
----------------------------------------------------- */
:root {
    --color-text-basic: #000;
    --color-primary: #007365;
    --color-secondary: #e6f4f0;

    --color-orange: #ef856e;
    --color-emerald: #5bd2b4;
}

/*
-----------------------------------------------------

	=GLOBAL LAYOUT

-----------------------------------------------------
*/
* {
    margin: 0;
    padding: 0;
}

*,
*:before,
*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    font-family: 'Noto Sans JP', "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
    -webkit-font-smoothing: antialiased !important;
    -webkit-text-stroke: 1px transparent;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-rendering: optimizeLegibility;
    color: var(--color-text-basic);
    font-size: 10px;
    font-weight: 400;
    line-height: 2.0;
    word-wrap: break-word;
    letter-spacing: 0.0em;
}

body {
    font-size: 1.8rem;
}

body::before {
    content: "";
    position: fixed;
    z-index: -99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
pre,
dt,
dd,
li {
    line-height: 2.0;
}

p,
ul,
ol,
dl,
table {
    margin-bottom: 2em;
}

p:last-child,
ul:last-child,
ol:last-child,
dl:last-child,
table:last-child {
    margin-bottom: 0;
}

table {
    width: 100%;
    border-collapse: collapse;
    line-height: 1.8;
    text-align: left;
}

th,
td {
    padding: 1em 1.5em;
    vertical-align: top;
    border: none;
}

th {
    text-align: justify;
    font-weight: bold;
    padding-left: 0;
}

tr {
    border-bottom: solid 1px rgba(0, 0, 0, 0.1);
}

tr:last-child {}

hr {
    clear: both;
    border: none;
}

img {
    display: inline-block;
    vertical-align: bottom;
    max-width: 100%;
    height: auto;
}

a img {
    border: none;
}

a {
    color: var(--color-text-basic);
    text-decoration: underline;
}

a {
    cursor: pointer;
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

a:hover {
    opacity: 0.5;
    text-decoration: none;
}

/*::selection {
	background-color: rgba(0,0,0,0.25);
}*/
em {}

ol {
    counter-reset: number;
    list-style: none;
}

ol li {
    position: relative;
    padding-left: 2.5em;
}

ol li:not( :last-child) {
    margin-bottom: 1.5em;
}

ol li::before {
    position: absolute;
    left: 0;
    counter-increment: number;
    content: "(" counter(number)")";
    margin: 0 1.0em 0 0;
}

ol li ol:last-child {
    margin-bottom: 2em;
}

ol li ol li::before {
    content: "(" counter(number, lower-roman)")";
}

ol li ol li:not( :last-child) {
    margin-bottom: .5em;
}

strong {
    font-weight: bold;
}

iframe {
    display: block;
    max-width: 100%;
}

form {}

input[type=text],
input[type=email],
input[type=tel],
input[type=password],
textarea,
select {
    padding: 5px;
    font-size: 16px;
    font-weight: inherit;
    color: inherit;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

input[type=text],
input[type=email],
input[type=tel],
input[type=password],
textarea,
select {
    background-color: #eee;
    border: 1px solid #eee;
    line-height: 1;
    vertical-align: middle;
    max-width: 100%;
    border-radius: 5px;
}

textarea {}

input[type=text] {
    margin-bottom: 0.5em;
}

input[type=text]:last-child {
    margin-bottom: 0;
}

input[type=email] {}

input[type=submit] {
    cursor: pointer;
}

input[type=text]:focus,
textarea:focus {}

form ul {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

form ul li {
    display: inline-block !important;
}

form label {
    margin-right: 1.4em;
}

form input[type*="submit"] {
    display: block;
    width: 100%;
    max-width: 300px;
    margin: 0 auto 20px;
    padding: 1em 2em;
    border: none;
    background-color: #e45539;
    color: #fff;
    font-size: 1.0em;
    font-weight: bold;
    text-align: center;
    border-radius: 5px;
    cursor: pointer;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-transition: all ease-out 0.1s;
    -moz-transition: all ease-out 0.1s;
    -ms-transition: all ease-out 0.1s;
    transition: all ease-out 0.1s;
}

form input[type*="submit"]:hover {
    opacity: 0.7;
}

::placeholder {
    color: #ddd;
}



/*
-----------------------------------------------------

	=GLOBAL STYLE

-----------------------------------------------------
*/
#container {}

#main {
    position: relative;
    z-index: 2;
}

.c-wrapper {
    width: 1200px;
    max-width: 100%;
    margin: auto;
}

.u-wrapper-1120 {
    width: 1120px;
}

.u-wrapper-1080 {
    width: 1080px;
}

.u-wrapper-1000 {
    width: 1000px;
}

.u-wrapper-960 {
    width: 960px;
}

.u-wrapper-900 {
    width: 900px;
}

.u-wrapper-840 {
    width: 840px;
}

.u-wrapper-800 {
    width: 800px;
}

.u-wrapper-780 {
    width: 780px;
}

.u-wrapper-720 {
    width: 720px;
}

@media screen and (min-width: 0px) and (max-width: 1119px) {
    .c-wrapper {
        padding: 0 6.25vw;
    }
}

@media screen and (min-width: 800px) {
    #container {}
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #container {}

    .c-wrapper {
        padding: 0 6.25vw;
        margin: auto;
    }
}

/*
-----------------------------------------------------

	=MEDIA QUERIES RESPONSIVE STRUCTURE

-----------------------------------------------------
*/

/* DESKTOP
----------------------------------------------------- */
@media screen and (min-width: 800px) {
    .sp {
        display: none !important;
    }

    body {
        min-width: 1120px;
    }
}

/* SMARTPHONE
----------------------------------------------------- */
@media screen and (min-width: 0px) and (max-width: 799px) {
    .pc {
        display: none !important;
    }

    html {
        font-size: 10px;
    }

    body {
        font-size: 1.2rem;
        letter-spacing: 0;
    }

    /* APPERANCE
	--------------------------------------------------*/
    input[type="button"],
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="submit"],
    select {
        -webkit-appearance: none;
        border-radius: 0;
    }

    iframe {
        width: 100%;
        max-height: 240px;
    }

    th,
    td {
        font-size: 1.2rem;
        padding: 1em 0.5em;
    }
}



/* =ANIMATION - BACKGROUND
----------------------------------------------------- */
/* スクロールで背景色を変更 (script.jsに記述あり) */
.js-bg-magic {
    position: relative;
}

.js-bg-magic::before {
    content: "";
    position: fixed;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: all 1.6s ease 0s;
    -moz-transition: all 1.6s ease 0s;
    -ms-transition: all 1.6s ease 0s;
    transition: all 1.6s ease 0s;
}

.js-bg-magic.show::before {
    opacity: 0.70;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/* =ANIMATION - INVIEW.JS (jquery.inview.js)
----------------------------------------------------- */
.js-inview {
    transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -webkit-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -moz-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -ms-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -o-transition: 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
}

.js-inview.inview-with-delay {
    transition: 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -webkit-transition: 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -moz-transition: 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -ms-transition: 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -o-transition: 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
}

.js-inview.inview-fadein {
    opacity: 0;
}

.js-inview.inview-fadein.is-show {
    opacity: 1;
}

.js-inview.inview-zoomin {
    opacity: 0;
    transform: scale(1.3);
    -webkit-transform: scale(1.3);
    -moz-transform: scale(1.3);
    -ms-transform: scale(1.3);
    -o-transform: scale(1.3);
    filter: blur(5px);
    -webkit-filter: blur(5px);
    -moz-filter: blur(5px);
    -ms-filter: blur(5px);
    -o-filter: blur(5px);
}

.js-inview.inview-zoomin.is-show {
    opacity: 1;
    filter: blur(0);
    -webkit-filter: blur(0);
    -moz-filter: blur(0);
    -ms-filter: blur(0);
    -o-filter: blur(0);
    transform: scale(1);
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
}

.js-inview.inview-zoom {
    opacity: 0;
    transform: scale(0.9);
    -webkit-transform: scale(0.9);
    -moz-transform: scale(0.9);
    -ms-transform: scale(0.9);
    -o-transform: scale(0.9);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    -o-backface-visibility: hidden;
}

.js-inview.inview-zoom.is-show {
    opacity: 1;
    transform: scale(1);
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
}

.js-inview.inview-zoom-slowly {
    transition: 12.0s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
    -webkit-transition: 12.0s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
    -moz-transition: 12.0s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
    -ms-transition: 12.0s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
    -o-transition: 12.0s cubic-bezier(0.19, 1, 0.22, 1) 0.4s;
    transform: scale(1);
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    -o-backface-visibility: hidden;
}

.js-inview.inview-zoom-slowly.is-show {
    transform: scale(1.025);
    -webkit-transform: scale(1.025);
    -moz-transform: scale(1.025);
    -ms-transform: scale(1.025);
    -o-transform: scale(1.025);
}

.js-inview.inview-blur {
    opacity: 0;
    filter: blur(100px);
    -webkit-filter: blur(100px);
    -moz-filter: blur(100px);
    -ms-filter: blur(100px);
    -o-filter: blur(100px);
}

.js-inview.inview-blur.is-show {
    opacity: 1;
    filter: blur(0);
    -webkit-filter: blur(0);
    -moz-filter: blur(0);
    -ms-filter: blur(0);
    -o-filter: blur(0);
}

.js-inview.inview-floatup {
    transition: .8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -webkit-transition: .8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -moz-transition: .8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -ms-transition: .8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;
    -o-transition: .8s cubic-bezier(0.19, 1, 0.22, 1) 0.2s;

    opacity: 0;
    transform: translate3d(0px, 200px, 0px);
    -webkit-transform: translate3d(0px, 200px, 0px);
    -moz-transform: translate3d(0px, 200px, 0px);
    -ms-transform: translate3d(0px, 200px, 0px);
    -o-transform: translate3d(0px, 200px, 0px);
}

.js-inview.inview-floatup.is-show {
    opacity: 1;
    transform: translate3d(0px, 0, 0px);
    -webkit-transform: translate3d(0px, 0, 0px);
    -moz-transform: translate3d(0px, 0, 0px);
    -ms-transform: translate3d(0px, 0, 0px);
    -o-transform: translate3d(0px, 0, 0px);
}

.js-inview.inview-floatintoright {
    opacity: 0;
    transform: translate3d(-40px, 0px, 0px);
    -webkit-transform: translate3d(-40px, 0px, 0px);
    -moz-transform: translate3d(-40px, 0px, 0px);
    -ms-transform: translate3d(-40px, 0px, 0px);
    -o-transform: translate3d(-40px, 0px, 0px);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    -o-backface-visibility: hidden;
}

.js-inview.inview-floatintoright.is-show {
    opacity: 1;
    transform: translate3d(0px, 0, 0px);
    -webkit-transform: translate3d(0px, 0, 0px);
    -moz-transform: translate3d(0px, 0, 0px);
    -ms-transform: translate3d(0px, 0, 0px);
    -o-transform: translate3d(0px, 0, 0px);
}

.js-inview.inview-floatintoleft {
    opacity: 0;
    transform: translate3d(40px, 0px, 0px);
    -webkit-transform: translate3d(40px, 0px, 0px);
    -moz-transform: translate3d(40px, 0px, 0px);
    -ms-transform: translate3d(40px, 0px, 0px);
    -o-transform: translate3d(40px, 0px, 0px);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -ms-backface-visibility: hidden;
    -o-backface-visibility: hidden;
}

.js-inview.inview-floatintoleft.is-show {
    opacity: 1;
    transform: translate3d(0px, 0, 0px);
    -webkit-transform: translate3d(0px, 0, 0px);
    -moz-transform: translate3d(0px, 0, 0px);
    -ms-transform: translate3d(0px, 0, 0px);
    -o-transform: translate3d(0px, 0, 0px);
}

.js-reveal {}

.js-reveal>*,
.js-reveal>*::after {
    animation-delay: 0.2s;
    animation-iteration-count: 1;
    animation-duration: 600ms;
    animation-fill-mode: both;
}

.js-reveal>* {
    position: relative;
    white-space: nowrap;
    cursor: default;
    display: inline-block;
    opacity: 0;
}

.js-reveal>*:not( :last-child) {
    margin-bottom: 5px;
}

.js-reveal.is-show>* {
    animation-name: clip-text;
}

.js-reveal>*::after {
    content: "";
    position: absolute;
    z-index: 999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-primary);
    transform: scaleX(0);
    transform-origin: 0 50%;
    pointer-events: none;
}

.js-reveal.is-show>*::after {
    animation-name: text-revealer;
}

@keyframes clip-text {
    0% {
        opacity: 0;
        clip-path: inset(0 100% 0 0);
    }

    50% {
        opacity: 1;
    }

    100% {
        opacity: 1;
        clip-path: inset(0 0 0 0);
    }
}

@keyframes text-revealer {

    0%,
    50% {
        transform-origin: 0 50%;
    }

    60%,
    100% {
        transform-origin: 100% 50%;
    }

    60% {
        transform: scaleX(1);
    }

    100% {
        transform: scaleX(0);
    }
}

@media screen and (min-width: 600px) {}

@media screen and (min-width: 0px) and (max-width: 599px) {
    .js-reveal {}

    .js-reveal>* {
        white-space: inherit;
    }
}

/*
-----------------------------------------------------

	=CORPORATE SITE

    PRELOADER
    HEADER
    NAVIGATION
    FOOTER
    COMMON PARTS
    TOP PAGE
    SUB PAGES

-----------------------------------------------------
*/


/*
-----------------------------------------------------

    =PRELOADER (imagesloaded.pkgd.min.js)

-----------------------------------------------------
*/

.js-imageloaded {}

.js-imageloaded.loaded {}


#progress,
#progress * {}

#progress {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    padding: 0;
    display: block;
    overflow: hidden;
    z-index: 999999;
}

#progress .progress-start {
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    z-index: 999999;
    opacity: 0;
    -webkit-transition: all cubic-bezier(0.230, 1.34494c, 0.320, 1.34494c) 1.2s;
    -moz-transition: all cubic-bezier(0.230, 1.34494c, 0.320, 1.34494c) 1.2s;
    -ms-transition: all cubic-bezier(0.230, 1.34494c, 0.320, 1.34494c) 1.2s;
    transition: all cubic-bezier(0.230, 1.34494c, 0.320, 1.34494c) 1.2s;
    display: none;
}

#progress.complete10 .progress-start {
    left: -100%;
}

#progress .progress-loading {
    background-color: #fff;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    z-index: 999999;
}

#progress .progress-loading .logo {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#progress .progress-loading .logo svg,
#progress .progress-loading .logo img {
    width: 250px;
    -webkit-transition: all cubic-bezier(0.190, 1.34494c, 0.220, 1.34494c) 0.8s;
    -moz-transition: all cubic-bezier(0.190, 1.34494c, 0.220, 1.34494c) 0.8s;
    -ms-transition: all cubic-bezier(0.190, 1.34494c, 0.220, 1.34494c) 0.8s;
    transition: all cubic-bezier(0.190, 1.34494c, 0.220, 1.34494c) 0.8s;
}

#progress,
#progress .progress-loading {
    -webkit-transition: all cubic-bezier(0.550, 0.055, 0.675, 0.190) 0.6s;
    -moz-transition: all cubic-bezier(0.550, 0.055, 0.675, 0.190) 0.6s;
    -ms-transition: all cubic-bezier(0.550, 0.055, 0.675, 0.190) 0.6s;
    transition: all cubic-bezier(0.550, 0.055, 0.675, 0.190) 0.6s;
}

#progress.complete100,
#progress.complete100 .progress-loading {
    left: 0%;
}

#progress.complete100 {
    opacity: 0;
    z-index: -9999;
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    @supports (-webkit-touch-callout: none) {
        #progress {
            height: -webkit-fill-available;
        }
    }

    #progress .progress-loading .logo img {
        width: 45%;
    }
}

/*
-----------------------------------------------------

	=HEADER (CORPORATE SITE)

-----------------------------------------------------
*/

/* 全ページ共通 - ヘッダー初期位置 */
.header-global {
    position: fixed;
    z-index: 9991;
    top: inherit;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    background-color: transparent;
}

.header-global,
.header-global * {
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.header-global>.l-inner {
    padding: 40px;
    align-items: flex-start;
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.header-global>.l-inner .l-header-left,
.header-global>.l-inner .l-header-right {
    display: flex;
    align-items: center;
}

.header-global>.l-inner .l-header-left {}

.header-global>.l-inner .l-header-right {}

.header-global>.l-inner .nav-pc {}

.header-global>.l-inner .nav-sp {}


.l-logo-recruitmentsite {
    position: relative;
    width: 126px;
    margin-right: 160px;
}

.l-logo-recruitmentsite a::after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 115%;
    margin: auto;
    display: flex;
    align-items: center;
    width: 10em;
    height: 25px;
    color: #aaa;
    padding: 0.2em 0;
    content: "RECRUITMENT SITE";
    font-family: "Brother-1816", sans-serif;
    font-size: 1.2rem;
    font-weight: normal;
    line-height: 1.0;
}

.l-logo-recruitmentsite a:hover {
    opacity: 1;
}

/* .header-global>.l-inner .l-header-left>.l-logo {
    position: relative;
    display: inline-block;
    vertical-align: top;
    max-width: 100%;
    background: url(assets/images/logo-white.webp) no-repeat;
    background-size: contain;
    margin: 0 0 0 0;
} */

.header-global>.l-inner .l-header-left>.l-logo img {
    display: block;
    opacity: 1;
}

/* 画面スクロール時 - 全ページ共通 */
.js-status-scrolled .header-global {}

@media screen and (min-width: 800px) {
    #main {}

    .js-header-indent #main {
        padding-top: 120px;
    }

    .header-global>.l-inner {
        min-width: 1380px;
    }

    .header-global>.l-inner .l-header-left,
    .header-global>.l-inner .l-header-right {
        height: 80px;
    }

    .header-global>.l-inner .l-header-left {
        background-color: #fff;
        padding: 0 40px;
        border-radius: 40px;
    }

    .header-global>.l-inner .l-header-right {}

    /* ヘッダー初期位置のみ - 全ページ共通 */
    .js-status-before-main .header-global {}

    .js-status-before-main .header-global>.l-inner {}

    .js-status-before-scroll .header-global>.l-inner .l-header-left,
    .js-status-before-scroll .header-global>.l-inner .l-header-right {}

    /* 画面スクロール時 - 全ページ共通 */
    .js-status-scrolled .header-global>.l-inner {}

    .js-status-scrolled .header-global>.l-inner .l-header-left,
    .js-status-scrolled .header-global>.l-inner .l-header-right .c-button-readmore {
        box-shadow: 10px 10px 30px rgba(0, 0, 0, .1);
    }

    /* ヘッダー初期位置 - 背景透過ver.*/
    .js-header-transparent {
        background-color: transparent;
    }

    .js-header-transparent.js-status-before-scroll .header-global>.l-inner {
        padding: 40px 80px;
    }

    /* .js-header-transparent.js-status-before-main .header-global {
        background-color: transparent;
    }

    .js-header-transparent.js-status-before-main .header-global,
    .js-header-transparent.js-status-before-main .header-global a {}

    .js-header-transparent.js-status-before-main .header-global>.l-inner .l-header-left .l-logo img {
        opacity: 0;
    }

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li,
    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li a {
        color: #fff;
    }

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li ul {
        background-color: transparent;
    }

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li ul li,
    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li ul li a {
        color: #fff;
    }

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li.has-child {}

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main>li>a::before {}

    .js-header-transparent.js-status-before-main .header-global>.l-inner .nav-pc ul.nav-main li.has-child::after {
        border-color: #fff;
    } */
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main {
        padding-top: 0;
    }

    .js-header-indent #main {
        padding-top: 80px;
    }

    .header-global {
        height: 60px;
        margin: 10px;
        width: calc(100% - 10px*2);
        background-color: #fff;
        border-radius: 35px;
    }

    .header-global>.l-inner {
        padding: 0 25px;
        height: 100%;
    }

    .header-global>.l-inner {
        align-items: center;
    }

    .header-global>.l-inner .l-header-left {
        width: 100%;
        padding: 15px 0;
        justify-content: flex-start;
    }

    .header-global>.l-inner .l-header-right {}

    .header-global>.l-inner .l-header-left .l-logo {
        margin: 0 0 0;
    }

    .l-logo-recruitmentsite {
        width: 80px;
    }

    .l-logo-recruitmentsite a {
        text-decoration: none;
    }

    .l-logo-recruitmentsite a::after {
        font-size: .9rem;
        position: static;
        height: auto;
    }

    /* オリジナル - ヘッダー - ENTRYボタン調整 */
    .header-global>.l-inner .l-header-right {
        padding-right: calc(65px - 25px);
    }

    .header-global>.l-inner .l-header-right .c-button-readmore {
        width: 120px;
        height: 44px;
        padding: 0.5em 1.5em;
        font-size: 1.2rem;
    }

    .header-global>.l-inner .l-header-right .c-button-readmore .l-japanese {
        display: none;
    }

    .header-global>.l-inner .l-header-right .c-button-readmore .l-arrow {
        background-color: transparent;
        right: 10px;
    }

    .header-global>.l-inner .l-header-right .c-button-readmore .l-arrow svg {
        fill: #fff;
    }

    /* ヘッダー初期位置 - 背景透過ver. */
    /* .js-header-transparent.js-status-before-main .header-global {
        background-color: transparent;
        box-shadow: none;
    }

    .js-header-transparent.js-status-before-main .header-global>.l-inner .l-header-left .l-logo {}

    .js-header-transparent.js-status-before-main .header-global>.l-inner .l-header-left .l-logo img {
        opacity: 0;
    }


    .js-header-transparent.js-status-before-main a.trigger-bars span {
        background-color: #fff;
    } */

    /* 画面スクロール時 - 全ページ共通 */
    .js-status-scrolled .header-global {
        box-shadow: 10px 10px 30px rgba(0, 0, 0, .1);
    }
}

@media screen and (min-width: 800px) and (max-width: 1399px) {}


/*
-----------------------------------------------------

	=NAVIGATION - PC

-----------------------------------------------------
*/

@media screen and (min-width: 800px) {

    /* =NAVIGATION - PC
	----------------------------------------------------- */
    .nav-pc {
        margin: 0 0 0 0;
    }

    .nav-pc .l-inner {
        line-height: 0;
    }

    .nav-pc * {
        -webkit-transition: all ease-out 0.2s;
        -moz-transition: all ease-out 0.2s;
        -ms-transition: all ease-out 0.2s;
        transition: all ease-out 0.2s;
    }

    .nav-pc ul.nav-main {
        display: flex;
        align-items: center;
        letter-spacing: 0;
        font-size: 0;
    }

    .nav-pc ul.nav-main li {
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 1.25;
        letter-spacing: 0.0em;
    }

    .nav-pc ul.nav-main li:not(:last-child) {
        margin: 0 2em 0 0;
    }

    .nav-pc ul.nav-main li a {
        position: relative;
        display: block;
        color: var(--color-text-basic);
        text-decoration: none;
    }

    .nav-pc ul.nav-main li a:hover {
        opacity: inherit;
    }

    /* 第1階層のみ */
    .nav-pc ul.nav-main>li>a {
        padding: 0.2em 0;
    }

    .nav-pc ul.nav-main>li>a:hover {
        opacity: 0.5;
    }

    .nav-pc ul.nav-main>li>a::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 0.0001%;
        height: 1px;
        background-color: var(--color-text-basic);
        -webkit-transition: all ease-out 0.1s;
        -moz-transition: all ease-out 0.1s;
        -ms-transition: all ease-out 0.1s;
        transition: all ease-out 0.1s;
    }

    .nav-pc ul.nav-main>li>a:hover::before {
        width: 100%;
    }

    /* 第2階層 (子要素にさらにulがある場合) */
    .nav-pc ul.nav-main li {
        position: relative;
    }

    .nav-pc ul.nav-main li.has-child {
        padding-right: 15px;
    }

    .nav-pc ul.nav-main li.has-child::after {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto 0;
        border-bottom: solid 1px var(--color-primary);
        border-right: solid 1px var(--color-primary);
        width: 6px;
        height: 6px;
        transform: rotate(45deg);
        -webkit-transition: all ease-out 0.2s;
        -moz-transition: all ease-out 0.2s;
        -ms-transition: all ease-out 0.2s;
        transition: all ease-out 0.2s;
    }

    .nav-pc ul.nav-main li ul {
        display: none;
        position: absolute;
        top: 100%;
        left: -20px;
        width: 17em;
        padding: 20px;
        padding-top: 10px;
        background-color: #fff;
        border-radius: 0 0 5px 5px;
    }

    .nav-pc ul.nav-main li:hover ul {
        display: block;
    }

    .nav-pc ul.nav-main li ul li {
        display: block;
        padding: 0.5em 0em;
        font-size: 85%;
        text-align: left;
        text-transform: none;
    }

    .nav-pc ul.nav-main li ul li a {
        padding: 0;
        color: var(--color-text-basic);
    }

    .nav-pc ul.nav-main li ul li a::before {}

    .nav-pc ul.nav-main li ul li a:hover {
        opacity: 0.5;
    }
}

/* =NAVIGATION - ACTION BUTTON （ここはスマホでも共通CSS）
----------------------------------------------------- */
/* 第1階層のみ - 特殊デザインのボタンを流用 */
.nav-action ul.nav-main {}

.nav-action ul.nav-main li {}

.nav-action ul.nav-main li>a {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* メガメニュー */
ul.nav-main li .l-megamenu {
    display: none;
    position: absolute;
    top: inherit;
    left: 0;
    right: 0;
    width: calc(100% - 40px*2);
    height: auto;
    margin: 0 auto;
}

.l-megamenu {}

.l-megamenu .l-inner {
    margin-top: 20px;
    border-radius: 40px;
    padding: 60px 0 0;
    background-color: #fff;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, .1);
}

.l-megamenu .l-inner .l-wrapper {}

.l-megamenu .l-inner .l-header {}

.l-megamenu .l-inner .l-content {}

.l-megamenu,
.l-megamenu a {
    color: #000 !important;
}

.l-megamenu .l-inner .l-content .l-thumbnail {
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 0.35em;
}

.l-megamenu .l-inner .l-content .l-mynavi {
    display: block;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 10px;
    border: solid 1px #00a9eb;
}

.l-megamenu .l-inner .l-content .l-mynavi:last-child {
    margin-bottom: 0;
}

.l-megamenu .l-inner .l-content .l-mynavi img {
    display: inline-block;
    vertical-align: middle;
}

.l-megamenu .l-inner .l-content .c-title-underline {
    font-size: .9em;
}

.l-megamenu .l-inner .l-content .l-text {
    font-size: .9em;
    font-weight: bold;
}

@media screen and (min-width: 800px) {
    ul.nav-main li:hover .l-megamenu {
        display: block;
    }

    .l-megamenu .l-inner .l-wrapper {
        display: flex;
        align-items: flex-start;
    }

    .l-megamenu .l-inner .l-header {
        width: calc(100% - 820px - 2em);
    }

    .l-megamenu .l-inner .l-content {
        width: 820px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.nav-main li {
        display: block;
    }

    .l-megamenu {
        display: none;
    }

    ul.nav-main li.active .l-megamenu {
        display: block;
    }

    ul.nav-main li .l-megamenu {
        width: calc(100% - 30px*2);
        width: 320px;
        height: auto;
        margin: 0 0 0 auto;
    }

    .l-megamenu {}

    .l-megamenu .l-inner {
        margin-top: calc(10px + 10px);
        border-radius: 20px;
        padding: 30px 0px;
    }

    .l-megamenu .l-inner .l-header {
        display: none;
    }

    .l-megamenu .l-inner .l-content .l-mynavi {
        padding: 4px;
    }
}

/*
-----------------------------------------------------

	=NAVIGATION - SP

-----------------------------------------------------
*/

@media screen and (min-width: 0px) and (max-width: 799px) {

    /* =OVERLAY BACKGROUND
    ----------------------------------------------------- */
    .nav-overlay {
        position: fixed;
        z-index: 9990;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100dvh;
        background-color: var(--color-text-basic);
        -webkit-transition: opacity ease-out 0.25s;
        -moz-transition: opacity ease-out 0.25s;
        -ms-transition: opacity ease-out 0.25s;
        transition: opacity ease-out 0.25s;
        opacity: 0;
        pointer-events: none;
    }

    .nav-overlay.active {
        opacity: 0.25;
        pointer-events: inherit;
    }

    /* =NAVIGATION - SP
	----------------------------------------------------- */
    .nav-sp {
        position: fixed;
        z-index: 9992;
        top: 0;
        right: 0;
        bottom: auto;
        width: 70vw;
        height: 100vh;
        padding: 0;
        border-radius: 0;
        background-color: rgba(255, 255, 255, 1);
        background-color: var(--color-secondary);
        color: var(--color-text-basic);
        box-shadow: 5px 8.66px 20px 0px rgba(0, 0, 0, 0.07);
        box-shadow: 15px 25.981px 50px 0px rgba(126, 126, 126, 0.2);
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
        -webkit-transform: translate3d(0, -100%, 0);
        -moz-transform: translate3d(0, -100%, 0);
        -ms-transform: translate3d(0, -100%, 0);
        transform: translate3d(0, -100%, 0);
        -webkit-transition: opacity ease-out 0.25s;
        -moz-transition: opacity ease-out 0.25s;
        -ms-transition: opacity ease-out 0.25s;
        transition: opacity ease-out 0.25s;
        opacity: 0;
    }

    .nav-sp.on {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }

    .nav-sp.on .l-inner {}

    .nav-sp .l-inner {
        padding: 0 6.25vw;
        padding-bottom: 20vw;
    }

    .nav-sp .l-inner .l-logo {
        height: 70px;
        display: flex;
        align-items: center;
        margin: 0;
    }

    .nav-sp .l-nav-footer ul.nav-main {
        margin: 0 0 1em 0;
        margin: 0;
    }

    .nav-sp .l-nav-footer ul.nav-main li {
        display: block;
        color: var(--color-text-basic);
        line-height: 2;
    }

    .nav-sp .l-nav-footer ul.nav-main li a:not([class]) {
        display: block;
        color: var(--color-text-basic);
        text-decoration: none;
    }

    .nav-sp .l-nav-footer ul.nav-main li a:not([class]) :hover {
        opacity: 0.25;
    }

    /* .nav-sp .l-nav-footer .l-heading {
        margin: 2em 0 10px;
    }

    .nav-sp .l-nav-footer .l-heading:first-child {
        margin-top: 0;
    } */

    /* ナビゲーション - 第1階層 */
    .nav-sp ul.nav-main>li:not(:last-child) {
        margin-bottom: 10px;
    }

    .nav-sp ul.nav-main>li>a:not([class]) {
        position: relative;
    }

    .nav-sp ul.nav-main>li>a:not([class])::before {}

    /* ナビゲーション - 第2階層 */
    .nav-sp .l-nav-footer ul.nav-main ul {
        margin: 0;
    }

    .nav-sp .l-nav-footer ul.nav-main ul li {
        margin: 0.5em 0;
        position: relative;
        padding-left: 0;
        font-size: 1.3rem;
    }

    .nav-sp .l-nav-footer ul.nav-main ul li:before {}

    .nav-sp .l-nav-footer ul.nav-main ul li a {}

    /* =TOGGLER
	----------------------------------------------------- */
    ul.nav-icon {
        position: fixed;
        z-index: 9999;
        top: 0;
        right: 0;
        margin: 0;
        padding: 0;
        margin: 10px 15px;
        text-align: right;
        font-size: 0;
        letter-spacing: 0;
    }

    ul.nav-icon li {
        display: inline-block;
        vertical-align: top;
        z-index: 9999;
        top: 0;
        right: 0;
        width: 60px;
        height: 60px;
        border-radius: 0;
        background-color: var(--color-text-basic);
        text-align: center;
        -webkit-transition: all ease-out 0.4s;
        -moz-transition: all ease-out 0.4s;
        -ms-transition: all ease-out 0.4s;
        transition: all ease-out 0.4s;
        cursor: pointer;
    }

    ul.nav-icon li:not(:last-child) {
        margin-right: 0;
    }

    ul.nav-icon li a {
        display: block;
        text-decoration: none;
    }

    ul.nav-icon li.toggler {
        padding: 21px 0;
        background-color: transparent;
    }

    .is-scrolled ul.nav-icon li.toggler {}

    ul.nav-icon li.toggler a.trigger-bars {
        display: inline-block;
    }

    a.trigger-bars,
    a.trigger-bars span {
        box-sizing: border-box;
        display: inline-block;
        -webkit-transition: all ease-out 0.4s;
        -moz-transition: all ease-out 0.4s;
        -ms-transition: all ease-out 0.4s;
        transition: all ease-out 0.4s;
    }

    a.trigger-bars {
        position: relative;
        z-index: 9999;
        width: 32px;
        height: 19px;
        color: var(--color-text-basic);
    }

    a.trigger-bars::after {
        position: absolute;
        width: 200%;
        left: -50%;
        top: 27px;
        display: block;
        letter-spacing: 0em;
        font-size: 1rem;
        font-weight: bold;
        text-transform: uppercase;
        line-height: 1;
    }

    a.trigger-bars span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: var(--color-primary);
        background-color: var(--color-text-basic);
        border-radius: 0;
        -webkit-transition: all ease-out 0.14s;
        -moz-transition: all ease-out 0.14s;
        -ms-transition: all ease-out 0.14s;
        transition: all ease-out 0.14s;
    }

    a.trigger-bars span:nth-of-type(1) {
        top: 0;
    }

    a.trigger-bars span:nth-of-type(2) {
        top: 9px;
    }

    a.trigger-bars span:nth-of-type(3) {
        bottom: 0;
    }

    /*ul.nav-icon li.toggler.active { background-color: #fff;}*/
    .active a.trigger-bars {
        color: var(--color-primary);
        color: var(--color-text-basic);
    }

    .active a.trigger-bars span {}

    .active a.trigger-bars span:nth-of-type(1) {
        -webkit-transform: translateY(9px) rotate(-45deg);
        transform: translateY(9px) rotate(-45deg);
    }

    .active a.trigger-bars span:nth-of-type(2) {
        opacity: 0;
    }

    .active a.trigger-bars span:nth-of-type(3) {
        -webkit-transform: translateY(-9px) rotate(45deg);
        transform: translateY(-9px) rotate(45deg);
    }
}






/*
-----------------------------------------------------

	=FOOTER

-----------------------------------------------------
*/
.footer-global {
    position: relative;
    z-index: 90;
    font-weight: normal;
    background: url(assets/images/object-ribbon-footer.webp) no-repeat center top 30px;
    background-size: 1550px auto;
    background-color: #e6f4f0;
}

.footer-global::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.footer-global,
.footer-global a {}

.footer-global a {
    text-decoration: none;
}

.footer-global p {
    line-height: 1.8;
}

.footer-global hr:not([class]) {
    height: 2em;
}

.footer-global .c-section {}

@media screen and (min-width: 800px) {
    .footer-global .c-section {
        padding: 120px 0 30px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .footer-global {
        font-size: 1.0rem;
    }
}

/* フッター - ナビゲーションなどのエリア
----------------------------------------------------- */
.footer-global .l-footer-navigation-area {}

.footer-global .l-footer-navigation-area .l-inner {
    position: relative;
}

.footer-global .l-footer-navigation-area .l-logo {}

.footer-global .l-footer-navigation-area .l-address {
    font-size: 1.2rem;
}

.footer-global .l-footer-navigation-area .l-regal {
    margin: 4em 0 0;
}



@media screen and (min-width: 800px) {
    .footer-global .l-footer-navigation-area {}

    .footer-global .l-footer-navigation-area .footer-left {
        width: 300px;
        justify-content: flex-start;
    }

    .footer-global .l-footer-navigation-area .footer-right {
        width: calc(100% - 300px - 80px);
        border-left: solid 1px rgba(0, 0, 0, 0.15);
        padding-left: 80px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {

    .footer-global .l-footer-navigation-area {
        padding: 6.25vw 0 0;
    }

    .footer-global .l-footer-navigation-area .footer-left,
    .footer-global .l-footer-navigation-area .footer-right {
        width: 100%;
        justify-content: flex-start;
    }

    .footer-global .l-footer-navigation-area .footer-right {
        display: none;
    }

    .footer-global .l-footer-navigation-area .c-flex-parent.u-responsive>.c-flex-child {
        margin: 0;
    }

    .footer-global .l-footer-navigation-area .footer-left>*:last-child {
        margin-bottom: 0;
    }

    .footer-global .l-footer-navigation-area .l-address {
        font-size: 1.0rem;
    }
}

/* フッター - ナビゲーションなどのエリア - ナビゲーション横並びver.
----------------------------------------------------- */
.l-nav-footer {}

.l-nav-footer .l-heading {
    margin: 0 0 0.25em;
    color: var(--color-text-basic);
    font-size: 2.1rem;
    font-weight: bold;
}

.l-nav-footer ul {}

.l-nav-footer ul li {
    letter-spacing: 0;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 2.5;
}

.l-nav-footer ul li a {
    position: relative;
    display: inline-block;
    color: inherit;
    text-decoration: none;
}

.l-nav-footer ul li a:hover {}

.l-nav-footer ul ul {}

.l-nav-footer ul ul li {
    font-size: .875em;
    font-weight: normal;
}

.l-nav-footer ul ul li a {
    position: relative;
    padding-left: 1em;
    padding-left: 0;
}

@media screen and (min-width: 800px) {
    .l-nav-footer .c-flex-parent .c-flex-child {
        margin: 0 2em 0 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-nav-footer {}

    .l-nav-footer .l-heading {
        font-size: 1.33em;
    }

    .l-nav-footer ul li {
        font-size: 1.4rem;
    }

    .l-nav-footer ul ul li a::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto 0;
        width: 5px;
    }
}

/* フッター - コピーライト
----------------------------------------------------- */
.footer-global .l-footer-copyright-area {
    padding: 0;
    font-size: 1.2rem;
}

.footer-global .l-footer-copyright-area,
.footer-global .l-footer-copyright-area a {}

.footer-global .l-footer-copyright-area .l-inner {
    padding: 0 0 60px;
    align-items: center;
}

.footer-global .l-footer-copyright-area .copyright {
    font-weight: bold;
    letter-spacing: 0.0em;
    line-height: 1;
}

.footer-global .l-footer-copyright-area .copyright p {
    margin: 0;
}

.footer-global .l-footer-copyright-area a {}

.footer-global .l-footer-copyright-area a:hover {
    opacity: .5;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .footer-global .l-footer-copyright-area {
        padding: 6.25vw 0 0;
        font-size: .9rem;
    }

    .footer-global .l-footer-copyright-area .l-inner {
        padding: 6.25vw 0;
    }

    .footer-global .l-footer-copyright-area .copyright {
        font-size: .9rem;
    }

    .footer-global .l-footer-copyright-area .c-flex-parent.u-responsive>.c-flex-child {
        margin-bottom: 6.25vw;
    }

    /* .footer-global ul.c-list-sns {
        margin: 0 0 6.25vw;
        text-align: left;
    }

    .footer-global ul.c-list-sns:last-child {
        margin-bottom: 0;
    } */
}



/*
-----------------------------------------------------

	=COMMON PARTS - SECTION

-----------------------------------------------------
*/
.js-anchor {
    visibility: hidden;
    height: 0;
    display: block;
    padding-top: 120px;
    margin-top: -120px;
    pointer-events: none;
}

.c-block:not( :last-child) {
    margin-bottom: 162px;
}

.c-section {
    padding: 120px 0;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-block:not( :last-child) {
        margin: 0 auto 12.5vw;
    }

    .c-section {
        padding: 12.5vw 0;
    }
}

/* HORIZONTAL RULE
----------------------------------------------------- */
hr {
    clear: both;
    border: none;
    margin: 30px auto;
    height: 0;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    hr {
        margin: 3.125vw auto;
    }
}

hr.hr-border {
    margin: 60px auto;
    height: 1px;
    background-color: rgba(0, 0, 0, 0.15);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    hr.hr-border {
        margin: 6.25vw auto;
    }
}

hr.hr-theme {
    margin: 0 auto;
    height: 3px;
    background-color: var(--color-primary);
    max-width: calc(100% - 40px*2);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    hr.hr-theme {
        max-width: calc(100% - 6.25vw*2);
    }
}

hr.hr-half {
    margin: 15px auto;
}

@media screen and (min-width: 800px) {
    hr.hr-x2 {
        margin: 60px auto;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* その他
----------------------------------------------------- */
.c-section-header {
    text-align: center;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

.c-flexible-indent {
    padding: 0 40px;
    margin: 0 auto;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-flexible-indent {
        padding: 0 3.125vw;
    }
}

/*
-----------------------------------------------------

	=COMMON PARTS - DECORATION

-----------------------------------------------------
*/


/* フォントカラー、加工など
----------------------------------------------------- */
.u-fc-theme {
    color: var(--color-primary);
}

.u-radius {
    overflow: hidden;
    border-radius: 10px;
}

/* 罫線ラインマーカー */
.u-text-underline {
    position: relative;
    display: inline-block;
}

.u-text-underline::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0.15em;
    background-color: var(--color-primary);
    mix-blend-mode: multiply
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* 汎用の枠・白背景エリア
----------------------------------------------------- */
.c-whitebox {
    padding: 80px;
    background-color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-whitebox {
        padding: 6.25vw;
    }
}

/* 汎用のカバー画像エリア
----------------------------------------------------- */
.c-cover-image {
    position: relative;
    width: 100%;
}

.c-cover-image img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
}

/* 汎用のフレーム
----------------------------------------------------- */
.c-frame-theme {
    position: relative;
    z-index: 2;
    margin: 0 0 2em;
    border-radius: 10px;
    padding: 2em;
    background-color: var(--color-primary);
    color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


.c-indent-block {
    border-left: solid 10px var(--color-primary);
    padding-left: 90px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-indent-block {
        border-left: solid 5px var(--color-primary);
        padding-left: 6.25vw;
    }
}


/*
-----------------------------------------------------

	=COMMON PARTS - HEADING

-----------------------------------------------------
*/


/* 強調した文章（ABOUTセクションなどでの装飾）
----------------------------------------------------- */
.c-featured-text {
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 0.0em;
    line-height: 2.0;
}

@media screen and (min-width: 800px) {
    .c-featured-text.u-medium {}

    .c-featured-text.u-small {}
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-featured-text {
        font-size: 1.15em;
    }
}



/* 見出し - 強弱をつけた見出し 通常45pt
----------------------------------------------------- */
.c-title-focus {
    margin: 0 0 1.5em;
    font-size: 4.5rem;
    font-weight: 900;
    line-height: 1.35;
    letter-spacing: -0.05em;
}

.c-title-focus em {
    font-style: normal;
    font-size: 1.8em;
}

.c-title-focus.u-ver-large {
    font-size: 6.4rem;
}

.c-title-focus .l-english {
    font-family: "Brother-1816 Black", sans-serif;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-focus {
        font-size: 2.0rem;
    }

    .c-title-focus em {
        font-size: 1.5em;
    }
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* 見出し - セクション・ページの大見出し 72pt, 108px, 48pt
----------------------------------------------------- */
.c-title-section {
    margin: 0 0 .75em;
    font-size: 7.2rem;
    font-weight: bold;
    line-height: 1.25;
}

.c-title-section:last-child {
    margin-bottom: 0;
}

.c-title-section>* {
    display: block;
}

.c-title-section .l-english {
    color: var(--color-primary);
    vertical-align: text-bottom;
    font-family: "Brother-1816 Black", sans-serif;
    line-height: .9;
}

.c-title-section .l-japanese {
    margin: 20px 0 0;
    font-size: 2.4rem;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-section {
        margin: 0 0 1em;
        font-size: 4.0rem;
    }

    .c-title-section .l-japanese {
        margin: 10px 0 0;
        font-size: 1.5rem;
    }
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

.c-title-section.u-ver-large {
    font-size: 10.8rem;
}

.c-title-section.u-ver-small {
    font-size: 4.8rem;
}

.c-title-section.u-ver-small .l-japanese {
    font-size: 1.6rem;
}

.c-title-section.u-ver-white .l-english {
    color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-section.u-ver-large {
        font-size: 4.6rem;
    }

    .c-title-section.u-ver-small {
        font-size: 2.6rem;
    }

    .c-title-section.u-ver-small .l-japanese {
        font-size: .9em;
    }
}


/* 見出し - 下線ありシンプルな見出し 14pt
----------------------------------------------------- */
.c-title-underline {
    margin: 0 0 1.5em;
    padding: 0 0 10px;
    color: var(--color-primary);
    border-bottom: solid 1px var(--color-primary);
    font-size: 1em;
    line-height: 1.0;
}

.c-title-underline .l-japanese {}

.c-title-underline .l-english {
    font-family: "Brother-1816 Medium", sans-serif;
    font-size: 1.1em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

.c-title-underline.u-ver-black {
    color: var(--color-text-basic);
    border-color: var(--color-text-basic);
}


/* 見出し - 日本語48pt
----------------------------------------------------- */
.c-title-japanese {
    margin: 0 0 1.25em;
    font-size: 4.8rem;
    font-weight: 500;
    line-height: 1.35;
}

.c-title-japanese>* {
    display: block;
}

.c-title-japanese .l-japanese {
    display: block;
}

.c-title-japanese .l-english {
    margin: 0.5em 0 0;
    font-size: 3.2rem;
    font-family: "Brother-1816", sans-serif;
    font-weight: bold;
    line-height: 1.1;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-japanese {
        margin: 0 0 1.5em;
        font-size: 2.6rem;
    }

    .c-title-japanese .l-english {
        font-size: 1.6rem;
    }
}

.c-title-japanese.u-ver-medium {
    font-size: 3.6rem;
}

.c-title-japanese.u-ver-small {
    font-size: 2.1rem;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-japanese.u-ver-medium {
        font-size: 1.8rem;
    }

    .c-title-japanese.u-ver-small {
        font-size: 1.6rem;
    }
}


/*
-----------------------------------------------------

	=COMMON PARTS - HEADING (SUB PAGES ONLY)

-----------------------------------------------------
*/


/* 見出し - 下層ページで汎用するセクションの大見出し64pt
----------------------------------------------------- */
.c-title-focus-subpages {
    margin: 0 0 .75em;
    font-size: 6.0rem;
    font-weight: 900;
    line-height: 1.05;
    line-height: 1.25;
}

.c-title-focus-subpages:last-child {
    margin-bottom: 0;
}

.c-title-focus-subpages .l-sub {
    display: inline-block;
    margin: 0 0 0.75em;
    color: var(--color-primary);
    font-size: 4.8rem;
    font-weight: 500;
    border: solid 2px var(--color-primary);
    border-radius: 10px;
    padding: 0.45em .6em;
}

.c-title-focus-subpages .l-japanese {
    display: block;
}

.c-title-focus-subpages .l-japanese em {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    padding: 0 0 0.25em;
    color: var(--color-primary);
    font-size: 1.5em;
}

.c-title-focus-subpages .l-japanese em::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 12px;
    background: url(assets/images/sub-feature-underline-marker.webp) no-repeat center bottom;
    background-size: contain;
}

.c-title-focus-subpages .l-numbering {
    display: none;
    position: absolute;
    top: inherit;
    left: 0;
    margin: 0 0.25em 0 0;
    color: var(--color-primary);
    vertical-align: text-bottom;
    font-size: 1.1em;
    font-family: "Brother-1816 Bold", sans-serif;
    line-height: .9;
}

.c-title-focus-subpages.u-ver-numbering {
    position: relative;
}

.c-title-focus-subpages.u-ver-numbering .l-japanese {
    padding-left: 2.0em;
}

.c-title-focus-subpages.u-ver-numbering .l-numbering {
    display: inline-block;
}

@media screen and (min-width: 800px) {
    .c-title-focus-subpages.u-ver-numbering .l-japanese.u-ver-adjustment {
        /* emのズレを調整 */
        margin-top: -0.5em;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-focus-subpages {
        margin: 0 0 1em;
        font-size: 2.4rem;
        line-height: 1.25;
    }

    .c-title-focus-subpages .l-sub {
        font-size: 1.8rem;
        border-width: 1px;
    }

    .c-title-focus-subpages .l-japanese {}

    .c-title-focus-subpages .l-japanese em {
        font-size: 1.3em;
    }

    .c-title-focus-subpages .l-numbering {
        margin: 3px 0 0;
        font-size: 1.8rem;
    }

    .c-title-focus-subpages.u-ver-numbering .l-japanese {
        padding-left: 2.0em;
    }
}



/* 見出し - 下層ページで汎用するサブ見出し42pt
----------------------------------------------------- */
.c-title-categorized {
    margin: 0 0 .75em;
    padding: 0.75em 0;
    border: solid 1px var(--color-primary);
    border-left: none;
    border-right: none;
    font-size: 4.2rem;
    font-weight: bold;
    line-height: 1.25;
    display: flex;
    align-items: center;
}

.c-title-categorized:last-child {
    margin-bottom: 0;
}

.c-title-categorized .l-english,
.c-title-categorized .l-japanesea {}

.c-title-categorized .l-english {
    margin: 0 1.0em 0 0;
    color: #fff;
    font-family: "Brother-1816 Bold", sans-serif;
    font-size: 1.8rem;
    font-weight: 500;
    background-color: var(--color-primary);
    border-radius: 4em;
    padding: 0.45em 1.5em;
    display: flex;
    align-items: center;
}

.c-title-categorized .l-japanese {}

@media screen and (min-width: 800px) {
    .c-title-categorized.u-ver-vertical-top {
        align-items: flex-start;
    }

    .c-title-categorized.u-ver-vertical-top .l-english {
        margin-top: 10px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-categorized {
        padding: 1.0em 0;
        flex-direction: column;
        align-items: flex-start;
        font-size: 1.9rem;
    }

    .c-title-categorized .l-english {
        display: inline-block;
        margin: 0 0 10px;
        font-size: 1.2rem;
    }

    .c-title-categorized .l-japanese {}
}



/* 見出し - 下層ページ - 英語48pt + 日本語24pt（プロジェクト事例など）
----------------------------------------------------- */
.c-title-project {
    margin: 0 0 2.0em;
    padding: 0 0 1em;
    border-bottom: solid 1px var(--color-primary);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.25;
    display: flex;
    align-items: center;
}

.c-title-project:last-child {
    margin-bottom: 0;
}

.c-title-project .l-english,
.c-title-project .l-japanesea {}

.c-title-project .l-english {
    margin: 0 0.75em 0 0;
    color: var(--color-primary);
    font-family: "Brother-1816 Bold", sans-serif;
    font-size: 4.8rem;
    display: flex;
    align-items: center;
}

.c-title-project .l-japanese {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-project {
        display: block;
        font-size: 1em;
    }

    .c-title-project .l-english {
        display: block;
        margin: 0 0 0.25em;
        font-size: 2.4rem;
    }
}

.c-title-project.u-ver-noborder {
    padding: 0;
    border-bottom: none;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 見出し - 日本語24pt + サブで英語もあり
----------------------------------------------------- */
.c-title-24 {
    margin: 0 0 1.25em;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
}

.c-title-24 .l-english {
    display: block;
    margin: 0 0 0.25em;
    font-family: "Brother-1816", sans-serif;
    opacity: .3;
}

.c-title-24 .l-japanese {
    display: block;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-24 {
        font-size: 1.6rem;
    }

    .c-title-24 .l-english {
        font-size: .75em;
    }
}

































/* 見出し - 日本語54pt + 英語32pt
----------------------------------------------------- */
/* .c-title-54 {
    margin: 0 0 1.5em;
    font-size: 5.4rem;
    font-weight: bold;
    line-height: 1.35;
}

.c-title-54>* {
    display: block;
}

.c-title-54 .l-japanese {
    display: block;
}

.c-title-54 .l-english {
    margin: 0.5em 0 0;
    font-size: 3.2rem;
    font-family: "Brother-1816", sans-serif;
    font-weight: bold;
    line-height: 1.1;
}

@media screen and (min-width: 800px) {
    .c-title-54.u-ver-medium {
        font-size: 4.0rem;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-54 {
        margin: 0 0 1.5em;
        font-size: 2.6rem;
    }

    .c-title-54 .l-english {
        font-size: 1.6rem;
    }
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {} */


/* 見出し - 日本語36pt
----------------------------------------------------- */
/* .c-title-36 {
    margin: 0 0 1.25em;
    font-size: 3.5rem;
    font-weight: bold;
    line-height: 1.5;
}

.c-title-36 .l-english {
    display: block;
    color: var(--color-primary);
    font-family: "Brother-1816", sans-serif;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.25;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-36 {
        font-size: 2.1rem;
    }
} */



/* 見出し - 日本語20pt
----------------------------------------------------- */
/* .c-title-20 {
    margin: 0em 0 1.5em;
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 1.5;
}

.c-title-20>* {
    display: block;
}

.c-title-20 .l-japanese {}

.c-title-20 .l-english {
    display: block;
    margin: .75em 0 0;
    font-family: "Brother-1816", sans-serif;
    font-size: 1.6rem;
    font-weight: normal;
    opacity: 0.5;
    letter-spacing: -0.025em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-20 {
        font-size: 1em;
    }

    .c-title-20 .l-english {
        font-size: 1.0rem;
    }
} */


/*
-----------------------------------------------------

	=COMMON PARTS - BUTTON

-----------------------------------------------------
*/

/* ボタン - 矢印アイコン付きRead moreボタン
----------------------------------------------------- */
.c-button-readmore {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 320px;
    height: 80px;
    line-height: 1.0;
    padding: 0 2em;
    border-radius: 6em;
    border: solid 2px #fff;
    background-color: var(--color-primary);
    color: #fff;
    font-family: "Brother-1816 Black", sans-serif;
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 0;
    text-align: left;
    text-decoration: none;
}

.c-button-readmore .l-english,
.c-button-readmore .l-japanese,
.c-button-readmore .l-arrow {
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.c-button-readmore .l-english,
.c-button-readmore .l-japanese {
    display: block;
    line-height: 1.1;
}

.c-button-readmore .l-japanese {
    margin-top: 0.25em;
    font-size: 1.6rem;
    font-weight: bold;
}

.c-button-readmore .l-arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 16px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background-color: #fff;
    margin: auto 0;
    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.c-button-readmore .l-arrow svg {
    fill: var(--color-primary);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 16px;
    height: 20px;
    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.c-button-readmore:hover {
    opacity: 1;
    filter: brightness(1.25);
}

.c-button-readmore:hover .l-english {
    border-color: transparent;
}

.c-button-readmore:hover .l-arrow {}

.c-button-readmore:hover .l-arrow svg {
    fill: var(--color-primary);
}

@media screen and (min-width: 800px) {
    .c-button-readmore.u-ver-medium {
        width: 280px;
        height: 70px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-button-readmore {
        width: 210px;
        max-width: 100%;
        height: 54px;
        font-size: 1.5rem;
    }

    .c-button-readmore .l-english {}

    .c-button-readmore .l-japanese {
        font-size: 1.2rem;
    }

    .c-button-readmore .l-arrow {
        width: 28px;
        height: 28px;
    }

    .c-button-readmore .l-arrow svg {
        zoom: 0.5;
    }
}

.u-ta-r .c-button-readmore {
    margin-left: auto;
}

.u-ta-c .c-button-readmore {
    margin-left: auto;
    margin-right: auto;
}

.c-button-readmore .l-arrow.u-ver-rotate {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.c-button-readmore.u-ver-orange {
    background-color: var(--color-orange);
}

.c-button-readmore.u-ver-orange .l-arrow {}

.c-button-readmore.u-ver-orange:hover .l-arrow {}

.c-button-readmore.u-ver-orange .l-arrow svg {
    fill: var(--color-orange);
}

.c-button-readmore.u-ver-orange:hover .l-arrow svg {}


.c-button-readmore.u-ver-comingsoon {
    background-color: #ccc;
}

.c-button-readmore.u-ver-comingsoon .l-arrow {
    display: none;
}

.c-button-readmore.u-ver-comingsoon:hover {
    opacity: 1;
    filter: brightness(1);
}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/* ボタン - 小さなテキストとアロー
----------------------------------------------------- */
.c-link-arrow {
    position: relative;
    display: inline-block;
    padding: 0 1em 0 0;
    font-size: 1.25em;
    font-family: "Brother-1816", sans-serif;
    color: var(--color-text-basic);
    font-weight: bold;
    text-decoration: none;
    line-height: .8;
}

.c-link-arrow::after {
    content: "";
    position: absolute;
    top: 3px;
    bottom: 0;
    margin: auto 0;
    right: 0;
    background: url(assets/images/icon-arrow-right-green.webp) no-repeat center;
    background-size: contain;
    width: 15px;
    height: 18px;
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.c-link-arrow:hover {
    color: var(--color-primary);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-link-arrow {
        font-size: 1em;
    }

    .c-link-arrow::after {
        width: calc(15px / 2 * 1);
        height: calc(18px / 2 * 1);
    }
}

.c-link-arrow.u-ver-rotate::after {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

@media screen and (min-width: 800px) {
    .c-link-arrow.u-ver-small {
        font-size: 1em;
    }

    .c-link-arrow.u-ver-small::after {
        width: 11px;
        height: 13px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}




/* =ナビゲーション - ページ内コンテンツ （下層ページのみ）
----------------------------------------------------- */
ul.c-list-nav li {
    margin-bottom: 1em;
}
@media screen and (min-width: 800px) {}
@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 横並びver. (CULTUREページのイントロで使用) */
ul.c-list-nav.u-ver-horizontal {}
ul.c-list-nav.u-ver-horizontal li {}
ul.c-list-nav.u-ver-horizontal li a.c-link-arrow {
    display: block;
    padding: 1.25em 0;
    border-bottom: solid 2px var(--color-primary);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/*
-----------------------------------------------------

	=COMMON PARTS - LIST

-----------------------------------------------------
*/
/* 各種SNSアイコン定義 
----------------------------------------------------- */
i.icon-twitter {
    display: inline-block;
    background: url(assets/images/icon-sns-twitter.webp) no-repeat center;
    background-size: 100% auto;
    width: 22px;
    height: 22px;
}

i.icon-facebook {
    display: inline-block;
    background: url(assets/images/icon-sns-facebook.webp) no-repeat center;
    background-size: 100% auto;
    width: 24px;
    height: 24px;
}

i.icon-instagram {
    display: inline-block;
    background: url(assets/images/icon-sns-instagram.webp) no-repeat center;
    background-size: 100% auto;
    width: 24px;
    height: 24px;
}

i.icon-tiktok {
    display: inline-block;
    background: url(assets/images/icon-sns-tiktok.webp) no-repeat center;
    background-size: 100% auto;
    width: 19px;
    height: 22px;
}


i.icon-note {
    display: inline-block;
    background: url(assets/images/icon-sns-note.webp) no-repeat center;
    background-size: 100% auto;
    width: 18px;
    height: 18px;
}

i.icon-youtube {
    display: inline-block;
    background: url(assets/images/icon-sns-youtube.webp) no-repeat center;
    background-size: 100% auto;
    width: 26px;
    height: 20px;
}

i.icon-hatena {
    display: inline-block;
    background: url(assets/images/icon-sns-hatena.webp) no-repeat center;
    background-size: 100% auto;
    width: 26px;
    height: 21px;
}

i.icon-linkedin {
    display: inline-block;
    background: url(assets/images/icon-sns-linkedin.webp) no-repeat center;
    background-size: 100% auto;
    width: 21px;
    height: 21px;
}

i.icon-line {
    display: inline-block;
    background: url(assets/images/icon-sns-line.webp) no-repeat center;
    background-size: 100% auto;
    width: 25px;
    height: 24px;
}

@media screen and (min-width: 800px) {
    .u-large i.icon-tiktok {
        width: 29px;
        height: 34px;
    }

    .u-large i.icon-instagram {
        width: 37px;
        height: 37px;
    }

    .u-large i.icon-youtube {
        width: 39px;
        height: 28px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* リスト - SNSロゴのみ VER.
----------------------------------------------------- */
ul.c-list-sns {
    display: block;
    font-size: 0;
    letter-spacing: 0;
}

ul.c-list-sns:not( :last-child) {
    margin: 0 0 3rem;
}

ul.c-list-sns li {
    display: inline-block;
    vertical-align: middle;
    font-size: 1.2rem;
    line-height: 1;
    width: 40px;
}

ul.c-list-sns li:not( :last-child) {
    margin: 0 10px 0 0;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-sns {}

    ul.c-list-sns li {
        font-size: .9rem;
    }
}

/* リスト - SNS円形アイコン
----------------------------------------------------- */
ul.c-list-sns-circle {
    display: flex;
}

ul.c-list-sns-circle li {}

ul.c-list-sns-circle li:not( :last-child) {
    margin: 0 10px 0 0;
}

ul.c-list-sns-circle li a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: var(--color-secondary);
}

@media screen and (min-width: 800px) {
    ul.c-list-sns-circle.u-large li:not( :last-child) {
        margin: 0 20px 0 0;
    }

    ul.c-list-sns-circle.u-large li a {
        width: 80px;
        height: 80px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* リスト - SNSシェアボタン
----------------------------------------------------- */
ul.c-list-share {
    margin: 0 0 2rem;
    font-size: 0;
    letter-spacing: 0;
}

ul.c-list-share.u-with-heading::before {
    content: "SHARE";
    display: inline-block;
    vertical-align: text-bottom;
    margin: 0 1em 0 0;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.05em;
}

ul.c-list-share li {
    display: inline-block;
    vertical-align: middle;
    margin: 0 20px 0px 0;
    font-size: 1.6rem;
}

ul.c-list-share li a {
    display: block;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-share li {
        zoom: .8;
    }
}

/* リスト - 箇条書きリスト
----------------------------------------------------- */
ul.c-list-simple {}

ul.c-list-simple li {
    margin: 0 0 1.5em;
    position: relative;
    padding-left: 1.2em;
    font-size: 1.4rem;
    line-height: 1.8;
    letter-spacing: 0.00em;
    opacity: 0.7;
}

ul.c-list-simple li::before {
    content: "ー";
    position: absolute;
    left: 0;
    top: 0.8em;
    display: inline-block;
    vertical-align: middle;
    margin: 0 1.25em 0 0;
    color: var(--color-primary);
    font-size: 0.9rem;
    opacity: 0.5;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-simple li::before {
        top: 0.1em;
    }
}

.c-list-simple.u-ver-indent-off li {
    margin-left: -1.2em;
}

/* リスト - 箇条書きリスト（丸型）
----------------------------------------------------- */
ul.c-list-circle {}

ul.c-list-circle li {
    margin: 0 0 1.5em;
    position: relative;
    padding-left: 1.2em;
    line-height: 1.8;
    letter-spacing: 0.00em;
}

ul.c-list-circle li::before {
    content: "● ";
    position: absolute;
    left: 0;
    top: 0.8em;
    display: inline-block;
    vertical-align: middle;
    margin: 0 1.25em 0 0;
    color: var(--color-emerald);
    font-size: 0.9rem;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-circle li::before {
        top: 0.1em;
    }
}

/* リスト - シンプルなインライン
----------------------------------------------------- */
ul.c-list-inline {}

ul.c-list-inline li {
    display: inline-block;
    vertical-align: middle;
    margin: 0 2em 0 0;
}

/* リスト - ボタン横並びリスト
----------------------------------------------------- */
ul.c-list-button {
    font-size: 0;
    letter-spacing: 0;
}

ul.c-list-button li {
    display: inline-block;
    margin: 0 10px 10px 0;
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/*
-----------------------------------------------------

	=COMMON PARTS - ARCHIVE LIST

-----------------------------------------------------
*/

/* カテゴリー・年別絞り込みボタン（※TOPページ、お知らせなどで使用）
----------------------------------------------------- */

/* アーカイブリスト - 全体 */
.c-news-archive-header {}

/* アーカイブリスト - カテゴリー・年別絞り込みボタン部分 */
ul.c-list-news-archive {
    margin: 0;
    font-size: 0;
    letter-spacing: 0;
}

ul.c-list-news-archive:last-child {
    margin-bottom: 0;
}

ul.c-list-news-archive li {
    display: inline-block;
    vertical-align: top;
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: 0.05em;
}

ul.c-list-news-archive li a {
    display: inline-block;
    color: var(--color-text-basic);
    text-decoration: none;
    margin: 0em 2em 0.5em 0;
    padding: 0.35em 0;
    border-bottom: solid 2px transparent;
}

ul.c-list-news-archive li.active a,
ul.c-list-news-archive li a[aria-current],
ul.c-list-news-archive li a:hover {
    opacity: 1;
    border-color: var(--color-emerald);
    color: var(--color-emerald);
}

ul.c-list-news-archive li.active a,
ul.c-list-news-archive li a[aria-current] {}

ul.c-list-news-archive li a:hover {}

ul.c-list-news-archive li ul,
ul.c-list-news-archive li ul li {
    display: inline-block;
}

ul.c-list-news-archive li ul li a {
    margin: 0 2em 0 0;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-news-archive {
        position: relative;
        margin: 0 0 2rem;
        padding-left: 0;
        margin-left: 0;
    }

    ul.c-list-news-archive::before {
        display: none;
    }

    ul.c-list-news-archive li {
        margin: 0 0 .75em 0;
        font-size: 1.1rem;
    }

    ul.c-list-news-archive li a {}
}

/* アーカイブリスト - タグ絞り込みボタン部分 */
ul.c-list-news-tag {
    margin: 15px 0 0;
    font-size: 0;
    letter-spacing: 0;
}

ul.c-list-news-tag:last-child {
    margin-bottom: 0;
}

ul.c-list-news-tag li {
    display: inline-block;
    vertical-align: top;
    margin: 0 15px 15px 0;
    font-size: 1.3rem;
}

ul.c-list-news-tag li a {
    display: block;
    padding: 0.75em 1.5em;
    line-height: 1;
    font-weight: normal;
    text-decoration: none;
    background-color: #fff;
    color: var(--color-text-basic);
    border-radius: 1.5em;
}

ul.c-list-news-tag li.active a,
ul.c-list-news-tag li a[aria-current],
ul.c-list-news-tag li a:hover {
    opacity: 1;
    background-color: var(--color-primary);
    color: #fff;
}

ul.c-list-news-tag li.active a,
ul.c-list-news-tag li a[aria-current] {}

ul.c-list-news-tag li a:hover {}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-news-tag {
        margin: 0;
    }

    ul.c-list-news-tag li {
        margin: 0 7px 7px 0;
        font-size: 1.0rem;
    }
}

/*
-----------------------------------------------------

	=COMMON PARTS - LOOP

-----------------------------------------------------
*/

/* =BASIC [全ループ共通]
----------------------------------------------------- */
/* オウンドメディア配下のループのカスタマイズ -->ownedmedia.css */

.loop {}

.loop .loop-article {}

.more-link {
    display: none;
}

.loop,
.loop * {
    -webkit-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.6s;
    -moz-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.6s;
    -ms-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.6s;
    transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.6s;
}

/* NEWアイコン */
.loop .loop-article {
    position: relative;
}
.loop .loop-article::before {
    content: "";
    position: absolute;
    z-index: 1;
    top: -20px;
    left: -20px;
    width: 99px;
    height: 99px;
    background: url(assets/images/icon-new.webp) no-repeat center;
    background-size: 100% auto;
    display: none;
} 

.loop .loop-article.u-ver-new::before {
    display: block;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop .loop-article::before {
        top: -15px;
        left: -15px;
        width: 60px;
        height: 60px;
    }
}

/* 画像 */
.loop .loop-image {
    position: relative;
    height: 0;
    padding-bottom: 52.5%;
    padding-bottom: 66.66%;
    border-radius: 10px;
    overflow: hidden;
}

.loop .loop-image img {
    position: absolute;
    overflow: hidden;
    object-fit: cover;
    width: 100%;
    height: 100%;
    -webkit-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.8s;
    -moz-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.8s;
    -ms-transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.8s;
    transition: all cubic-bezier(0.190, 1, 0.220, 1) 0.8s;
}

.loop .loop-image:hover a {
    opacity: 1;
}

.loop .loop-article:hover .loop-image img {
    -webkit-transform: scale(1.025);
    -moz-transform: scale(1.025);
    -ms-transform: scale(1.025);
    transform: scale(1.025);
}

.loop .loop-header {
    padding: 20px 0 0;
}

.loop .loop-header>*:not( :last-child) {
    margin-bottom: 20px;
}

.loop .loop-title {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.6;
}

.loop .loop-title a {
    color: inherit;
    text-decoration: none;
}

.loop .loop-title a:hover {
    opacity: 0.3;
    color: inherit;
}

.loop .loop-meta {
    font-size: 1.3rem;
}

/* インライン配置ver. */
.loop .loop-meta>* {
    display: inline-block;
}

.loop .loop-meta>*:not( :last-child) {
    margin-right: 2em;
}

.loop .loop-date {
    color: var(--color-text-basic);
    font-family: "Brother-1816 Bold", sans-serif;
    letter-spacing: 0.0em;
}

.loop .loop-modified_date {
    opacity: 0.5;
}

/* カテゴリー - 通常テキストver. 
.loop .loop-category,
.loop .loop-category a {
    color: var(--color-text-basic);
    font-weight: 500;
}

.loop .loop-category {
    display: inline-block;
}

.loop .loop-category a {
    display: block;
    text-decoration: none;
}

.loop .loop-category a:hover {
    opacity: .5;
}
*/

/* カテゴリー - 囲みver. */
.loop .loop-category a {
    display: block;
    text-decoration: none;
    padding: 0.5em 1em;
    border-radius: 3em;
    background-color: var(--color-emerald);
    color: #fff;
}

.loop .loop-category a:hover {
    opacity: .5;
}


/* 画像上ver.  */
.loop .loop-image .loop-category {
    position: absolute;
    left: 0;
    top: 0;
    padding: 0.5em 1em;
    border-radius: 0 0 10px 0;
    background-color: #fff;
    color: var(--color-text-basic);
    font-size: 1.3rem;
    font-weight: 500;
}

.loop .loop-image .loop-category a {
    display: block;
    text-decoration: none;
}

.loop .loop-image .loop-category a:hover {
    opacity: .5;
}

ul.list-tag {
    font-size: 0;
    letter-spacing: 0;
}

/* タグ - 囲みver. */
ul.list-tag li {
    display: inline-block;
    margin: 0 10px 10px 0;
    font-size: 1.2rem;
}

ul.list-tag li a {
    display: block;
    padding: 0.5em 1.5em;
    line-height: 1;
    font-weight: normal;
    text-decoration: none;
    background-color: rgba(0, 0, 0, .08);
    border: solid 0 #333;
    color: var(--color-text-basic);
    border-radius: 1.5em;
}

ul.list-tag li a:before {
    content: "#";
}

ul.list-tag li a:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, .18);
}


/* タグ - ハッシュタグver. 
ul.list-tag li {
    display: inline-block;
    margin: 0 10px 10px 0;
    font-size: 1.3rem;
    line-height: 1.5;
}

ul.list-tag li a {
    display: block;
    line-height: 1;
    font-weight: normal;
    text-decoration: none;
    color: var(--color-text-basic);
    opacity: 0.75;
}

ul.list-tag li a:before {
    content: "#";
}

ul.list-tag li a:hover {
    color: var(--color-primary);
}
*/

.loop .loop-content {
    display: none;
    margin: 1em 0 0;
    font-size: 0.9em;
}

.loop .loop-content p {
    line-height: 1.8;
}

.loop .loop-content p:not( :last-child) {
    margin-bottom: 0.75em;
}

.loop .loop-more {
    display: none;
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop .loop-image .loop-category {
        margin: 0;
    }

    .loop .loop-image .loop-category a {
        font-size: .9rem;
    }

    .loop .loop-meta {
        font-size: 1.2rem;
    }

    .loop .loop-meta>*:not( :last-child) {
        margin-right: 1.5em;
    }

    .loop .loop-title {
        font-size: 1.25em;
    }

    ul.list-tag li {
        font-size: .9rem;
    }

    ul.list-tag li {
        margin: 0 10px 5px 0;
    }

    ul.list-tag li a {}

    .loop .loop-content {
        font-size: 1em;
    }
}

/* =LOOP TYPE - MAIN [メインでよく使う基本的なループ]
----------------------------------------------------- */
.loop.loop-type-main {}

.loop.loop-type-main .loop-article {}

.loop.loop-type-main .loop-image {}

.loop.loop-type-main .loop-image img {}

.loop.loop-type-main .loop-image img:hover {}

.loop.loop-type-main .loop-header {}

.loop.loop-type-main .loop-header>*:not( :last-child) {}

.loop.loop-type-main .loop-meta {}

.loop.loop-type-main .loop-date {}

.loop.loop-type-main .loop-category {}

.loop.loop-type-main .loop-category a {}

.loop.loop-type-main .loop-tag {}

.loop.loop-type-main .loop-tag ul.list-tag li {}

.loop.loop-type-main .loop-tag ul.list-tag li a {}

.loop.loop-type-main .loop-tag ul.list-tag li a:hover {}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop.loop-type-main {}

    .loop.loop-type-main .loop-article {
        width: 100%;
        margin: 0 0 4vw;

        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }

    .loop.loop-type-main .loop-article:last-child {
        border-bottom: none;
    }

    .loop.loop-type-main .loop-image {
        width: 40%;
    }

    .loop.loop-type-main .loop-header {
        width: calc(60% - 4vw);
        padding: 0;
    }

    .loop.loop-type-main .loop-image {
        padding-bottom: 20vw;
        padding-bottom: 25vw;
    }

    .loop.loop-type-main .loop-header {
        margin-top: 0;
    }


    .loop.loop-type-main .loop-header>*:not( :last-child) {
        margin-bottom: 10px;
    }

    .loop.loop-type-main .loop-date {
        font-size: 1.2rem;
    }

    .loop.loop-type-main .loop-category {}

    .loop.loop-type-main .loop-title {
        font-size: 1.2rem;
    }

    .loop.loop-type-main .loop-content {
        display: none;
        font-size: 9px;
    }

    .loop.loop-type-main .loop-tag ul.list-tag li {
        font-size: .9rem;
    }
}


/* =TYPE : FOCUS  [優劣を付けたループ(PC ONLY)]
----------------------------------------------------- */
/* @media screen and (min-width: 800px) {
    .loop.loop-type-focus {
        position: relative;
        margin: 0 -25px -25px 0;
        width: calc(100% + 25px);
        padding-left: 640px;
        min-height: 720px;
    }

    .loop.loop-type-focus .loop-article {
        margin: 0 25px 25px 0;
        width: calc(50% - 25px);
    }

    .loop.loop-type-focus .loop-article .loop-title {}

    .loop.loop-type-focus .loop-article:nth-child(1) {
        position: absolute;
        top: 0;
        left: 0%;
        width: 580px;
    }

    .loop.loop-type-focus .loop-article:nth-child(1):last-child {
        position: relative;
        top: 0;
        left: -640px;
    }

    .loop.loop-type-focus .loop-article:nth-child(1) .loop-image {
        padding-bottom: 85%;
    }

    .loop.loop-type-focus .loop-article:nth-child(1) .loop-title {
        font-size: 2.4rem;
    }

    .loop.loop-type-focus .loop-article:nth-child(n+2) .loop-header {}

    .loop.loop-type-focus .loop-article:nth-child(n+2) .loop-tag,
    .loop.loop-type-focus .loop-article:nth-child(n+2) .loop-content {
        display: none;
    }

    .loop.loop-type-focus .loop-article:nth-child(n+2) .loop-title {
        margin-bottom: 0;
        font-size: 1.6rem;
    }
} */


/*
-----------------------------------------------------

	=COMMON PARTS - ARTICLE
    ※ 募集要項などでも一部共通

-----------------------------------------------------
*/

/* 記事本文中のスタイル
----------------------------------------------------- */
.article {}

/* ARTICLE - HEADER
----------------------------------------------------- */
.article .article-header {
    margin-bottom: 40px;
}

.article .article-header>*:not( :last-child) {
    margin-bottom: 25px;
}

.article .article-header>*:last-child {
    margin-bottom: 0;
}

.article .article-header:after {
    content: ".";
    display: block;
    height: 0px;
    font-size: 0;
    clear: both;
    visibility: hidden;
}

.article .article-title {
    margin: 0 0 0.75em;
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1.6;
}

.article .article-meta {
    font-size: 1.4rem;
}

.article .article-meta:not( :last-child) {
    margin-bottom: 25px;
}

.article .article-meta>* {
    display: inline-block;
}

.article .article-meta>*:not( :last-child) {
    margin-right: 2em;
    padding-right: 0;
    border-right: solid 0 rgba(68, 68, 68, 0.5);
}

.article .article-date {
    font-family: "Brother-1816", sans-serif;
    font-weight: 500;
    opacity: 0.5;
}

.article .article-modified_date {
    color: #aaa;
    font-size: 1.2rem;
}

.article .article-category {
    display: inline-block;
    font-family: "Brother-1816", sans-serif;
    font-weight: 500;
    text-transform: uppercase;
}

.article .article-category a {
    display: block;
    text-decoration: underline;
}

.article .article-category a:hover {
    opacity: .5;
    text-decoration: none;
}

.article .article-meta ul.list-tag li {}

.article .article-meta ul.list-tag li a {}

.article .article-meta ul.list-tag li a:hover {}

.article .article-header ul.c-list-share {
    margin-top: 60px;
}

.article .article-summary {}

.article .article-summary p {
    font-size: 1.2rem;
    line-height: 1.75;
    letter-spacing: 0;
}

.article .article-readingtime {
    background-color: rgba(0, 0, 0, 0.05);
    padding: 1em 1.5em;
    font-size: 90%;
    font-weight: bold;
    color: #aaa;
}

.article .article-readingtime strong {
    display: inline-block;
    color: #333;
}

@media screen and (min-width: 800px) {
    .article .article-header .c-image-content {
        align-items: flex-start;
    }

    .article .article-header .c-image-content>.c-image {
        width: 300px;
    }

    .article .article-header .c-image-content>.c-content {
        width: calc(100% - 300px - 40px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .article {
        box-shadow: none;
    }

    .article .article-image {
        float: none;
        width: 100%;
        height: auto;
        margin: 0 0 2em;
    }

    .article .article-header {
        margin-bottom: 4vw;
    }

    .article .article-header>*:not( :last-child) {
        margin-bottom: 4vw;
    }

    .article .article-meta {
        font-size: 1.2rem;
    }

    .article .article-title {
        margin-bottom: 4vw;
        font-size: 1.8em;
    }

    .article .article-content {
        font-size: 1.4rem;
    }
}


/* ARTICLE - CONTENT
----------------------------------------------------- */
.article .article-content {
    font-size: .975em;
    letter-spacing: 0.00em;
}

.article .article-content p {
    line-height: 2;
}

.article .article-content p:not(:last-child) {
    margin-bottom: 2em;
}

.article .article-content h1,
.article .article-content h2,
.article .article-content h3,
.article .article-content h4,
.article .article-content h5,
.article .article-content h6 {
    margin: 0 0 1em;
    font-weight: bold;
    line-height: 1.8;
}

.article .article-content h2:not(:first-child),
.article .article-content h3:not(:first-child),
.article .article-content h4:not(:first-child),
.article .article-content h5:not(:first-child),
.article .article-content h6:not(:first-child) {
    margin-top: 2em;
}

.article .article-content h1 {}

.article .article-content h2 {
    position: relative;
    margin: 0 0 1.0em;
    font-size: 140%;
    line-height: 1.6;
    padding-bottom: 0.0em;
    border-bottom: solid 0 #dcdcdc;
}

/* .article .article-content h2::before {
    content: "";
    position: absolute;
    top: 0.5em;
    left: -50px;
    width: 37px;
    height: 28px;
} */

.article .article-content h3 {
    position: relative;
    padding-bottom: 0.35em;
    border-bottom: solid 1px rgba(0, 0, 0, 0.15);
    font-size: 130%;
}

/* .article .article-content h3::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100px;
    height: 2px;
    background-color: var(--color-primary);
} */

.article .article-content h4 {
    font-size: 120%;
}

.article .article-content h5 {
    font-size: 110%;
}

.article .article-content h6 {
    font-size: 100%;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .article .article-content h2 {}

    /* .article .article-content h2::before {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 37px;
        height: 28px;
        background-position: center top;
        background-size: 100% auto;
    } */
}

/* =Image */
.article .article-content img {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* =Horizontal Rule */
.article .article-content hr {
    border: none;
    height: 1px;
    background-color: #dcdcdc;
    margin: 5vw auto;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* =Table */
/* .article .article-content table {
    margin-bottom: 30px;
    border: solid 1px #dcdcdc;
}

.article .article-content tr {
    border: 0;
}

.article .article-content th,
.article .article-content td {
    padding: 0.5em 1.0em;
    border: solid 1px #dcdcdc;
    background-color: rgba(0, 0, 0, 0.025);
}

.article .article-content th {
    background-color: rgba(0, 0, 0, 0.05);
} */

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .article .article-content th {
        min-width: 6em;
    }
}

/* =blockquote */
.article .article-content blockquote:not(:last-child) {
    margin-bottom: 3em;
}

.article .article-content blockquote {
    padding: 1.25em 2em;
    background-color: #f9f9f9;
    border: solid 1px #ececec;
    font-size: 0.91em;
}

.article .article-content blockquote::before {}

.article .article-content blockquote::after {}

.article .article-content blockquote p:not(:last-child) {
    margin-bottom: 1em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* Definition List */
.article .article-content dl {
    padding: 1.4em;
    border: solid 3px #000;
}

.article .article-content dl dt,
.article .article-content dl dd {
    margin: 0 auto .7125em;
}

.article .article-content dl dt {
    font-weight: bold;
    font-size: 108%;
}

.article .article-content dl dd {
    padding-left: 1.3125em;
    font-size: 90%;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* Unordered List */
.article .article-content ul:not([class]) {
    margin-bottom: 3em;
}

.article .article-content ul:not([class]):last-child {
    margin-bottom: 0;
}

.article .article-content ul:not([class]) li {
    margin: 0 0 0.25em;
    position: relative;
    padding-left: 1.25em;
}

.article .article-content ul:not([class]) li::before {
    content: "● ";
    position: absolute;
    left: 0;
    top: 1em;
    color: var(--color-primary);
    font-size: 0.9rem;
}

.article .article-content ul:not([class]) li:last-child {
    margin-bottom: 0;
}

.article .article-content ul:not([class]) li a {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .article .article-content ul:not([class]) li::before {
        content: "● ";
        position: absolute;
        left: 0;
        top: 0.5em;
    }
}

/* Ordered List */
.article .article-content ol {
    counter-reset: section;
}

.article .article-content ol:not(:last-child) {
    margin-bottom: 3em;
}

.article .article-content ol {}

.article .article-content ol li {
    margin: 0 0 0.25em;
    display: list-item;
    list-style: decimal-leading-zero;
    /*margin-left: 2.1em; */
    padding-left: 1.25em;
    list-style: none;
}

.article .article-content ol>li:before {
    content: counters(section, '-', decimal) '. ';
    counter-increment: section;
    color: var(--color-primary);
}

.article .article-content ol:not([class]) li a {
    text-decoration: none;
}

.article .article-content ol ol {
    margin-left: 1em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* Markdown */
.article .article-content mark {
    background-color: inherit;
}

.article .article-content strong {
    font-weight: bold;
}

.article .article-content em {
    font-style: italic;
}

.article .article-content code {
    display: inline-block;
    padding: 0.1em 0.5em;
    color: #e7edf3;
    background-color: #333;
    border-radius: 3px;
    border: solid 1px #d6dde4;
}

.article .article-content kbd {
    display: inline-block;
    margin: 0 0.2em;
    padding: 0.4em 0.6em;
    background-color: #f1f1f1;
    border-bottom: 3px solid #b4b4b4;
    border-radius: 3px;
    vertical-align: middle;
    font-size: 0.9em;
    line-height: 1.1;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .1);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* sup, sub */
.article .article-content sup {
    font-size: 60%;
    vertical-align: top;
    position: relative;
    top: -0.5em;
}

.article .article-content sub {
    font-size: 60%;
    vertical-align: bottom;
    position: relative;
    bottom: -0.5em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* ARTICLE - FOOTER
----------------------------------------------------- */
.article-footer {}

.article-footer .article-sns {
    text-align: right;
}

.article-author {
    margin-bottom: 2em;
    border: solid 0 #dcdcdc;
    background-color: #f1f1f1;
    padding: 2.0em;
}

.article-author .pic {
    float: right;
    width: 150px;
    max-width: 28%;
    margin: 0 0 0 2em;
}

.article-author .pic img.avatar {
    border-radius: 0;
}

.article-author .tit,
.article-author .txt {
    overflow: inherit;
    margin-bottom: 5px;
}

.article-author .tit {
    margin-bottom: 20px;
    font-size: 150%;
    font-weight: bold;
    line-height: 1.25;
}

.article-author .tit span {
    display: block;
    margin-right: 1em;
    margin-bottom: 1em;
    color: #666;
    font-size: 1.2rem;
    font-weight: normal;
}

.article-author .txt,
.article-author .link {
    color: #666;
    font-size: 1.2rem;
}

.article-author .link {
    text-align: right;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/*
-----------------------------------------------------

	=FRONTPAGE (TOP)

-----------------------------------------------------
*/

/* TOPページのメインコンテンツ背景 */
#container.u-ver-toppage {
    overflow: hidden;
}

#main.u-ver-toppage {
    background-color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 1600px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main.u-ver-toppage .l-button .c-button-readmore {
        margin-left: auto;
    }
}


/*
-----------------------------------------------------

    =TOP - BACKGROUND (VIDEO)

----------------------------------------------------- 
*/
/* TOPページのファーストビュー（下層「採用情報」ページでも共通） */
.l-top-bg {
    position: fixed;
    z-index: 1;
    left: 0;
    right: 0;
    top: 0;
    overflow: hidden;
    width: calc(100%);
    height: calc(100vh);
    min-height: 540px;
    margin: 0 auto;
    background-color: #000;
    -webkit-transition: all ease-out 0.3s;
    -moz-transition: all ease-out 0.3s;
    -ms-transition: all ease-out 0.3s;
    transition: all ease-out 0.3s;
}

.l-top-bg::before {
    content: "";
    position: absolute;
    z-index: 2;
    left: 0;
    top: 0;
    width: 100%;
    height: 30%;
}

.footer-is-show .l-top-bg {
    opacity: 0;
    pointer-events: none;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 1600px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    /* .l-top-bg {
        top: 70px;
        border-radius: 20px;
        width: calc(100% - 3.125vw*2);
        height: 100dvh;
        height: calc(100dvh - 70px - 3.125vw);
        min-height: inherit;
    }

    .js-status-scrolled .l-top-bg {
        top: 70px;
        height: calc(100dvh - 70px);
        width: 100%;
        border-radius: 0;
    } */
}

/* VIDEO */
.l-top-bg .l-video {
    position: absolute;
    z-index: 1;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background-color: #000;
}

.l-top-bg .video::before {}

.l-top-bg .l-video video,
.l-top-bg .l-video img {
    object-fit: cover;
    object-position: center top;
    width: 100%;
    height: 100%;
    opacity: 1;
    opacity: .7;
    -webkit-transition: all ease-out 0.6s;
    -moz-transition: all ease-out 0.6s;
    -ms-transition: all ease-out 0.6s;
    transition: all ease-out 0.6s;
}

.js-status-scrolled .l-top-bg .l-video video,
.js-status-scrolled .l-top-bg .l-video img {
    opacity: .35;
}

/*
-----------------------------------------------------

    =TOP - FIRSTVIEW

----------------------------------------------------- 
*/
/* TOPページのファーストビュー */
.l-top-fv {
    position: relative;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100vw;
    height: calc(100vh);
    min-height: 540px;
    background-color: transparent;
}

.l-top-fv::before {
    content: "";
    position: absolute;
    z-index: 1;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

@media screen and (min-width: 800px) {
    .l-top-fv .c-wrapper {
        padding: 0 6.25vw;
    }
}

@media screen and (min-width: 1200px) {
    .l-top-fv .c-wrapper {
        padding: 0;
    }
}

@media screen and (min-width: 1600px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-fv {
        height: 100dvh;
        margin-bottom: 0;
        min-height: auto;
    }

    .l-top-fv .c-wrapper {
        padding: 0 6.25vw;
    }
}

/* FIRSTVIEW - CONTENT */
.l-top-fv .l-content {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.l-top-fv .l-content .l-object {
    position: absolute;
    z-index: -1;
    left: -350px;
    top: 120px;
    width: 1730px;
}

.l-top-fv .l-content .l-tagline {
    position: relative;
    z-index: 1;
    bottom: 0;
    width: 100%;
    height: 100%;
    padding: 40px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.l-top-fv .l-content .l-tagline .c-wrapper {}

.l-top-fv .l-content .l-tagline .l-text {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
    -moz-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
    -ms-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
    -o-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1) 1.2s;
}

.l-top-fv .l-content .l-tagline .l-object img {}

.l-top-fv .l-content .l-tagline .l-text01 {
    width: 1000px;
}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 1600px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-fv .l-content {
        margin: 0;
        width: 100vw;
    }

    .l-top-fv .l-content .l-object {
        left: -460px;
        top: 130px;
        width: 221vw;

        left: -540px;
        top: 240px;
        width: 241vw;
    }

    .l-top-fv .l-content .l-tagline {
        padding: 6.25vw;
        justify-content: center;
    }

    .l-top-fv .l-content .l-tagline .l-text01 {
        width: 100%;
    }
}

/* FIRSTVIEW - SCROLL */
.l-top-fv .l-scroll {
    position: absolute;
    z-index: 3;
    bottom: 0;
    right: 0;
    width: 6em;
    height: auto;
    padding: 0.75em;
    color: #fff;
}

.l-top-fv .l-scroll .l-scroll-text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 1px;
    height: 120px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
}

.l-top-fv .l-scroll .l-scroll-text::before {
    position: absolute;
    top: -6em;
    left: -0.4em;
    content: "SCROLL";
    font-family: "Brother-1816", sans-serif;
    font-size: 1.1rem;
    font-weight: 500;
    letter-spacing: 0.20em;
    line-height: 1;
}

.l-top-fv .l-scroll .l-scroll-text::after {
    position: absolute;
    left: 0;
    content: "";
    width: 1px;
    height: 0;
    background-color: #fff;
    -webkit-animation: scrollEffect 4s infinite;
    animation: scrollEffect 4s infinite;
}

@keyframes scrollEffect {
    20% {
        height: 0%;
    }

    35% {
        height: 100%;
    }

    85% {
        height: 100%;
    }

    100% {
        height: 0%;
    }
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-fv .l-scroll {
        bottom: 0;
        right: 6.25vw;
        width: 4em;
    }

    .l-top-fv .l-scroll .l-scroll-text {
        height: 100px;
    }

    .l-top-fv .l-scroll .l-scroll-text::before {
        font-size: 0.9rem;
    }
}

/*
-----------------------------------------------------

    =TOP - COMMON PARTS

----------------------------------------------------- 
*/

/* 角丸 */
.c-radius {
    border-radius: 20px;
    overflow: hidden;
}

.u-radius10 {
    border-radius: 10px;
}

.u-radius15 {
    border-radius: 15px;
}

.u-radius20 {
    border-radius: 20px;
}

.u-radius30 {
    border-radius: 30px;
}

.u-radius40 {
    border-radius: 40px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-radius {
        border-radius: 8px;
        overflow: hidden;
    }
}

/* ループする背景 */
.loop-animation-background {
    width: 100%;
    overflow: hidden;
    -webkit-user-select: none;
    user-select: none;
    background-repeat: repeat-x;
    animation-duration: 56s;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    will-change: background-position-x;
}

/* フル幅のセクション設定 */
.c-flexible-container {
    border-radius: 30px;
    overflow: hidden;
    width: calc(100% - 40px * 2);
    margin: 0 auto 40px;
    padding: 0 40px;
    max-width: 1600px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-flexible-container {
        border-radius: 10px;
        width: calc(100% - 6.25vw - 6.25vw);
        margin: 0 auto 6.25vw;
        padding: 0;
    }
}

/* フロートしているオブジェクト */
.c-object-figures {
    z-index: -1;
    pointer-events: none;
}

.c-object-figures img {
    zoom: 0.5;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-object-figures img {
        zoom: 0.125;
    }
}

/*
-----------------------------------------------------

    =TOP - INTRO

----------------------------------------------------- 
*/
.l-top-intro {
    position: relative;
    z-index: 1;
    color: #fff;
    overflow: hidden;
    border-radius: 0;
    /* width: calc(100% - 40px * 2); */
    margin: 0 auto;
}

.l-top-intro::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* background-color: #000; */
    background-image: -moz-linear-gradient(-180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 60%);
    background-image: -webkit-linear-gradient(-180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 60%);
    background-image: -ms-linear-gradient(-180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 60%);
    background-image: linear-gradient(-180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 60%);
}

.l-top-intro .c-featured-text p {}

.l-top-intro .l-main-content {}

@media screen and (min-width: 800px) {
    .l-top-intro .c-section {
        padding: 300px 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-intro .c-section {
        padding: 100px 0 25.0vw;
    }

    .l-top-intro .c-wrapper {
        padding: 0 6.25vw;
    }
}


/* ループするテキスト */
.l-top-intro .loop-animation-background {
    position: relative;
    z-index: 3;
    height: calc(306px / 2);
    background-size: auto 100%;
    animation-name: loop-animation-top-intro;
}

.l-top-intro .loop-animation-background {
    background-image: url(assets/images/object-looped_text-top-pholosophy.webp);
}

@keyframes loop-animation-top-intro {
    0% {
        background-position-x: 0;
    }

    100% {
        background-position-x: -2120px;
    }
}

@media screen and (min-width: 800px) {
    .l-top-intro .loop-animation-background {
        margin: 0 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-intro .loop-animation-background {
        margin: 0 0;
        height: calc(306px / 4);
    }
}


/*
-----------------------------------------------------

    =TOP - MESSAGE

----------------------------------------------------- 
*/
.l-top-message {
    position: relative;
    z-index: 1;
    background: url(assets/images/top-message-bg.webp) no-repeat center top;
    background-size: cover;
}

.l-top-message::before {}

.l-top-message .c-section {
    overflow: hidden;
}

.l-top-message .l-tagline {
    position: absolute;
    z-index: 1;
    top: -9vw;
    left: 0;
    width: 100%;
    height: auto;
}

.l-top-message .l-main-content {
    position: relative;
    z-index: 2;
}

.l-top-message .l-main-content .c-image-content>.c-image {
    position: relative;
    z-index: 1;
}

.l-top-message .l-main-content .c-image-content>.c-content {
    position: relative;
    z-index: 2;
}

.l-top-message .l-main-content .l-name-sign {
    justify-content: flex-start;
    align-items: flex-end;
}

.l-top-message .l-main-content .l-name-sign .l-logo {
    width: 200px;
    margin-right: 60px;
}

@media screen and (min-width: 800px) {
    .l-top-message .l-main-content .c-image-content {
        align-items: flex-end;
    }

    .l-top-message .l-main-content .c-image-content>.c-image {
        width: 660px;
    }

    .l-top-message .l-main-content .c-image-content>.c-content {
        width: 470px;
        padding: 80px 0 340px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-message::before {
        background-position: right 0 top 25%;
        background-size: 90vw auto;
    }

    .l-top-message .l-main-content .c-image-content>.c-image {
        margin: 0 auto;
        height: 80vw;
        text-align: center;
    }

    .l-top-message .l-main-content .c-image-content>.c-content {
        width: 100vw;
        max-width: 100vw;
        margin: 0 -6.25vw;
        padding: 6.25vw 6.25vw 12.5vw;
        background-color: #fff;
    }

    .c-title-section .l-icon {
        width: 40px;
    }

    .l-top-message .l-main-content .c-image-content>.c-image img {
        width: 80%;
    }

    .l-top-message .l-main-content .c-image-content>.c-image .l-object {
        position: absolute;
        left: auto;
        right: -5vw;
        bottom: 80px;
    }

    .l-top-message .l-main-content .l-name-sign .l-logo {
        width: 150px;
        margin-right: 40px;
    }

    .l-top-message .l-button {
        text-align: right;
    }
}


/* 共通パーツ - 署名（※下層ページでも共通）
----------------------------------------------------- */
.c-name-sign {
    font-weight: 500;
}

.c-name-sign .u-ver-subpages {
    opacity: 0.5;
}

.c-name-sign .l-sub {
    font-size: .875em;
    opacity: 0.5;
}

.c-name-sign .l-main {
    font-size: 2.8rem;
}

.c-name-sign .l-main .l-japanese {}

.c-name-sign .l-main .l-english {
    display: inline-block;
    vertical-align: middle;
    margin-left: 1em;
    font-family: "Brother-1816", sans-serif;
    font-size: 1.6rem;
    font-weight: normal;
    opacity: 0.5;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-name-sign .l-main img {
        zoom: 0.25;
    }

    .c-name-sign .l-main {
        font-size: 1.5em;
    }
}


.c-name-sign.u-ver-vertical>* {
    display: block
}

.c-name-sign.u-ver-vertical .l-main {
    margin: 0.35em 0 0;
    line-height: .9;

    padding-top: 0 !important;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/*
-----------------------------------------------------

    =TOP - ABOUT ~ DATA

----------------------------------------------------- 
*/
.l-top-about-header-object {
    position: relative;
    z-index: 2;
    margin: -10vw 0 0;
    width: 100%;
}

.l-top-about-data-group {
    position: relative;
    z-index: 2;
    background-color: var(--color-secondary);
    padding: 0 0 40px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-about-header-object {
        display: none;
    }
}

/*
-----------------------------------------------------

    =TOP - ABOUT

----------------------------------------------------- 
*/
.l-top-about {
    position: relative;
    z-index: 2;
    background-color: var(--color-secondary);
}

.l-top-about::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-drops-top-about.webp) no-repeat right 90% top 45%;
    background-size: 800px auto;
}

@media screen and (min-width: 800px) {
    .l-top-about .l-main-content .c-image-content {
        align-items: flex-start;
    }

    .l-top-about .l-main-content .c-image-content>.c-image {
        width: 920px;
        margin: -180px -120px 0 0;
    }

    .l-top-about .l-main-content .c-image-content>.c-content {
        width: 780px;
        width: 690px;
        margin: 0 -150px 0 0;
        padding: 0px 0 0;
    }

    .l-top-about .l-main-content .l-cover {
        position: relative;
        right: -60px;
    }

    .l-top-about .l-main-content .l-text {
        width: 440px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {

    .l-top-about {
        padding-top: 6.25vw;
    }

    .l-top-about::before {
        background-position: left -10% top 25%;
        background-size: 90vw auto;
    }

    .l-top-about .l-main-content .c-image-content>.c-image {
        width: calc(100vw - 10vw);
        max-width: 100vw;
        margin: 0 10vw 0 auto;
        height: 80vw;
    }

    .l-top-about .l-main-content .c-image-content>.c-content {
        width: 100%;
        margin: 6.25vw 0 12.5vw;
    }
}



.l-top-about .l-sub-content {}

@media screen and (min-width: 800px) {
    .l-top-about .l-sub-content .c-image-content {
        align-items: center;
    }

    .l-top-about .l-sub-content .c-image-content>.c-image {
        width: 660px;
    }

    .l-top-about .l-sub-content .c-image-content>.c-content {
        width: calc(100% - 660px - 80px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/*
-----------------------------------------------------

    =TOP - DATA

----------------------------------------------------- 
*/
.l-top-data {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background: url(assets/images/top-data-bg.webp) no-repeat center top;
    background-size: cover;
    background-color: #fef6ee;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, .1);
}

.l-top-data::before {}

.l-top-data .c-section {
    padding: 50px 0;
}

@media screen and (min-width: 800px) {
    .l-top-data .c-image-content {
        align-items: center;
    }

    .l-top-data .c-image-content>.c-image {
        width: 760px;
    }

    .l-top-data .c-image-content>.c-content {
        width: calc(100% - 760px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/*
-----------------------------------------------------

    =TOP - GUIDEBOOK

----------------------------------------------------- 
*/
.l-top-guidebook {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background-color: #fff;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, .1);
}

.l-top-guidebook::before {}

.l-top-guidebook a {
    color: inherit;
    text-decoration: none;
}

.l-top-guidebook .c-section {
    padding: 50px 0;
}

.l-top-guidebook .l-main-content {
    background: url(assets/images/icon-arrow-slider-right.webp) no-repeat right 40px center;
    background-size: 64px auto;
}

@media screen and (min-width: 800px) {
    .l-top-guidebook .c-image-content {
        align-items: center;
        justify-content: center;
    }

    .l-top-guidebook .c-image-content>.c-image {
        width: 360px;
    }

    .l-top-guidebook .c-image-content>.c-content {
        width: calc(100% - 360px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-guidebook .c-section {
        padding: 6.25vw;
    }

    .l-top-guidebook .l-main-content {
        background: none;
    }

    .l-top-guidebook .c-image-content>.c-image {
        text-align: center;
    }
}

/*
-----------------------------------------------------

    =TOP - WORKSTYLE ~ CULTURE

----------------------------------------------------- 
*/

.l-top-workstyle-culture-group {
    position: relative;
    z-index: 2;
    background: url(assets/images/object-ribbon-top-workstyle.webp) no-repeat right -200px top -450px;
    background-size: 1440px auto;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-workstyle-culture-group {
        background-position: right -50vw top -35vw;
        background-size: 120vw auto;
    }
}




/*
-----------------------------------------------------

    =TOP - WORKSTYLE

----------------------------------------------------- 
*/
.l-top-workstyle {
    position: relative;
    z-index: 2;
}

.l-top-workstyle::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-loop-dots-top-culture.webp) no-repeat right 10% bottom;
    background-size: 600px auto;
}

@media screen and (min-width: 800px) {
    .l-top-workstyle .c-image-content {
        align-items: center;
    }

    .l-top-workstyle .c-image-content>.c-image {
        width: 800px;
        margin: 0 0 0 -180px;
    }

    .l-top-workstyle .c-image-content>.c-content {
        width: 460px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-workstyle::before {
        background-size: 70vw auto;
    }
}



/* ループするギャラリー */
.l-top-workstyle .loop-animation-background {
    position: relative;
    z-index: 3;
    height: calc(880px / 2);
    background-size: auto 100%;
    animation-name: loop-animation-top-worksyle;
    margin: 0 0 -80px;
}

.l-top-workstyle .loop-animation-background {
    background-image: url(assets/images/top-workstyle-gallery.webp);
}

@keyframes loop-animation-top-worksyle {
    0% {
        background-position-x: 0;
    }

    100% {
        background-position-x: -2500px;
    }
}

@media screen and (min-width: 800px) {
    .l-top-workstyle .loop-animation-background {}
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-workstyle .loop-animation-background {
        height: calc(880px / 4);
        margin: 0;
    }
}

/*
-----------------------------------------------------

    =TOP - CULTURE

----------------------------------------------------- 
*/
.l-top-culture {
    position: relative;
    z-index: 1;
    background: url(assets/images/object-drops-top-culture.webp) no-repeat left 80% bottom 15px;
    background-size: 600px auto;
}

.l-top-culture::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-circle-top-culture.webp) no-repeat left -10% top;
    background-size: 960px auto;
}

@media screen and (min-width: 800px) {
    .l-top-culture {
        min-height: 960px;
    }

    .l-top-culture .c-image-content {
        align-items: center;
        padding: 100px 0 0;
    }

    .l-top-culture .c-image-content>.c-image {
        width: 800px;
        margin: 0 -180px 0 0;
    }

    .l-top-culture .c-image-content>.c-content {
        width: 550px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-culture {
        background-position: left 80% top 15px;
        background-size: 50vw auto;
    }

    .l-top-culture::before {
        background-position: left -20% bottom 19%;
        background-size: 80vw auto;
    }
}



/*
-----------------------------------------------------

    =TOP - COLUMN

----------------------------------------------------- 
*/
.l-top-column {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-top-column::before {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background-color: #fef6ee;
}

@media screen and (min-width: 800px) {
    .l-top-column .c-image-content {
        align-items: flex-start;
    }

    .l-top-column .c-image-content>.c-image {
        width: 50%;
    }

    .l-top-column .c-image-content>.c-content {
        width: 50%;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* 記事ループ部分 */
.l-top-column-slider {
    position: relative;
    z-index: 2;
}


.loop.loop-type-top-column .loop-image {
    position: relative;
    overflow: inherit;
}

.loop.loop-type-top-column .loop-image img {
    border-radius: 10px;
    overflow: hidden;
}

.loop.loop-type-top-column .loop-title {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}   


/* SWIPER.JS
-------------------------------------------------- */
.l-top-column-slider {
    position: relative;
}

.l-top-column-slider .swiper-grandparent {
    position: relative;
}

.l-top-column-slider .swiper-grandparent .swiper-parent {
    max-width: 100%;
}

.l-top-column-slider .swiper-grandparent .swiper-parent .swiper-container {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-column-slider .swiper-grandparent {
        width: 100%;
    }
}

/* SLIDE
-------------------------------------------------- */
.l-top-column-slider .swiper-wrapper {
    flex-wrap: inherit !important;
    margin-bottom: 0px !important;
}

@media screen and (min-width: 800px) {
    .l-top-column-slider .swiper-grandparent .swiper-parent .swiper-container {
        /* for NEW Icon */
        padding: 20px;
        margin: -20px;
    }

    .l-top-column-slider .swiper-slide {
        width: 280px;
        min-height: 480px;
        margin: 0 40px 0 0;
    }

    .l-top-column-slider .swiper-slide-active {
        width: calc(1120px / 2);
        width: 560px;
        opacity: 1;
    }

    .l-top-column-slider .swiper-slide-active .loop-title {
        font-size: 2.4rem;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-top-column-slider .swiper-grandparent .swiper-parent .swiper-container {
        /* for NEW Icon */
        padding: 15px;
        margin: -15px;
    }

    .l-top-column-slider .swiper-slide {
        width: 100%;
        margin: 0 12.25vw 0 0;
    }
}

/* PREV & NEXT
-------------------------------------------------- */
.l-top-column-slider .swiper-button-prev,
.l-top-column-slider .swiper-container-rtl .swiper-button-next,
.l-top-column-slider .swiper-button-next,
.l-top-column-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: auto !important;
    bottom: 30px !important;
    margin: 0 !important;
    width: 64px !important;
    height: 64px !important;
}

.l-top-column-slider .swiper-button-prev,
.l-top-column-slider .swiper-container-rtl .swiper-button-next {
    left: auto !important;
    right: 80px !important;
    background-image: url(assets/images/icon-arrow-slider-left.webp) !important;
}

.l-top-column-slider .swiper-button-next,
.l-top-column-slider .swiper-container-rtl .swiper-button-prev {
    right: 0 !important;
    background-image: url(assets/images/icon-arrow-slider-right.webp) !important;
}

@media screen and (min-width: 0px) and (max-width: 799px) {

    /* PREV & NEXT */
    .l-top-column-slider .swiper-button-prev,
    .l-top-column-slider .swiper-container-rtl .swiper-button-next,
    .l-top-column-slider .swiper-button-next,
    .l-top-column-slider .swiper-container-rtl .swiper-button-prev {
        top: 0 !important;
        bottom: 0 !important;
        width: 48px !important;
        height: 48px !important;
        margin: auto 0 !important;
    }

    .l-top-column-slider .swiper-button-prev,
    .l-top-column-slider .swiper-container-rtl .swiper-button-next {
        right: auto !important;
        left: -15px !important;
    }

    .l-top-column-slider .swiper-button-next,
    .l-top-column-slider .swiper-container-rtl .swiper-button-prev {
        left: auto !important;
        right: -10px !important;
    }
}

/* PAGINATION
-------------------------------------------------- */
.l-top-column-slider .swiper-container .swiper-pagination {
    left: auto;
    right: 0;
    bottom: 0;
    width: auto;
    text-align: right;
    margin: 30px;
}

.l-top-column-slider .swiper-container .swiper-pagination-bullet {
    background-color: #fff;
}

.l-top-column-slider .swiper-container .swiper-pagination-bullet-active {
    background-color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/*
-----------------------------------------------------

    =TOP - JOBS [募集要項]

----------------------------------------------------- 
*/
.l-top-jobs {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/*
-----------------------------------------------------

    =COMMON PARTS - ACTION - CONTACT

----------------------------------------------------- 
*/
/* アクション - お問い合わせ */
.l-action-entry {
    position: relative;
    z-index: 3;
    background: url(assets/images/action-bg.webp) no-repeat center center;
    background-size: cover;
    color: #fff;
    overflow: hidden;
}

.l-action-entry::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-ribbon-action.webp) no-repeat left bottom -10px;
    background-size: 100% auto;
}

.l-action-entry .l-main-content {}

.l-action-entry .l-main-content .l-title01 {
    font-family: "Brother-1816 Black", sans-serif;
    font-size: 22.0rem;
    line-height: .9;
}

.l-action-entry .l-main-content .l-title02 {
    margin-bottom: .25em;
    font-size: 12.0rem;
}

@media screen and (min-width: 800px) {
    .l-action-entry .c-section {
        padding: 24vw 0 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-action-entry .c-section {
        padding: 44vw 0 0;
    }

    .l-action-entry .l-main-content .l-title01 {
        font-size: 16vw;
    }

    .l-action-entry .l-main-content .l-title02 {
        margin-bottom: .75em;
        font-size: 6vw;
    }
}


/* ボタン - ACTION ENTRY */
.c-button-action-entry {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    height: 180px;
    line-height: 1.0;
    padding: 0 2em;
    border-radius: 40px;
    background-color: var(--color-orange);
    color: #fff;
    font-size: 3.2rem;
    font-weight: bold;
    letter-spacing: 0;
    text-align: left;
    text-decoration: none;
}

.c-button-action-entry .l-english,
.c-button-action-entry .l-japanese,
.c-button-action-entry .l-arrow {
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.c-button-action-entry .l-english,
.c-button-action-entry .l-japanese {
    display: inline-block;
    vertical-align: middle;
}

.c-button-action-entry .l-english {
    margin-right: 0.45em;
    font-family: "Brother-1816 Black", sans-serif;
    font-size: 9.0rem;
}

.c-button-action-entry .l-japanese {
    font-weight: bold;
}

.c-button-action-entry .l-arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2em;
    width: 64px;
    height: 64px;
    margin: auto;
}

.c-button-action-entry .l-arrow svg {
    fill: var(--color-primary);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 16px;
    height: 20px;
    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.c-button-action-entry:hover {
    opacity: 1;
    filter: brightness(1.25);
}

.c-button-action-entry:hover .l-english {
    border-color: transparent;
}

.c-button-action-entry:hover .l-arrow {}

.c-button-action-entry:hover .l-arrow svg {
    fill: var(--color-primary);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-button-action-entry {
        width: 100%;
        max-width: 100%;
        height: 80px;
        padding: 0 2em;
        border-radius: 15px;
        font-size: 1.5rem;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
    }

    .c-button-action-entry .l-english,
    .c-button-action-entry .l-japanese {
        display: block;
    }

    .c-button-action-entry .l-english {
        margin: 0 0 5px;
        font-size: 2.6rem;
    }

    .c-button-action-entry .l-arrow {
        width: 32px;
        height: 32px;
    }

    .c-button-action-entry .l-arrow svg {
        width: 20px;
    }
}

/*
-----------------------------------------------------

	=SUBPAGES
		FIRSTVIEW
        COMMON PARTS - LAYOUT & BACKGROUND
        COMMON PARTS - HEADING
        COMMON PARTS - BUTTON

-----------------------------------------------------
*/

/*
-----------------------------------------------------

    =SUBPAGES - COMMON PARTS

----------------------------------------------------- 
*/
/* =SUBPAGES - COMMON PARTS - LAYOUT & BACKGROUND
----------------------------------------------------- */
#container.u-ver-subpages {
    position: relative;
    z-index: 1;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #container.u-ver-subpages {
        overflow: hidden;
    }
}


/* =SUBPAGES - PAGE BACKGROUND
----------------------------------------------------- */
#main.u-ver-subpages {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* =SUBPAGES - COMMON PARTS - FIRSTVIEW
----------------------------------------------------- */
.c-sub-fv {
    position: relative;
    z-index: 3;
    pointer-events: none;
}

.c-sub-fv::before {
    content: "";
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    height: calc(100% + 100%);
    background: url(assets/images/object-ribbon-sub-fv.webp) no-repeat center top 30px;
    background-size: 2150px auto;
}

.c-sub-fv .l-tagline {
    position: relative;
    z-index: 3;
}

.c-sub-fv .l-tagline .c-wrapper {
    position: relative;
    z-index: 1;
}

.c-sub-fv .l-title {
    margin-bottom: 0;
}

.c-sub-fv .l-cover {
    position: relative;
    z-index: -1;
}

.c-sub-fv .l-cover .c-cover-image {
    width: calc(100% + 160px);
    margin-right: -160px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-sub-fv::before {
        background-position: center top 55px;
        background-size: 170vw auto;
    }

    .c-sub-fv .l-cover .c-cover-image {
        width: calc(100% + 12.5vw);
        margin-right: -12.5vw;
    }
}


/* ループするテキスト */
.c-sub-fv .loop-animation-background {
    position: relative;
    z-index: 3;
    height: calc(267px / 2);
    background-size: auto 100%;
    animation-name: loop-animation-sub-fv;
}

.c-sub-fv .loop-animation-background {
    background-image: url(assets/images/object-looped_text-sub-fv.webp);
}

@keyframes loop-animation-sub-fv {
    0% {
        background-position-x: 0;
    }

    100% {
        background-position-x: -2500px;
    }
}

@media screen and (min-width: 800px) {
    .c-sub-fv .loop-animation-background {
        margin: 0 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-sub-fv .loop-animation-background {
        margin: 0 0;
        height: calc(267px / 4);
    }
}

/* SERVICESの下層コンテンツのみ */
.u-page-services_detail .c-sub-fv {}

@media screen and (min-width: 800px) {
    .u-page-services_detail .c-sub-fv .c-section {
        padding-bottom: 320px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .u-page-services_detail .c-sub-fv .l-title {
        margin-bottom: 2em;
    }
}



/* =SUBPAGES - COMMON PARTS - BREADCRUMBS
----------------------------------------------------- */
/* パンくずリスト */
#breadcrumbs {
    position: relative;
    z-index: 2;
    margin: 0;
    padding: 2em 0;
    font-size: 1.6rem;
    font-weight: bold;
    letter-spacing: 0.0em;
}

#breadcrumbs,
#breadcrumbs a {
    color: var(--color-primary);
}

#breadcrumbs a {
    display: inline-block;
    text-decoration: none;
    color: var(--color-primary);
    line-height: 2;
}

#breadcrumbs a:hover {
    text-decoration: none;
}

#breadcrumbs .l-inner {}

#breadcrumbs p {
    line-height: 2;
}

#breadcrumbs p>span>span:first-child {
    position: relative;
    display: inline-block;
    visibility: visible;
    background: url(assets/images/icon-breadcrumbs-home.webp) no-repeat left center;
    background-size: 21px auto;
    padding-left: 26px;
}

#breadcrumbs p>span>span:first-child::before {}

#breadcrumbs p>span {
    font-family: serif;
}

#breadcrumbs p>span>span {}

#breadcrumbs p>span a {}

#breadcrumbs p>span a,
#breadcrumbs p>span span.breadcrumb_last {
    display: inline-block;
    position: relative;
    visibility: visible;

    font-family: "Poppins", 'Noto Sans JP', "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
}

#breadcrumbs p>span span.breadcrumb_last {
    color: var(--color-text-basic);
}

#breadcrumbs p>span a:first-child {}

@media screen and (min-width: 800px) {
    #breadcrumbs {}
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #breadcrumbs {
        font-size: 1.1rem;
    }

    #breadcrumbs .l-inner {}

    #breadcrumbs p>span>span:first-child {
        background-size: 15px auto;
    }

    #breadcrumbs p>span a::before {
        width: 7px;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - MESSAGE

-----------------------------------------------------
*/
#main.u-page-message {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = MESSAGE - メインコンテンツ
----------------------------------------------------- */
.l-sub-message-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-message-main::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-ribbon-sub-message-bg.webp) no-repeat right 50% top 60%;
    background-size: 1870px auto;
}

.l-sub-message-main .l-main-content {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* ギャラリー部分 */
@media screen and (min-width: 800px) {
    .c-gallery-3pics.l-parent {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(2, 1fr);
        grid-column-gap: 0px;
        grid-row-gap: 0px;
    }

    .c-gallery-3pics.l-parent .l-child01 {
        grid-area: 1 / 1 / 3 / 2;
        width: 670px;
        padding-right: 30px;
    }

    .c-gallery-3pics.l-parent .l-child02 {
        grid-area: 1 / 2 / 2 / 3;
        width: 540px;
        padding-bottom: 20px;
    }

    .c-gallery-3pics.l-parent .l-child03 {
        grid-area: 2 / 2 / 3 / 3;
        width: 540px;
    }
}


@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-gallery-3pics.l-parent .l-child {
        margin-bottom: 3.125vw;
    }
}

/*
-----------------------------------------------------

	=SUB PAGES - ABOUT（※WORKSTYLEとほぼ共通）

-----------------------------------------------------
*/
#main.u-page-about {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background-color: var(--color-secondary);
}

#main.u-page-about::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 840px;
    background-color: #fff;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main.u-page-about::before {
        height: 50vw;
    }
}

/* = ABOUT - イントロ（WORKSTYLEページでも共通）
----------------------------------------------------- */
.l-sub-about-intro {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-about-intro::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
@media screen and (min-width: 800px) {
    .l-sub-about-intro .c-image-content {
        align-items: flex-start;
    }

    .l-sub-about-intro .c-image-content>.c-image {
        width: calc(400px);
    }

    .l-sub-about-intro .c-image-content>.c-content {
        width: calc(100% - 400px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* = ABOUT - メインコンテンツ（WORKSTYLEページでも共通）
----------------------------------------------------- */
.l-sub-about-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background: url(assets/images/object-loops-sub-about-bg.webp) no-repeat right 50% top 60%;
    background-size: 1180px auto;
}

@media screen and (min-width: 800px) {
    .l-sub-about-main .c-image-content {
        align-items: flex-start;
    }

    .l-sub-about-main .c-image-content>.c-image {
        width: calc(640px);
    }

    .l-sub-about-main .c-image-content>.c-content {
        width: calc(100% - 640px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/*
-----------------------------------------------------

	=SUB PAGES - PHILOSOPHY [企業理念]

-----------------------------------------------------
*/
#main.u-page-philosophy {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

#main.u-page-philosophy::before {
    content: "";
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(assets/images/object-ribbon-sub-philosophy-bg.webp) no-repeat right -160px bottom -40px;
    background-size: 1900px auto;
    mix-blend-mode: multiply;
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main.u-page-philosophy::before {
        position: absolute;
        background-position: right -90vw bottom -20px;
        background-size: 240vw auto;
        mix-blend-mode: multiply;
    }
}

/* = PHILOSOPHY - メインコンテンツ
----------------------------------------------------- */
.l-sub-philosophy-main {
    position: relative;
    z-index: 1;
}

.l-sub-philosophy-main.js-bg-magic::before {
    position: absolute;
    -webkit-transition: all .4s ease .2s;
    -moz-transition: all .4s ease .2s;
    -ms-transition: all .4s ease .2s;
    transition: all .4s ease .2s;
}

.l-sub-philosophy-main.l-block03.js-bg-magic::before {}

.l-sub-philosophy-main.js-bg-magic.show::before {
    opacity: 1;
}

.l-sub-philosophy-main.l-block01::before {
    background-color: #fff;
}

.l-sub-philosophy-main.l-block02::before {
    background-color: var(--color-secondary);
}

.l-sub-philosophy-main.l-block03::before {
    background-color: var(--color-primary);
}

.l-sub-philosophy-main.l-block03,
.l-sub-philosophy-main.l-block03 * {
    color: #fff;
}

.l-sub-philosophy-main .c-title-focus-subpages {
    padding-left: 0;
}

.l-sub-philosophy-main .c-title-focus-subpages .l-numbering {
    position: static;
    display: block;
    margin: 0 0 0.5em;
}

.l-sub-philosophy-main .c-title-focus-subpages .l-japanese {
    display: block;
    padding-left: 0;
}

@media screen and (min-width: 800px) {
    .l-sub-philosophy-main .c-image-content {
        align-items: flex-start;
    }

    .l-sub-philosophy-main .c-image-content>.c-image {
        width: calc(100% - 920px - 40px);
    }

    .l-sub-philosophy-main .c-image-content>.c-content {
        width: calc(920px);
    }

    .l-sub-philosophy-main .c-title-focus-subpages .l-japanese {
        font-size: 4.5rem;
    }

    .l-sub-philosophy-main .c-title-japanese.u-ver-medium .l-japanese {
        font-size: 3.2rem;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/*
-----------------------------------------------------

	=SUB PAGES - FEATURE [高松建設の強み]

-----------------------------------------------------
*/
#main.u-page-feature {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = FEATURE - メインコンテンツ
----------------------------------------------------- */
.l-sub-feature-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-feature-main::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* 強みのラインナップ (他のページでも共通で使用する可能性があるため、.c-クラスで命名) 
----------------------------------------------------- */
.c-sub-feature-lineup {}

.c-sub-feature-lineup .lineup {
    margin-bottom: 60px;
}

.c-sub-feature-lineup .lineup:last-child {
    margin-bottom: 0;
}

@media screen and (min-width: 800px) {
    .c-sub-feature-lineup .lineup .c-image-content {
        align-items: flex-start;
    }

    .c-sub-feature-lineup .lineup .c-image-content>.c-image {
        width: calc(540px);
    }

    .c-sub-feature-lineup .lineup .c-image-content>.c-content {
        width: calc(100% - 540px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* プロジェクト事例 - ラインナップ */
.l-sub-feature-project-lineup {}

.l-sub-feature-project-lineup .lineup {
    margin-bottom: 60px;
}

.l-sub-feature-project-lineup .lineup:last-child {
    margin-bottom: 0;
}

.l-sub-feature-project-lineup .lineup .l-title {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* フローチャート */
.l-sub-feature-flow-lineup .lineup {
    position: relative;
}

.l-sub-feature-flow-lineup .lineup:last-child {
    margin-bottom: 0;
}

.l-sub-feature-flow-lineup .lineup::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    right: -32px;
    bottom: 0;
    margin: auto 0;
    background: url(assets/images/icon-arrow-right-green.webp) no-repeat center;
    background-size: contain;
    width: 15px;
    height: 18px;
    -webkit-transition: all ease-out 0.2s;
    -moz-transition: all ease-out 0.2s;
    -ms-transition: all ease-out 0.2s;
    transition: all ease-out 0.2s;
}

.l-sub-feature-flow-lineup .lineup:last-child::before {
    display: none;
}

.l-sub-feature-flow-lineup .lineup .l-inner {
    position: relative;
    background-color: var(--color-secondary);
    padding: 30px;
    border-radius: 10px;
    /* display: flex;
    align-items: center;
    justify-content: space-between; */
}

.l-sub-feature-flow-lineup .lineup .l-inner .l-numbering {
    position: absolute;
    top: 0;
    right: 0;
    margin: 30px;
    height: 1em;
    display: inline-block;
    font-family: "Brother-1816 Bold", sans-serif;
    font-size: 2.4rem;
    color: var(--color-emerald);
    line-height: .9;
}

.l-sub-feature-flow-lineup .lineup .l-inner .l-part {
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 .75em;
    padding: 0.5em 1.1em;
    border-radius: 10px;
    color: #fff;
    background-color: var(--color-emerald);
    font-size: .9em;
    font-weight: bold;
    text-align: center;
}

.l-sub-feature-flow-lineup .lineup .l-inner .l-part .l-japanese {}

.l-sub-feature-flow-lineup .lineup .l-inner .l-title {
    font-size: 2.1rem;
    font-weight: bold;
}

@media screen and (min-width: 800px) {
    /* .l-sub-feature-flow-lineup.c-flex-row {
        width: calc(100% + 1%);
    }

    .l-sub-feature-flow-lineup.c-flex-row>.c-flex-child {
        margin: 0 1% 1% 0;
    }

    .l-sub-feature-flow-lineup.c-flex-row.u-col-2>.c-flex-child {
        width: calc(100% / 2 - 1%);
    }

    .l-sub-feature-flow-lineup.c-flex-row.u-col-3>.c-flex-child {
        width: calc(100% / 3 - 1%);
    } */
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-feature-flow-lineup .lineup .l-inner {
        padding: 3.125vw;
    }

    .l-sub-feature-flow-lineup .lineup .l-inner .l-numbering {
        margin: 3.125vw;
        font-size: 1.8rem;
    }

    .l-sub-feature-flow-lineup .lineup .l-inner .l-title {
        font-size: 1.6rem;
    }

    /* 矢印 */
    .l-sub-feature-flow-lineup.c-flex-row.u-responsive>.c-flex-child {
        margin-bottom: 30px;
    }

    .l-sub-feature-flow-lineup .lineup {}
    .l-sub-feature-flow-lineup .lineup::before {
        top: auto;
        right: 0;
        left: 0;
        bottom: -24px;
        margin: 0 auto;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
    }
}


/* FLEXSLIDER.CSS - OVERRIDE */
.flexslider {
    z-index: 2;
    background-color: transparent !important;
    margin-bottom: 0 !important;
    border: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

.flexslider,
.flexslider .slides {
    height: 100%;
}

.flexslider .slides li {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    overflow: hidden;
}

.flexslider .slides li img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* PAGER */
.flexslider ol.flex-control-paging {
    counter-reset: number;
    list-style: none;
    bottom: -27px !important;
}

.flexslider ol.flex-control-paging li {
    padding: 0 !important;
    margin-bottom: 0 !important;
    vertical-align: middle;
    font-size: 0;
    line-height: 0;
}

.flexslider ol.flex-control-paging li:before {
    display: none;
}

.flexslider ol.flex-control-paging li a {
    width: 9px !important;
    height: 9px !important;
    background-color: #ccc !important;
    box-shadow: none !important;
}

.flexslider ol.flex-control-paging li a.flex-active {
    background-color: #333 !important;
}

/* TRANSITION EFFECT */
.flexslider.zoom .slides li {
    overflow: hidden;
}

.flexslider.zoom .slides li img {
    -webkit-transition: all ease-out 24.0s;
    -moz-transition: all ease-out 24.0s;
    -ms-transition: all ease-out 24.0s;
    transition: all ease-out 24.0s;
}

.flexslider.zoom .slides .flex-active-slide img {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.flexslider.zoom-out .slides li {
    overflow: hidden;
}

.flexslider.zoom-out .slides li img {
    -webkit-transition: all ease-out 12.0s;
    -moz-transition: all ease-out 12.0s;
    -ms-transition: all ease-out 12.0s;
    transition: all ease-out 12.0s;
    -webkit-transform: scale(1.05);
    -moz-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05);
}

.flexslider.zoom-out .slides .flex-active-slide img {
    -webkit-transform: scale(1.0);
    -moz-transform: scale(1.0);
    -ms-transform: scale(1.0);
    transform: scale(1.0);
    opacity: 1;
}

.flex-direction-nav a {
    background-size: 100% auto !important;
    top: auto !important;
    bottom: 70px !important;
    width: 64px !important;
    height: 64px !important;
    opacity: 1 !important;
    font-size: 0 !important;
}

.flex-direction-nav a::before {
    display: none !important;
}

.flex-direction-nav a.flex-prev {
    left: 70px !important;
    background-image: url(assets/images/icon-arrow-slider-left-white.webp) !important;
}

.flex-direction-nav a.flex-next {
    left: calc(70px + 64px + 10px) !important;
    background-image: url(assets/images/icon-arrow-slider-right-white.webp) !important;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .flex-direction-nav a {
        bottom: 3.125vw !important;
        width: 40px !important;
        height: 40px !important;
    }

    .flex-direction-nav a.flex-prev {
        left: 3.125vw !important;
    }

    .flex-direction-nav a.flex-next {
        left: calc(3.125vw + 40px + 10px) !important;
    }
}


/* 汎用 - 施設画像ギャラリーのスライダー */
.c-slider-facilities {
    position: relative;
    z-index: 3;
    overflow: hidden;
}

.c-slider-facilities .l-slider {
    position: relative;
    z-index: 1;
    overflow: hidden;
    border-radius: 20px;
}

.c-slider-facilities .l-description {}

.c-slider-facilities .l-description .l-inner {
    padding: 2em;
}

.c-slider-facilities .l-description .l-inner .c-indent-block {}

.c-slider-facilities.u-ver-orange .l-description .l-inner .c-indent-block {
    border-color: var(--color-orange);
}

.c-slider-facilities.u-ver-emerald .l-description .l-inner .c-indent-block {
    border-color: var(--color-emerald);
}

.c-slider-facilities .js-slider-facilities {}

.c-slider-facilities .js-slider-facilities .slides>* {
    border-radius: 0;
}

.c-slider-facilities .js-slider-facilities .slides>* img {
    display: block;
}

.c-slider-facilities .js-slider-facilities .slides>* .slide-caption {
    position: absolute;
    z-index: 9;
    left: 0;
    bottom: 0;
    margin: 8px;
    display: inline-block;
    background-color: rgba(0, 0, 0, 0.2);
    padding: 0.5em 1em;
    color: #fff;
    font-size: 0.8em;
}

.c-slider-facilities .js-slider-facilities .flex-direction-nav a {}

@media screen and (min-width: 800px) {
    /* 
    ABSOLUTE VER.
    .c-slider-facilities .l-description {
        position: relative;
        z-index: 2;
        margin: -120px 0 0;
        width: 740px;
        height: auto;
        background-color: #fff;
    }

    .c-slider-facilities.u-ver-right .l-description {
        margin-left: auto;
    }

    .c-slider-facilities .l-description .l-inner .c-indent-block {
        padding-left: 40px;
        border-left-width: 5px;
    }

    .c-slider-facilities.u-ver-left .js-slider-facilities .flex-direction-nav a.flex-prev {
        left: auto !important;
        right: calc(70px + 64px + 10px) !important;
    }

    .c-slider-facilities.u-ver-left .js-slider-facilities .flex-direction-nav a.flex-next {
        left: auto !important;
        right: 70px !important;
    } */

    .c-slider-facilities .l-description .l-inner {
        padding: 2em 0;
    }

    .c-slider-facilities .l-description .l-inner .c-indent-block {
        padding-left: 40px;
        border-left-width: 5px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-slider-facilities .l-slider {
        border-radius: 10px;
    }

    .c-slider-facilities .l-description .l-inner {
        padding: 2em 0 0;
    }
}

/* OTHER CONTENTS (他のページでも共通) 
----------------------------------------------------- */
.c-sub-other-contents {
    background-color: var(--color-primary);
    color: #fff;
}

.c-sub-other-contents,
.c-sub-other-contents a {
    text-decoration: none;
    color: #fff;
}

.c-sub-other-contents a:hover {
    opacity: 1;
    color: var(--color-emerald);
}

.c-sub-other-contents .c-indent-block {
    border-color: rgba(255, 255, 255, 0.5);
    border-width: 1px;
}

.c-sub-other-contents-lineup .lineup {}

.c-sub-other-contents-lineup .lineup .l-inner {}

.c-sub-other-contents-lineup .lineup .l-inner .l-image {
    position: relative;
    z-index: 1;
}

.c-sub-other-contents-lineup .lineup .l-inner .l-title {
    position: relative;
    z-index: 2;
    margin: -2em 0 0;
}

.c-sub-other-contents-lineup .lineup .l-inner .l-title .l-english {
    display: block;
    font-family: "Brother-1816 Black", sans-serif;
    text-transform: uppercase;
    font-size: 4.8rem;
    margin: 0 0 0 -.35em;
}

.c-sub-other-contents-lineup .lineup .l-inner .l-title .l-japanese {
    display: block;
    margin: .5em 0;
    font-size: 2em;
    font-weight: normal;
}

.c-sub-other-contents-lineup .lineup .l-inner .l-title .c-link-arrow {
    margin: 0;
    color: var(--color-emerald);
    font-family: "Brother-1816 Bold", sans-serif;
}

.c-sub-other-contents-lineup .lineup .l-inner .l-title .c-link-arrow::after {
    background-image: url(assets/images/icon-arrow-right-emerald.webp);
}

@media screen and (min-width: 800px) {
    .c-sub-other-contents-lineup .lineup {
        margin-bottom: 0;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-sub-other-contents-lineup.c-flex-row.u-responsive>.c-flex-child {
        margin-bottom: 6.25vw;
    }

    .c-sub-other-contents-lineup.c-flex-row.u-responsive>.c-flex-child:last-child {
        margin-bottom: 0;
    }

    .c-sub-other-contents-lineup .lineup .l-inner .l-title {
        margin: 1.5em 0 0;
    }

    .c-sub-other-contents-lineup .lineup .l-inner .l-title .l-english {
        font-size: 2.0rem;
        margin: 0;
    }

    .c-sub-other-contents-lineup .lineup .l-inner .l-title .l-japanese {
        font-size: 1.6rem;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - DATA

-----------------------------------------------------
*/
#main.u-page-data {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background-color: #fef6ee;
}

#main.u-page-data::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 600px;
    background-image: -moz-linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 100%);
    background-image: -webkit-linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 100%);
    background-image: -ms-linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 100%);
    pointer-events: none;
}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main.u-page-data::before {
        height: 70vh;
    }
}

/* = DATA - メインコンテンツ
----------------------------------------------------- */
.l-sub-data-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-data-main::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


/* = DATA - 各種データ内容 PT1（TOPページでも流用）
----------------------------------------------------- */
.l-sub-data-lineup {}

.l-sub-data-lineup .lineup {
    background-color: #fff;
    box-shadow: 10px 17.321px 20px 0px rgba(0, 0, 0, 0.05);
    border-radius: 10px;
    font-weight: bold;
    line-height: 1.5;
}

.l-sub-data-lineup .lineup .l-inner {
    padding: 1.5em 2.0em;
    padding-top: 100px;
}

.l-sub-data-lineup .lineup .l-inner .l-header {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: 1.5em 0 1.5em;
}

.l-sub-data-lineup .lineup .l-inner .l-header .l-title {
    text-align: center;
    color: var(--color-primary);
    line-height: 1.5;
}

.l-sub-data-lineup .lineup .l-inner .l-header .l-title .l-japanese {
    font-size: 3.2rem;
    font-weight: bold;
}

.l-sub-data-lineup .lineup .l-inner .l-header .l-sub {
    font-size: 1em;
    font-weight: normal;
}

.l-sub-data-lineup .lineup .l-inner .l-image {
    margin: 0 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.l-sub-data-lineup .lineup .l-inner .l-image.u-ver-vertival {
    flex-direction: column;
}

.l-sub-data-lineup .lineup .l-inner .l-number {
    margin: 0 0 30px;
    text-align: center;
    font-family: "Brother-1816 Black", 'Noto Sans JP', sans-serif;
    font-size: 1.7em;
    font-weight: bold;
}

.l-sub-data-lineup .lineup .l-inner .l-number.u-ver-with-description {
    margin-bottom: 10px;
}

.l-sub-data-lineup .lineup .l-inner .l-number .l-num,
.l-sub-data-lineup .lineup .l-inner .l-number .l-decimal,
.l-sub-data-lineup .lineup .l-inner .l-number .l-unit {
    display: inline-block;
    vertical-align: middle;
    line-height: 1.25;
}

.l-sub-data-lineup .lineup .l-inner .l-number .l-num {
    font-size: 11.0rem;
    letter-spacing: -0.025em;
    line-height: .9;
}

.l-sub-data-lineup .lineup .l-inner .l-number .l-decimal {
    font-size: 6.4rem;
}

.l-sub-data-lineup .lineup .l-inner .l-number .l-unit {
    text-align: left;
}

.l-sub-data-lineup .lineup .l-inner .l-text {
    text-align: center;
    font-weight: bold;
}

.l-sub-data-lineup .lineup .l-inner .l-text p {
    line-height: 1.5;
}

@media screen and (min-width: 800px) {
    .l-sub-data-lineup {
        width: calc(100% + 3%);
    }

    .l-sub-data-lineup .lineup {
        margin: 0 3% 3% 0;
    }

    .l-sub-data-lineup .lineup.u-ver-small {
        width: calc(100% / 3 * 1 - 3%);
    }

    .l-sub-data-lineup .lineup.u-ver-medium {
        width: calc(100% / 5 * 2 - 3%);
    }

    .l-sub-data-lineup .lineup.u-ver-large {
        width: calc(100% / 5 * 3 - 3%);
    }

    .l-sub-data-lineup .lineup.u-ver-max {
        width: calc(100% / 5 * 4 - 3%);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup {
        margin-bottom: 6.25vw;
    }

    .l-sub-data-lineup .lineup .l-inner {
        padding: 6.25vw;
        padding-top: 6.25vw;
    }

    .l-sub-data-lineup .lineup .l-inner .l-header {
        position: static;
        margin: 0 0 1.5em;
    }

    .l-sub-data-lineup .lineup .l-inner .l-header .l-title .l-japanese {
        font-size: 2.4rem;
    }

    .l-sub-data-lineup .lineup .l-inner .l-number .l-num {
        font-size: 6.4rem;
    }

    .l-sub-data-lineup .lineup .l-inner .l-number .l-decimal {
        font-size: 3.2rem;
    }
}


/* 各種データ別の調整
----------------------------------------------------- */
/* 業歴 */
.l-sub-data-lineup .lineup.u-data-history {}

@media screen and (min-width: 800px) {
    .l-sub-data-lineup .lineup.u-data-history .l-image {
        margin-top: 2em;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 耐震基準 */
.l-sub-data-lineup .lineup.u-data-protect {}

/* グループ会社 */
.l-sub-data-lineup .lineup.u-data-group {
    background: #fff url(assets/images/sub-data-object-group.webp) no-repeat center bottom 40px;
    background-size: 150% auto;
    background-size: auto 140px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-group {
        padding-bottom: 24vw;
        background-size: 80% auto;
        background-size: auto 90px;

        /* padding-bottom: inherit;
        background: none;
        background-color: #fff; */
    }
}

/* 勤務地 */
.l-sub-data-lineup .lineup.u-data-area {
    position: relative;
}

@media screen and (min-width: 800px) {

    .l-sub-data-lineup .lineup.u-data-area .l-block,
    .l-sub-data-lineup .lineup.u-data-area .l-block * {
        text-align: left;
    }

    .l-sub-data-lineup .lineup.u-data-area .l-image {
        position: absolute;
        z-index: -1;
        bottom: 0;
        right: 0;
        margin: 2.0em;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 年間休日 */
.l-sub-data-lineup .lineup.u-data-holiday {}

/* 職場環境 */
.l-sub-data-lineup .lineup.u-data-young {}

/* 設計部員数 */
.l-sub-data-lineup .lineup.u-data-designer {}

@media screen and (min-width: 800px) {
    .l-sub-data-lineup .lineup.u-data-designer {
        padding: 30px 0;
        padding-right: 20%;
        background: #fff url(assets/images/sub-data-object-designer.webp) no-repeat right -50px bottom -60px;
        background-size: 320px auto;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-designer .l-image img {
        margin-top: 6.25vw;
        width: 60%;
    }
}

/* 1級建築士 */
.l-sub-data-lineup .lineup.u-data-architect {}

@media screen and (min-width: 800px) {
    .l-sub-data-lineup .lineup.u-data-architect {
        padding: 30px 0;
        padding-right: 10%;
        background: #fff url(assets/images/sub-data-object-architect.webp) no-repeat right 50px bottom -70px;
        background-size: 130px auto;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-architect .l-image img {
        margin-top: 6.25vw;
        width: 20%;
    }
}

/* 1級建築施工管理技士 */
.l-sub-data-lineup .lineup.u-data-architect2 {
    padding-top: 1em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 設計部男女比率 */
.l-sub-data-lineup .lineup.u-data-male_female {}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent {
    justify-content: flex-start;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-image {
    margin-right: 20px;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-block {}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-block .l-number {
    text-align: left;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-block .l-number .l-num {
    font-size: 8.0rem;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-number .l-category {
    display: inline-block;
    vertical-align: middle;
    margin-right: 0.5em;
    padding: 0.2em 0.75em;
    border-radius: 10px;
    background-color: #4ddde0;
    color: #fff;
    font-size: 2.4rem;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-number.u-ver-male .l-category {}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-number.u-ver-female .l-category {
    background-color: #a0dd88;
}

.l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-block .l-text {
    text-align: left;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-number .l-category {
        font-size: 1.4rem;
    }

    .l-sub-data-lineup .lineup.u-data-male_female .l-inner .l-parent .l-block .l-number .l-num {
        font-size: 3.2rem;
    }
}

/* 平均年齢 */
.l-sub-data-lineup .lineup.u-data-age {}

.l-sub-data-lineup .lineup.u-data-age .l-inner {
    padding-bottom: 0;
}

.l-sub-data-lineup .lineup.u-data-age .l-inner .l-image {
    height: 200px;
    margin: 0 auto;
    overflow: hidden;
    display: block;
    text-align: center;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 累計完工棟数 */
.l-sub-data-lineup .lineup.u-data-total {
    background: #fff url(assets/images/sub-data-object-total.webp) no-repeat left -10px bottom 0px;
    background-size: 110% auto;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-total {
        padding-bottom: 10vw;
    }
}

/* 設計施工率 */
.l-sub-data-lineup .lineup.u-data-engagement {}

.l-sub-data-lineup .lineup.u-data-engagement .l-inner {
    padding-bottom: 0;
}

.l-sub-data-lineup .lineup.u-data-engagement .l-inner .l-image {
    height: 170px;
    margin: 20px auto 0;
    overflow: hidden;
    display: block;
    text-align: center;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* TCG技術研究所 */
.l-sub-data-lineup .lineup.u-data-lab {}

@media screen and (min-width: 800px) {
    .l-sub-data-lineup .lineup.u-data-lab {
        padding-top: 1em;
    }

    .l-sub-data-lineup .lineup.u-data-lab .l-inner .l-parent {
        align-items: center;
    }

    .l-sub-data-lineup .lineup.u-data-lab .l-inner .l-parent .l-image {
        margin-top: -30px;
    }

    .l-sub-data-lineup .lineup.u-data-lab .l-inner .l-parent .l-block {
        margin-top: -60px;
    }

    .l-sub-data-lineup .lineup.u-data-lab .l-inner .l-parent .l-block .l-number .l-num {
        font-size: 8.0rem;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup .lineup.u-data-lab .l-inner .l-parent .l-image img {
        width: 50%;
    }
}


/* = DATA - 男性労働者の育児休業等及び女性の活躍に関する情報公表
----------------------------------------------------- */
.l-sub-data-sub {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-data-sub::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* = DATA - 各種データ内容 PT2（男性労働者の育児休業等及び女性の活躍に関する情報公表）
----------------------------------------------------- */
.l-sub-data-lineup.u-ver-minorchange {}

.l-sub-data-lineup.u-ver-minorchange .lineup {
    background-color: #e0efec;
    box-shadow: none;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner {
    padding: 1.5em 2.0em;
    padding-top: 1.5em;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-header {
    position: static;
    margin: 0 0 1.5em;
    background-color: var(--color-primary);
    border-radius: 10px;
    padding: 0.75em 1em;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-header .l-title {
    text-align: left;
    color: #fff;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-header .l-title .l-japanese {
    font-size: 2.4rem;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-header .l-sub {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number {
    text-align: left;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number.u-ver-with-description {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-num,
.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-decimal,
.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-unit {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-category {
    display: inline-block;
    vertical-align: middle;
    margin-right: 0.5em;
    width: 9em;
    font-size: .9em;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-num {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number.u-ver-medium .l-num {
    font-size: 1.4em;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-decimal {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-number .l-unit {}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-text {
    text-align: left;
}

.l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-text p {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-data-lineup.u-ver-minorchange .lineup .l-inner .l-header .l-title .l-japanese {
        font-size: 1.6rem;
    }
}

/* 各種データ別の調整 PT2（男性労働者の育児休業等及び女性の活躍に関する情報公表）
----------------------------------------------------- */

/* 男女の平均勤続年数の差異 */
.l-sub-data-lineup .lineup.u-data-balance-male_female {}

.l-sub-data-lineup .lineup.u-data-balance-male_female .l-inner .l-number .l-category {
    width: 3em;
}

@media screen and (min-width: 800px) {}



/*
-----------------------------------------------------

	=SUB PAGES - WORKSTYLE

-----------------------------------------------------
*/
#main.u-page-workstyle {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = WORKSTYLE - メインコンテンツ（ABOUTを流用）
----------------------------------------------------- */
#main.u-page-workstyle .l-sub-about-main {
    background: url(assets/images/object-loop-dots-sub-workstyle.webp) no-repeat right 70% top 40%;
    background-size: 600px auto;
}


@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    #main.u-page-workstyle .l-sub-about-main {
        background-size: 70vw auto;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - OCCUPATION [職種紹介]

-----------------------------------------------------
*/
#main.u-page-occupation {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = OCCUPATION - イントロ
----------------------------------------------------- */
.l-sub-occupation-intro {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {
    .l-sub-occupation-intro .c-image-content {
        align-items: flex-start;
    }

    .l-sub-occupation-intro .c-image-content>.c-image {
        width: calc(370px);
    }

    .l-sub-occupation-intro .c-image-content>.c-content {
        width: calc(100% - 370px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 動画コンテンツ */
.l-movie-area {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background: url(assets/images/sub-occupation-movie-bg.webp) no-repeat center;
    background-size: cover;
    color: #fff;
    text-align: center;
    border-radius: 20px;
}

.l-movie-area .l-inner {
    padding: 4em 2em;
}

.l-movie-area .l-inner .l-video {
    width: 844px;
    margin: 0 auto 2em;
}

.l-movie-area .l-inner .l-header {
    margin-bottom: 0.75em;
}

.l-movie-area .l-inner .l-header .l-title {
    font-weight: bold;
}

.l-movie-area .l-inner .l-header .l-title .l-sub {
    display: inline-block;
    margin: 0 0 0.25em;
    padding: 0.35em 1.0em;
    border-radius: 5px;
    border: solid 1px #fff;
    font-size: 2.4rem;
}

.l-movie-area .l-inner .l-header .l-title .l-japanese {
    display: block;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-movie-area .l-inner .l-video {
        width: 100%;
    }

    .l-movie-area .l-inner .l-header .l-title .l-sub {
        font-size: 1.4rem;
    }

    .l-movie-area .l-inner .l-text {
        text-align: left
    }
}


/* = OCCUPATION - 職種チャート図エリア
----------------------------------------------------- */
.l-sub-occupation-chart {
    position: relative;
    z-index: 2;
    overflow: hidden;
    background-color: var(--color-secondary);
}

.l-occupation-chart-wrap {}

.l-occupation-chart-wrap .l-block {}

.l-occupation-chart-wrap .l-block01 {}

.l-occupation-chart-wrap .l-block02 {}

.l-occupation-chart-wrap .l-block03 {}

@media screen and (min-width: 800px) {
    .l-occupation-chart-wrap {
        position: relative;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: stretch;
    }

    .l-occupation-chart-wrap .l-block {
        height: 1030px;
    }

    .l-occupation-chart-wrap .l-block01 {
        position: absolute;
        z-index: 1;
        top: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
        width: 300px;
    }

    .l-occupation-chart-wrap .l-block02,
    .l-occupation-chart-wrap .l-block03 {
        width: 420px;
    }

    .l-occupation-chart-wrap .l-block02 .l-block-balloon {
        height: 100%;
    }

    .l-occupation-chart-wrap .l-block03 .l-block-balloon {
        height: 400px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-occupation-chart .c-section {
        padding: 6.25vw 0;
    }
}

/* ブロック : フローチャート部分 */
.l-occupation-chart-wrap .l-block-chart {}

ul.l-chart-lineup {}

ul.l-chart-lineup li {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 160px;
    margin-bottom: 50px;
    background-color: var(--color-primary);
    color: #fff;
    font-size: 2.8rem;
    font-weight: bold;
}

ul.l-chart-lineup li:nth-child(1) {
    background-color: #5ea79e;
}

ul.l-chart-lineup li:nth-child(2) {
    background-color: #469a8f;
}

ul.l-chart-lineup li:nth-child(3) {
    background-color: #2f8d81;
}

ul.l-chart-lineup li:nth-child(4) {
    background-color: #007365;
}

ul.l-chart-lineup li:nth-child(5) {}

ul.l-chart-lineup li::after {
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: transparent;
    /* 下側に吹き出し*/
    top: 100%;
    left: 0%;
    border-top-color: var(--color-primary);
    margin-left: 0px;
    border-width: 150px;
    border-top-width: 30px;
}

ul.l-chart-lineup li:nth-child(1)::after {
    border-top-color: #5ea79e;
}

ul.l-chart-lineup li:nth-child(2)::after {
    border-top-color: #469a8f;
}

ul.l-chart-lineup li:nth-child(3)::after {
    border-top-color: #2f8d81;
}

ul.l-chart-lineup li:nth-child(4)::after {
    border-top-color: #007365;
}

ul.l-chart-lineup li:nth-child(5)::after {
    border-top-color: var(--color-primary);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.l-chart-lineup li {
        height: auto;
        padding: .75em 0 0;
        margin-bottom: 30px;
        font-size: 1.8rem;
    }

    ul.l-chart-lineup li::after {
        margin-left: auto;
        border-width: calc(50vw - 6.25vw);
        border-top-width: 25px;
    }
}

/* ブロック : 白背景（テキスト情報部分） */
.l-occupation-chart-wrap .l-block-balloon {
    margin-bottom: 20px;
    background-color: #fff;
}

.l-occupation-chart-wrap .l-block-balloon:last-child {
    margin-bottom: 0;
}

.l-occupation-chart-wrap .l-block-balloon .l-inner {
    padding: 1.5em;
}

.l-occupation-chart-wrap .l-block-balloon .l-inner .l-title {
    margin-bottom: 1.5em;
    padding-bottom: 1.0em;
    border-bottom: solid 2px var(--color-primary);
    font-size: 1.05em;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
}

.l-occupation-chart-wrap .l-block-balloon .l-inner .l-title em {
    font-style: normal;
    color: #38b495;
}

ul.l-list-popup {}

ul.l-list-popup.c-flex-row>li {
    margin-bottom: 0;
}

ul.l-list-popup li a {
    display: block;
    text-decoration: none;
    padding-left: calc(14px + 8px);
    background: url(assets/images/icon-information-sub-occupation.webp) no-repeat left center;
    background-size: 14px auto;
    font-size: 15px;
    font-weight: 500;
}

.l-occupation-chart-wrap .c-list-nav li {
    margin-bottom: 0;
}

.l-occupation-chart-wrap .c-list-nav .c-link-arrow {
    color: var(--color-primary);
    font-size: 1em;
}

.l-occupation-chart-wrap .c-list-nav .c-link-arrow::after {
    top: 0;
    width: 12px;
    height: 16px;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.l-list-popup.c-flex-row.u-responsive>.c-flex-child {
        margin-bottom: 0;
    }

    ul.l-list-popup li a {
        font-size: 1.3rem;
    }

    .l-occupation-chart-wrap .c-list-nav .c-link-arrow::after {
        top: 0;
        width: 6px;
        height: 8px;
    }
}


/*
-----------------------------------------------------

    =COMMON PARTS - MODAL
    （jquery.magnific-popup.min.js を使用したモーダルウィンドウのスタイル。）
    
    公式ドキュメント：
    https://dimsemenov.com/plugins/magnific-popup/documentation.html

----------------------------------------------------- 
*/

/* =jquery.magnific-popup.min.js　のスタイルをベースに、必要に応じてカスタマイズして使用。
-----------------------------------------------------  */

/* Add Animation Effect
----------------------------------------------------- */
.mfp-bg.mfp-ready {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.mfp-bg.mfp-removing {
    opacity: 0;
    -webkit-transform: translate3d(0, -0.5%, 0);
    -moz-transform: translate3d(0, -0.5%, 0);
    -ms-transform: translate3d(0, -0.5%, 0);
    transform: translate3d(0, -0.5%, 0);

}

.mfp-wrap .mfp-content {
    opacity: 0;

    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.mfp-wrap.mfp-ready .mfp-content {
    opacity: 1;
}

.mfp-wrap.mfp-removing .mfp-content {
    opacity: 0;
}

/* Layout - Background 
----------------------------------------------------- */
.mfp-bg {
    opacity: 0;
    background-color: rgba(0, 0, 0, 0.8) !important;

    -webkit-transform: translate3d(0, -0.5%, 0);
    -moz-transform: translate3d(0, -0.5%, 0);
    -ms-transform: translate3d(0, -0.5%, 0);
    transform: translate3d(0, -0.5%, 0);
    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.mfp-wrap {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100vh !important;
}

.mfp-wrap .mfp-container {
    padding-left: 0;
    padding-right: 0;
}

.mfp-wrap .mfp-content {
    vertical-align: top;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* Layout - Modal
----------------------------------------------------- */
.mfp-wrap .modal {
    position: relative;
    margin: 20vh auto;
    height: calc(100vh - 20vh*2);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    background-color: #fff;
}

.mfp-wrap .modal img {}

.mfp-wrap .modal a {
    text-decoration: none;
}

.mfp-wrap .modal .c-modal-inner {}

@media screen and (min-width: 800px) {
    .mfp-wrap .modal {
        width: 800px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .mfp-wrap .modal {
        margin: 16vh auto;
        width: 90vw;
        height: 68vh;
        padding: 0;
    }
}

/* Layout - Close
----------------------------------------------------- */
.mfp-wrap .modal .mfp-close {
    opacity: 1;
    font-size: 0;
    right: 0;
    top: 0;
    margin: 4vw;
    width: 40px;
    height: 40px;
    background: url(assets/images/icon-modal-close.webp) no-repeat center;
    background-size: 100% auto;
    -webkit-transition: all ease-out 0.25s;
    -moz-transition: all ease-out 0.25s;
    -ms-transition: all ease-out 0.25s;
    transition: all ease-out 0.25s;
}

.mfp-wrap .modal .mfp-close:hover {
    opacity: 0.5;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .mfp-wrap .modal .mfp-close {
        right: 0;
    }
}

/* Layout - Next & Previous
----------------------------------------------------- */
.mfp-arrow {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* 以下、モーダル内のCSS（クラス名など含め自由記述）
----------------------------------------------------- */
.c-popup-content {
    padding: 3em;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {

    .c-popup-content {
        padding: 6.25vw;
    }
}


/* = OCCUPATION - メインコンテンツ （FEATURE、TRAININGと同じレイアウト）
----------------------------------------------------- */
.l-sub-occupation-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* やりがいなど（アコーディオン） */
.l-sub-occupation-detail-lineup {}

.l-sub-occupation-detail-lineup .lineup,
.l-sub-occupation-detail-lineup .lineup .l-header,
.l-sub-occupation-detail-lineup .lineup .l-header::before,
.l-sub-occupation-detail-lineup .lineup .l-content {
    border-radius: 0;
}

.l-sub-occupation-detail-lineup>.lineup {}

.l-sub-occupation-detail-lineup>.lineup:not( :last-child) {
    margin: 0 0 2em;
}

.l-sub-occupation-detail-lineup .lineup .l-header {
    position: relative;
    display: flex;
    align-items: center;
    padding: 1.5em 0;
    border-bottom: solid 1px var(--color-primary);
    background: url(assets/images/icon-accordion-open.webp) no-repeat right center;
    background-size: 24px auto;
    background-color: #fff;
    margin: 0;
}

.l-sub-occupation-detail-lineup .lineup .l-header.js-acc-header-on {
    background-image: url(assets/images/icon-accordion-close.webp);
}

.l-sub-occupation-detail-lineup .lineup .l-header .l-title {
    position: relative;
    margin-bottom: 0;
    padding-left: 55px;
    background: url(assets/images/icon-information-sub-occupation.webp) no-repeat left center;
    background-size: 40px auto;
}

.l-sub-occupation-detail-lineup .lineup .l-content {
    padding: 3em 0 0;
}

.l-sub-occupation-detail-lineup .lineup .l-content .l-text {
    position: relative;
}

.l-sub-occupation-detail-lineup .lineup .l-content .l-text::before {}

@media screen and (min-width: 800px) {
    .l-sub-occupation-detail-lineup .lineup .l-header {}
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-occupation-detail-lineup .lineup {}

    .l-sub-occupation-detail-lineup .lineup .l-header {
        background-size: 16px auto;
    }

    .l-sub-occupation-detail-lineup .lineup .l-header .l-title {
        padding-left: 30px;
        background-size: 16px auto;
    }
}


/* = OCCUPATION - インタビュー記事リンク （外部メディアサイトと連携）
----------------------------------------------------- */
.l-sub-occupation-interview {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-occupation-interview::before {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background-color: #fef6ee;
}

@media screen and (min-width: 800px) {
    .l-sub-occupation-interview .c-section {
        padding-bottom: 2em;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-sub-occupation-interview .c-section {
        padding: 6.25vw 0 !important;
    }

    .l-sub-occupation-interview::before {
        height: 100%;
    }

    .l-sub-occupation-interview .c-title-categorized br {
        display: none;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - TRAINING [研修制度]

-----------------------------------------------------
*/
#main.u-page-training {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = TRAINING - メインコンテンツ (ほぼFEATUREと同じレイアウト)
----------------------------------------------------- */
.l-sub-training-intro {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* = TRAINING - メインコンテンツ (ほぼFEATUREと同じレイアウト)
----------------------------------------------------- */
.l-sub-training-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* 汎用項目ボックス（CULTUREページでも共通） */
.c-box-item-lineup .lineup {
    padding: 2.5em;
    border-radius: 15px;
    background-color: var(--color-secondary);
}

.c-box-item-lineup .lineup:last-child {}

.c-box-item-lineup .lineup .l-inner {
    position: relative;
}

.c-box-item-lineup .lineup .l-inner .l-image {
    margin: -15px;
    margin-bottom: 2em;
}

.c-box-item-lineup .lineup .l-inner .l-title {
    font-size: 2.1rem;
    font-weight: bold;
}

@media screen and (min-width: 800px) {
    .c-box-item-lineup.c-flex-row {}

    /* .c-box-item-lineup .lineup:last-child,
    .c-box-item-lineup .lineup:nth-last-child(2) {
        margin-bottom: 0;
    } */
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-box-item-lineup .lineup {
        padding: 6.25vw;
    }
    
    .c-box-item-lineup .lineup .l-inner {}

    .c-box-item-lineup .lineup .l-inner .l-title {
        font-size: 1.6rem;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - CULTURE [社風・文化を知る]

-----------------------------------------------------
*/
#main.u-page-culture {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

/* = CULTURE - イントロ
----------------------------------------------------- */
.l-sub-culture-intro {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {
    .l-sub-culture-intro .c-image-content {
        align-items: flex-start;
    }

    .l-sub-culture-intro .c-image-content>.c-image {
        width: calc(370px);
    }

    .l-sub-culture-intro .c-image-content>.c-content {
        width: calc(100% - 370px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}

.c-list-nav .c-list-green {
    margin-top: 2em;
}

.c-list-green {}

.c-list-green li {
    margin: 0 0 0px;
    color: var(--color-primary);
    font-size: 2.0rem;
    font-weight: 500;
    line-height: 1.25;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-list-green li {
        font-size: 1.2rem;
    }
}

/* = CULTURE - メインコンテンツ (ほぼFEATUREと同じレイアウト)
----------------------------------------------------- */
.l-sub-culture-main {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/* = CULTURE - コラム導線
----------------------------------------------------- */
.l-sub-culture-column {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-culture-column::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #f9f1ea url(assets/images/sub-culture-column-bg.webp) no-repeat right top;
    background-size: 100% auto;
}

@media screen and (min-width: 800px) {
    .l-sub-XXXXXX-main .c-image-content {
        align-items: flex-start;
    }

    .l-sub-XXXXXX-main .c-image-content>.c-image {
        width: calc(400px);
    }

    .l-sub-XXXXXX-main .c-image-content>.c-content {
        width: calc(100% - 400px - 60px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}













/*
----------------------------------------------------

	=SUB PAGES - JOBS - ARCHIVE

-----------------------------------------------------
*/

/* = JOBS - 一覧ページ
----------------------------------------------------- */
.l-sub-jobs-archive {
    position: relative;
    z-index: 2;
}

.l-jobs-lineup .lineup {
    display: block;
    text-decoration: none;
}

.l-jobs-lineup .lineup .l-image {
    overflow: hidden;
    position: relative;
    padding-bottom: 52.5%;
    padding-bottom: 66.66%;
    border-radius: 15px;
    background-color: #ccc;
}

.l-jobs-lineup .lineup .l-image img {
    position: absolute;
    z-index: 1;
    object-fit: cover;
    width: 100%;
    height: 100%;
    height: 100%;
    -webkit-transition: all cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -moz-transition: all cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    -ms-transition: all cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
    transition: all cubic-bezier(0.19, 1, 0.22, 1) 0.6s;
}

.l-jobs-lineup .lineup .l-image::before {}

.l-jobs-lineup .lineup .l-content {
    margin: 1em 0;
}

.l-jobs-lineup .lineup .l-content,
.l-jobs-lineup .lineup .l-content a {
    text-decoration: none;
}

.l-jobs-lineup .lineup .l-content .l-inner {
    padding: 30px;
}

.l-jobs-lineup .lineup .l-content .l-meta {
    margin: 0 0 1em;
    font-size: 1.4rem;
    font-weight: normal;
}

.l-jobs-lineup .lineup .l-content .l-meta>* {
    display: inline-block;
    vertical-align: middle;
    line-height: 1.25;
    margin: 0 0.75em 0 0;
    padding: 0 0.75em 0 0;
    border-right: 1px solid rgba(255, 255, 255, 0.5);
}

.l-jobs-lineup .lineup .l-content .l-meta>*:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}

.l-jobs-lineup .lineup .l-content .l-location {
    padding-left: 18px;
    background: url(assets/images/icon-marker.webp) no-repeat left center;
    background-size: 10px auto;
    color: var(--color-emerald);
    font-weight: bold;
}

.l-jobs-lineup .lineup .l-content .l-category {
    font-weight: bold;
    opacity: 0.6;
}

.l-jobs-lineup .lineup .l-content .l-title {
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 1.6;
}

.l-jobs-lineup .lineup:hover {
    opacity: 1;
}

.l-jobs-lineup .lineup:hover .l-image img {
    transform: scale(1.1);
    -webkit-transform: scale(1.1);
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .sub-recruit-other-jobs .c-section {}

    .l-jobs-lineup.u-responsive {}

    .l-jobs-lineup.u-responsive>.lineup {
        margin-bottom: 6.25vw;
    }

    /* .l-jobs-lineup .lineup .l-image {}

	.l-jobs-lineup .lineup .l-content {
        margin-top: 3.125vw;
    } */

    .l-jobs-lineup .lineup {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
    }

    .l-jobs-lineup .lineup .l-image {
        width: 35%;
        padding-bottom: calc(66.66% / 100 * 35);
    }

    .l-jobs-lineup .lineup .l-content {
        width: calc(100% - 35% - 3.125vw);
        margin-top: 0;
    }

    .l-jobs-lineup .lineup .l-content .l-meta {
        margin-bottom: 3.125vw;
        font-size: 1.2rem;
    }

    .l-jobs-lineup .lineup .l-content .l-location {}

    .l-jobs-lineup .lineup .l-content .l-title {
        font-size: 1.4rem;
    }

    .l-jobs-lineup .lineup .l-content .l-text {
        font-size: 1.2rem;
    }
}

/*
-----------------------------------------------------

	=SUBPAGES - JOBS - ARTICLE

-----------------------------------------------------
*/

/* JOBS - ARTICLE - ページ全体
----------------------------------------------------- */
.l-sub-jobs-article {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* JOBS - ARTICLE - 記事部分
----------------------------------------------------- */
.l-jobs-header {}

.l-jobs-header .c-image-content>.c-image {}

.l-jobs-header .c-image-content>.c-content {}

.l-jobs-header .l-thumbnail {
    position: relative;
    height: 0;
    padding-bottom: 66.66%;
    border-radius: 10px;
    overflow: hidden;
}

.l-jobs-header .l-thumbnail img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.l-jobs-header .l-meta {
    margin: 0 0 2em;
    font-size: 0.9em;
}

.l-jobs-header .l-meta>* {
    display: inline-block;
    vertical-align: middle;
}

.l-jobs-header .l-meta>*:not(:last-child) {
    margin: 0 20px 0 0;
}

.l-jobs-header .l-location {
    padding-left: 18px;
    background: url(assets/images/icon-marker.webp) no-repeat left center;
    background-size: 10px auto;
    color: var(--color-emerald);
    font-weight: bold;
}

.l-jobs-header .l-category li {
    display: inline-block;
    margin: 0 10px 0 0;
    padding: 0.25em 1em;
    border-radius: 4em;
    background-color: var(--color-emerald);
    color: #fff;
    font-size: .9em;
    font-weight: bold;
}

.l-jobs-header .l-title {
    margin-bottom: 1.25em;
}

.l-jobs-header ul.list-tag li {
    display: inline-block;
    vertical-align: top;
    margin: 0 10px 0 0;
    color: #aaa;
    font-size: 1.2rem;
    line-height: 1.5;
    font-weight: normal;
    text-decoration: none;
}

.l-jobs-header ul.list-tag li::before {
    content: "#";
}

.l-jobs-main {}

.c-frame-jobs {}

.c-frame-jobs:not(:last-child) {
    margin: 0 0 2em;
}

.c-title-jobs {
    margin: 0 0 0.75em;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.5;
}

.c-title-jobs span {
    display: inline-block;
}

.c-title-jobs.white span {
    border-color: #fff;
}

table.table-jobs {}

table.table-jobs tr {
    border-bottom: solid 1px rgba(0, 0, 0, 0.1);
}

table.table-jobs th,
table.table-jobs td {
    border: none;
    letter-spacing: 0;
    vertical-align: middle;
}

table.table-jobs th {}

@media screen and (min-width: 800px) {
    .l-jobs-header .c-image-content>.c-image {
        width: 640px;
        margin: -0 -0 0 0;
    }

    .l-jobs-header .c-image-content>.c-content {
        width: calc(100% - 640px - 60px);
    }

    /* .c-frame-jobs {
		align-items: flex-start;
	}

	.c-frame-jobs>.l-title {}

	.c-frame-jobs>.l-content {
		width: calc(100% - 400px - 40px);
	} */
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-frame-jobs {}

    .c-title-jobs {
        font-size: 1.8rem;
        text-align: center;
    }

    table.table-jobs,
    table.table-jobs tr,
    table.table-jobs th,
    table.table-jobs td {
        display: block;
        width: 100% !important;
        height: auto !important;
    }

    table.table-jobs tr {
        padding-bottom: 2em;
        margin-bottom: 2em;
    }

    table.table-jobs tr,
    table.table-jobs th,
    table.table-jobs td {
        display: block;
        width: 100% !important;
        height: auto !important;
    }

    table.table-jobs th,
    table.table-jobs td {
        padding: 0;
    }

    table.table-jobs th {
        padding-bottom: 10px;
    }
}

.single-jobs article p {
    margin-bottom: 0em;
}

/* JOBS - ARTICLE - 新着の募集要項
----------------------------------------------------- */
.l-sub-jobs-latest {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* SWIPER.JS
-------------------------------------------------- */
.l-jobs-latest-slider {
    position: relative;
}

.l-jobs-latest-slider .swiper-grandparent {
    position: relative;
}

.l-jobs-latest-slider .swiper-grandparent .swiper-parent {
    overflow: hidden;
    max-width: 100%;
}

.l-jobs-latest-slider .swiper-grandparent .swiper-parent .swiper-container {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}

/* SLIDE
-------------------------------------------------- */

@media screen and (min-width: 800px) {
    .l-jobs-latest-slider .swiper-grandparent .swiper-parent .swiper-container .swiper-wrapper {
        width: calc(100% + 4%);
        margin-right: -4%;
    }

    .l-jobs-latest-slider .swiper-grandparent .swiper-parent .swiper-container .swiper-wrapper .swiper-slide {
        width: calc(100% / 3 - 4%);
        margin-right: 4%;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-jobs-latest-slider .swiper-grandparent .swiper-parent .swiper-container .swiper-wrapper .swiper-slide {
        width: 100%;
        margin-right: 4%;
    }
}

/* PREV & NEXT
-------------------------------------------------- */
.l-jobs-latest-slider .swiper-button-prev,
.l-jobs-latest-slider .swiper-container-rtl .swiper-button-next,
.l-jobs-latest-slider .swiper-button-next,
.l-jobs-latest-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: 0 !important;
    bottom: 0 !important;
    margin: auto 0 !important;
    width: 15px !important;
    height: 100% !important;
}

.l-jobs-latest-slider .swiper-button-prev,
.l-jobs-latest-slider .swiper-container-rtl .swiper-button-next {
    left: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-left.webp) !important;
}

.l-jobs-latest-slider .swiper-button-next,
.l-jobs-latest-slider .swiper-container-rtl .swiper-button-prev {
    right: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-right.webp) !important;
}

@media screen and (min-width: 0px) and (max-width: 799px) {

    /* PREV & NEXT */
    .l-jobs-latest-slider .swiper-button-prev,
    .l-jobs-latest-slider .swiper-container-rtl .swiper-button-next,
    .l-jobs-latest-slider .swiper-button-next,
    .l-jobs-latest-slider .swiper-container-rtl .swiper-button-prev {
        width: 9px !important;
        height: 100% !important;
    }

    .l-jobs-latest-slider .swiper-button-prev,
    .l-jobs-latest-slider .swiper-container-rtl .swiper-button-next {
        left: 3.125vw !important;
    }

    .l-jobs-latest-slider .swiper-button-next,
    .l-jobs-latest-slider .swiper-container-rtl .swiper-button-prev {
        right: 3.125vw !important;
    }
}


/*
-----------------------------------------------------

	=SUB PAGES - ENTRY

-----------------------------------------------------
*/
#main.u-page-entry {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.l-sub-entry-main {}

@media screen and (min-width: 800px) {
    .l-sub-entry-main .c-section {
        padding-top: 2em;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {}


/*
-----------------------------------------------------

	=SUBPAGES - ENTRY - THAMKS

-----------------------------------------------------
*/
#main.u-page-thanks {
    position: relative;
    z-index: 2;
    overflow: hidden;
}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {}



/*
-----------------------------------------------------

	=SUBPAGES - FORM (PLUG-IN)

-----------------------------------------------------
*/
/* フォーム（WPプラグイン「Contact Form 7」を使用） */
/* フォーム本体 */
.form-main {
    padding-top: 0;
    width: 960px;
    max-width: 100%;
}

.form-main * {
    line-height: 1.8;
}

.form-main table.table-form {
    width: 100%;
    border-collapse: collapse;
    line-height: 1.75;
    text-align: left;
}

.form-main table.table-form tr,
.form-main table.table-form th,
.form-main table.table-form td {
    display: block;
    width: 100%;
    vertical-align: top;
    text-align: left;
    border: none;
}

.form-main table.table-form tr {
    margin: 0 0 2em;
}

.form-main table.table-form tr {}

.form-main table.table-form th,
.form-main table.table-form td {
    padding: 0.5em 0;
    font-weight: normal;
}

.form-main table.table-form th {
    font-size: 1.25em;
    font-weight: bold;
}

.form-main input[type="text"],
.form-main input[type="email"],
.form-main input[type="tel"],
.form-main select,
.form-main textarea {
    width: 100%;
    padding: 1.25em;
    border-radius: 10px;
    background-color: transparent;
    background-color: var(--color-secondary);
    border: solid 1px var(--color-secondary);
    font-family: inherit;
    font-size: 1.6rem;
    font-weight: bold;
}

.mwform-tel-field input[type="text"],
.mwform-zip-field input[type="text"] {
    display: inline-block;
    vertical-align: unset;
}

.form-main textarea {
    width: 100%;
}

.form-main select {
    appearance: none;
    -webkit-appearance: none;
    max-width: 100%;
    background: url(assets/images/icon-form-select.webp) no-repeat right 1em center;
    background-color: var(--color-secondary);
    background-size: 9px auto;
}

.form-main select option.placeholder {
    color: rgba(51, 51, 51, 0.5);
}

.form-main .vertical label {
    display: block;
}

.form-main ::placeholder {
    color: rgba(51, 51, 51, 0.5);
}

.form-main em {
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 0 1em;
    padding: 0.25em 1.0em;
    border-radius: 3px;
    background-color: var(--color-primary);
    color: #fff;
    font-size: 0.75em;
    font-weight: 600;
    line-height: 1.2;
}

.form-main .error {
    display: block;
    margin: .5em 0 0;
    padding: .5em 1em;
    border: solid 1px #F00;
    background-color: #fbf1f1;
    color: #f00;
    border-radius: 0;
}

.form-main a {}

@media screen and (min-width: 800px) {}

@media screen and (min-width: 0px) and (max-width: 799px) {

    .form-main table.table-form,
    .form-main table.table-form tr,
    .form-main table.table-form th,
    .form-main table.table-form td {
        display: block;
        width: 100%;
        background-color: transparent;
        border: none;
    }

    .form-main table.table-form {}

    .form-main table.table-form tr {}

    .form-main table.table-form th,
    .form-main table.table-form td {
        padding: 5px 0;
        font-size: 1em;
    }

    .form-main input,
    .form-main input[type="text"],
    .form-main input[type="tel"],
    .form-main input[type="email"],
    .form-main textarea,
    .form-main select,
    .form-main input[type*="submit"] {
        font-size: 14px;
    }

    .form-main input[type="text"],
    .form-main input[type="tel"],
    .form-main input[type="email"],
    .form-main textarea {
        width: 100%;
        padding: 0.75em;
    }

    .form-main select {
        padding: 0.5em;
        width: 100%;
    }

    .form-main input[type="radio"] {
        padding: 0;
        vertical-align: middle;
        position: relative;
        top: -1px;
    }

    .form-main input[type="checkbox"] {
        padding: 0;
        vertical-align: middle;
        position: relative;
        top: -1px;
    }

    .form-main input[type="file"] {
        width: 100%;
        padding: 0;
        font-size: 12px;
    }

    .form-main input[type*="submit"] {
        width: 100%;
    }
}

/* レイアウト調整 */
.form-main .horizontal>br {
    display: none;
}

.form-main .horizontal label {
    display: block;
    padding: 1.005em;
    line-height: 1;
    vertical-align: middle;
    width: 100%;
    max-width: 100%;
    border-radius: 10px;
    background-color: transparent;
    background-color: var(--color-secondary);
    border: solid 1px var(--color-secondary);
}

.form-main .horizontal label:hover {
    border-color: #f00;
}

@media screen and (min-width: 800px) {
    .form-main .horizontal {
        font-size: 0;
        letter-spacing: 0;
    }

    .form-main .horizontal .wpcf7-list-item {
        display: inline-block;
        vertical-align: text-top;
        font-size: 1.6rem;
        font-weight: bold;
    }

    .form-main .horizontal.u-col-3 .wpcf7-list-item {
        width: 32.33%;
        margin: 0 1% 1% 0;
    }

    .form-main .horizontal.u-col-2 .wpcf7-list-item {
        width: 49%;
        margin: 0 1% 1% 0;
    }

    .form-main .horizontal.u-col-1 .wpcf7-list-item {
        width: 100%;
        margin: 0 0% 1% 0;
    }

    .form-main .horizontal label {
        padding: 1.25em;
    }

    .form-main .horizontal-half {
        display: -webkit-flex;
        display: flex;
        -webkit-justify-content: space-between;
        justify-content: space-between;
        flex-shrink: 0;
        justify-items: center;
        align-items: center;
        align-items: flex-start;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .form-main .horizontal-half .half-item {
        margin-bottom: 0;
        width: 50%;
    }

    .form-main .horizontal-half .half-item:nth-child(odd) {
        padding-right: 10px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {

    .form-main .horizontal .wpcf7-list-item,
    .form-main .horizontal-half .half-item {
        display: inline-block;
        vertical-align: middle;
        width: 100%;
        margin: 0 0 1%;
    }

    .form-main .horizontal-half .half-item {
        margin-bottom: 10px;
    }
}

/* 送信ボタン - ボタンの全領域をクリック可能に変更 */
.form-main .submit-button {
    position: relative;
}

.form-main input[type*="submit"] {
    display: inline;
    font-size: inherit;
    font-weight: inherit;
    width: auto;
    text-align: inherit;
    margin: auto 0;
    padding: 0;
    background-color: transparent;
}

.form-main .submit-button input[type*="submit"] {
    display: block;
    position: absolute;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    padding: 1em 2em;
    cursor: pointer;
    opacity: 0;
}

/* 送信ボタン - ボタンのデザイン装飾 */
/* ベースCSS --> .c-button-readmore */
.form-main .c-button-readmore .l-english,
.form-main .c-button-readmore .l-japanese {
    line-height: 1.1;
}