@charset "UTF-8";
@import url("/home/artcampus/assets/css/ress.css");
@import url("/home/artcampus/assets/css/fonts.css");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined");
@import url('https://fonts.googleapis.com/css2family=Noto+Sans+JP:wght@400;600&family=Noto+Sans:wght@400;600;&display=swap');
/*
font-family: "Noto Sans JP", sans-serif; font-weight: 400;
font-family: "Noto Sans JP", sans-serif; font-weight: 600;
font-family: "Noto Sans", sans-serif; font-weight: 400;
font-family: "Noto Sans", sans-serif; font-weight: 600;
*/

/*-----------------------------------------------------------------
リセット
----------------------------------------------------------------- */
*,
*:before,
*:after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    border: 0;
    outline: 0;
}

ol,
ul,
li {
    list-style: none;
}

:focus,
:active {
    outline: 0;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

th,
td {
    padding: 8px;
}

.switch {
    visibility: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
dt,
dl,
dd {
    font-size: inherit;
    margin: 0;
    padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.6;
}

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
}

html {
    font-size: 62.5%;
    line-height: 1.8;
    font-family: Arial, Helvetica, sans-serif;
}

img {
    max-width: 100%;
    height: auto;
}

/* 共通（ベース） */
body {
    color: var(--color-text-primary);
    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: 0.01em;
    overflow-wrap: break-word;
    text-rendering: optimizeLegibility;
}

/* 日本語用 */
:lang(ja) body {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    word-break: break-all;
    -moz-font-feature-settings: "pkna" 1;
    -webkit-font-feature-settings: "pkna" 1;
    font-feature-settings: "pkna" 1;
}

/* 英語用 */
:lang(en) body {
    font-family: 'Noto Sans', sans-serif;
    font-weight: 400;

    font-size: 1.5rem;
    line-height: 1.5;
    letter-spacing: 0.1em;
    word-break: normal;
}

.en {
    font-family: 'Noto Sans', sans-serif;
    line-height: 1.5;
    letter-spacing: 0.1em;
    word-break: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 600;
}

b,
strong,
.textB {
    font-weight: 600;
}

@media screen and (min-width: 360px) {
    * {
        -webkit-text-size-adjust: none;
    }
}

/* ----------- anchor */
a {
    color: var(--color-text-primary);
    text-decoration: none;
}

/*a:hover {opacity:0.8;} */
a .imgbt:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
    cursor: pointer;
}

a {
    -webkit-tap-highlight-color: var(--color-text-primary);
    ;
}

a.telLink:hover {
    opacity: 1;
    cursor: default;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}



/* footer {
  margin-top: auto;
} */

body.noscroll {
    overflow: hidden;
}

/*----------------------------------------------------
 body Bg
----------------------------------------------------*/

body {
    background-color: #ffffff;
}

/*----------------------------------------------------
 heater
----------------------------------------------------*/
header {
    padding: 15px 2%;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.05);
}

.h-logo a {
    display: inline-block;
}

.h-logo img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0;
}

.h-logo .tit {
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.3;
    margin-top: 3px;
}

.btn-lang {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 70px;
    height: 45px;
    line-height: 1;
    color: var(--select-color01);
    background-color: var(--color-text-primary);
    border-radius: 5px;
    font-size: 1.8rem;
    font-family: "Noto Sans", sans-serif;
    font-weight: 600;
    transition: all 0.5s;
}

.btn-lang::before {
    content: "";
    display: inline-block;
    width: 23px;
    height: 21px;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M325-111.5q-73-31.5-127.5-86t-86-127.5Q80-398%2080-480.5t31.5-155q31.5-72.5%2086-127t127.5-86Q398-880%20480.5-880t155%2031.5q72.5%2031.5%20127%2086t86%20127Q880-563%20880-480.5T848.5-325q-31.5%2073-86%20127.5t-127%2086Q563-80%20480.5-80T325-111.5ZM480-162q26-36%2045-75t31-83H404q12%2044%2031%2083t45%2075Zm-104-16q-18-33-31.5-68.5T322-320H204q29%2050%2072.5%2087t99.5%2055Zm208%200q56-18%2099.5-55t72.5-87H638q-9%2038-22.5%2073.5T584-178ZM170-400h136q-3-20-4.5-39.5T300-480q0-21%201.5-40.5T306-560H170q-5%2020-7.5%2039.5T160-480q0%2021%202.5%2040.5T170-400Zm216%200h188q3-20%204.5-39.5T580-480q0-21-1.5-40.5T574-560H386q-3%2020-4.5%2039.5T380-480q0%2021%201.5%2040.5T386-400Zm268%200h136q5-20%207.5-39.5T800-480q0-21-2.5-40.5T790-560H654q3%2020%204.5%2039.5T660-480q0%2021-1.5%2040.5T654-400Zm-16-240h118q-29-50-72.5-87T584-782q18%2033%2031.5%2068.5T638-640Zm-234%200h152q-12-44-31-83t-45-75q-26%2036-45%2075t-31%2083Zm-200%200h118q9-38%2022.5-73.5T376-782q-56%2018-99.5%2055T204-640Z%22%2F%3E%3C%2Fsvg%3E');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
}

