@charset "UTF-8";
/*
Theme Name:  タカラボベース
Template: twentynineteen
Author:  タカラボベース
Author URI:
Description:
Version: 1.0.0
Updated: 2025-06-03
*/

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

	=THEME COLOR = #002d78

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

@import url(reset.css);
@import url(wordpress.css);

/* CSS Variable
----------------------------------------------------- */
:root {
    --color-black: #000000;
    --color-white: #ffffff;
    --color-text-basic: #000000;
    --color-primary: #002d78;
    --color-secondary: #eef0f4;

}

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

	=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: normal;
    line-height: 2.0;
    word-wrap: break-word;
    letter-spacing: 0.0em;
}

body {
    font-size: 1.6rem;
    background-color: #fff;
}

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.2;
}

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 {
    font-weight: bold;
    text-align: justify;
}

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-primary);
    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 {
    opacity: 0.5;
}



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

	=GLOBAL STYLE

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

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

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

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

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

.u-wrapper-134494c {
    width: 134494cpx;
}

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

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

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

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

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

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

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

    .c-wrapper {
        width: auto;
        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%;
    }

    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;
    transition: all 0.5s ease 0s;
    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.8;
}

@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-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);
}


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

	=CORPORATE SITE

    PRELOADER
    HEADER
    NAVIGATION
    FOOTER
    COMMON PARTS
    TOP PAGE
    SUB PAGES

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

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

	=HEADER (CORPORATE SITE)

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

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

.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>.inner {
    padding: 30px;
    align-items: center;
    -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>.inner .header-left,
.header-global>.inner .header-right {
    display: flex;
    align-items: center;
}

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

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

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

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

.logo-corporatesite {
    width: calc(190px /1);
    width: calc(728px /2);
}

.header-global>.inner .header-left>.logo {
    position: relative;
    display: inline-block;
    vertical-align: top;
    max-width: 100%;
    margin: 0 0 0 15px;
}

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


.header-global>.inner .header-left>.logo img {}

.header-global>.inner .nav-pc ul.nav-main li a {}

.header-global>.inner .nav-pc ul.nav-main li a:hover {}



/* 全ページ共通 - 画面スクロール時 */
.scrolled .header-global {
    background-color: #fff;
    box-shadow: 15px 25.981px 30px 0px rgba(0, 0, 0, 0.05);
}

.scrolled .header-global .nav-pc ul.nav-main li ul {
    background-color: #fff;
}

@media screen and (min-width: 800px) {
    .header-global {
        height: 100px;
    }

    #main {
        padding-top: 100px;
    }

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

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

    .header-global>.inner .header-right>* {
        margin-left: 20px;
    }

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


    /* 背景透過ver. - ヘッダー初期位置 */

    /* 背景透過ver. - 画面スクロール時 */
}

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

    .header-global {
        height: 70px;
    }

    .header-global>.inner {
        padding: 0 3.125vw;
        padding: 0 6.25vw;
        height: 100%;
    }

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

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

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

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

    .logo-corporatesite {
        width: 240px;
    }

    /* 背景透過ver. - ヘッダー初期位置 */

    /* 背景透過ver. - 画面スクロール時 */

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

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

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

	=SEARCHFORM - PC & SP

-----------------------------------------------------
*/
.searchform {
    position: relative;
    width: 100%;
}

.searchform input {
    padding: 0.5em 1.75em;
    height: 40px;
}

.searchform .assistive-text {
    display: none;
}

.searchform .field {
    width: 100%;
    margin: 0;
    padding-left: 40px;
    font-size: 13px;
    border: solid 2px #dcdcdc;
    border-radius: 25px;
    background-color: transparent;
    box-shadow: none;
}

.searchform .submit {
    position: absolute;
    top: 0;
    left: 0;
    width: 50px;
    height: 40px;
    margin: 0;
    font-size: 0;
    background: url(assets/images/icon-search.webp) no-repeat center;
    background-size: 16px auto;
    border-radius: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.searchform .submit:hover {}

@media screen and (min-width: 800px) {
    .header-global .search {
        width: 220px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .searchform {
        width: 100%;
        max-width: 100%;
    }

    .searchform input {
        padding: 8px;
    }

    .searchform .field {
        font-size: 16px;
    }

    .searchform .submit {
        font-size: 0 !important;
        background-position: center;
    }

    ::placeholder {
        font-size: 13px;
    }

}


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

	=NAVIGATION - PC

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

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

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

    .nav-pc .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.4rem;
        font-weight: normal;
        line-height: 1.5;
        letter-spacing: 0.0em;
        text-transform: uppercase;
    }

    .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: 0.4;
    }

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

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

    .nav-pc ul.nav-main>li>a::before {
        display: none;

        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 0.0001%;
        height: 2px;
        background-color: var(--color-primary);
        -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 {}

    .nav-pc ul.nav-main li.has-child::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
        border-bottom: solid 1px #000;
        border-right: solid 1px #000;
        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: 12em;
        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 0;
        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 {}
}

/* =NAVIGATION - ACTION BUTTON
----------------------------------------------------- */
@media screen and (min-width: 800px) {
    .nav-action {
        margin: 0 0 0 25px;
    }

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

    .nav-action ul.nav-main li {
        font-size: 1.8rem;
        font-weight: bold;
        letter-spacing: 0.00em;
    }

    .nav-action ul.nav-main li:not(:last-child) {
        margin: 0 0 0 0;
        margin: 0 10px 0 0;
    }
}

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

	=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;
        left: 0;
        bottom: auto;
        width: 100vw;
        height: 100vh;
        padding: 0;
        border-radius: 0;
        background-color: rgba(255, 255, 255, 1);
        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 .inner {}

    .nav-sp .inner {
        padding: 16px 6.25vw;
        padding-bottom: 20vw;
    }

    .nav-sp .inner .logo {
        margin: 0 0 6.25vw;
    }

    .nav-sp ul.nav-main {
        margin: 0 0 2em 0;
        margin: 0;
    }

    .nav-sp ul.nav-main li {
        display: block;
        color: var(--color-text-basic);
        font-size: 1.4rem;
        font-weight: bold;
        letter-spacing: 0.00em;
    }

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

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

    .nav-sp .l-nav-footer {
        margin: 0 0 30px;
        padding: 0 0 30px;
        border-bottom: solid 1px rgba(0, 0, 0, 0.15);
    }

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

    /* .nav-sp ul.nav-main>li>a:not([class]) {
        position: relative;
        padding-left: 1em;
    }

    .nav-sp ul.nav-main>li>a:not([class])::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        border-top: solid 1px var(--color-white);
        border-right: solid 1px var(--color-white);
        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;
    } */

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

    .nav-sp ul.nav-main ul li {
        margin: 1.5em 0;
        position: relative;
        padding-left: 1em;
        font-size: 1.2rem;
        font-weight: normal;
    }

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

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

    /* =TOGGLER
	----------------------------------------------------- */
    ul.nav-icon {
        position: fixed;
        z-index: 9999;
        top: 0;
        right: 0;
        margin: 0;
        padding: 0;
        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: 90px;
        height: 70px;
        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: 27px 0;
        background-color: transparent;
    }

    .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;
}

.footer-global::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-secondary);
}

/* お問い合わせページのみ、飲み、フッターをカスタマイズ */
.footer-global.u-ver-contact {
    padding-top: 80px;
    background-color: #fff;
}

.footer-global.u-ver-contact::before {
    top: 80px;
    height: calc(100% - 80px);
}

.footer-global.u-ver-contact::after {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 80px;
    border-radius: 80px 80px 0 0;
    background-color: var(--color-primary);
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .footer-global.u-ver-contact {
        padding-top: 30px;
    }

    .footer-global.u-ver-contact::before {
        top: 30px;
        height: calc(100% - 30px);
    }

    .footer-global.u-ver-contact::after {
        top: 0;
        left: 0;
        height: 30px;
        border-radius: 30px 30px 0 0;
    }
}

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

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

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

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

.footer-global .c-section {
    padding: 60px 0;
}

@media screen and (min-width: 800px) {
    .footer-global .c-section {}
}

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


/* フッター - CTAエリア
----------------------------------------------------- */
.l-action-contact-wrapper {
    position: relative;
    z-index: 1;
}

.l-action-contact-wrapper::after {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background-color: var(--color-secondary);
}

/* アクション - お問い合わせ */
.l-action-contact {
    position: relative;
    width: calc(100% - 60px * 2);
    margin: 0 auto;
    border-radius: 5px;
    overflow: hidden;
}

.l-action-contact .l-button-area {}

.l-action-contact .l-button-area>.l-button {
    width: 50%;
    background-color: #000;
    color: #fff;
    text-align: center;
}

.l-action-contact .l-button-area .l-button.u-ver-download {
    background-color: var(--color-primary);
}

.l-action-contact .l-button-area .l-button .inner {
    padding: 100px 50px;
}