@media only screen and (min-width:1201px) {
    header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        align-items: center;
        backdrop-filter: blur(5px);
        height: 80px;
        position: sticky;
        top: 0;
        left: 0;
        z-index: 15;

    }

    .btn-lang:hover {
        background-color: var(--color-text-hover);
    }

    .h-logo a:hover {
        opacity: 0.6;
    }
}

@media only screen and (max-width:1200px) {
    header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        align-items: center;
        height: 60px;
    }

    .h-logo a {
        max-width: 220px;
        width: 100%;
        display: block;
        height: auto;
        line-height: 1;
        padding: 0;
        margin: 0;
    }

    .h-logo a img {
        padding: 0;
        margin: 0;
        margin-left: 0;
        padding-left: 0;
    }


    .h-logo a svg {
        display: block;
        margin-left: 0;
        padding-left: 0;
    }

    .h-logo .tit {
        font-size: 1.1rem;
        padding: 0;
        margin: 0;
    }

    .btn-lang {
        width: 60px;
        position: fixed;
        right: calc(15px + 56px);
        top: 10px;
        height: 40px;
        z-index: 16;
    }

}

/*----------------------------------------------------
 menu
----------------------------------------------------*/
#navMenu ul a {
    font-size: 1.2rem;
    text-align: center;
    line-height: 2;
}

#navMenu ul a::before {
    transition: all 0.5s;
    content: attr(data-subtitle);
    font-family: "Noto Sans", sans-serif;
    letter-spacing: 0.08em;
    font-weight: 600;
    font-size: 1.8rem;
    text-transform: uppercase;
}

@media only screen and (min-width:1201px) {
    #btn_menu {
        display: none;
    }

    #navMenu {
        margin-left: auto;
        margin-right: 20px;
    }

    #navMenu ul {
        display: flex;
        gap: 0 20px;
    }

    #navMenu ul a:hover::before,
    #navMenu ul a.current {
        color: var(--color-text-hover);
    }

    #navMenu ul a span {
        display: block;
    }

    #navMenu ul a::before {
        display: block;
        line-height: 1;
    }

    #navMenu .snsBox {
        display: none;
    }
}


@media only screen and (max-width:1200px) {
    #navMenu {
        display: none;
    }

    header.active #navMenu {
        position: fixed;
        width: 100vw;
        background-color: #fff;
        height: 100vh;
        top: 0;
        left: 0;
        display: block;
        padding: 80px 4% 20px 4%;
        z-index: 14;
    }

    header #navMenu ul li {
        padding-left: 15px;
        position: relative;
        padding: 8px 0 8px 15px;
    }

    header #navMenu ul li::before {
        content: "";
        display: block;
        width: 10px;
        height: 2px;
        background-color: var(--color-text-primary);
        position: absolute;
        left: 0;
        top: 27px;
    }


    header #navMenu a span {
        margin-left: 10px;
        font-size: 1.2rem;
    }

    #navMenu ul a.subblank::before {
        padding-right: 20px;
        background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2220px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2220px%22%20fill%3D%22%23231815%22%3E%3Cpath%20d%3D%22M216-144q-29.7%200-50.85-21.15Q144-186.3%20144-216v-528q0-29.7%2021.15-50.85Q186.3-816%20216-816h264v72H216v528h528v-264h72v264q0%2029.7-21.15%2050.85Q773.7-144%20744-144H216Zm171-192-51-51%20357-357H576v-72h240v240h-72v-117L387-336Z%22%2F%3E%3C%2Fsvg%3E');
        background-position: right center;
        background-size: 18px;
        background-repeat: no-repeat;
    }

    #btn_menu {
        position: fixed;
        top: 8px;
        right: 15px;
        z-index: 20;
    }

    #btn_menu>span {
        width: 45px;
        height: 45px;
        border-radius: 50%;
        background-color: rgba(255, 255, 255, 0.8);
        border: 1.5px solid var(--color-text-primary);
        display: block;
    }

    #btn_menu>span span {
        display: inline-block;
        transition: all .4s;
        /*アニメーションの設定*/
        position: absolute;
        left: 9px;
        height: 1.5px;
        border-radius: 2px;
        background: var(--color-text-primary);
        width: 28px;
    }

    #btn_menu>span span:nth-of-type(1) {
        top: 14px;
    }

    #btn_menu>span span:nth-of-type(2) {
        top: 22px;
    }

    #btn_menu>span span:nth-of-type(3) {
        top: 30px;
    }

    header.active #btn_menu>span span:nth-of-type(1) {
        top: 15px;
        left: 11px;
        transform: translateY(6px) rotate(-45deg);
        width: 23px;
    }

    header.active #btn_menu>span span:nth-of-type(2) {
        opacity: 0;
        /*真ん中の線は透過*/
    }

    header.active #btn_menu>span span:nth-of-type(3) {
        top: 27px;
        left: 11px;
        transform: translateY(-6px) rotate(45deg);
        width: 23px;
    }

    #navMenu .snsBox {
        font-size: 3.0rem;
    }

    #navMenu .snsBox {
        display: flex;
        gap: 10px;
    }

    #navMenu .snsBox a {
        font-size: 30px;
        display: inline-block;
    }
}