.l-action-contact .l-button-area .l-button .inner .c-title-section.u-vertical {
    padding: 0 0 30px;
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-action-contact {
        width: calc(100% - 6.25vw * 2);
        margin: 0 auto;
    }

    .l-action-contact .l-button-area>.l-button {
        width: 100%;
        margin: 0;
    }

    .l-action-contact .l-button-area .l-button .inner {
        padding: 12.5vw 6.25vw 6.25vw;
    }

    .l-action-contact .l-button-area .l-button .inner .c-title-section.u-vertical {
        margin: 0 0 15px;
        padding: 0 0 15px;
    }
}



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

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

.footer-global .navigation-area .logo {
    margin: 0 2em 2em 0;
}

@media screen and (min-width: 800px) {
    .footer-global .navigation-area {
        padding-bottom: 0;
    }

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

    .footer-global .navigation-area .footer-right {
        width: calc(100% - 450px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .footer-global .navigation-area {
        padding: 12.5vw 0 0;
    }

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

    .footer-global .navigation-area .footer-left {}

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

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

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

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

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

.l-nav-footer ul {}

.l-nav-footer ul li {
    letter-spacing: 0;
    font-size: 1.5rem;
    font-weight: 500;
}

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

.logo-link {
    display: block;
    margin: 0 0 5px;
}

.text-link {
    display: block;
    padding-left: 25px;
    background: url(assets/images/icon-external.webp) no-repeat left center;
    background-size: 16px auto;
    font-weight: bold;
}

.l-nav-footer ul ul {}

.l-nav-footer ul ul li {
    opacity: 0.6;
    font-weight: normal;
}

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

.l-nav-footer ul ul li a::before {
    display: none;
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto 0;
    width: 8px;
    height: 1px;
    background-color: #fff;
}

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

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

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

    .footer-global .l-nav-footer ul li {
        font-size: 1.1rem;
        font-weight: normal;
    }

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

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

    .footer-global .l-nav-footer ul li .text-link {
        font-weight: 600;
        padding-left: 20px;
        background-size: 12px auto;
    }

    .footer-global .l-nav-footer ul li .logo-link img {
        zoom: 0.6;
    }

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

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

.footer-global .copyright-area .inner {
    border-top: solid 1px rgba(0, 0, 0, 0.10);
    padding: 40px 0 0;
    align-items: center;
}

.footer-global .copyright-area .copyright {
    font-family: neue-haas-grotesk-display, sans-serif;
    color: #888888;
    letter-spacing: 0.05em;
    line-height: 1;
}

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

.footer-global .copyright-area a {
    opacity: 0.5;
}

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

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

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

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

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

    .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;
    }
}



.c-button-pagetop {
    position: fixed;
    z-index: 9999;
    right: 30px;
    bottom: 30px;
    height: 50px;
    width: 50px;
    background: #000;
    border: solid 0 #000;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.c-button-pagetop .l-arrow {
    height: 10px;
    width: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: translateY(20%) rotate(-45deg);
}

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

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



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

	=MAIN [メインカラム / サイドバー]

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

/* 採用コラム - メインコンテンツ */
.l-media-contents {
    position: relative;
    z-index: 2;
}

/* 2カラム - メインカラム・サイドバー */
#main-and-side {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

#main-and-side>#primary {
    width: 730px;
}

#main-and-side>#secondary {
    width: calc(100% - 730px - 60px);
    width: 320px;
}


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

    #main-and-side>#primary,
    #main-and-side>#secondary {
        width: 100%;
        padding-top: 0;
    }

    #primary {
        margin-bottom: 6.25vw;
    }

    #secondary {}
}

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

	=PRIMARY [メインカラム]

-----------------------------------------------------
*/
#primary {}

/* 記事一覧部分
----------------------------------------------------- */

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

	=SECONDARY [サイドバー]

-----------------------------------------------------
*/
#secondary {}

#secondary .l-sidebar {
    height: 100%;
}

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

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


/* サイドバー - 汎用レイアウト
----------------------------------------------------- */
.l-sidebar .c-block:not( :last-child) {
    margin: 0 0 40px;
}

.l-sidebar .c-frame-side {
    padding: 20px;
    background-color: var(--color-secondary);
}

.l-sidebar .c-frame-side,
.l-sidebar .c-frame-side * {}

@media screen and (min-width: 800px) {
    .l-sidebar .u-sticky {
        position: sticky;
        z-index: 99;
        top: 140px;
    }
}

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

/* サイドバー - 導線エリア
----------------------------------------------------- */
.l-action-sidebar {
    background-color: var(--color-primary);
    color: #fff;
    text-align: center;
}

.l-action-sidebar .inner {
    padding: 40px;
}

.l-action-sidebar .inner .l-heading {
    margin: 0 0 30px;
    font-size: 2.1rem;
    font-weight: bold;
    line-height: 1.5;
}

.l-action-sidebar .inner .l-button ul li:not( :last-child) {
    margin-bottom: 20px;
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .l-action-sidebar .inner {
        padding: 6.25vw;
    }

    .l-action-sidebar .inner .l-button ul li:not( :last-child) {
        margin-bottom: 10px;
    }
}




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

	=COMMON PARTS - SECTION

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

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

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

hr {
    clear: both;
    border: none;
    height: 60px;
}

hr.sep {
    background-color: rgba(255, 255, 255, 0.25);
    height: 1px;
}

hr.hr-border {
    margin: 2em auto;
    height: 1px;
    background-color: #dcdcdc;
}

.x2 {
    zoom: 0.5;
}

.c-section-header {
    text-align: center;
}

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

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

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

    hr {
        height: 6.25vw;
    }
}

/* フル幅のセクション設定 */
.c-flexible-container {
    border-radius: 40px;
    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;
    }
}

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

	=COMMON PARTS - DECORATION

-----------------------------------------------------
*/
.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;
    }
}

.u-fc-theme {
    color: var(--color-primary);
}

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

.c-frame {
    padding: 2.0em;
}

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

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

	=COMMON PARTS - HEADING

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

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

@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.1em;
    }
}


/* 見出し - セクション見出し英語 54pt
----------------------------------------------------- */
.c-title-section {
    margin: -30px 0 .6em;
    padding: 0 0 10px;
    border-bottom: solid 1px rgba(0, 0, 0, 0.15);
    font-size: 5.4rem;
    line-height: 1.5;
}

.c-title-section .english {
    display: inline-block;
    vertical-align: middle;
    font-family: futura-pt, sans-serif;
    font-weight: bold;
    line-height: 1.0;
}

.c-title-section .japanese {
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 0 1em;
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 1.5;
}

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

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

    .c-title-section .japanese {
        font-size: 1.3rem;
    }
}

/* Variations */
.c-title-section.u-vertical {}

.c-title-section.u-vertical .english,
.c-title-section.u-vertical .japanese {
    display: block;
}

.c-title-section.u-ver-white {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.25);
}

.c-title-section.js-acc-header {
    cursor: pointer;
    background: url(assets/images/icon-accordion-open.webp) no-repeat right top 45px;
    background-size: 18px auto;
}

.c-title-section.js-acc-header.js-acc-header-on {
    background-image: url(assets/images/icon-accordion-close.webp);
}

.c-title-section.u-ver-sidebar {
    margin: 0 0 25px;
    padding: 0;
    border-bottom: none;
    font-size: 3.2rem;
}

.c-title-section.u-ver-sidebar .english,
.c-title-section.u-ver-sidebar .japanese {
    display: block;
}

.c-title-section.u-ver-sidebar .japanese {
    margin: 0.5em 0 0;
    font-size: 1.4rem;
}


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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-section.js-acc-header {
        background-position: right center;
        background-size: 13px auto;
    }

    .c-title-section.u-responsive .english,
    .c-title-section.u-responsive .japanese {
        display: block;
        margin: 0;
    }

    .c-title-section.u-responsive .japanese {
        margin: 0.5em 0 0;
    }
}

































/* 見出し - 日本語 42pt
----------------------------------------------------- */
.c-title-42 {
    margin: 0 0 50px;
    font-size: 4.1rem;
    font-weight: bold;
    line-height: 1.6;
}

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

.c-title-42 .japanese {}

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

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



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

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

.c-title-36 .japanese {}

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

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



/* 見出し - ナンバリング（ハウス型）
----------------------------------------------------- */
.c-icon-numbering {
    position: relative;
    display: inline-block;
    margin: 0 0 1.5em;
    left: -10px;
}

.c-icon-numbering>* {
    display: block;
}

.c-icon-numbering .house img {
    width: 132px;
}

.c-icon-numbering .numbering {
    position: absolute;
    z-index: 1;
    top: auto;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
    height: 75%;
    text-align: center;
    color: #fff;
    font-family: "Boston Bold";
    font-size: 3.6rem;
    letter-spacing: 0.1em;
    display: flex;
    align-items: center;
    justify-content: center;
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-icon-numbering .house img {
        width: 80px;
    }

    .c-icon-numbering .numbering {
        font-size: 2.4rem;
    }
}


@media screen and (min-width: 800px) {
    .c-icon-numbering.u-large .house img {
        width: 170px;
    }

    .c-icon-numbering.u-large .numbering {
        font-size: 4.8rem;
    }
}

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


/* 見出し - 日本語 32pt
----------------------------------------------------- */
.c-title-32 {
    margin: 0 0 0.75em;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: -0.05em;
}

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

.c-title-32 .japanese {}

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

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

/* Variations */
.c-title-32.u-ver-leaf .japanese {
    display: inline-block;
    padding-left: 45px;
    background: url(assets/images/icon-leaf.webp) left 0 center no-repeat;
    background-size: 33px auto;
}

.c-title-32.u-white {
    color: #fff;
}

.c-title-32.u-ver-leaf.u-white .japanese {
    background-image: url(assets/images/icon-leaf-white.webp);
}

.c-title-32.u-ver-leaf.u-ver-homecare .japanese {
    background-image: url(assets/images/icon-leaf-homecare.webp);
}

.c-title-32.u-ver-leaf.u-ver-assistedliving .japanese {
    background-image: url(assets/images/icon-leaf-assistedliving.webp);
}


@media screen and (min-width: 800px) {
    .c-title-32.u-large {
        font-size: 4.8rem;
    }
}

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

    .c-title-32.u-ver-leaf .japanese {
        padding-left: 28px;
        background-size: 20px auto;
    }
}


/* 見出し - 日本語24pt （※下層ページのみ）
----------------------------------------------------- */
.c-title-24 {
    margin: 0em 0 .75em;
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1.5;
}

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

.c-title-24 .english {
    font-size: 1.2rem;
    color: var(--color-primary);
    font-family: neue-haas-grotesk-display, sans-serif;
}

.c-title-24 .japanese {}

@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-round {
    margin: 0 0 1.0em;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.5;
    padding: 0.5em 1em;
    border-radius: 30px;
    background-color: var(--color-primary);
    color: #fff;
}

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

.c-title-round.u-ver-homecare {
    background-color: var(--color-service-homecare);
}

.c-title-round.u-ver-assistedliving {
    background-color: var(--color-service-assistedliving);
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-title-round {
        border-radius: 0.5em;
        font-size: 1.7rem;
    }
}


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

	=COMMON PARTS - BUTTON

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


/* ボタン - アイコン付き（ #header 内で使用）
----------------------------------------------------- */
/* header内で使用されるボタン */
.c-button-icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: auto;
    min-width: 160px;
    max-width: 100%;
    height: 40px;
    line-height: 1.25;
    padding: 0em 1.5em;
    border-radius: 5px;
    background-color: #000;
    color: #fff;
    font-size: 1.3rem;
    font-weight: bold;
    text-decoration: none;
}

.c-button-icon,
.c-button-icon * {
    -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-icon>* {
    position: relative;
    z-index: 1;
}

.c-button-icon .icon {
    display: block;
    margin: 0 15px 0 0;
}

.c-button-icon:hover {
    opacity: 0.5;
}

.c-button-icon:hover>.icon {}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-button-icon {
        width: 100%;
        min-width: inherit;
        max-width: 100%;
        height: 44px;
        font-size: 1.3rem;
    }

    .c-button-icon .arrow::after {
        border-width: 2px;
        width: 7px;
        height: 7px;
    }
}

/* Alignment variations */
.u-ta-r .c-button-icon {
    margin-left: auto;
}

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

/* Color variations */
.c-button-icon.u-ver-navy {
    background-color: var(--color-primary);
}

/* Icon variations */
.c-button-icon.u-ver-contact {}

.c-button-icon.u-ver-contact:hover {}

.c-button-icon.u-ver-contact .icon {
    width: 19px;
    height: 17px;
    background: url(assets/images/icon-button-contact.webp) no-repeat center;
    background-size: 100% auto;
}

.c-button-icon.u-ver-download {}

.c-button-icon.u-ver-download:hover {}

.c-button-icon.u-ver-download .icon {
    width: 19px;
    height: 19px;
    background: url(assets/images/icon-button-download.webp) no-repeat center;
    background-size: contain;
}


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

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



/* ボタン - メイン（角丸＋矢印あり）
----------------------------------------------------- */
.c-button-main {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 240px;
    max-width: 100%;
    height: 60px;
    line-height: 1.25;
    padding: 0em 1.25em;
    padding-right: 48px;
    border-radius: 5px;
    background-color: var(--color-primary);
    color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 0;
    text-decoration: none;
}

.c-button-main,
.c-button-main * {
    -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-main>* {
    position: relative;
    z-index: 1;
}

.c-button-main .arrow {
    content: "";
    position: absolute;
    top: 3px;
    bottom: 0;
    left: auto;
    right: 30px;
    margin: auto 0;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    width: 9px;
    height: 9px;
    transform: rotate(45deg);
    -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-main .arrow::after {}

.c-button-main:hover {
    opacity: 0.8;
}

.c-button-main:hover>.arrow {
    right: calc(30px - 5px);
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-button-main {
        font-size: 1.4rem;
        width: 100%;
        height: 60px;
        max-width: 100%;
        padding: 0em 48px;
    }

    .c-button-main .arrow {}

    .c-button-main .arrow::after {}
}


/* Alignment variations */
.u-ta-r .c-button-main {
    margin-left: auto;
}

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


.c-button-main.u-ver-white {
    background-color: #fff;
    color: #000;
}

.c-button-main.u-ver-white .arrow {
    border-top-color: #000;
    border-right-color: #000;
}




























/* ボタン - 小さなテキストとアロー
----------------------------------------------------- */
.c-link-small {
    position: relative;
    display: inline-block;
    padding: 0 28px 0 0;
    color: var(--color-text-basic);
    font-size: 1em;
    font-weight: 500;
    text-decoration: none;
    line-height: .8;
}

.c-link-small::after {
    content: "";
    position: absolute;
    top: 1px;
    bottom: 0;
    right: 3px;
    margin: auto 0;
    width: 18px;
    height: 18px;
    background: url(assets/images/icon-arrow-link-small.webp) no-repeat center;
    background-size: contain;
    -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;
}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-link-small {
        font-size: 1.2rem;
    }

    .c-link-small::after {
        width: 15px;
        height: 15px;
    }
}

.c-link-small:hover {}

.c-link-small:hover::after {
    right: 0;
}

/* .c-link-small.u-white {
    color: #fff;
}

.c-link-small.u-white::after {
    border-top-color: var(--color-white);
    border-right-color: var(--color-white);
} */

.c-link-small.u-ver-homecare {
    color: var(--color-service-homecare);
}

.c-link-small.u-ver-homecare::after {
    border-top-color: var(--color-service-homecare);
    border-right-color: var(--color-service-homecare);
}

.c-link-small.u-ver-assistedliving {
    color: var(--color-service-assistedliving);
}

.c-link-small.u-ver-assistedliving::after {
    border-top-color: var(--color-service-assistedliving);
    border-right-color: var(--color-service-assistedliving);
}

.c-link-small.u-ver-recruit {
    color: var(--color-secondary);
}

.c-link-small.u-ver-recruit::after {
    border-top-color: var(--color-secondary);
    border-right-color: var(--color-secondary);
}


@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-linkedin {
    display: inline-block;
    background: url(assets/images/icon-sns-linkedin.webp) no-repeat center;
    background-size: 100% auto;
    width: 21px;
    height: 21px;
}

@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 -10px -10px 0;
    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-family: "neue-haas-grotesk-display", sans-serif;
    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 10px 10px;
    font-size: 1.6rem;
}

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

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

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-share li {
        margin: 0 3px 5px;
        width: 35px;
    }
}

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

ul.c-list-simple li {
    margin: 0 0 0.35em;
    position: relative;
    padding-left: 1.2em;
    line-height: 1.8;
}

ul.c-list-simple li::before {
    content: "・";
    position: absolute;
    left: 0;
    display: inline-block;
    vertical-align: middle;
    margin: 0 1.25em 0 0;
}

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

ul.c-list-circle li {
    margin: 0 0 0.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-primary);
    font-size: 1.0rem;
}

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

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

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

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.c-list-inline.u-responsive li {
        display: block;
        margin: 0 0 20px;
    }
}

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

	=COMMON PARTS - ARCHIVE LIST

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

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

/* アーカイブリスト - 全体 */
.c-news-archive-header {
    font-family: neue-haas-grotesk-display, sans-serif;
    font-weight: 500;
    text-transform: uppercase;
}