/*----------------------------------------------------
 footer
----------------------------------------------------*/
footer {
    background-color: var(--color-text-primary);
    padding: 100px 4% 0 4%;
    color: var(--select-color01);
}

footer .f-logo {
    color: #fff;
    display: inline-block;
}

footer .f-logo img {
    display: block;
}

footer .f-logo span {
    display: inline-block;
    margin-top: 8px;
}

footer .f-logo-apu {
    color: #fff;
    display: inline-block;
}

footer .f-logo-apu img {
    display: block;
}

footer .f-logo-apu span {
    display: inline-block;
    margin-top: 8px;
    text-decoration: underline;
    font-size: 1.3rem;
}

footer .Copyright {
    font-size: 1.2rem;
    text-align: right;
    padding: 60px 0 20px 0;
}

footer .sitemap h3 {
    border-bottom: 2px solid #fff;
    padding-bottom: 10px;
    font-size: 1.8rem;
    margin-bottom: 20px;
    text-transform: uppercase;
}

footer .sitemap ul {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 20px;
}

footer .sitemap ul li {
    width: calc((100% - 40px) / 2);
}

footer .sitemap ul li a {
    color: #fff;
}

footer .sitemap ul li a {
    font-size: 1.2rem;
    line-height: 1.2;

}

footer .sitemap ul li {
    padding-left: 15px;
    position: relative;
}

footer .sitemap ul li::before {
    content: "";
    display: block;
    width: 10px;
    height: 2px;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 14px;
}

footer .sitemap ul li a span {
    display: block;
}

footer .sitemap ul li a::before {
    content: attr(data-subtitle);
    font-family: "Noto Sans", sans-serif;
    font-weight: 600;
    letter-spacing: 0.1em;
    font-size: 1.6rem;
    display: inline-block;
    text-transform: uppercase;
}

footer .sitemap ul li a.subblank::before {
    padding-right: 18px;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2220px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2220px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M216-144q-29.7%200-50.85-21.15Q144-186.3%20144-216v-528q0-29.7%2021.15-50.85Q186.3-816%20216-816h264v72H216v528h528v-264h72v264q0%2029.7-21.15%2050.85Q773.7-144%20744-144H216Zm171-192-51-51%20357-357H576v-72h240v240h-72v-117L387-336Z%22%2F%3E%3C%2Fsvg%3E');
    background-position: right center;
    background-size: 16px;
    background-repeat: no-repeat;
}


footer .snsBox {
    display: flex;
    gap: 10px;
    align-items: center;
}

footer .snsBox span {
    font-family: "Noto Sans", sans-serif;
    font-weight: 600;
    letter-spacing: 0.1em;
    font-size: 1.6rem;
    display: inline-block;
    text-transform: uppercase;
}

footer .snsBox a {
    color: #fff;
    font-size: 30px;
    display: inline-block;
}

@media only screen and (min-width:1100px) {

    footer .wrap {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    footer .sitemap {
        width: 100%;
        max-width: 520px;
    }

    footer .img-hover:hover {
        opacity: 0.8;
    }

    footer .f-logo-apu:hover span {
        text-decoration: none;
    }

    footer .snsBox a {
        transition: all 0.5s;
    }

    footer .sitemap ul li a::before {
        transition: all 0.5s;
    }

    footer .sitemap ul li a:hover::before,
    footer .snsBox a:hover {
        color: var(--color-text-hover);
    }
}

@media only screen and (max-width:1100px) {
    footer .copBox {
        margin-bottom: 40px;
    }
}



/*----------------------------------------------------
 shareBox
----------------------------------------------------*/

#btn_search {
    position: fixed;
    bottom: 30px;
    right: 30px;
    display: flex;
    align-items: center;
    color: #fff;
    padding: 16px;
    gap: 10px;
    background-color: var(--select-color01);
}

#btn_search img {
    width: 35px;
}

#btn_search span {
    display: block;
    font-size: 1.6rem;
    font-weight: 600;
}