.c-news-archive-header .inner-block {
    position: relative;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.c-news-archive-header .inner-block::before {
    display: none;
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto 0;
    width: 1px;
    height: 70%;
    background-color: rgba(0, 0, 0, 0.25);
}

.c-news-archive-header .title {
    margin: 10px 0;
    font-family: "neue-haas-grotesk-display", sans-serif;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 0.05em;
}

@media screen and (min-width: 800px) {
    .c-news-archive-header .title {
        width: 200px;
    }

    .c-news-archive-header .title+* {
        width: calc(100% - 200px);
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .c-news-archive-header {
        display: block;
    }

    .c-news-archive-header .inner-block {
        display: block;
        margin: 0 0 1em;
    }

    .c-news-archive-header .inner-block:last-child {
        margin-bottom: 0;
    }

    .c-news-archive-header .title {
        margin: 0 0 0.5em;
        font-size: 1.3rem;
    }
}

/* アーカイブリスト - カテゴリー・年別絞り込みボタン部分 */
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.8rem;
    font-weight: bold;
    letter-spacing: 0.0em;
}

ul.c-list-news-archive li a {
    display: inline-block;
    color: var(--color-primary);
    text-decoration: none;
    margin: 0 10px;
    padding: 0.2em 1.5em;
    border: solid 1px var(--color-primary);
    border-radius: 3em;
}

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;
    color: #fff;
    background-color: var(--color-primary);
}

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.2rem;
    }

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

/* アーカイブリスト - タグ絞り込みボタン部分 */
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 [全てのループの基本スタイル]
----------------------------------------------------- */
.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;
}


@media screen and (min-width: 800px) {
    .loop.c-flex-row>.c-flex-child {
        margin-bottom: 50px;
    }
}

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

.loop .loop-image {
    position: relative;
    height: 0;
    padding-bottom: 66.66%;
    border-radius: 5px;
    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: 35px 0 0;
}

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

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

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

.loop .loop-title {
    font-size: 2.0rem;
    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;
}

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

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

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

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop .loop-meta {
        font-size: 1.1rem;
    }
}

.loop .loop-date {
    color: var(--color-text-basic);
    opacity: 0.5;
    font-family: neue-haas-grotesk-display, sans-serif;
    font-weight: 600;
    letter-spacing: 0.10em;
}

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

.loop .loop-category,
.loop .loop-category a {}

.loop .loop-category {
    display: inline-block;
    font-weight: 500;
}

.loop .loop-category a {
    display: block;
    color: var(--color-text-basic);
    text-decoration: none;
}

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

.loop .loop-image .loop-category {
    position: absolute;
    right: 0;
    bottom: 0;
}

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

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

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

ul.list-tag li {
    display: inline-block;
    margin: 0 10px 10px 0;
    font-size: 1.4rem;
    line-height: 1.5;
}

ul.list-tag li a {
    display: block;
    line-height: 1;
    font-weight: normal;
    text-decoration: none;
    background-color: #f1f1f1;
    padding: .85em 2.0em;
    color: var(--color-text-basic);
    font-weight: bold;
    border-radius: 5px;
}

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

ul.list-tag li a:hover {
    opacity: 1;
    background-color: var(--color-primary);
    background-color: #000;
    color: #fff;
}

@media screen and (min-width: 800px) {
    ul.list-tag {
        margin: 0 -5px -5px 0;
    }

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

    .loop .loop-meta ul.list-tag li {
        font-size: 1.1rem;
    }

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

    ul.list-tag.u-small li {
        font-size: 1.1rem;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    ul.list-tag li {
        font-size: .9rem;
    }

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

    ul.list-tag li a {}

}

.loop .loop-content {
    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;
}

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

}

.loop .loop-more {}



/* =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-date {}

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

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

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

    /* VERSION - 横並び */
    .loop.loop-type-main.u-sp-horizonral .loop-article {
        width: 100%;
        margin: 0 0 8vw;

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

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

    .loop.loop-type-main.u-sp-horizonral .loop-image {
        width: 33%;
        padding-bottom: calc(66.66% / 100 * 33);
    }

    .loop.loop-type-main.u-sp-horizonral .loop-header {
        width: calc(100% - 33% - 4vw);
    }

    .loop.loop-type-main.u-sp-horizonral .loop-header {
        padding: 0;
    }

    .loop.loop-type-main.u-sp-horizonral .loop-date {}

    .loop.loop-type-main.u-sp-horizonral .loop-category {}

    .loop.loop-type-main.u-sp-horizonral .loop-title {}

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



/* =LOOP TYPE - SLIDER [スライダー機能のループ（Swiper.jsを利用）]
----------------------------------------------------- */
.l-fv-slider {}

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

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

/* VERSION - HORIZONTAL（画像と文章横並び） */
.loop.loop-type-slider.u-horizontal {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-right: -3%;
}

.loop.loop-type-slider.u-horizontal .loop-article {
    position: relative;
    z-index: 2;
    background-color: #fff;
    box-shadow: 10px 17.321px 60px 0px rgba(32, 86, 85, 0.07);
    border-radius: 7px;
    padding: 30px;
}

.loop.loop-type-slider.u-horizontal .loop-article .loop-inner {}

.loop.loop-type-slider.u-horizontal,
.loop.loop-type-slider.u-horizontal a {}

.loop.loop-type-slider.u-horizontal .loop-image,
.loop.loop-type-slider.u-horizontal .loop-header {}

.loop.loop-type-slider.u-horizontal .loop-image {
    margin: 0;
    width: 420px;
    height: 0;
    padding-bottom: calc(66.66% / 900 * 420);
    border-radius: 7px;
    overflow: hidden;
}

.loop.loop-type-slider.u-horizontal .loop-image img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.loop.loop-type-slider.u-horizontal .loop-image img:hover {
    opacity: 1;
}

.loop.loop-type-slider.u-horizontal .loop-header {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
    margin: 0;
    height: 100%;
    width: calc(900px - 420px - 60px - 30px);
    padding: 0 30px;
    display: flex;
    justify-items: center;
    align-items: center;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta:not( :last-child) {
    margin-bottom: 20px;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta>span {
    display: inline-block;
    vertical-align: middle;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta>span:not( :last-child) {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-date {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-category {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-category a {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-category a:hover {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-tag {
    display: block;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-tag ul.list-tag {
    margin-bottom: 0;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-tag ul.list-tag li a {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-tag ul.list-tag li a:hover {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-title {
    margin-bottom: 20px;
    font-size: 2.4rem;
    line-height: 1.5;
    font-weight: bold;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-title a {
    text-decoration: none;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-title a:hover {
    opacity: 0.8;
}

.loop.loop-type-slider.u-horizontal .loop-header .loop-content {}

.loop.loop-type-slider.u-horizontal .loop-header .loop-content p {}

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

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

    .loop.loop-type-slider.u-horizontal .loop-article {
        padding: 6.25vw;
        padding: 20px;
        flex-direction: column;
        margin-bottom: 0;
    }

    .loop.loop-type-slider.u-horizontal .loop-image {
        width: 100%;
        height: 0;
        padding-bottom: 66.66%;
    }

    .loop.loop-type-slider.u-horizontal .loop-header {
        position: static;
        width: 100%;
        padding: 6.25vw 3.125vw;
    }

    .loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-category a {}

    .loop.loop-type-slider.u-horizontal .loop-header .loop-meta .loop-date {}

    .loop.loop-type-slider.u-horizontal .loop-header .loop-title {
        margin-bottom: 10px;
        min-height: 3em;
        font-size: 1.5em;
    }
}

/* VERSION - VERTICAL （画像と文章縦並び） */
.loop.loop-type-slider.u-vertical {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-right: -3%;
}

.loop.loop-type-slider.u-vertical .loop-article {
    position: relative;
    z-index: 2;
    -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;

    overflow: hidden;
    border-radius: 25px;
}

.loop.loop-type-slider.u-vertical .loop-article:hover {
    z-index: 3;
    background-color: #fff;
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.15);
}

.loop.loop-type-slider.u-vertical .image {
    position: relative;
    height: 300px;
}

.loop.loop-type-slider.u-vertical .image img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.loop.loop-type-slider.u-vertical .header {
    position: relative;
    padding: 20px;
    background-color: rgba(255, 255, 255, 1);
}

.loop.loop-type-slider.u-vertical .header,
.loop.loop-type-slider.u-vertical .header a {
    text-decoration: none;
}

.loop.loop-type-slider.u-vertical .header>* {
    margin: 0 0 1.5rem;
}

.loop.loop-type-slider.u-vertical .header>*:last-child {
    margin: 0;
}

.loop.loop-type-slider.u-vertical .title {
    font-size: 1.7rem;
    font-weight: normal;
    line-height: 1.75;
}

.loop.loop-type-slider.u-vertical .title a {
    color: inherit;
}

.loop.loop-type-slider.u-vertical .meta {
    font-size: 1.2rem;
}

.loop.loop-type-slider.u-vertical .category {
    position: absolute;
    z-index: 2;
    display: block;
    bottom: 0;
    left: 0;
}

.loop.loop-type-slider.u-vertical .category a:hover {
    opacity: 1;
}

.loop.loop-type-slider.u-vertical .loop-date {
    color: #aaa;

}

.loop.loop-type-slider.u-vertical .content {
    display: none;
}

/* VERSION - FULL （フルスクリーン） */
.loop.loop-type-slider-full {}

.loop.loop-type-slider-full .loop-article {
    position: relative;
    z-index: 2;
    width: 100%;
}

.loop.loop-type-slider-full,
.loop.loop-type-slider-full *,
.loop.loop-type-slider-full a {}

.loop.loop-type-slider-full .loop-image,
.loop.loop-type-slider-full .loop-header {}

.loop.loop-type-slider-full .loop-image {
    position: relative;
    z-index: 1;
    overflow: hidden;
    width: 100%;
    height: 100%;
    background-color: #000;
    border-radius: 0;
}

.loop.loop-type-slider-full .loop-image img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    opacity: 0.75;
}

.loop.loop-type-slider-full .loop-image img:hover {}

.loop.loop-type-slider-full .loop-header {
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    margin: 60px;
    width: 100%;
    max-width: 800px;
    height: auto;
}

.loop.loop-type-slider-full .loop-header,
.loop.loop-type-slider-full .loop-header *,
.loop.loop-type-slider-full .loop-header a {
    color: #fff;
}

.loop.loop-type-slider-full .loop-header .loop-inner {}

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

.loop.loop-type-slider-full .loop-header .loop-meta {}

.loop.loop-type-slider-full .loop-header .loop-meta>span {
    display: inline-block;
    vertical-align: middle;
}

.loop.loop-type-slider-full .loop-header .loop-meta>span:not( :last-child) {}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-tag {}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-tag ul.list-tag {
    margin-bottom: 0;
}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-tag ul.list-tag li a {}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-tag ul.list-tag li a:hover {
    color: #fff;
}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-date {}

.loop.loop-type-slider-full .loop-header .loop-meta .loop-category,
.loop.loop-type-slider-full .loop-header .loop-meta .loop-category a {
    border-color: #fff;
}

.loop.loop-type-slider-full .loop-header .loop-title {
    font-size: 3.6rem;
    line-height: 1.6;
    font-weight: bold;
}

.loop.loop-type-slider-full .loop-header .loop-title a {
    text-decoration: none;
}

.loop.loop-type-slider-full .loop-header .loop-title a:hover {
    opacity: 1;
}

.loop.loop-type-slider-full .loop-header .loop-text {}

.loop.loop-type-slider-full .loop-header .loop-text p {}

@media screen and (min-width: 800px) {
    .loop.loop-type-slider-full {
        height: 80vh;
        min-height: 720px;
    }
}

@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop.loop-type-slider-full {
        height: 400px;
        min-height: 400px;
    }

    .loop.loop-type-slider-full .loop-article {
        padding: 0;
    }

    .loop.loop-type-slider-full .loop-image,
    .loop.loop-type-slider-full .loop-header {}

    .loop.loop-type-slider-full .loop-image {
        width: 100%;
        height: 100%;
    }

    .loop.loop-type-slider-full .loop-header {
        margin: 0;
        padding: 3.125vw 6.25vw;
        width: 100%;
    }

    .loop.loop-type-slider-full .loop-header .loop-meta {}

    .loop.loop-type-slider-full .loop-header .loop-meta .loop-category a {
        font-size: 1.4rem;
    }

    .loop.loop-type-slider-full .loop-header .loop-meta .loop-date {}

    .loop.loop-type-slider-full .loop-header .loop-title {
        margin-bottom: 10px;
        min-height: 3em;
        font-size: 1.5em;
    }
}


/* スライダー部分のカスタマイズ (Swiper.js)
    ----------------------------------------------------- */
.l-fv-slider .swiper-grandparent {
    position: relative !important;
    overflow: hidden;
    width: 100%;
}

/* 
	--------------------------------------------------
	一枚フルサイズver. （swiper.min.css を上書き ）
	--------------------------------------------------
	*/
.swiper-parent {}

.swiper-grandparent .swiper-parent .swiper-container {}


/* 
	--------------------------------------------------
	左右のスライドを見せるver. （swiper.min.css を上書き ）
	--------------------------------------------------
	*/
.l-fv-slider .swiper-grandparent {
    /* For shadow */
    padding-top: 120px !important;
    margin-top: -120px !important;
}

.l-fv-slider .swiper-grandparent .swiper-parent {}

.l-fv-slider .swiper-grandparent .swiper-parent .swiper-container {
    overflow: visible !important;
}

.l-fv-slider .swiper-wrapper {
    flex-wrap: inherit !important;
    margin-bottom: 0px !important;
    padding-bottom: 90px !important;
}

.l-fv-slider .swiper-container {
    /* Prev & Next をフル画面にしたいとき
		position: static !important; */
}

.l-fv-slider .swiper-slide {
    width: auto;
    margin: auto;
    padding: 0;
}

.l-fv-slider .swiper-slide>* {
    width: 900px;
    max-width: 100%;
}

.l-fv-slider .swiper-slide-active {
    opacity: 1;
}

/* PREV & NEXT */
.l-fv-slider .swiper-button-prev,
.l-fv-slider .swiper-container-rtl .swiper-button-next,
.l-fv-slider .swiper-button-next,
.l-fv-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: 0 !important;
    bottom: 0 !important;
    bottom: 120px !important;
    margin: auto !important;
    width: 30px !important;
    height: 100% !important;
}

.l-fv-slider .swiper-button-prev,
.l-fv-slider .swiper-container-rtl .swiper-button-next {
    left: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-left.webp) !important;
}

.l-fv-slider .swiper-button-next,
.l-fv-slider .swiper-container-rtl .swiper-button-prev {
    right: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-right.webp) !important;
}

/* PAGINATION */
.l-fv-slider .swiper-container .swiper-pagination {
    left: 0;
    right: 0;
    bottom: calc(60px - 3px);
    width: auto;
    text-align: center;
    margin: 0px;
}

.l-fv-slider .swiper-container .swiper-pagination-bullet {
    background-color: #000;
    width: 50px;
    height: 3px;
    opacity: 0.25;
    margin: 0 5px;
    border-radius: 0;
    -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-fv-slider .swiper-container .swiper-pagination-bullet-active {
    width: 100px;
    opacity: 1;
}

/* PCで画面サイズ＜スライド幅以下になった場合の対処
	@media screen and (min-width: 0px) and (max-width: 999px) {
        .l-fv-slider .swiper-slide>* {
            width: 100%;
        }
    } */

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

    .l-fv-slider .swiper-container {}

    .l-fv-slider .swiper-slide {}

    .l-fv-slider .swiper-slide>* {
        width: 100%;
    }

    .l-fv-slider .swiper-slide-active {}

    /* センタリング ver. */
    .l-fv-slider .swiper-grandparent {}

    .l-fv-slider .swiper-grandparent .swiper-parent .swiper-container {
        overflow: hidden !important;
    }

    .l-fv-slider .swiper-button-next,
    .l-fv-slider .swiper-button-prev {}

    /* PREV & NEXT */
    .l-fv-slider .swiper-button-prev,
    .l-fv-slider .swiper-container-rtl .swiper-button-next,
    .l-fv-slider .swiper-button-next,
    .l-fv-slider .swiper-container-rtl .swiper-button-prev {
        top: auto !important;
        bottom: calc(60px - 15px) !important;
        right: auto !important;
        width: 30px !important;
        height: 30px !important;
    }

    .l-fv-slider .swiper-button-prev,
    .l-fv-slider .swiper-container-rtl .swiper-button-next {
        left: 6.25vw !important;
    }

    .l-fv-slider .swiper-button-next,
    .l-fv-slider .swiper-container-rtl .swiper-button-prev {
        left: calc(6.25vw + 40px) !important;
    }

    .l-fv-slider .swiper-container .swiper-pagination {
        left: calc(6.25vw + 80px) !important;
        right: auto !important;
        bottom: calc(60px - 3px) !important;
        width: auto;
        text-align: left;
    }

    .l-fv-slider .swiper-container .swiper-pagination-bullet {
        width: 30px;
        height: 3px;
        margin: 0 5px;
    }

    .l-fv-slider .swiper-container .swiper-pagination-bullet-active {
        width: calc(30px *2);
    }
}



/* =LOOP TYPE : SIDE  [サイドバーで表示するループ]
----------------------------------------------------- */
.loop.loop-type-side {}

.loop.loop-type-side .loop-article {
    margin-bottom: 30px;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.loop.loop-type-side .loop-article:last-child {
    margin-bottom: 0;
}

.loop.loop-type-side .loop-header {
    width: calc(100% - 90px - 1em);
    padding: 0;
}

.loop.loop-type-side .loop-image {
    position: relative;
    width: 90px;
    height: calc(90px * 0.6666);
    padding-bottom: 0;
    border-radius: 0;
}

.loop.loop-type-side .loop-image img {
    position: relative;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.loop.loop-type-side .loop-image img:hover {
    opacity: 0.7;
}

.ranking .loop.loop-type-side .loop-article:nth-child(1) .loop-image:before,
.ranking .loop.loop-type-side .loop-article:nth-child(2) .loop-image:before,
.ranking .loop.loop-type-side .loop-article:nth-child(3) .loop-image:before,
.ranking .loop.loop-type-side .loop-article:nth-child(4) .loop-image:before,
.ranking .loop.loop-type-side .loop-article:nth-child(5) .loop-image:before {
    content: "1";
    position: absolute;
    z-index: 1;
    top: -0;
    left: -0;
    width: 25px;
    height: 25px;
    line-height: 25px;
    border-radius: 0;
    background-color: #000;
    color: #fff;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
}

.ranking .loop.loop-type-side .loop-article:nth-child(1) .loop-image:before {
    content: "1";
    background-color: #dcb43b;
}

.ranking .loop.loop-type-side .loop-article:nth-child(2) .loop-image:before {
    content: "2";
    background-color: #b5b5b5;
}

.ranking .loop.loop-type-side .loop-article:nth-child(3) .loop-image:before {
    content: "3";
    background-color: #c8a96d;
}

.ranking .loop.loop-type-side .loop-article:nth-child(4) .loop-image:before {
    content: "4";
}

.ranking .loop.loop-type-side .loop-article:nth-child(5) .loop-image:before {
    content: "5";
}

.loop.loop-type-side .loop-header {
    padding: 0;
}

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

.loop.loop-type-side .loop-meta {
    margin-bottom: 5px;
    font-size: 1.0rem;
    line-height: 1.5;
}

.loop.loop-type-side .loop-meta>* {
    display: inline-block;
    vertical-align: middle;
    border: none;
}

.loop.loop-type-side .loop-meta>*:not( :first-child) {
    margin: 0 2em 0 0;
}

.loop.loop-type-side .loop-meta .date {
    display: none;
}

.loop.loop-type-side .loop-category,
.loop.loop-type-side .loop-category a {
    color: var(--color-text-basic);
    opacity: 0.5;
}

.loop.loop-type-side .loop-title {
    font-size: 1.3rem;
    font-weight: bold;
    line-height: 1.5;
}

.loop.loop-type-side .loop-title a {
    color: #333;
    text-decoration: none;
}

.loop.loop-type-side .loop-title a:hover {
    text-decoration: underline;
}

.loop.loop-type-side .loop-content {
    display: none;
}


@media screen and (min-width: 0px) and (max-width: 799px) {
    .loop.loop-type-side .loop-title {
        font-size: 1.2rem;
    }
}


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

	=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: 2em;
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1.5;
}

.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-category {
    display: inline-block;
}

.article .article-category a {
    display: block;
    color: var(--color-text-basic);
    text-decoration: none;
}

.article .article-category a:hover {
    opacity: .5;
    border-color: transparent;
}

.article .article-date {
    color: var(--color-text-basic);
    opacity: 0.5;
    font-family: neue-haas-grotesk-display, sans-serif;
    font-weight: 600;
    letter-spacing: 0.10em;
}

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

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

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

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

.article .article-header ul.c-list-share {}

.article .article-summary {
    font-size: 80%;
}

.article .article-summary p {
    font-size: 1.5rem;
    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-modified_date {
        float: right;
    }
    
    .article .article-meta.c-flex-parent .article-tag {
        width: calc(100% - 130px - 20px);
    }
    .article .article-meta.c-flex-parent .article-sns {
        /* float: right; */
        width: 130px;
    }
}

@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: 9.375vw;
    }

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

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

    .article .article-title {
        margin-bottom: 6.25vw;
        font-size: 1.8rem;
    }

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

    .article .article-modified_date {
        float: right;
        font-size: inherit;
    }

    /* .article .article-sns {
        float: right;
    } */

    .article .article-meta.c-flex-parent .article-tag {
        width: calc(100% - 130px - 20px);
        margin: 0 0 3.125vw;
    }
    .article .article-meta.c-flex-parent .article-sns {
        width: 130px;
    }
}


/* ARTICLE - CONTENT
----------------------------------------------------- */
.article .article-content {
    font-size: 1em;
    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: 500;
    line-height: 1.6;
}

.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: 1.5em;
    padding: 0.75em 1.5em;
    background-color: #f6f6f6;
}

.article .article-content h3 {
    position: relative;
    padding-bottom: 0.5em;
    border-bottom: solid 2px rgba(0, 0, 0, 0.15);
    font-size: 1.4em;
}

.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: 1.2em;
}

.article .article-content h5 {
    font-size: 1.1em;
}

.article .article-content h6 {
    font-size: 1em;
}

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

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

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

.article .article-content caption {
    font-size: 0.9em;
    color: #666;
    margin: 0.5em 0 1.5em;
}

@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: 2em;
}

.article .article-content blockquote {
    position: relative;
    padding: 5em 5em;
    background-color: #f6f6f6;
    border: solid 0 #ececec;
    font-size: 0.9em;
}

.article .article-content blockquote::before,
.article .article-content blockquote::after {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    width: calc(50px /2);
    height: calc(43px /2);
    margin: 2em;
    background: url(assets/images/icon-quote-before.webp) no-repeat left 0 top;
    background-size: 25px auto;
}

.article .article-content blockquote::before {
    top: 0;
    left: 0;
}

.article .article-content blockquote::after {
    right: 0;
    bottom: 0;
    background-image: url(assets/images/icon-quote-after.webp);
}

.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) {
    .article .article-content blockquote {
        padding: 5em 2em;
    }

    .article .article-content blockquote::before,
    .article .article-content blockquote::after {
        background-size: 18px auto;
    }
}

/* 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) {}

/* =Embed, Inline Frame */
.article .article-content iframe {
    width: 100%;
}

.article .article-content .wp-block-embed iframe {
    width: 100%;
}

@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: var(--color-secondary);
    padding: 3.0em;
}

.article-author .article-author-header {
    margin: 0 0 1em;
    align-items: center;
}

.article-author .article-author-header .avatar-area {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
}

.article-author .article-author-header .name-area {
    width: calc(100% - 80px - 1em);
}

.article-author .article-author-header .name-area .name .name-main {
    display: block;
    font-size: 1.5em;
    font-weight: 500;
}

.article-author .article-author-header .name-area .name .name-sub {
    display: block;
    font-size: .9em;
    opacity: 0.5;
}

.article-author .article-author-text {
    font-size: .8em;
}

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

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

    .article-author .article-author-header .avatar-area {
        width: 50px;
        height: 50px;
    }

    .article-author .article-author-header .name-area {
        width: calc(100% - 50px - 1em);
    }
}



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

	=TOP PAGE

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

/* TOPページのメインコンテンツ背景 */
/* .top#container {}

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

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

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

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

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

	=TOP PAGE - COLUMN

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

.l-top-column {
    position: relative;
    z-index: 1;
}

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

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

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

	=TOP PAGE - CASE

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

.l-top-case {
    position: relative;
    z-index: 1;
    overflow: hidden;
    background-color: #f2f2f2;
}

.l-description:not(:last-child) {
    margin-bottom: 2em;
}

.c-text-small {
    font-size: 1.3rem;
}

.l-top-case ul.list-tag li a {
    background-color: #fff;
}

.l-top-case ul.list-tag li a:hover {
    background-color: #000;
}

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

    .l-top-case .c-image-content>.c-image {
        position: relative;
        z-index: 1;
        width: 1120px;
        margin-right: calc(-290px + -60px);
    }

    .l-top-case .c-image-content>.c-content {
        position: relative;
        z-index: 2;
        width: 290px;
    }
}

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

/* スライダー部分のカスタマイズ
    ----------------------------------------------------- */
.l-case-slider .swiper-grandparent {
    position: relative !important;
    overflow: hidden;
    width: 100%;
}

/* 
	--------------------------------------------------
	左右のスライドを見せるver. （swiper.min.css を上書き ）
	--------------------------------------------------
	*/
.l-case-slider .swiper-grandparent {}

.l-case-slider .swiper-grandparent .swiper-parent {}

.l-case-slider .swiper-grandparent .swiper-parent .swiper-container {
    overflow: hidden !important;
}

.l-case-slider .swiper-wrapper {
    flex-wrap: inherit !important;
    margin-bottom: 0px !important;
    padding-bottom: 60px !important;
}

.l-case-slider .swiper-container {
    /* Prev & Next をフル画面にしたいとき
		position: static !important; */
}

.l-case-slider .swiper-slide {
    width: auto;
    margin: 0 auto;
    padding: 0;
}

.l-case-slider .swiper-slide>* {
    width: 340px;
    margin-right: 40px;
}

.l-case-slider .swiper-slide-active {
    opacity: 1;
}

/* PREV & NEXT */
.l-case-slider .swiper-button-prev,
.l-case-slider .swiper-container-rtl .swiper-button-next,
.l-case-slider .swiper-button-next,
.l-case-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: auto !important;
    left: 0 !important;
    right: auto !important;
    bottom: 0 !important;
    margin: 0 !important;
    width: 30px !important;
    height: 30px !important;
}