.searchMenu {
    opacity: 0;
    transition: opacity 0.6s ease-in-out, transform 0.6s ease-in-out;
    transform: translateY(-20px);
    pointer-events: none;
    position: fixed;
    z-index: 1;
    opacity: 0;
    top: 0;
    left: 0;
    padding: 80px 4% 0 4%;
    width: 100%;
    height: 100vh;
    background: #fff;
    background-image: linear-gradient(to top, #f3e7e9 0%, #e3eeff 99%, #e3eeff 100%);
}

.searchMenu.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    z-index: 20;
    display: block;
    overflow-y: scroll;
}

.searchMenu .searchMenuCl {
    position: absolute;
    right: 20px;
    top: 20px;
}

.searchMenu .searchMenuCl img {
    width: 35px;
    height: 35px;
}

.searchMenu .search_tag {
    background-color: rgba(255, 255, 255, 0.2);
    padding: 30px 20px;
    transition: .3s;
}

.search_tag {
    margin: 0 auto;
    max-width: 850px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 15px;
}

.search_tag li a {
    display: inline-block;
    font-size: 1.4rem;
    background-color: #fff;
    padding: 5px 15px;
    transition: .3s;
}

.search_tag li a::before {
    content: "#";
    margin-right: 2px;
}

#btn_share {
    /* background-color: #fff; */
    padding: 10px;
    text-align: center;
}

#btn_share p {
    font-weight: 600;
    line-height: 1;
    font-family: "Noto Sans", sans-serif;
}

#btn_share ul.icon-list {
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 0;
}

#btn_share ul.icon-list a {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--select-color01);
    width: 40px;
    height: 40px;
    border-radius: 100%;
    transition: .3s;
}

#btn_share ul.icon-list a img {
    height: 20px
}

@media only screen and (min-width:813px) {
    .search_tag li a:hover {
        background-color: rgba(255, 255, 255, 0.6);
    }

    #btn_search::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        opacity: 0;
        background-color: var(--select-color02);
        display: block;
        transition: .3s;
    }

    #btn_search:hover::before {
        opacity: 1;
    }

    #btn_search img,
    #btn_search span {
        z-index: 1;
    }

    #btn_share {
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 0.6s ease, transform 0.6s ease;
        pointer-events: none;
        position: fixed;
        left: 0;
        top: 50%;
        margin-top: -87px;
        z-index: 1;
        border-radius: 0 5px 5px 0;
    }

    #btn_share p {
        font-size: 1.0rem;
        letter-spacing: -0.04rem;
        margin-bottom: 8px;
    }

    #btn_share ul.icon-list {
        flex-flow: column;
    }

    #btn_share ul.icon-list a {
        transition: opacity 0.3s ease;
    }

    #btn_share ul.icon-list a:hover {
        background-color: var(--select-color02);
    }

    #btn_share.show {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

}

@media only screen and (max-width:813px) {
    #btn_share {
        display: block;
        padding: 40px 4%;
        background: rgba(0, 0, 0, .5);
    }

    #btn_share p {
        font-size: 2.0rem;
        margin-bottom: 20px;
    }

    #btn_share ul.icon-list {
        justify-content: center;
    }
}


/*----------------------------------------------------
 Animation
----------------------------------------------------*/
@keyframes slide_img {
    100% {
        background-position: -10000px 0
    }
}

@keyframes slide_img_r {
    100% {
        background-position: 10000px 0
    }
}

@keyframes slide_img_h {
    100% {
        background-position-x: 10000px
    }
}

.fadeUp.play {
    animation-name: fadeUpAnime;
    animation-duration: 0.9s;
    animation-fill-mode: forwards;
    opacity: 0;
    animation-delay: 0.1s;
}

@keyframes fadeUpAnime {
    from {
        opacity: 0;
        transform: translateY(5px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fadeUp {
    opacity: 0;
}

/*- breadcrumbs --------  */
.breadcrumbsBox {
    margin-top: auto;
    width: 100%;
    display: flex;
    align-items: center;
}

#breadcrumbs {
    width: calc(100% - 44px);
    display: block;
    font-size: 1.2rem;
    margin-right: 10px;
    padding: 0 2%;
}

#breadcrumbs>li {
    display: inline;
    vertical-align: middle;
    text-decoration: none;
    position: relative;
    font-weight: 600;
}

#breadcrumbs>li:not(:last-of-type) {
    padding: 0 20px 0 0;
}

#breadcrumbs>li:not(:last-of-type)::before {
    content: "";
    display: block;
    width: 10px;
    background-color: #757575;
    height: 1px;
    right: 5px;
    top: 50%;
    margin-top: -1px;
    position: absolute;
}

#breadcrumbs a {
    color: #757575;
    text-decoration: none;
    font-weight: 400;
}

#breadcrumbs a:hover {
    text-decoration: underline;
}