.l-case-slider .swiper-button-prev,
.l-case-slider .swiper-container-rtl .swiper-button-next {
    left: 0 !important;
    background-image: url(assets/images/icon-arrow-slider-left-white.webp) !important;
}

.l-case-slider .swiper-button-next,
.l-case-slider .swiper-container-rtl .swiper-button-prev {
    left: 40px !important;
    background-image: url(assets/images/icon-arrow-slider-right-white.webp) !important;
}

/* PAGINATION */
.l-case-slider .swiper-container .swiper-pagination {
    left: 90px;
    right: 0;
    bottom: calc(15px - 3px);
    width: auto;
    text-align: left;
    margin: 0;
}

.l-case-slider .swiper-container .swiper-pagination-bullet {
    background-color: #000;
    width: 50px;
    height: 3px;
    opacity: 0.25;
    margin: 0 5px;
    border-radius: 0;
    -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-case-slider .swiper-container .swiper-pagination-bullet-active {
    width: 100px;
    opacity: 1;
}


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

    .l-case-slider .swiper-container {}

    .l-case-slider .swiper-slide {}

    .l-case-slider .swiper-slide>* {
        width: 100%;
        /* slidesPerView: 'auto' の場合は、SP時のスライドの幅をCSSで指定 */
        width: calc(100vw - 6.25vw * 2.1);
        margin-right: 6.25vw;
    }

    .l-case-slider .swiper-slide-active {
        opacity: 1;
    }

    /* センタリング ver. */
    .l-case-slider .swiper-grandparent {}

    .l-case-slider .swiper-grandparent .wrapper {
        padding: 0 !important;
    }

    .l-case-slider .swiper-grandparent .swiper-parent .swiper-container {
        overflow: hidden !important;
    }

    .l-case-slider .swiper-button-next,
    .l-case-slider .swiper-button-prev {
        /*display: none !important;*/
    }

    /* PREV & NEXT */
    .l-case-slider .swiper-button-prev,
    .l-case-slider .swiper-container-rtl .swiper-button-next,
    .l-case-slider .swiper-button-next,
    .l-case-slider .swiper-container-rtl .swiper-button-prev {
        top: auto !important;
        bottom: calc(15px - 15px) !important;
        right: auto !important;
        width: 30px !important;
        height: 30px !important;
    }

    .l-case-slider .swiper-button-prev,
    .l-case-slider .swiper-container-rtl .swiper-button-next {
        left: 0 !important;
    }

    .l-case-slider .swiper-button-next,
    .l-case-slider .swiper-container-rtl .swiper-button-prev {
        left: calc(0 + 40px) !important;
    }

    .l-case-slider .swiper-container .swiper-pagination {
        left: calc(0 + 80px) !important;
        right: auto !important;
        bottom: calc(15px - 3px) !important;
        width: auto;
        text-align: left;
    }

    .l-case-slider .swiper-container .swiper-pagination-bullet {
        width: 30px;
        height: 3px;
        margin: 0 5px;
    }

    .l-case-slider .swiper-container .swiper-pagination-bullet-active {
        width: calc(30px *2);
    }
}

/* スライダーの中身＝ループ部分のカスタマイズ
----------------------------------------------------- */
.l-case-slider .loop .loop-article {}

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

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


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

	=TOP PAGE - DOWNLOAD

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

.l-top-download {
    position: relative;
    z-index: 1;
    overflow: hidden;
    background: url(assets/images/top-download-bg.webp) no-repeat center;
    background-size: cover;
}

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

    .l-top-download .c-image-content>.c-image {
        position: relative;
        z-index: 1;
        width: 1120px;
        margin-right: calc(-290px + -60px);
    }

    .l-top-download .c-image-content>.c-content {
        position: relative;
        z-index: 2;
        width: 290px;
    }
}

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

/* スライダー部分のカスタマイズ
    ----------------------------------------------------- */
.l-download-slider .swiper-grandparent {
    position: relative !important;
    overflow: hidden;
    width: 100%;
}

/* 
	--------------------------------------------------
	左右のスライドを見せるver. （swiper.min.css を上書き ）
	--------------------------------------------------
	*/
.l-download-slider .swiper-grandparent {}

.l-download-slider .swiper-grandparent .swiper-parent {}

.l-download-slider .swiper-grandparent .swiper-parent .swiper-container {
    overflow: visible !important;
}

.l-download-slider .swiper-wrapper {
    flex-wrap: inherit !important;
    margin-bottom: 0px !important;
    padding-bottom: 60px !important;
}

.l-download-slider .swiper-container {
    /* Prev & Next をフル画面にしたいとき
		position: static !important; */
}

.l-download-slider .swiper-slide {
    width: auto;
    margin: 0 auto;
    padding: 0;
}

.l-download-slider .swiper-slide>* {
    width: 340px;
    margin-right: 40px;
}

.l-download-slider .swiper-slide-active {
    opacity: 1;
}

/* PREV & NEXT */
.l-download-slider .swiper-button-prev,
.l-download-slider .swiper-container-rtl .swiper-button-next,
.l-download-slider .swiper-button-next,
.l-download-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: 0 !important;
    bottom: 0 !important;
    bottom: 120px !important;
    margin: auto !important;
    width: 30px !important;
    height: 100% !important;
}

.l-download-slider .swiper-button-prev,
.l-download-slider .swiper-container-rtl .swiper-button-next {
    left: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-left-white.webp) !important;
}

.l-download-slider .swiper-button-next,
.l-download-slider .swiper-container-rtl .swiper-button-prev {
    right: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-right-white.webp) !important;
}

/* PAGINATION */
.l-download-slider .swiper-container .swiper-pagination {
    left: 0;
    right: 0;
    bottom: calc(0 - 3px);
    width: auto;
    text-align: center;
    margin: 0;
}

.l-download-slider .swiper-container .swiper-pagination-bullet {
    background-color: #000;
    width: 50px;
    height: 3px;
    opacity: 0.25;
    margin: 0 5px;
    border-radius: 0;
    -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-download-slider .swiper-container .swiper-pagination-bullet-active {
    width: 100px;
    opacity: 1;
}

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

    /* 左右のスライドを隠す - 透過処理 */
    .l-download-slider .swiper-slide {
        -webkit-transition: none;
        -moz-transition: none;
        -ms-transition: none;
        transition: none;
        opacity: 0;
    }

    .l-download-slider .swiper-slide-active,
    .l-download-slider .swiper-slide-active+*,
    .l-download-slider .swiper-slide-active+*+* {
        opacity: 1;
    }
}

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

    .l-download-slider .swiper-container {}

    .l-download-slider .swiper-slide {}

    .l-download-slider .swiper-slide-active {}

    .l-download-slider .swiper-slide>* {
        width: 100%;
        /* slidesPerView: 'auto' の場合は、SP時のスライドの幅をCSSで指定 */
        width: 80vw;
        margin-right: 6.25vw;
    }

    /* センタリング ver. */
    .l-download-slider .swiper-grandparent {}

    .l-download-slider .swiper-grandparent .swiper-parent .swiper-container {
        overflow: hidden !important;
    }

    .l-download-slider .swiper-button-next,
    .l-download-slider .swiper-button-prev {
        /*display: none !important;*/
    }

    /* PREV & NEXT */
    .l-download-slider .swiper-button-prev,
    .l-download-slider .swiper-container-rtl .swiper-button-next,
    .l-download-slider .swiper-button-next,
    .l-download-slider .swiper-container-rtl .swiper-button-prev {
        top: auto !important;
        bottom: calc(15px - 15px) !important;
        right: auto !important;
        width: 30px !important;
        height: 30px !important;
    }

    .l-download-slider .swiper-button-prev,
    .l-download-slider .swiper-container-rtl .swiper-button-next {
        left: 6.25vw !important;
    }

    .l-download-slider .swiper-button-next,
    .l-download-slider .swiper-container-rtl .swiper-button-prev {
        left: calc(6.25vw + 40px) !important;
    }

    .l-download-slider .swiper-container .swiper-pagination {
        left: calc(6.25vw + 80px) !important;
        right: auto !important;
        bottom: calc(15px - 3px) !important;
        width: auto;
        text-align: left;
    }

    .l-download-slider .swiper-container .swiper-pagination-bullet {
        width: 30px;
        height: 3px;
        margin: 0 5px;
    }

    .l-download-slider .swiper-container .swiper-pagination-bullet-active {
        width: calc(30px *2);
    }
}

/* スライダーの中身＝ループ部分のカスタマイズ
----------------------------------------------------- */
.l-download-slider .loop .loop-article {}