#pageTop {
    width: 80px;
    height: 80px;
    background-color: var(--color-text-primary);
    margin-left: auto;
    font-family: "Noto Sans", sans-serif;
    font-weight: 600;
    color: var(--select-color01);
    font-size: 1.2rem;
    text-align: center;
}

#pageTop span {
    line-height: 1;
    margin-bottom: 5px;
    display: inline-block;
}

#pageTop .ico-pan {
    width: 34px;
    height: 34px;
    background: url(../../img/common/ico-pen.svg) no-repeat center center;
    background-size: contain;
    display: inline-block;
}


@media only screen and (min-width:813px) {
    #pageTop:hover {
        opacity: 0.6;
    }
}

@media only screen and (max-width: 812px) {
    #breadcrumbs {
        font-size: 1.0rem;
    }

    #breadcrumbs {
        text-align: left;
    }
}


/*- wap --------  */

.wrap01 {
    width: 100%;
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
}

.wrap02 {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.wrap03 {
    width: 100%;
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}

.section_wap {
    padding: 0 4% 0;
}

@media only screen and (min-width:813px) {}

/*- single Page --------  */


/*- title --------  */

.title01 {
    color: var(--color-text-title);
    font-size: 3.6rem;
    margin-bottom: 30px;
}

.title01::before {
    content: "";
    width: 179px;
    height: 28px;
    display: block;
    background-image: url(../../img/common/ico-title01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    margin-bottom: -14px;
}

.title02 {
    color: var(--color-text-title);
    font-size: 3.6rem;
    margin-bottom: 30px;
}
@media only screen and (min-width:813px) {}
@media only screen and (max-width:812px) {
    .title01,
    .title02 {
        font-size: 2.8rem;
    }

    .title01 {
        line-height: 1.6;
    }

    .title01::before {
        content: "";
        width: 130px;
        height: 26px;
    }
}

.under_title{
        text-align: center;
        position: relative;
        overflow: hidden;
        padding: 120px 4%;
        display: flex;
        justify-content: center;
        align-items: center;
}
.under_title::before{
    content: "";
    opacity: 0.6;
    background: linear-gradient(32deg, rgb(255, 255, 224) 0%, rgb(176, 224, 230) 33%, rgb(255, 255, 224) 70%, rgb(240, 255, 255) 100%);
    animation: 12s ease 0s infinite alternate none running huerotatorBg;
    width: 100vw;
    height: 100vh;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    z-index: -2;
}

@keyframes huerotatorBg {
  0% {
    -webkit-filter: hue-rotate(0deg);
    filter: hue-rotate(0deg);
  }

  100% {
    -webkit-filter: hue-rotate(360deg);
    filter: hue-rotate(360deg);
  }
}
.under_title p{
    font-family: "Noto Sans", sans-serif;
    font-weight: 600;
    margin-bottom: 0px;
    color: var(--color-text-sub);
    text-transform: uppercase;
    font-size: clamp(3.6rem, 5vw, 4.2rem);
    letter-spacing: 0.06em;
}
.under_title h1{font-size: clamp(2.3rem, 5vw, 3.6rem);}

.under_title h1 span{display: inline-block;}
.under_title > div::before, .under_title > div::after {
    content: "";
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: 100%;
    width: 25vw;
    height: 100%;
}
.under_title > div::before {
  top: 2px;
  right: -1px;
  background-image: url(/home/artcampus/assets/img/common/bg_line01_R.svg);
  background-position: right top;
  transform-origin: right top;
  transform: rotate(16deg);
}

.under_title > div::after {
  bottom: 0;
  left: -1px;
  background-image: url(/home/artcampus/assets/img/common/bg_line01_L.svg);
  background-position: left bottom;
  transform-origin: left bottom;
  transform: rotate(11deg);
}

@media only screen and (min-width:813px) {

.under_title > div::before {
    width: 25vw;
    height: 100%;
  }

  .under_title > div::after {
    width: 25vw;
    height: 100%;
  }

}
@media only screen and (max-width:812px) {
.under_title{
    padding: 80px 4%;
}
  .under_title > div::before {
    width: 29vw;
    height: 100%;
    transform: rotate(0deg);
  }

  .under_title > div::after {
    width: 30vw;
    height: 100%;
    transform: rotate(0deg);
  }

}

@media only screen and (min-width:813px) {}
@media only screen and (max-width:812px) {}

.marker01 {
    background: linear-gradient(180deg, transparent 30%, rgba(152, 230, 84, 0.4) 40%, rgba(255, 248, 167, 0.5) 100%);
}

/*- btn --------  */
.btn-more,.btn-more02 {
    position: relative;
    display: inline-block;
    padding: 0 40px 0 4px;
    background-image: linear-gradient(var(--color-text-primary), var(--color-text-primary));
    background-size: 100% 1px;
    background-position: bottom left;
    background-repeat: no-repeat;
    padding-bottom: 5px;
    transition: background-size 0.3s ease-out;
}


.btn-more::after,.btn-more02::after{
    position: absolute;
    content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23231815%22%3E%3Cpath%20d%3D%22M647-440H160v-80h487L423-744l57-56%20320%20320-320%20320-57-56%20224-224Z%22%2F%3E%3C%2Fsvg%3E');
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    top: 50%;
    right: 3px;
    margin-top: -12px;
}
.btn-more02::after {
        transform: rotate(-0.13turn);
}



@media only screen and (min-width:813px) {
    .btn-more:hover,.btn-more02:hover {
        background-size: 0 1px;
        background-position: bottom right;
    }
}



/*- table --------  */
.table01 {
    border-collapse: collapse;
}

.table01 td,
.table01 th {
    padding: 20px 0;
    text-align: left;
}

.table01 tr td {
    border-bottom: solid 1px var(--select-color01);
}

.table01 tr th {
    border-bottom: solid 1px var(--select-color01);
}

.table01 tbody tr th {
    width: 20%;
    font-weight: 600;
    letter-spacing: 0.48px;
}

.table01 tbody tr td {
    letter-spacing: 0.8px;
    padding-left: 2%;
}

@media only screen and (min-width:813px) {}

@media only screen and (max-width:812px) {
    .table01 tbody tr th {
        width: 25%;
    }
}

.table02 {
    border-collapse: collapse;
    border: solid 1px #EEEEEE;
}

.table02 td,
.table02 th {
    padding: 10px 15px;
}

.table02 tbody tr th {
    text-align: center;
    vertical-align: middle;
    background-color: #d9d9d9;
    font-weight: 600;
}

@media only screen and (min-width:813px) {
    .table02 tr:not(:last-of-type) th {
        border-bottom: solid 1px #fff;
    }

    .table02 tr:not(:last-of-type) td {
        border-bottom: solid 1px #EEEEEE;
    }

    .table02 tr td:not(:last-of-type) {
        border-right: solid 1px #EEEEEE;
    }

    .table02 tbody tr th {
        width: 33%;
        text-align: center;
        vertical-align: middle;
        background-color: #d9d9d9;
        font-weight: 600;
    }

    .table02 tbody tr td {
        width: 33%;
        vertical-align: middle;
        text-align: center;
    }
}

@media only screen and (max-width:812px) {
    .table02 tbody td {
        width: 100%;
        display: inline-block;
    }

    .table02 tbody th {
        width: 100%;
        display: inline-block;
    }

    .table02 tr td:last-of-type::before {
        content: attr(data-label);
        display: block;
        font-size: 1.3rem;
        font-weight: 400;
    }
}

.table03 {
    border-collapse: collapse;
    border: solid 1px #EEEEEE;
    width: 100%;
    max-width: 540px;
}

.table03 td {
    padding: 10px 15px;
}

.table03 tr:not(:last-of-type) td {
    border-bottom: solid 1px #EEEEEE;
}

.table03 tr:not(:last-of-type) th {
    border-bottom: solid 1px #fff;
}

.table03 tbody tr th {
    width: 50%;
    text-align: center;
    vertical-align: middle;
    background-color: #d9d9d9;
    font-weight: 600;
}

.table03 tbody tr td {
    width: 50%;
    text-align: center;
    vertical-align: middle;
}

@media only screen and (min-width:813px) {}

@media only screen and (max-width:812px) {}


/*- list --------  */
.list01 {
    list-style: none;
}

.list01 li {
    position: relative;
    padding-left: 1.6rem;
    margin-bottom: 5px;
}

.list01 li:before {
    content: "・";
    display: inline-block;
    line-height: 140%;
    position: absolute;
    margin-top: 3px;
    left: 0;
}

.list01 li:last-child {
    margin-bottom: 0;
}

@media only screen and (max-width:812px) {
    .list01 li {
        line-height: 1.4;
    }

    .list01 li:before {
        line-height: 1.4;
        top: 0;
    }
}

.list_notes {
    list-style: none;
    font-size: 1.3rem;
}

.list_notes li {
    position: relative;
    padding-left: 1.6rem;
}

:lang(jp).list_notes li:before {
    content: "※";
    display: inline-block;
    line-height: 140%;
    position: absolute;
    margin-top: 3px;
    left: 0;
}

:lang(en).list_notes li:before {
    content: "*";
    display: inline-block;
    line-height: 140%;
    position: absolute;
    margin-top: 3px;
    left: 0;
}

.list_notes li:last-child {
    margin-bottom: 0;
}

/* 英数字 */
.list_n01 {
    counter-reset: number;
    list-style: none;
}

.list_n01>li {
    padding-left: 17px;
    position: relative;
}

.list_n01>li:before {
    counter-increment: number;
    content: counter(number) ".";
    display: inline-block;
    position: absolute;
    left: 0;
}

.list_n01>li:not(:last-of-type) {
    margin-bottom: 10px;
}

/* 英数字 */
.list_n02 {
    counter-reset: number2;
    list-style: none;
}

.list_n02>li {
    padding-left: 25px;
    position: relative;
}

.list_n02>li:before {
    counter-increment: number2;
    content: counter(number2) ")";
    display: inline-block;
    position: absolute;
    left: 0;
}

.list_n02>li:last-child {
    margin-bottom: 0;
}

/* indent */
.int01 {
    text-indent: -1em;
    padding-left: 1em;
}
.int02 {
    text-indent: -2em;
    padding-left: 2em;
}
.int03 {
    text-indent: -3em;
    padding-left: 3em;
}

.int01 i,.int02 i,.int03 i{
display: inline;
}



/*----------------------------------------------------
 common
----------------------------------------------------*/
.fl {
    float: left;
}

.fr {
    float: right;
}

/* placeholder */
input::-webkit-input-placeholder {
    font-size: smaller;
}

input:-moz-placeholder {
    font-size: smaller;
}

@media only screen and (min-width:813px) {
    .pcNone {
        display: none !important;
    }

    .btPCNone {
        display: none !important;
    }
}

@media only screen and (max-width:812px) {
    .spNone {
        display: none !important;
    }
}

@media only screen and (min-width:431px) {
    .spOnly {
        display: none;
    }
}

@media only screen and (max-width:430px) {
    .pcOnly {
        display: none;
    }
}

@media only screen and (min-width:813px) {
    a[href*="tel:"] {
        pointer-events: none !important;
        text-decoration: none !important;
    }
}

@media only screen and (max-width: 812px) {

    a[href*="tel:"] {
        pointer-events: initial;
    }
}

.mb0 {
    margin-bottom: 0 !important;
}

.mb5 {
    margin-bottom: 5px !important;
}

.mb10 {
    margin-bottom: 10px !important;
}

.mb15 {
    margin-bottom: 15px !important;
}

.mb20 {
    margin-bottom: 20px !important;
}

.mb25 {
    margin-bottom: 25px !important;
}

.mb30 {
    margin-bottom: 30px !important;
}

.mb40 {
    margin-bottom: 40px !important;
}

.mb50 {
    margin-bottom: 50px !important;
}

.mb60 {
    margin-bottom: 60px !important;
}

.mb70 {
    margin-bottom: 70px !important;
}

.mb80 {
    margin-bottom: 80px !important;
}

.mb90 {
    margin-bottom: 90px !important;
}

.mb100 {
    margin-bottom: 100px !important;
}

.mb120 {
    margin-bottom: 120px !important;
}

.ml0 {
    margin-left: 0 !important;
}

.ml5 {
    margin-left: 5px !important;
}

.ml10 {
    margin-left: 10px !important;
}

.ml12 {
    margin-left: 12px !important;
}

.ml13 {
    margin-left: 13px !important;
}

.ml15 {
    margin-left: 15px !important;
}

.ml20 {
    margin-left: 20px !important;
}

.ml25 {
    margin-left: 25px !important;
}

.ml30 {
    margin-left: 30px !important;
}

.mr0 {
    margin-right: 0 !important;
}

.mr5 {
    margin-right: 5px !important;
}

.mr10 {
    margin-right: 10px !important;
}

.mr15 {
    margin-right: 15px !important;
}

.mr20 {
    margin-right: 20px !important;
}

.mr30 {
    margin-right: 30px !important;
}

.mt0 {
    margin-top: 0 !important;
}

.mt5 {
    margin-top: 5px !important;
}

.mt10 {
    margin-top: 10px !important;
}

.mt15 {
    margin-top: 15px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.mt50 {
    margin-top: 50px !important;
}

.mt60 {
    margin-top: 60px !important;
}

.pt0 {
    padding-top: 0px !important;
}

.pt5 {
    padding-top: 5px !important;
}

.pt10 {
    padding-top: 10px !important;
}

.pt20 {
    padding-top: 20px !important;
}

.pt30 {
    padding-top: 30px !important;
}

.pt40 {
    padding-top: 40px !important;
}

.pb5 {
    padding-bottom: 5px !important;
}

.pb10 {
    padding-bottom: 10px !important;
}

.pb20 {
    padding-bottom: 20px !important;
}

.pb60 {
    padding-bottom: 60px !important;
}

.pb100 {
    padding-bottom: 100px !important;
}

.text08 {
    font-size: 0.8rem !important;
}

.text09 {
    font-size: 0.9rem !important;
}

.text10 {
    font-size: 1rem !important;
}

.text11 {
    font-size: 1.1rem !important;
}

.text12 {
    font-size: 1.2rem !important;
}

.text13 {
    font-size: 1.3rem !important;
}

.text14 {
    font-size: 1.4rem !important;
}

.text15 {
    font-size: 1.5rem !important;
}

.text16 {
    font-size: 1.6rem !important;
}

.text18 {
    font-size: 1.8rem !important;
}

.text20 {
    font-size: 2rem !important;
}

.text24 {
    font-size: 2.4rem !important;
}

.text28 {
    font-size: 2.8rem !important;
}

.text30 {
    font-size: 3rem !important;
}

.textC {
    text-align: center !important;
}

.textR {
    text-align: right !important;
}

.textL {
    text-align: left !important;
}

.textB {
    font-weight: 700 !important;
}

.textN {
    font-weight: 500 !important;
}

.textU {
    text-decoration: underline !important;
}

.textI {
    padding-left: 1rem !important;
    text-indent: -1rem !important;
}

.textI2 {
    padding-left: 1.6rem !important;
    text-indent: -1.6rem !important;
}

.bold {
    font-weight: bold;
}

.box10p {
    width: 10% !important;
}

.box15p {
    width: 15% !important;
}

.box20p {
    width: 20% !important;
}

.box35p {
    width: 35% !important;
}

.box40p {
    width: 40% !important;
}

.box45p {
    width: 45% !important;
}

.box48p {
    width: 48% !important;
}

.box49p {
    width: 49% !important;
}

.box50p {
    width: 50% !important;
}

.box55p {
    width: 55% !important;
}

.box60p {
    width: 60% !important;
}

.box65p {
    width: 65% !important;
}

.box70p {
    width: 70% !important;
}

.box75p {
    width: 75% !important;
}

.box80p {
    width: 80% !important;
}

.box100p {
    width: 100% !important;
}

.lrAuto {
    margin-left: auto;
    margin-right: auto;
}

.flex02>figure img,
.flex03>figure img {
    width: 100%;
    height: auto;
}

@media only screen and (min-width:813px) {
    .flex02 {
        display: flex;
        flex-wrap: wrap;
        gap: 24px;
    }

    .flex02>div,
    .flex02>figure {
        width: calc((100% - 24px) / 2) !important;
    }
}

@media only screen and (max-width:812px) {

    .flex02>div:not(:last-child),
    .flex02>figure:not(:last-child) {
        margin-bottom: 40px;
    }
}

@media only screen and (min-width:813px) {
    .flex03 {
        display: flex;
        flex-wrap: wrap;
        gap: 24px;
    }

    .flex03>div,
    .flex03>figure {
        width: calc((100% - 48px) / 3) !important;
    }
}

@media only screen and (max-width:812px) {

    .flex03>div:not(:last-child),
    .flex03>figure:not(:last-child) {
        margin-bottom: 40px;
    }
}

a.link_w {
    text-decoration: underline;
    color: #fff;
    font-weight: 400;
}

a.link_w:hover {
    opacity: 0.8;
    text-decoration: none;
}

a.link {
    text-decoration: underline;
    font-weight: 400;
}

a.link:hover {
    opacity: 0.8;
    text-decoration: none;
}

@media only screen and (min-width:813px) {
    a[href*="tel:"].link_w {
        pointer-events: none;
        border-bottom: none;
    }

    a[href*="tel:"].link {
        pointer-events: none;
        border-bottom: none;
    }
}

.va_b {
    vertical-align: bottom;
}

.va_m {
    display: inline-block;
    vertical-align: middle;
}

.va_t {
    vertical-align: top;
}

@media only screen and (max-width:812px) {
    a[href*="tel:"].link_w {
        color: #fff !important;
    }

    .textCsp {
        text-align: center !important;
    }

    .textRsp {
        text-align: right !important;
    }

    .textLsp {
        text-align: left !important;
    }

    .mb20sp {
        margin-bottom: 20px !important;
    }
}

adress {
    font-style: normal !important;
}

:root {
    --color-text-primary: #231815;
    --color-text-title: #262634;
    --color-text-sub: #aaaaaa;
    --color-text-hover: #d6b80f;

    --select-color01: #FFFFFF;
    --select-color02: #FAF5F5;
    --select-color03: #FBFBFB;
    --select-color04: #E3DFE0;
    --select-color05: #E6CD86;
    --select-color06: #A3CEAF;
    --select-color07: #83B8DC;
    --select-color08: #E0A1B8;



    --grade-color01: linear-gradient(32deg, rgba(255, 255, 224, 1) 0%, rgba(176, 224, 230, 1) 33%, rgba(255, 255, 224, 1) 70%, rgba(240, 255, 255, 1) 100%);
    --grade-color02: linear-gradient(90deg, rgba(152, 230, 84, 1) 0%, rgba(255, 248, 167, 1) 100%);


    /* 透過カラー（蛍光マーカー風） */
    --color01-alpha: rgba(0, 169, 104, 0.3);
}