.loop.loop-type-download .loop-article {
    height: 100%;
    background-color: #fff;
    border-radius: 5px;
    overflow: hidden;
}

.loop.loop-type-download .loop-image {
    border-radius: 0;
}

.loop.loop-type-download .loop-header {
    padding: 35px;
}

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

.loop.loop-type-download .loop-header ul.list-tag {}

.loop.loop-type-download .loop-header .loop-title {
    margin-bottom: 3em;
}

.loop.loop-type-download .loop-header .loop-more {
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 35px;
}


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

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


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

	=TOP PAGE - WEBINAR

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

.l-top-webinar {
    position: relative;
    z-index: 1;
    overflow: hidden;
    background-color: #fff;
}

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

    .l-top-webinar .c-image-content>.c-image {
        position: relative;
        z-index: 1;
        width: 1120px;
        margin-right: calc(-290px + -60px);
    }

    .l-top-webinar .c-image-content>.c-content {
        position: relative;
        z-index: 2;
        width: 290px;
    }
}

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

/* スライダー部分のカスタマイズ
    ----------------------------------------------------- */
.l-webinar-slider .swiper-grandparent {
    position: relative !important;
    overflow: hidden;
    width: 100%;
}

/* 
	--------------------------------------------------
	左右のスライドを見せるver. （swiper.min.css を上書き ）
	--------------------------------------------------
	*/
.l-webinar-slider .swiper-grandparent {}

.l-webinar-slider .swiper-grandparent .swiper-parent {}

.l-webinar-slider .swiper-grandparent .swiper-parent .swiper-container {
    overflow: visible !important;
}

.l-webinar-slider .swiper-wrapper {
    flex-wrap: inherit !important;
    margin-bottom: 0px !important;
    padding-bottom: 60px !important;
}

.l-webinar-slider .swiper-container {
    /* Prev & Next をフル画面にしたいとき
		position: static !important; */
}

.l-webinar-slider .swiper-slide {
    width: auto;
    margin: 0 auto;
    padding: 0;
}

.l-webinar-slider .swiper-slide>* {
    width: 340px;
    margin-right: 50px;
}

.l-webinar-slider .swiper-slide-active {
    opacity: 1;
}

/* PREV & NEXT */
.l-webinar-slider .swiper-button-prev,
.l-webinar-slider .swiper-container-rtl .swiper-button-next,
.l-webinar-slider .swiper-button-next,
.l-webinar-slider .swiper-container-rtl .swiper-button-prev {
    background-size: 100% auto !important;
    top: 0 !important;
    bottom: 0 !important;
    bottom: 120px !important;
    margin: auto !important;
    width: 30px !important;
    height: 100% !important;
}

.l-webinar-slider .swiper-button-prev,
.l-webinar-slider .swiper-container-rtl .swiper-button-next {
    left: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-left.webp) !important;
}

.l-webinar-slider .swiper-button-next,
.l-webinar-slider .swiper-container-rtl .swiper-button-prev {
    right: -50px !important;
    background-image: url(assets/images/icon-arrow-slider-right.webp) !important;
}

/* PAGINATION */
.l-webinar-slider .swiper-container .swiper-pagination {
    left: 0;
    right: 0;
    bottom: calc(0 - 3px);
    width: auto;
    text-align: center;
    margin: 0;
}

.l-webinar-slider .swiper-container .swiper-pagination-bullet {
    background-color: #000;
    width: 50px;
    height: 3px;
    opacity: 0.25;
    margin: 0 5px;
    border-radius: 0;
    -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-webinar-slider .swiper-container .swiper-pagination-bullet-active {
    width: 100px;
    opacity: 1;
}

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

    /* 左右のスライドを隠す - 透過処理 */
    .l-webinar-slider .swiper-slide {
        -webkit-transition: none;
        -moz-transition: none;
        -ms-transition: none;
        transition: none;
        opacity: 0;
    }

    .l-webinar-slider .swiper-slide-active,
    .l-webinar-slider .swiper-slide-active+*,
    .l-webinar-slider .swiper-slide-active+*+* {
        opacity: 1;
    }

    /* .l-webinar-slider .swiper-container::before,
        .l-webinar-slider .swiper-container::after {
            content: "";
            position: absolute;
            top: 0;
            bottom: 0;
            width: 100vw;
            background-color: #fff;
        } */
}

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

    .l-webinar-slider .swiper-container {}

    .l-webinar-slider .swiper-slide {}

    .l-webinar-slider .swiper-slide-active {}

    .l-webinar-slider .swiper-slide>* {
        width: 100%;
        /* slidesPerView: 'auto' の場合は、SP時のスライドの幅をCSSで指定 */
        width: 80vw;
        margin-right: 6.25vw;
    }

    /* センタリング ver. */
    .l-webinar-slider .swiper-grandparent {}

    .l-webinar-slider .swiper-grandparent .swiper-parent .swiper-container {
        overflow: hidden !important;
    }

    .l-webinar-slider .swiper-button-next,
    .l-webinar-slider .swiper-button-prev {
        /*display: none !important;*/
    }

    /* PREV & NEXT */
    .l-webinar-slider .swiper-button-prev,
    .l-webinar-slider .swiper-container-rtl .swiper-button-next,
    .l-webinar-slider .swiper-button-next,
    .l-webinar-slider .swiper-container-rtl .swiper-button-prev {
        top: auto !important;
        bottom: 0 !important;
        right: auto !important;
        width: 30px !important;
        height: 30px !important;
    }

    .l-webinar-slider .swiper-button-prev,
    .l-webinar-slider .swiper-container-rtl .swiper-button-next {
        left: 6.25vw !important;
    }

    .l-webinar-slider .swiper-button-next,
    .l-webinar-slider .swiper-container-rtl .swiper-button-prev {
        left: calc(6.25vw + 40px) !important;
    }

    .l-webinar-slider .swiper-container .swiper-pagination {
        left: calc(6.25vw + 80px) !important;
        right: auto !important;
        bottom: calc(15px - 3px) !important;
        width: auto;
        text-align: left;
    }

    .l-webinar-slider .swiper-container .swiper-pagination-bullet {
        width: 30px;
        height: 3px;
        margin: 0 5px;
    }

    .l-webinar-slider .swiper-container .swiper-pagination-bullet-active {
        width: calc(30px *2);
    }
}

/* スライダーの中身＝ループ部分のカスタマイズ
----------------------------------------------------- */
.l-webinar-slider .loop .loop-article {}

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

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




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

	=SUB PAGES
        COMMON PARTS
            BREADCRUMBS
		ARTICLE
        ARCHIVE
            CATEGORY, TAG, SEARCH

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

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

    =SUB PAGES - COMMON PARTS

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

/* =COMMON PARTS - BREADCRUMBS
----------------------------------------------------- */
/* パンくずリスト */
#breadcrumbs {
    position: relative;
    z-index: 2;
    line-height: 40px;
    font-size: 1.4rem;
    font-weight: normal;
    background-color: var(--color-secondary);
}

#breadcrumbs,
#breadcrumbs a {
    color: inherit;
}

#breadcrumbs a {
    display: inline-block;
    text-decoration: none;
    opacity: 0.5;
}

#breadcrumbs a:hover {
    text-decoration: underline;
}

#breadcrumbs .inner {
    padding: 15px 45px;
}

#breadcrumbs p {}

#breadcrumbs p>span>span:first-child {
    display: inline-block;
    padding-left: 24px;
    background: url(assets/images/icon-breadcrumbs-home.webp) no-repeat left center;
    background-size: 15px auto;
}

#breadcrumbs p>span {
    font-family: serif;
}

#breadcrumbs p>span>span {}

#breadcrumbs p>span a,
#breadcrumbs p>span span.breadcrumb_last {
    font-family: neue-haas-grotesk-display, 'Noto Sans JP', "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Meiryo", "メイリオ", sans-serif, serif;
    display: inline-block;
}

#breadcrumbs p>span a::before {}

#breadcrumbs p>span span.breadcrumb_last {}

#breadcrumbs p>span a:first-child {}

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

@media screen and (min-width: 0px) and (max-width: 799px) {
    #breadcrumbs {
        line-height: 30px;
        font-size: .9rem;
    }

    #breadcrumbs .inner {
        padding: 10px 6.25vw;
    }

    #breadcrumbs p>span>span:first-child {
        padding-left: 14px;
        background-size: 10px auto;
    }
}



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

	=ARCHIVE

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

.l-archive-main {}

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

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


/* =ARCHIVE - SEARCH [よく検索されているタグ]
----------------------------------------------------- */
/* アコーディオンで開閉 [script.js] */
.l-archive-tags {}


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

	=ARCHIVE - CATEGORY

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

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

	=ARCHIVE - TAG

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

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

	=ARCHIVE - SEARCH

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


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

	=ARTICLE

-----------------------------------------------------
*/
.l-article-main {}

/* ※記事本文のスタイルは、前述 .article にて定義済み */

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

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