@charset "UTF-8";
/*-------------
vars
-------------*/
:root{
    --inner-width: 1200px;
    --inner-width_sp: 90.625vw;
    --inner-sides: 40px;
    --inner-sides_sp: 4.6875vw;
    --min-width: var(--inner-width);
    
    --base-brown: #4d372e;
    --base-light-brown: #8a7869;
    --base-dark-brown: #755a4a;
    --border-brown: #ccc0b8;
    --border-light-brown: #e6dbd2;
    --bg-brown: #f0e9e4;
    --bg-light-brown: #faf7f5;
    --bg-dark-brown: #e6ddd4;
    --text-brown: #614a3f;
    --dot-brown: #c7b299;
    
    --bg-gray: #f7f8f8;
    
    --accent-black: #1a1a1a;
    --accent-red: #ed1c24;
    --accent-green: #248f5e;
    --accent-dark-green: #00947e;
    --accent-light-green: #8dc03e;
    
    --accent-orange: #ffa30b;
    --bg-orange: #fedfb3;
    
    --base-pink: #f679ad;
    --accent-pink: #f668b2;
    --bg-pink: #ffe6f3;
    --bg-light-pink: #feeef4;
    
    --box-shadow: 0 5px 20px rgba(71,42,4,.15);
    --arrow-right: url(../images/btn-arrow.svg) no-repeat center right / auto;
    --icon-pdf: url(../images/icon_pdf.svg) no-repeat center / contain;

    --font-sans: "Noto Sans JP", sans-serif;
    --font-maru: "Zen Maru Gothic", sans-serif;
    --fontsize-base: 1.5rem;
    
    --linear: .5s linear;
    --ease: .5s ease;
}
@media screen and (max-width:768px){
    :root{
        --inner-width: var(--inner-width_sp);
        --inner-sides: var(--inner-sides_sp);
        --min-width: 320px;
        
        --box-shadow: 0 3px 12px rgba(71,42,4,.15);
        --arrow-right: url(../images/btn-arrow@sp.svg) no-repeat center right / auto;
        
        --fontsize-base: 1.4rem;
    }
}

/*-------------
base
-------------*/
html{
    font-size: 62.5%;
}
body{
    width: 100%;
    min-width: var(--inner-width);
    background: var(--bg-light-brown);
    color: var(--base-brown);
    font-family: var(--font-sans);
    font-optical-sizing: auto;
    font-size: var(--fontsize-base);
    line-height: 1.8;
    text-align: left;
    letter-spacing: .02em;
    overflow-wrap: anywhere;
    word-break: normal;
    line-break: strict;
}
@media screen and (max-width:768px){
    body{
        min-width: 0;
    }
}
img{
    max-width: 100%;
    height: auto;
}
:where(.wrapper, .container){
    container-type: inline-size;
}
:where(.wrapper *), 
:where(.container) *{
    --container-sides: calc(50cqw - (var(--inner-width) / 2));
    --container-side-pos: calc((100% - 100cqw) / 2);
}
::selection{
    background: var(--base-brown);
    color: #fff;
}

/* common */
@media screen and (min-width:769px){
    .sp{
        display: none!important;
    }
}
@media screen and (max-width:768px){
    .pc{
        display: none!important;
    }
}
.clearfix::after,
.cf::after{
    content: "";
    display: block;
    clear: both;
}
.visually-hidden{
    clip: rect(0, 0, 0, 0);
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    user-select: none;
}
.preload *,
.preload *::before,
.preload *::after{
    transition: none!important;
}
.floatL, .l{
    float: left;
}
.floatR, .r{
    float: right;
}
.clearBoth, .c_b{
	clear:both;
}
.dispIB, .d-ib{
    display: inline-block;
}
img.dispIB, img.d-ib{
    width: revert-layer;
    height: revert-layer;
}

/* margin */
.mRkern{
    margin-right: -.4em;
}
.mLkern{
    margin-left: -.4em;
}
.mLRkern{
    margin-right: -.4em;
    margin-left: -.4em;
}
.mB5{
	margin-bottom: 5px!important;
}
.mB10{
	margin-bottom: 10px!important;
}
.mB15{
	margin-bottom: 15px!important;
}
.mB20{
	margin-bottom: 20px!important;
}
.mB30{
	margin-bottom: 30px!important;
}
.mR10{
	margin-right: 10px!important;
}

/* text */
.txtInd, .txt_ind {
    text-indent: -1.02em;
    padding-left: 1.02em;
}
.ffsPalt, .ffs-palt{
	font-feature-settings: "palt" 1;
}
.ffSans, .ff-sans{
    font-family: var(--font-sans)!important;
}
.txtRed{
    color: var(--accent-red)!important;
}
.txtSmall{
    font-size: .7em;
}
.txtCenter, .ta-c{
    text-align: center;
}
.txtRight, .ta-r{
    text-align: right;
}
.wsNowrap, .ws-no{
    white-space: nowrap;
}
*:has(> wbr:not(.pc):not(.sp)){
    word-break: keep-all;
    overflow-wrap: break-word;
}
@media screen and (min-width:769px){
    *:has(> wbr.pc){
        word-break: keep-all;
        overflow-wrap: break-word;
    }
}
@media screen and (max-width:768px){
    *:has(> wbr.sp){
        word-break: keep-all;
        overflow-wrap: break-word;
    }
}

/* a */
@media (any-hover: hover){
    :where(a:hover){
        text-decoration: none;
    }
}
.txtLink:not(:hover){
    text-decoration: underline;
}
.fadeHover{
    transition: opacity var(--ease);
}
@media (any-hover: hover){
    .fadeHover:hover{
        opacity: .7;
    }
    .undrHover:not(:hover){
        text-decoration: underline;
    }
}
:where(a:has(> img:only-child)),
:where(a:has(> picture:only-child)){
    transition: opacity var(--ease);
}
@media (any-hover: hover){
    :where(a:has(> img:only-child)):hover,
    :where(a:has(> picture:only-child)):hover{
        opacity: .7;
    }
}
@media screen and (min-width:769px){
    body:not(.viewing_mobile) a[href^="tel:"]{
        text-decoration: none!important;
        pointer-events: none;
    }
    body:not(.viewing_mobile) a[href^="tel:"]:hover{
        opacity: 1;
    }
}

/*-------------
accordion
-------------*/
.accordion-btn:not(.is--ready){
    pointer-events: none;
}
.accordion-btn.is--ready{
    cursor: pointer;
}
@media screen and (max-width:768px){
    .accordion-btn_sp:not(.is--ready){
        pointer-events: none;
    }
    .accordion-btn_sp.is--ready{
        cursor: pointer;
    }
}
.accordion-btn:not(._active):not([data-target-class]) + *:not(.accordion-container),
.accordion-content{
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
@media screen and (max-width:768px){
    .accordion-btn_sp:not(._active):not([data-target-class]) + *:not(.accordion-container),
    .accordion-content_sp{
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }
}
.accordion-container{
    overflow: hidden;
    transition: height .3s ease;
}
.accordion-container.is--hit_low{
    transition: height .2s ease;
}
.accordion-container:not(.is--open){
    height: 0!important;
}
@media screen and (min-width:769px){
    .accordion-container.is--limit_sp{
        height: auto!important;
    }
}

/*-------------
header
-------------*/
.header{
    --header-nav-hit: 56px;
    display: flex;
    align-items: center;
    position: relative;
    z-index: 99;
    padding: 10px var(--container-sides) calc(12px + var(--header-nav-hit));
}
@media screen and (max-width:768px){
    .wrapper{
        --header-hit: 50px;
        padding-top: var(--header-hit);
    }
    .header{
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        padding: 0;
        box-shadow: 0 1px 0 var(--border-light-brown);
    }
}
.header-head{
    flex: 0 0 auto;
}
.header-menu-btn{
    display: none;
}
@media screen and (max-width:768px){
    .header-head{
        display: flex;
        align-items: center;
        height: var(--header-hit);
        padding-left: var(--inner-sides_sp);
        background: var(--bg-light-brown);
    }
    .header-logo{
        width: 192px;
    }
    .header-menu-btn{
        display: block;
        position: absolute;
        top: 0;
        right: 0;
        width: var(--header-hit);
        height: var(--header-hit);
        background: var(--accent-black);
    }
    .header-menu-btn::before,
    .header-menu-btn::after{
        position: absolute;
        left: calc(50% - 12px);
        width: 24px;
        content: "";
        transition: transform var(--ease);
    }
    .header-menu-btn::before{
        top: calc(50% - 8px);
        height: 16px;
        background: url(../images/header-menu-bar.svg) no-repeat top center / contain,
        url(../images/header-menu-bar.svg) no-repeat bottom center / contain;
    }
    .header-menu-btn._open::before{
        transform: rotate(45deg);
        background: url(../images/header-menu-bar.svg) no-repeat center / contain;
    }
    .header-menu-btn::after{
        top: calc(50% - 1px);
        height: 2px;
        background: url(../images/header-menu-bar.svg) no-repeat center / contain;
    }
    .header-menu-btn._open::after{
        transform: rotate(-45deg);
    }
}
.header-menu{
    flex: 0 0 auto;
    margin-left: auto;
}
@media screen and (max-width:768px){
    .header-menu{
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100dvh;
        padding-top: var(--header-hit);
        overflow: auto;
        background: rgba(0,0,0,.7);
        pointer-events: auto;
        cursor: pointer;
        transition: opacity var(--ease);
    }
    .header-menu:not(._active),
    .header-menu:not(._active) *{
        z-index: -999;
        pointer-events: none;
        user-select: none;
    }
    .header-menu:not(._show){
        opacity: 0;
    }
}

/* header-nav */
.header-nav{
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: var(--header-nav-hit);
    background: var(--bg-brown);
    transition: box-shadow var(--ease);
}
@media screen and (min-width:769px){
    .header-nav._fixed{
        opacity: 0;
        position: fixed;
        top: 0;
        bottom: auto;
        z-index: 99;
        transform: translateY(calc(var(--header-nav-hit) * -1));
        box-shadow: 0 2px 5px rgba(71,42,4,.15);
    }
    .header-nav._fixed._down{
        opacity: 1;
        transform: translateY(0);
        transition: opacity var(--ease), transform var(--ease);
    }
    .header-nav._fixed._up{
        opacity: 0;
        transform: translateY(calc(var(--header-nav-hit) * -1));
    }
}
@media screen and (max-width:768px){
    .header-nav{
        position: static;
        height: auto;
    }
}
.header-nav-list{
    display: flex;
    justify-content: center;
    height: 100%;
    padding-left: 1px;
}
.header-nav-list-item{
    position: relative;
    margin-left: -1px;
}
.header-nav-list-item:first-child::before,
.header-nav-list-item::after{
    position: absolute;
    bottom: 14px;
    right: 0;
    width: 1px;
    height: calc(100% - 28px);
    background: var(--border-brown);
    content: "";
    pointer-events: none;
}
.header-nav-list-item:first-child::before{
    right: auto;
    left: 0;
}
@media screen and (max-width:768px){
    .header-nav-list{
        flex-direction: column;
        padding: 1px 0 0;
    }
    .header-nav-list-item{
        margin: -1px 0 0;
    }
    .header-nav-list-item:first-child::before,
    .header-nav-list-item::after{
        bottom: 0;
        width: 100%;
        height: 1px;
        background: var(--border-light-brown);
    }
    .header-nav-list-item:first-child::before{
        bottom: calc(100% - 1px);
    }
}
.header-nav-list__link{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    padding: 0 26px 2px;
    font-family: var(--font-maru);
    font-size: 1.6rem;
    font-weight: bold;
    line-height: calc(1em + 8px);
    letter-spacing: 0;
}
@media screen and (max-width:768px){
    .header-nav-list__link{
        justify-content: flex-start;
        min-height: 50px;
        padding: 10px var(--inner-sides_sp) 10px;
    }
}
.header-nav__sub-list-btn{
    display: none;
}
@media screen and (max-width:768px){
    .header-nav-list__link:has(+ .header-nav__sub-list-btn){
        padding-right: 50px;
    }
    .header-nav__sub-list-btn{
        display: block;
        position: absolute;
        top: 0;
        right: 0;
        width: 50px;
        height: 50px;
    }
    .header-nav__sub-list-btn::before,
    .header-nav__sub-list-btn::after{
        position: absolute;
        top: calc(50% - 1px);
        left: calc(50% - 6px);
        width: 12px;
        height: 2px;
        border-radius: 1px;
        background: var(--base-brown);
        content: "";
        transition: opacity var(--ease), transform var(--ease);
    }
    .header-nav__sub-list-btn._active::before{
        opacity: 0;
        transform: rotate(90deg);
    }
    .header-nav__sub-list-btn:not(._active):after{
        transform: rotate(-90deg);
    }
}
.header-nav__sub-list{
    position: absolute;
    bottom: -7px;
    left: 50%;
    transform: translate(-50%, 100%);
    min-width: 220px;
    padding: 10px 15px;
    border-radius: 10px;
    background: var(--base-dark-brown); 
    transition: opacity var(--ease), transform var(--ease);
}
@media screen and (min-width:769px){
    .header-nav__sub-list:not(._active){
        display: none;
    }
    .header-nav__sub-list:not(._show){
        opacity: 0;
        transform: translate(-50%, 98%);
    }
    .header-nav__sub-list::before{
        clip-path: polygon(0 100%, 50% 0, 100% 100%);
        position: absolute;
        top: -12px;
        left: calc(50% - 7px);
        width: 14px;
        height: 14px;
        background: var(--base-dark-brown);
        content: "";
    }
    .header-nav__sub-list::after{
        position: absolute;
        top: -7px;
        left: 0;
        width: 100%;
        height: 7px;
        content: "";
    }
}
@media screen and (max-width:768px){
    .header-nav__sub-list{
        position: static;
        transform: none;
        min-width: 0;
        padding: 0;
        border-radius: 0;
    }
}
.header-nav__sub-list-item a{
    display: block;
    position: relative;
    padding: 8px 6px 9px 26px;
    color: #fff;
    font-family: var(--font-maru);
    font-size: 1.6rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    letter-spacing: 0;
    white-space: nowrap;
    transition: color var(--ease);
}
@media screen and (max-width:768px){
    .header-nav__sub-list-item a{
        padding: 13px var(--inner-sides_sp) 14px calc(var(--inner-sides_sp) + 27px);
        font-size: 1.6rem;
    }
}
.header-nav__sub-list-item:not(:last-child) a{
    border-bottom: solid 1px #99867a;
}
@media (any-hover: hover){
    .header-nav__sub-list-item a:hover{
        color: #fff2b3;
    }
}
.header-nav__sub-list-item a::before{
    position: absolute;
    top: calc(50% - 5px);
    left: 8px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--accent-orange);
    content: "";
}
@media screen and (max-width:768px){
    .header-nav__sub-list-item a::before{
        left: calc(var(--inner-sides_sp) + 8px);
    }
}

/* header-contact */
.header-contact{
    display: flex;
    align-items: center;
    gap: 0 15px;
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    padding-right: var(--container-sides);
}
@media screen and (max-width:768px){
    .header-contact{
        flex-direction: column;
        gap: 12px 0;
        padding: 15px 0;
        border-bottom: solid 1px #e6dcd4;
        background: var(--bg-brown);
    }
}
.header-contact-tel{
    flex: 0 0 auto;
}
.header-contact-tel img{
    display: block;
}
@media screen and (max-width:768px){
    .header-contact-tel{
        width: 240px;
    }
    .header-contact-tel img{
        width: 100%;
    }
}
.header-contact-info{
    flex: 0 0 auto;
    min-width: 175px;
    padding: 7px 15px 6px;
    border-radius: 5px;
    background: var(--bg-dark-brown);
    font-size: 1.2rem;
    line-height: calc(1em + 3px);
    letter-spacing: 0;
}
.header-contact-info-term{
    margin-bottom: 3px;
    font-weight: bold;
}
@media screen and (max-width:768px){
    .header-contact-info{
        display: flex;
        min-width: 240px;
    }
    .header-contact-info-term{
        margin-bottom: 0;
    }
}

/*-------------
footer
-------------*/
.footer{
    display: grid;
    grid-template-columns: calc(50% - 80px) 1fr;
    position: relative;
    margin-top: 100px;
    background: var(--bg-brown);
}
@media screen and (max-width:768px){
    .footer{
        display: block;
        margin-top: 80px;
    }
}
.footer-pagetop{
    position: absolute;
    top: -80px;
    right: 0;
    z-index: 1;
    width: calc(60px + var(--inner-sides));
    height: 80px;
}
.footer-pagetop-btn{
    position: absolute;
    right: var(--inner-sides);
    bottom: 20px;
    width: 60px;
    height: 60px;
    border-radius: 50%;
}
@media screen and (max-width:768px){
    .footer-pagetop{
        top: -55px;
        width: calc(40px + var(--inner-sides));
        height: 55px;
    }
    .footer-pagetop-btn{
        bottom: 15px;
        width: 40px;
        height: 40px;
    }
}
.footer-pagetop-btn._fixed{
    position: fixed;
    transition: opacity var(--ease);
}
@media screen and (max-width:768px){
    .footer-pagetop-btn._fixed{
        bottom: max(env(safe-area-inset-bottom), 15px);
    }
}
.footer-pagetop-btn:not(._show){
    opacity: 0;
    pointer-events: none;
}
.footer-pagetop-btn a{
    display: block;
    transform: rotate(45deg);
    width: 100%;
    height: 100%;
    border-radius: inherit;
    background: var(--base-brown);
}
.footer-pagetop-btn a::before,
.footer-pagetop-btn a::after{
    position: absolute;
    top: 25px;
    left: 25px;
    width: 12px;
    height: 2px;
    border-radius: 1px;
    background: #fff;
    content: "";
}
.footer-pagetop-btn a::before{
    width: 2px;
    height: 12px;
}
@media screen and (max-width:768px){
    .footer-pagetop-btn a::before,
    .footer-pagetop-btn a::after{
        top: 16px;
        left: 16px;
        width: 10px;
    }
    .footer-pagetop-btn a::before{
        width: 2px;
        height: 10px;
    }
}

/* footer-inner */
.footer-inner{
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    justify-content: center;
    min-height: 500px;
    padding: 50px 80px 40px var(--container-sides);
}
@media screen and (max-width:768px){
    .footer-inner{
        display: block;
        min-height: 0;
        padding: 30px var(--inner-sides_sp) 40px;
    }
}
.footer-logo{
    margin-bottom: 20px;
}
@media screen and (max-width:768px){
    .footer-logo{
        width: 243px;
        margin-bottom: 15px;
    }
}
.footer-support{
    margin-bottom: 17px;
}
.footer-support a{
    display: flex;
    align-items: center;
    position: relative;
    height: 80px;
    padding: 0 65px 0 87px;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
    background: #fff url(../images/footer-support_img.svg) no-repeat center left 17px / auto;
}
.footer-support a::before{
    position: absolute;
    top: calc(50% - 18px);
    right: 15px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--base-brown);
    content: "";
}
.footer-support a::after{
    position: absolute;
    top: calc(50% - 5px);
    right: 24px;
    width: 18px;
    height: 10px;
    background: var(--arrow-right);
    content: "";
}
@media screen and (max-width:768px){
    .footer-support a{
        height: auto;
        min-height: 56px;
        padding: 10px 48px 10px 60px;
        border-radius: 5px;
        background-position: center left 11px;
        background-size: auto 52px;
    }
    .footer-support a::before{
        top: calc(50% - 12px);
        right: 10px;
        width: 24px;
        height: 24px;
    }
    .footer-support a::after{
        top: calc(50% - 3px);
        right: 16px;
        width: 12px;
        height: 6px;
        background-size: auto 6px;
    }
    .footer-support img{
        display: block;
        width: min(216px, 100%);
        height: auto;
        margin: 0 auto;
    }
}
.footer-info{
    margin-bottom: 20px;
    font-size: 1.4rem;
}
@media screen and (max-width:768px){
    .footer-info{
        margin-bottom: 19px;
    }
}
.footer-info-address{
    margin-bottom: 15px;
    line-height: calc(1em + 4px);
}
@media screen and (max-width:768px){
    .footer-info-address{
        margin-bottom: 14px;
        line-height: calc(1em + 6px);
    }
}
.footer-info-tel{
    display: flex;
    flex-wrap: wrap;
    line-height: calc(1em + 6px);
}
.footer-info-tel:not(:last-child){
    margin-bottom: 4px;
}
.footer-link-list{
    display: flex;
    gap: 20px;
}
.footer-link-list a{
    display: block;
    padding: 5px 0 3px;
    border-bottom: solid 1px currentColor;
    font-size: 1.4rem;
    line-height: calc(1em + 5px);
    transition: border-color var(--ease);
}
@media (any-hover: hover){
    .footer-link-list a:hover{
        border-color: rgba(255,255,255,0);
    }
}
.footer-copy{
    display: block;
    margin-top: 58px;
    font-size: 1.2rem;
    line-height: calc(1em + 3px);
    letter-spacing: 0;
}
@media screen and (max-width:768px){
    .footer-copy{
        margin-top: 25px;
    }
}

/* footer-visual */
.footer-visual{
    position: relative;
    overflow: hidden;
    border-radius: 50px 0 0 0;
    user-select: none;
}
.footer-visual img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width:768px){
    .footer-visual{
        border-radius: 40px 0 0 0;
    }
    .footer-visual img{
        position: static;
        height: auto;
    }
}

/*-------------
button
-------------*/
.arrowBtn{
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    min-height: 60px;
    padding: 9px 60px 11px;
    border-radius: 99px;
    background: var(--accent-black);
    color: #fff;
    line-height: calc(1em + 4px);
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    transition: background var(--ease);
}
@media screen and (max-width:768px){
    .arrowBtn{
        padding: 10px 50px;
        font-size: 1.4rem;
    }
}
@media (any-hover: hover){
    .arrowBtn:hover{
        background: var(--base-brown);
    }
}
.arrowBtn::after{
    position: absolute;
    top: calc(50% - 5px);
    right: 20px;
    width: 28px;
    height: 10px;
    background: var(--arrow-right);
    content: "";
    transition: transform var(--ease);
}
@media screen and (max-width:768px){
    .arrowBtn::after{
        top: calc(50% - 4px);
        width: 20px;
        height: 8px;
    }
}
@media (any-hover: hover){
    .arrowBtn:hover::after{
        transform: translateX(5px);
    }
}
.arrowBtn[href*=".pdf"]{
    text-align: left;
}
.arrowBtn[href*=".pdf"]::before{
    flex: 0 0 auto;
    transform: translateY(1px);
    width: 24px;
    height: 24px;
    margin-right: 8px;
    background: var(--icon-pdf);
    content: "";
}
@media screen and (max-width:768px){
    .arrowBtn[href*=".pdf"]{
        justify-content: flex-start;
        padding-left: 27px;
    }
    .arrowBtn[href*=".pdf"]::before{
        transform: none;
        width: 18px;
        height: 18px;
    }
}

/*-------------
トップページ
-------------*/
@media screen and (min-width:769px){
    .toppage .header{
        height: 0;
        padding: 0;
        overflow: hidden;
    }
    .toppage .header:not(._out-top-hero) .header-nav{
        opacity: 0;
    } 
}
@media screen and (max-width:768px){
    .toppage .header{
        transition: box-shadow var(--ease);
    }
    .toppage .header:not(._out-top-hero){
        box-shadow: none;
    }
}

/* top-hero */
.top-hero{
    display: grid;
    grid-template-columns: 1fr auto;
    position: relative;
    z-index: 0;
    min-height: clamp(630px, 39.84375dvw, 100dvh);
}
@media screen and (max-width:768px){
    .top-hero{
        display: block;
        min-height: 0;
    }
}
.top-hero-visual{
    position: relative;
    user-select: none;
}
@media screen and (max-width:768px){
    .top-hero-visual{
        height: 100vw;
    }
}
.top-hero-visual__msg{
    position: absolute;
    top: 80px;
    left: max(calc(var(--container-sides) - 40px), 80px);
}
@media screen and (max-width:768px){
    .top-hero-visual__msg{
        top: 10px;
        right: var(--inner-sides_sp);
        left: auto;
        width: 152px;
    }
}
.top-hero-visual-slider{
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: calc(100% + 80px);
    height: 100%;
}
@media screen and (max-width:768px){
    .top-hero-visual-slider{
        width: 100%;
    }
}
.top-hero-visual-slide{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.top-hero-visual-slider img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: bottom right;
}
.top-hero-header{
    display: flex;
    flex-direction: column;
    position: relative;
    width: max(20dvw, 300px);
    padding-top: 30px;
    border-radius: 80px 0 0 0;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .top-hero-header{
        clip: rect(0, 0, 0, 0);
        width: 1px;
        height: 1px;
        margin: -1px;
        padding: 0;
        overflow: hidden;
    }
}
.top-hero-header::before{
    clip-path: path("M20,0C20,11.046,11.046,20,0,20v2H22V0h-2Z");
    position: absolute;
    bottom: 0;
    left: -20px;
    bottom: -2px;
    width: 22px;
    height: 22px;
    background: var(--bg-light-brown);
    content: "";
}
.top-hero-logo{
    width: 260px;
    margin: 0 auto 34px;
}
.top-hero-nav{
    padding-bottom: 20px;
}
.top-hero-nav-list{
    border-top: solid 1px var(--border-light-brown);
}
.top-hero-nav-list-item{
    position: relative;
}
.top-hero-nav-list__link{
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 1;
    min-height: 57px;
    padding: 9px 15px 11px;
    border-bottom: solid 1px var(--border-light-brown);
    font-family: var(--font-maru);
    font-size: 1.6rem;
    font-weight: bold;
    letter-spacing: 0;
    text-align: center;
}
.top-hero-nav__sub-list{
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(calc(-100% - 7px), -50%);
    min-width: 220px;
    padding: 10px 15px;
    border-radius: 10px;
    background: var(--base-dark-brown); 
    transition: opacity var(--ease), transform var(--ease);
}
.top-hero-nav__sub-list:not(._active){
    display: none;
}
.top-hero-nav__sub-list:not(._show){
    opacity: 0;
    transform: translate(-100%, -50%);
}
.top-hero-nav__sub-list::before{
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    position: absolute;
    top: calc(50% - 7px);
    right: -12px;
    width: 14px;
    height: 14px;
    background: var(--base-dark-brown);
    content: "";
}
.top-hero-nav__sub-list::after{
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    position: absolute;
    top: 0;
    right: 0;
    transform: translateX(100%);
    width: calc(max(10dvw, 150px) + 7px);
    height: 100%;
    content: "";
}
.top-hero-nav__sub-list-item a{
    display: block;
    position: relative;
    padding: 8px 6px 9px 26px;
    color: #fff;
    font-family: var(--font-maru);
    font-size: 1.6rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    letter-spacing: 0;
    white-space: nowrap;
    transition: color var(--ease);
}
.top-hero-nav__sub-list-item:not(:last-child) a{
    border-bottom: solid 1px #99867a;
}
@media (any-hover: hover){
    .top-hero-nav__sub-list-item a:hover{
        color: #fff2b3;
    }
}
.top-hero-nav__sub-list-item a::before{
    position: absolute;
    top: calc(50% - 5px);
    left: 8px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--accent-orange);
    content: "";
}

/* top-contact */
.top-contact{
    position: relative;
    z-index: 1;
    width: 1000px;
    margin: 60px auto 50px;
    overflow: hidden;
    border-radius: 5px;
}
@media screen and (max-width:768px){
    .top-contact{
        width: var(--inner-width_sp);
        margin: 40px auto 29px;
    }
}
.top-contact-title{
    padding: 8px 0 9px;
    background: var(--accent-orange);
    color: #fff;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-contact-title{
        font-size:1.8rem;
    }
}
.top-contact-list{
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 30px;
    padding: 23px 0 18px;
    background: #fff;
}
.top-contact-list::before{
    flex: 0 0 auto;
    width: 1px;
    height: 120px;
    background: var(--border-brown);
    content: "";
}
@media screen and (max-width:768px){
    .top-contact-list{
        display: block;
        padding: 12px 10px 13px;
    }
    .top-contact-list::before{
        content: none;
    }
}
.top-contact-list-item{
    flex: 0 0 auto;
    min-width: 400px;
}
.top-contact-list-item:first-child{
    order: -1;
}
@media screen and (max-width:768px){
    .top-contact-list-item{
        min-width: 0;
    }
    .top-contact-list-item:first-child{
        margin-bottom: 15px;
    }
}
.top-contact-list-title{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    margin-bottom: 7px;
    padding-bottom: 5px;
    border-bottom: dashed 1px var(--border-brown);
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 5px);
}
.top-contact-list-title::before{
    flex: 0 0 auto;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--accent-pink);
    content: "";
}
@media screen and (max-width:768px){
    .top-contact-list-title{
        margin-bottom: 10px;
        padding-bottom: 3px;
        font-size: 1.4rem;
    }
    .top-contact-list-title::before{
        width: 10px;
        height: 10px;
    }
}
.top-contact-list-title._orange::before{
    background: var(--accent-orange);
}
.top-contact-list-tel{
    text-align: center;
}
@media screen and (max-width:768px){
    .top-contact-list-tel img{
        width: auto;
        max-height: 30px;
    }
}
.top-contact-list-time{
    margin-top: 15px;
    padding: 5px 10px 6px;
    border-radius: 99px;
    background: var(--bg-brown);
    font-size: 1.3rem;
    line-height: calc(1em + 5px);
    letter-spacing: 0;
    text-align: center;
}
@media screen and (max-width:768px){
    .top-contact-list-time{
        margin-top: 8px;
        padding: 7px 10px 8px;
        border-radius: 5px;
    }
}
.top-contact-list-time-head{
    display: inline;
    font-weight: bold;
}
.top-contact-list-time-body{
    display: inline;
}
.top-contact-list-desc{
    margin-top: 2px;
    font-size: 1.3rem;
    line-height: calc(1em + 5px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-contact-list-desc{
        margin-top: 5px;
        font-size: 1.2rem;
    }
}

/* top-assist */
.top-assist{
    width: 1000px;
    margin: 50px auto 80px;
}
@media screen and (max-width:768px){
    .top-assist{
        width: var(--inner-width);
        margin: 29px auto 50px;
    }
}
.top-assist-title{
    position: relative;
    z-index: 0;
    margin-bottom: 24px;
    font-family: var(--font-maru);
    font-size: 42px;
    font-weight: bold;
    line-height: calc(1em + 18px);
    text-align: center;
}
.top-assist-title::before{
    opacity: .8;
    filter: blur(20px);
    position: absolute;
    top: -33px;
    left: 236px;
    z-index: -1;
    width: 87px;
    height: 87px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
.top-assist-title::after{
    opacity: .5;
    filter: blur(20px);
    position: absolute;
    top: 0px;
    right: 150px;
    z-index: -1;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
@media screen and (max-width:768px){
    .top-assist-title{
        font-size: 2.8rem;
        line-height: calc(1em + 12px);
    }
    .top-assist-title::before{
        filter: blur(10px);
        top: 1px;
        left: calc(50% - 120px);
        width: 40px;
        height: 40px;
    }
    .top-assist-title::after{
        filter: blur(10px);
        top: auto;
        right: calc(50% - 125px);
        bottom: -2px;
        width: 50px;
        height: 50px;
    }
}
.top-assist-lead{
    margin-bottom: 34px;
    font-size: 1.8rem;
    line-height: calc(1em + 14px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-assist-lead{
        margin-bottom: 25px;
        font-size: 1.4rem;
        line-height: calc(1em + 11px);
        text-align: left;
    }
}
.top-assist-list{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.top-assist-list-img{
    margin-bottom: 18px;
}
.top-assist-list-desc{
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-assist-list{
        grid-template-columns: calc(50% + .5px) calc(50% - .5px); 
        gap: 0;
    }
    .top-assist-list-item:not(:nth-child(-n+2)){
        padding-top: 20px;
        border-top: solid 1px var(--border-gray);
    }
    .top-assist-list-item:not(:nth-last-child(-n+2)){
        padding-bottom: 19px;
    }
    .top-assist-list-item:nth-child(odd){
        padding-right: 10px;
        border-right: solid 1px var(--border-gray);
    }
    .top-assist-list-item:nth-child(2n){
        padding-left: 10px;
    }
    .top-assist-list-img{
        margin-bottom: 8px;
    }
    .top-assist-list-desc{
        font-size: 1.5rem;
    }
}
.top-assist-btn{
    width: 440px;
    margin: 49px auto 0;
}
@media screen and (max-width:768px){
    .top-assist-btn{
        width: 100%;
        margin-top: 40px;
    }
}
@media screen and (min-width:769px){
    .top-assist-btn a{
        min-height: 70px;
    }
    .top-assist-btn a::after{
        right: 35px;
    }
}

/* top-song */
.top-song{
    position: relative;
    z-index: 0;
    margin: -80px 0;
    padding: 80px var(--container-sides);
    overflow: hidden;
}
.top-song::before{
    filter: blur(20px);
    position: absolute;
    top: 44px;
    right: calc(var(--container-side-pos) - 45px);
    z-index: -1;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
.top-song::after{
    opacity: .5;
    filter: blur(20px);
    position: absolute;
    bottom: 53px;
    left: calc(var(--container-side-pos) - 83px);
    z-index: -1;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
@media screen and (max-width:768px){
    .top-song{
        margin: -50px 0;
        padding: 50px var(--container-sides);
    }
    .top-song::before{
        filter: blur(10px);
        top: 20px;
        right: calc(var(--container-side-pos) - 34px);
    }
    .top-song::after{
        filter: blur(10px);
        bottom: 15px;
        left: calc(var(--container-side-pos) - 35px);
        width: 110px;
        height: 110px;
    }
}
.top-song-outer{
    position: relative;
    padding-left: 650px;
    border-radius: 30px;
    overflow: hidden;
    box-shadow: var(--box-shadow);
    background: #fff;
}
@media screen and (max-width:768px){
    .top-song-outer{
        padding: 0;
        border-radius: 10px;
    }
}
.top-song-inner{
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 1;
    min-height: 520px;
    padding: 60px 60px 60px 20px;
    background: linear-gradient(to right, rgba(255,255,255,0), #fff 100px, #fff);
}
@media screen and (max-width:768px){
    .top-song-inner{
        display: block;
        min-height: 0;
        padding: 25px var(--inner-sides_sp) 20px;
        background: #fff;
    }
}
.top-song-title{
    margin-bottom: 15px;
    line-height: 1;
}
.top-song-title-sub{
    display: block;
    margin-bottom: 20px;
}
@media screen and (max-width:768px){
    .top-song-title{
        margin-bottom: 16px;
    }
    .top-song-title-sub{
        width: 196px;
        margin-bottom: 9px;
    }
    .top-song-title-main{
        display: block;
        width: 138px;
    }
}
.top-song-info{
    margin-bottom: 20px;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: calc(1em + 8px);
}
@media screen and (max-width:768px){
    .top-song-info{
        margin-bottom: 10px;
        font-size: 1.4rem;
    }
}
.top-song-desc{
    font-size: 1.5rem;
    line-height: calc(1em + 12px);
}
@media screen and (max-width:768px){
    .top-song-desc{
        font-size: 1.4rem;
        line-height: calc(1em + 11px);
    }
}
.top-song-btn{
    width: min(100%, 420px);
    margin: 35px auto 0 0;
}
@media screen and (max-width:768px){
    .top-song-btn{
        width: 100%;
        margin-top: 15px;
    }
}
@media screen and (min-width:769px){
    .top-song-btn a{
        min-height: 70px;
    }
    .top-song-btn a::after{
        right: 35px;
    }
}
.top-song-visual{
    position: absolute;
    top: 0;
    left: 0;
    width: 750px;
    height: 100%;
    user-select: none;
}
.top-song-visual img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width:768px){
    .top-song-visual{
        position: relative;
        width: 100%;
        height: auto;
    }
    .top-song-visual::before{
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 50px;
        background: linear-gradient(to top, rgba(255,255,255,0), #fff);
        content: "";
    }
    .top-song-visual img{
        width: 100%;
        height: auto;
    }
}

/* top-news */
.top-news{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0 40px;
    width: var(--inner-width);
    margin: 78px auto 110px;
}
@media screen and (max-width:768px){
    .top-news{
        display: block;
        margin: 48px auto 34px;
    }
}
.top-news-title{
    grid-column: 1 / 3;
    margin-bottom: 39px;
    font-family: var(--font-maru);
    font-size: 42px;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
@media screen and (max-width:768px){
    .top-news-title{
        margin-bottom: 20px;
        font-size: 2.8rem;
    }
}
.top-news-list{
    border-top: solid 1px var(--border-brown);
}
.top-news-link{
    margin-top: 20px;
    text-align: right;
}
.top-news-link a{
    display: inline-flex;
    align-items: center;
    gap: 12px;
    position: relative;
    margin-left: auto;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
}
.top-news-link a::before{
    order: 1;
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--base-brown);
    content: "";
}
.top-news-link a::after{
    position: absolute;
    top: calc(50% - 5px);
    right: 12px;
    width: 20px;
    height: 10px;
    background: var(--arrow-right);
    content: "";
}
.top-news__fb{
    width: 450px;
    height: 400px;
    overflow: hidden;
    background: #fff;
}
@media screen and (max-width:768px){
    .top-news__fb{
        width: 100%;
        margin-top: 30px;
    }
}

/* top-support */
.top-support{
    position: relative;
    z-index: 0;
    margin: -110px 0 -80px;
    padding: 110px var(--container-sides) 80px;
    overflow: hidden;
}
.top-support::before{
    filter: blur(20px);
    position: absolute;
    top: 70px;
    left: calc(var(--container-side-pos) - 40px);
    z-index: -1;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
.top-support::after{
    filter: blur(20px);
    position: absolute;
    right: calc(var(--container-side-pos) - 40px);
    bottom: 50px;
    z-index: -1;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
@media screen and (max-width:768px){
    .top-support{
        margin: -34px 0 -40px;
        padding: 34px var(--container-sides) 40px;
    }
    .top-support::before{
        filter: blur(10px);
        top: 44px;
        left: calc(var(--container-side-pos) - 50px);
        width: 100px;
        height: 100px;
    }
    .top-support::after{
        filter: blur(10px);
        right: calc(var(--container-side-pos) - 50px);
        bottom: 10px;
        width: 100px;
        height: 100px;
    }
}
.top-support-title{
    position: relative;
    z-index: 1;
    margin-bottom: -82px;
    font-family: var(--font-maru);
    font-size: 42px;
    font-weight: bold;
    line-height: calc(1em + 18px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-support-title{
        margin-bottom: -54px;
        font-size: 2.8rem;
        line-height: calc(1em + 12px);
    }
}
.top-support-inner{
    padding: 113px 50px 48px;
    border-radius: 30px;
    box-shadow: var(--box-shadow);
    background: #fff;
}
@media screen and (max-width:768px){
    .top-support-inner{
        padding: 78px var(--inner-sides_sp) 29px;
        border-radius: 10px;
    }
}
.top-support-lead{
    margin-bottom: 45px;
    color: var(--text-brown);
    font-size: 1.6rem;
    line-height: calc(1em + 12px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-support-lead{
        margin-bottom: 20px;
        font-size: 1.4rem;
        line-height: calc(1em + 11px);
        text-align: left;
    }
}
.top-support-list{
    display: flex;
    justify-content: center;
    gap: 10px;
    width: min(100%, 920px);
    margin: 0 auto;
}
.top-support-list-item{
    flex: 1;
}
@media screen and (max-width:768px){
    .top-support-list{
        flex-wrap: wrap;
        justify-content: center;
        gap: 19px 10px;
        width: 100%;
    }
    .top-support-list-item{
        flex: 0 0 auto;
        width: calc(50% - 5px);
    }
}
.top-support-list-img{
    width: 200px;
    margin: 0 auto 16px;
}
@media screen and (max-width:768px){
    .top-support-list-img{
        width: min(100%, 150px);
        margin-bottom: 8px;
    }
}
.top-support-list-desc{
    color: var(--text-brown);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 6px);
    text-align: center;
}
@media screen and (max-width:768px){
    .top-support-list-desc{
        font-size: 1.5rem;
        line-height: calc(1em + 3px);
    }
}

/* top-link-bnr */
.top-link-bnr{
    width: 1000px;
    margin: 80px auto 0;
}
.top-link-bnr-list{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
}
@media screen and (max-width:768px){
    .top-link-bnr{
        width: var(--inner-width);
        margin-top: 40px;
    }
    .top-link-bnr-list{
        gap: 15px 10px;
    }
}

/*-------------
breadcrumbs
-------------*/
.breadcrumbs-nav{
    position: relative;
    z-index: 1;
    margin: 18px 0 30px;
}
@media screen and (max-width:768px){
    .breadcrumbs-nav{
        display: none;
    }
}
.breadcrumbs{
    display: flex;
    align-items: center;
    width: var(--inner-width);
    margin: 0 auto;
}
.breadcrumbs-item{
    flex: 0 0 auto;
    position: relative;
    min-width: 0;
    padding-bottom: 1px;
    font-size: 1.4rem;
    line-height: calc(1em + 3px);
}
.breadcrumbs-item:not(:last-child){
    margin-right: 24px;
}
.breadcrumbs-item:not(:last-child)::after{
    position: absolute;
    top: calc(50% - 4px);
    right: -16px;
    width: 6px;
    height: 8px;
    background: url(../images/breadcrumbs-arrow.svg) no-repeat center / contain;
    content: "";
}
.breadcrumbs-item:last-child{
    flex: 1 1 auto;
}
.breadcrumbs-item a{
    display: block;
    position: relative;
    color: var(--base-light-brown);
}
.breadcrumbs-item a::after{
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 1px;
    background: currentColor;
    content: "";
}
@media (any-hover: hover){
    .breadcrumbs-item a:hover::after{
        opacity: 0;
    }
}
.breadcrumbs-item__name{
    display: block;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/*-------------
pages
-------------*/
@media screen and (max-width:768px){
    .main._pages{
        padding-top: 1px;
    }
}

/* page-header */
.page-header{
    position: relative;
    z-index: 1;
    width: var(--inner-width);
    margin: 30px auto 50px;
}
@media screen and (max-width:768px){
    .page-header{
        margin: 22px auto 20px;
    }
}
.page-header-title{
    position: relative;
    padding-top: 22px;
    text-align: center;
}
@media screen and (max-width:768px){
    .page-header-title{
        padding-top: 18px;
    }
}
.page-header-title-inner{
    display: block;
    font-family: var(--font-maru);
    font-size: 45px;
    font-weight: bold;
    line-height: calc(1em + 8px);
}
@media screen and (max-width:768px){
    .page-header-title-inner{
        font-size: 30px;
    }
}
.page-header-title::before,
.page-header-title-inner::before,
.page-header-title-inner::after{
    --my-color: var(--accent-red);
    position: absolute;
    top: 0;
    left: calc(50% - 7px);
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(var(--my-color) 0, var(--my-color), var(--bg-brown) 80%);
    content: "";
}
.page-header-title-inner::before{
    --my-color: var(--accent-pink);
    left: calc(50% - 33px);
}
.page-header-title-inner::after{
    --my-color: var(--accent-orange);
    left: calc(50% + 19px);
}
@media screen and (max-width:768px){
    .page-header-title::before,
    .page-header-title-inner::before,
    .page-header-title-inner::after{
        left: calc(50% - 6px);
        width: 12px;
        height: 12px;
    }
    .page-header-title-inner::before{
        left: calc(50% - 26px);
    }
    .page-header-title-inner::after{
        left: calc(50% + 14px);
    }
}
.page-header-title[data-en]::after{
    display: block;
    margin-top: 10px;
    color: var(--accent-pink);
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 5px);
    content: attr(data-en);
}
@media screen and (max-width:768px){
    .page-header-title[data-en]::after{
        margin-top: 4px;
        font-size: 1.4rem;
    }
}
.page-header._in-subtitle .page-header-title{
    padding-top: 0;
}
.page-header._in-subtitle .page-header-title::before,
.page-header._in-subtitle .page-header-title-inner::before,
.page-header._in-subtitle .page-header-title-inner::after{
    content: none;
}
.page-header-subtitle{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 9px;
}
@media screen and (max-width:768px){
    .page-header-subtitle{
        margin-bottom: 4px;
    }
}
.page-header-subtitle-inner{
    display: block;
    position: relative;
    z-index: 0;
    min-width: 220px;
    padding: 8px 25px 9px;
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
.page-header-subtitle-inner::before{
    filter: blur(5px);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    border-radius: 99px;
    background: var(--bg-orange);
    content: "";
}
@media screen and (max-width:768px){
    .page-header-subtitle-inner{
        min-width: 150px;
        padding: 5px 25px 6px;
        font-size: 1.4rem;
    }
    .page-header-subtitle-inner::before{
        filter: blur(4px);
    }
}

/* page-contents */
.page-contents-outer{
    position: relative;
    z-index: 0;
    padding: 90px var(--container-sides) 70px;
    margin: -90px 0 -70px;
    overflow: hidden;
}
.page-contents-outer::before{
    filter: blur(20px);
    position: absolute;
    top: 50px;
    left: calc(var(--container-side-pos) - 40px);
    z-index: -1;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
.page-contents-outer::after{
    filter: blur(20px);
    position: absolute;
    right: calc(var(--container-side-pos) - 40px);
    bottom: 50px;
    z-index: -1;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
@media screen and (max-width:768px){
    .page-contents-outer{
        padding: 50px 0;
        margin: -50px 0;
    }
    .page-contents-outer::before{
        filter: blur(10px);
        top: 20px;
        left: calc(var(--container-side-pos) - 30px);
        width: 100px;
        height: 100px;
    }
    .page-contents-outer::after{
        filter: blur(10px);
        right: calc(var(--container-side-pos) - 30px);
        bottom: 20px;
        width: 100px;
        height: 100px;
    }
}
:where(.page-contents){
    padding: 60px 100px;
    overflow: hidden;
    border-radius: 30px;
    box-shadow: var(--box-shadow);
    background: #fff;
}
@media screen and (max-width:768px){
    :where(.page-contents){
        padding: 25px var(--inner-sides_sp) 50px;
        border-radius: 0;
    }
}
:where(.page-contents > *:first-child),
:where(.page-contents > *:first-child) *:first-child{
    margin-top: 0;
}

/* page-sect */
:where(.page-sect-h):not(:first-child){
    margin-top: 80px;
}
:where(.page-sect-h):not(:last-child){
    margin-bottom: 80px;
}
@media screen and (max-width:768px){
    :where(.page-sect-h):not(:first-child){
        margin-top: 40px;
    }
    :where(.page-sect-h):not(:last-child){
        margin-bottom: 40px;
    }
}
:where(.page-sect-m):not(:first-child){
    margin-top: 40px;
}
:where(.page-sect-m):not(:last-child){
    margin-bottom: 40px;
}
@media screen and (max-width:768px){
    :where(.page-sect-m):not(:first-child){
        margin-top: 35px;
    }
    :where(.page-sect-m):not(:last-child){
        margin-bottom: 35px;
    }
}

/* sect-title */
:where(.sect-title-l){
    position: relative;
    margin: -4px 0 23px;
    padding: 0 0 18px 25px;
    border-bottom: solid 1px var(--border-brown);
    font-family: var(--font-maru);
    font-size: 36px;
    font-weight: bold;
    line-height: calc(1em + 6px);
}
:where(.sect-title-l)::before{
    position: absolute;
    top: 8px;
    left: 0;
    width: 6px;
    height: calc(100% - 28px);
    border-radius: 3px;
    background: var(--accent-pink);
    content: "";
}
@media screen and (max-width:768px){
    :where(.sect-title-l){
        margin: -3px 0 19px;
        padding: 0 0 11px 12px;
        font-size: 2.4rem;
    }
    :where(.sect-title-l)::before{
        top: 4px;
        width: 4px;
        height: calc(100% - 19px);
    }
}

/* sect-title-m */
:where(.sect-title-m){
    position: relative;
    margin: -4px 0 18px;
    padding-left: 28px;
    font-family: var(--font-maru);
    font-size: 2.8rem;
    font-weight: bold;
    line-height: calc(1em + 6px);
}
:where(.sect-title-m)::before{
    position: absolute;
    top: calc(.5em - 5px);
    left: 0;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--accent-orange);
    content: "";
}
@media screen and (max-width:768px){
    :where(.sect-title-m){
        margin: -3px 0 12px;
        padding-left: 20px;
        font-size: 2.2rem;
    }
    :where(.sect-title-m)::before{
        top: calc(.5em - 4px);
        width: 14px;
        height: 14px;
    }
}

/* sect-title-s */
:where(.sect-title-s){
    position: relative;
    margin: -4px 0 13px;
    padding-bottom: 8px;
    border-bottom: solid 1px var(--border-brown);
    font-family: var(--font-maru);
    font-size: 2rem;
    font-weight: bold;
    line-height: calc(1em + 6px);
}
:where(.sect-title-s)::after{
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 60px;
    height: 1px;
    background: var(--accent-pink);
    content: "";
}
@media screen and (max-width:768px){
    :where(.sect-title-s){
        margin: -3px 0 14px;
        padding-bottom: 7px;
        font-size: 1.8rem;
    }
}

/*-------------
news-list-item
-------------*/
.news-list-item a{
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: center;
    min-height: 69px;
    padding: 20px 15px 20px 10px;
    border-bottom: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .news-list-item a{
        display: block;
        min-height: 0;
        padding: 14px 0 11px;
    }
}
.news-list-head{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    align-items: center;
    gap: 0 20px;
    margin-right: 15px;
}
@media screen and (max-width:768px){
    .news-list-head{
        display: flex;
        gap: 0 5px;
        margin: 0 0 4px;
    }
}
.news-list-date{
    font-size: 1.6rem;
    line-height: 1;
    letter-spacing: 0;
}
@media screen and (max-width:768px){
    .news-list-date{
        font-size: 1.3rem;
    }
}
.news-list-cate{
    min-width: 100px;
    padding: 5px 15px 6px;
    border-radius: 99px;
    background: var(--accent-light-green);
    color: #fff;
    font-size: 1.4rem;
    line-height: calc(1em + 3px);
    letter-spacing: 0;
    text-align: center;
}
@media screen and (max-width:768px){
    .news-list-cate{
        min-width: 80px;
        padding: 4px 10px 5px;
        font-size: 1.3rem;
    }
}
.news-list-cate._id2{
    background: var(--accent-dark-green);
}
.news-list-title{
    margin-top: -2px;
    font-size: 1.6rem;
    line-height: calc(1em + 8px);
}
@media screen and (max-width:768px){
    .news-list-title{
        margin-top: 0;
        font-size: 1.5rem;
        line-height: calc(1em + 7px);
    }
}
@media (any-hover: hover){
    a:hover .news-list-title{
        text-decoration: underline;
    }
}

/*-------------
news
-------------*/
.news-layout{
    display: grid;
    grid-template-columns: 800px 1fr;
    gap: 0 40px;
}
@media screen and (min-width:769px){
    .news-layout{
        padding: 60px;
    }
}
@media screen and (max-width:768px){
    .news-layout{
        grid-template-columns: 100%;
        gap: 35px 0;
    }
}
.news-layout-main .sect-title-l{
    margin-bottom: 10px;
}
@media screen and (max-width:768px){
    .news-layout-main .sect-title-l{
        margin-bottom: 0;
    }
}

/* news-pager */
.news-pager{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0 20px;
    margin-top: 30px;
}
@media screen and (max-width:768px){
    .news-pager{
        justify-content: space-between;
        gap: 0;
        margin-top: 20px;
    }
}
.blog-pager-arrow{
    flex: 0 0 auto;
}
@media screen and (max-width:360px){
    .blog-pager-arrow{
        display: none;
    }
}
.blog-pager-arrow._next{
    order: 1;
}
.blog-pager-arrow a{
    display: block;
    position: relative;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--base-brown);
}
.blog-pager-arrow a::before{
    position: absolute;
    top: calc(50% - 5px);
    right: 16px;
    width: 18px;
    height: 10px;
    background: var(--arrow-right);
    content: "";
}
@media screen and (max-width:768px){
    .blog-pager-arrow a{
        width: 44px;
        height: 44px;
    }
    .blog-pager-arrow a::before{
        top: calc(50% - 4px);
        right: 12px;
        width: 20px;
        height: 8px;
    }
}
.blog-pager-arrow._prev a::before{
    transform: rotate(180deg);
}
.news-pager-list{
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 10px;
}
@media screen and (max-width:768px){
    .news-pager-list{
        gap: 2px;
    }
    .news-pager-list:only-child{
        margin: 0 auto;
    }
}
.news-pager-list-item a{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    padding-bottom: 2px;
    border-radius: 50%;
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1;
    transition: background var(--ease);
}
@media screen and (max-width:768px){
    .news-pager-list-item a{
        width: 44px;
        height: 44px;
        padding-bottom: 0;
        font-size: 1.6rem;
    }
}
@media (any-hover: hover){
    .news-pager-list-item a:not(._current):hover{
        background: var(--bg-dark-brown);
    }
}
.news-pager-list-item a._current{
    background: var(--accent-orange);
    color: #fff;
    pointer-events: none;
}
.news-pager-list._last::before,
.news-pager-list._middle::before,
.news-pager-list._first::after,
.news-pager-list._middle::after{
    display: block;
    flex: 0 0 auto;
    font-size: 14px;
    text-align: center;
    content: "…";
}
@media screen and (max-width:768px){
    .news-pager-list._last::before,
    .news-pager-list._middle::before,
    .news-pager-list._first::after,
    .news-pager-list._middle::after{
        margin: 0 -2px;
        font-size: 12px;
    }
}
.news-pager-list._last .news-pager-list-item:first-child,
.news-pager-list._middle .news-pager-list-item:first-child{
    order: -1;
}
.news-pager-list._first .news-pager-list-item:last-child,
.news-pager-list._middle .news-pager-list-item:last-child{
    order: 1;
}

/* news-sidenav */
.news-sidenav{
    border-radius: 8px;
    overflow: hidden;
}
.news-sidenav:not(:last-child){
    margin-bottom: 20px;
}
@media screen and (max-width:768px){
    .news-sidenav{
        border-radius: 5px;
    }
    .news-sidenav:not(:last-child){
        margin-bottom: 15px;
    }
}
.news-sidenav-title{
    padding: 10px 20px 11px;
    background: var(--base-dark-brown);
    color: #fff;
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
@media screen and (max-width:768px){
    .news-sidenav-title{
        padding: 10px 15px 11px;
    }
}
.news-sidenav-list{
    padding: 15px 20px 18px;
    background: var(--bg-brown);
}
@media screen and (max-width:768px){
    .news-sidenav-list{
        padding: 10px 15px 13px;
    }
}
.news-sidenav-list-item:not(:last-child){
    margin-bottom: 3px;
}
.news-sidenav-list-item a{
    display: block;
    position: relative;
    padding: 2px 0 3px 20px;
    font-size: 1.5rem;
    line-height: calc(1em + 5px);
    text-decoration: underline;
    text-underline-offset: 4px;
}
@media (any-hover: hover){
    .news-sidenav-list-item a:hover{
        text-decoration: none;
    }
}
.news-sidenav-list-item a::before{
    position: absolute;
    top: calc(.5em + 1px);
    left: 3px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--accent-orange);
    content: "";
}

/*-------------
news-dtl
-------------*/
.news-dtl-head{
    margin-bottom: 33px;
    padding-bottom: 20px;
    border-bottom: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .news-dtl-head{
        margin-bottom: 19px;
        padding-bottom: 14px;
    }
}
.news-dtl-head-info{
    display: flex;
    align-items: center;
    gap: 0 10px;
    margin-bottom: 8px;
}
@media screen and (max-width:768px){
    .news-dtl-head-info{
        gap: 0 8px;
    }
}
.news-dtl-head-cate{
    flex: 0 0 auto;
    padding: 4px 17px 5px;
    border-radius: 99px;
    background: var(--accent-light-green);
    color: #fff;
    font-size: 1.6rem;
    line-height: calc(1em + 3px);
}
@media screen and (max-width:768px){
    .news-dtl-head-cate{
        font-size: 1.3rem;
    }
}
.news-dtl-head-cate._id2{
    background: var(--accent-dark-green);
}
.news-dtl-head-date{
    font-size: 1.6rem;
    line-height: 1;
}
@media screen and (max-width:768px){
    .news-dtl-head-date{
        font-size: 1.5rem;
    }
}
.news-dtl-head-title{
    font-family: var(--font-maru);
    font-size: 40px;
    font-weight: bold;
    line-height: calc(1em + 12px);
}
@media screen and (max-width:768px){
    .news-dtl-head-title{
        font-size: 2.5rem;
    }
}

/* news-back */
.news-back{
    margin-top: 40px;
    padding-top: 40px;
    border-top: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .news-back{
        padding-top: 30px;
    }
}
.news-back-btn{
    width: 400px;
    margin: 0 auto;
}
@media screen and (max-width:768px){
    .news-back-btn{
        width: 100%;
    }
}
.news-back-btn a::after{
    right: auto;
    left: 20px;
    transform: rotate(180deg);
}
@media (any-hover: hover){
    .news-back-btn a:hover::after{
        transform: rotate(180deg) translateX(5px);
    }
}

/*-------------
about
-------------*/
.about-history-table{
    width: 100%;
    margin-top: 30px;
    border: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .about-history-table{
        display: block;
        margin-top: 25px;
    }
}
@media screen and (min-width:769px){
    .about-history-table tr:not(:last-child){
        border-bottom: solid 1px var(--border-brown);
    }   
}
@media screen and (max-width:768px){
    .about-history-table tr{
        display: block;
        width: 100%;
    }
}
.about-history-table :is(th, td){
    padding: 11px 15px 12px;
    line-height: calc(1em + 7px);
}
.about-history-table th{
    width: 140px;
    background: var(--base-light-brown);
    color: #fff;
    font-weight: bold;
}
@media screen and (max-width:768px){
    .about-history-table :is(th, td){
        display: block;
        width: 100%;
        padding: 10px 9px 11px;
        line-height: calc(1em + 7px);
    }
    .about-history-table th{
        padding: 8px 9px 9px;
    }
}

/* about-chart */
.about-chart{
    margin-top: 30px;
    padding: 30px;
    border-radius: 5px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .about-chart{
        margin-top: 25px;
        padding: 10px;
    }
}
.about-chart img{
    display: block;
    margin: 0 auto;
}

/* about-pdf */
.about-pdf-block{
    overflow: hidden;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.about-pdf-block:not(:last-child){
    margin-bottom: 10px;
}
@media screen and (max-width:768px){
    .about-pdf-block{
        border-radius: 5px;
    }
    .about-pdf-block:not(:last-child){
        margin-bottom: 5px;
    }
}
.about-pdf-block-head{
    position: relative;
    padding: 16px 58px 17px 20px;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
.about-pdf-block-head::after{
    position: absolute;
    top: calc(50% - 14px);
    right: 20px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    linear-gradient(to top, #fff, #fff) no-repeat center / 12px 2px, 
    var(--accent-orange);
    content: "";
    transition: transform var(--ease);
}
.about-pdf-block-head._active::after{
    transform: rotate(90deg);
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    var(--accent-orange);
}
@media screen and (max-width:768px){
    .about-pdf-block-head{
        padding: 12px 40px 13px 14px;
        font-size: 1.8rem;
    }
    .about-pdf-block-head::after{
        top: calc(50% - 10px);
        right: 10px;
        width: 20px;
        height: 20px;
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        linear-gradient(to top, #fff, #fff) no-repeat center / 8px 2px, 
        var(--accent-orange);
    }
    .about-pdf-block-head._active::after{
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        var(--accent-orange);
    }
}
.about-pdf-block-list{
    padding: 20px;
    border-top: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .about-pdf-block-list{
        padding: 10px 14px;
    }
}
.about-pdf-block-list-item:not(:last-child){
    margin-bottom: 5px;
}
.about-pdf-block-list-item a{
    display: flex;
    align-items: center;
    position: relative;
    min-height: 50px;
    padding: 7px 19px 10px 43px;
    border: solid 1px var(--border-brown);
    border-radius: 5px;
    background: #fff;
    line-height: calc(1em + 4px);
}
@media screen and (max-width:768px){
    .about-pdf-block-list-item a{
        min-height: 40px;
        padding: 7px 10px 9px 30px;
    }
}
@media (any-hover: hover){
    .about-pdf-block-list-item a:hover{
        text-decoration: underline;
    }
}
.about-pdf-block-list-item a::before{
    position: absolute;
    top: calc(50% - 12px);
    left: 14px;
    width: 24px;
    height: 24px;
    background: var(--icon-pdf);
    content: "";
}
@media screen and (max-width:768px){
    .about-pdf-block-list-item a::before{
        top: calc(50% - 9px);
        left: 10px;
        width: 18px;
        height: 18px;
    }
}

/*-------------
activities
-------------*/
.activ-list{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 30px;
}
.activ-list-item{
    padding: 30px 30px 25px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .activ-list{
        grid-template-columns: 100%;
        margin-top: 25px;
    }
    .activ-list-item{
        padding: 20px var(--inner-sides_sp) 15px;
        border-radius: 5px;
    }
}

/*-------------
report
-------------*/
.report-list-sect{
    overflow: hidden;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.report-list-sect:not(:last-child){
    margin-bottom: 10px;
}
@media screen and (max-width:768px){
    .report-list-sect{
        border-radius: 5px;
    }
    .report-list-sect:not(:last-child){
        margin-bottom: 5px;
    }
}
.report-list-sect-title{
    position: relative;
    padding: 16px 58px 17px 20px;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
.report-list-sect-title::after{
    position: absolute;
    top: calc(50% - 14px);
    right: 20px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    linear-gradient(to top, #fff, #fff) no-repeat center / 12px 2px, 
    var(--accent-orange);
    content: "";
    transition: transform var(--ease);
}
.report-list-sect-title._active::after{
    transform: rotate(90deg);
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    var(--accent-orange);
}
@media screen and (max-width:768px){
    .report-list-sect-title{
        padding: 11px 40px 12px 14px;
        font-size: 1.8rem;
    }
    .report-list-sect-title::after{
        top: calc(50% - 10px);
        right: 10px;
        width: 20px;
        height: 20px;
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        linear-gradient(to top, #fff, #fff) no-repeat center / 8px 2px, 
        var(--accent-orange);
    }
    .report-list-sect-title._active::after{
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        var(--accent-orange);
    }
}
.report-list{
    display: grid;
    grid-template-columns: auto 1fr;
    padding: 21px 20px 17px;
    border-top: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .report-list{
        display: block;
        padding: 10px 14px 12px;
    }
}
.report-list-item{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    align-items: center;
    gap: 0 15px;
    padding: 0 5px;
}
.report-list-item:not(:last-child){
    margin-bottom: 11px;
    padding-bottom: 12px;
    border-bottom: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .report-list-item{
        display: block;
        padding: 0;
    }
    .report-list-item:not(:last-child){
        margin-bottom: 14px;
    }
}
.report-list-date{
    min-width: 80px;
    color: var(--accent-orange);
    font-size: 1.4rem;
    line-height: calc(1em + 1px);
}
@media screen and (max-width:768px){
    .report-list-date{
        min-width: 0;
        margin-bottom: 6px;
        font-size: 1.3rem;
    }
}
.report-list-body *{
    line-height: calc(1em + 7px);
}
.report-list-title{
    font-size: 1.6rem;
    font-weight: bold;
}
.report-list-desc{
    margin-top: 3px;
    color: var(--text-brown);
}
@media screen and (max-width:768px){
    .report-list-title{
        font-size: 1.4rem;
    }
    .report-list-desc{
        font-size: 1.3rem;
    }
}

/*-------------
guide
-------------*/
:where(.guide-page .page-contents) p:not(:last-child){
    margin-bottom: 12px;
}
@media screen and (max-width:768px){
    :where(.guide-page .page-contents) p:not(:last-child){
        margin-bottom: 14px;
    }
}

/* guide-catch */
.guide-catch{
    position: relative;
    z-index: 0;
    margin: -10px 0 -8px;
    font-family: var(--font-maru);
    font-size: 42px;
    font-weight: bold;
    line-height: calc(1em + 18px);
    text-align: center;
}
@media screen and (max-width:768px){
    .guide-catch{
        margin: -6px 0;
        font-size: min(30px, 2.8rem);
        line-height: calc(1em + 12px);
    }
}
.guide-catch::before{
    opacity: .8;
    filter: blur(20px);
    position: absolute;
    top: -14px;
    left: 275px;
    z-index: -1;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
@media screen and (max-width:768px){
    .guide-catch::before{
        filter: blur(10px);
        top: 1px;
        left: calc(50% - 128px);
        width: 40px;
        height: 40px;
    }
}
.guide-catch::after{
    opacity: .5;
    filter: blur(20px);
    position: absolute;
    right: 175px;
    bottom: -7px;
    z-index: -1;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
@media screen and (max-width:768px){
    .guide-catch::after{
        filter: blur(10px);
        right: calc(50% - 220px);
        bottom: -8px;
        width: 50px;
        height: 50px;
    }
}
@media screen and (max-width:430px){
    .guide-catch::after{
        right: calc(50% - 120px);
    }
}

/* guide-cases */
.guide-cases{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px 0;
    margin-top: 25px;
}
@media screen and (max-width:768px){
    .guide-cases{
        grid-template-columns: 100%;
        margin-top: 15px;
    }
}
.guide-cases-item{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    align-items: center;
    gap: 0 20px;
    padding: 15px 20px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .guide-cases-item{
        display: block;
        padding: 10px;
        border-radius: 5px;
    }
}
.guide-cases-title{
    min-width: 200px;
    margin-bottom: 1px;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
@media screen and (max-width:768px){
    .guide-cases-title{
        min-width: 0;
        margin-bottom: 11px;
        font-size: 2rem;
    }
}
.guide-cases-list{
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.guide-cases-list-item{
    padding: 7px 15px 9px;
    border-radius: 5px;
    background: var(--bg-dark-brown);
    font-size: 1.6rem;
    line-height: calc(1em + 4px);
    text-align: center;
}
@media screen and (max-width:768px){
    .guide-cases-list{
        gap: 4px;
    }
    .guide-cases-list-item{
        flex: 1 1 auto;
        min-width: calc(50% - 2px);
        padding: 6px 10px;
        border-radius: 4px;
        font-size: 1.4rem;
    }
}

/* guide-assist */
.guide-assist{
    margin-top: 25px;
    padding: 32px 40px 40px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .guide-assist{
        margin-top: 20px;
        padding: 14px 20px 20px;
        border-radius: 5px;
    }
}
.guide-assist-list{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0 20px;
    margin-top: 35px;
}
@media screen and (max-width:768px){
    .guide-assist-list{
        grid-template-columns: repeat(2, calc(50% - 5px));
        gap: 13px 10px;
        margin-top: 15px;
    }
}
.guide-assist-list-img{
    width: 100%;
    aspect-ratio: 1 / 1;
    margin-bottom: 7px;
    overflow: hidden;
    border-radius: 50%;
    background: #fff;
}
@media screen and (max-width:768px){
    .guide-assist-list-img{
        margin-bottom: 3px;
        padding: 5px;
    }
}
.guide-assist-list-img img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.guide-assist-list-desc{
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 4px);
    text-align: center;
}
@media screen and (max-width:768px){
    .guide-assist-list-desc{
        font-size: 1.4rem;
    }
}
.guide-assist-btn{
    width: 440px;
    margin: 29px auto 0;
}
@media screen and (max-width:768px){
    .guide-assist-btn{
        width: 100%;
        margin-top: 18px;
    }
}

/*-------------
assist
-------------*/
.assist-tel{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 25px;
    overflow: hidden;
    border-radius: 5px;
    background: var(--bg-gray);
}
.assist-tel-body{
    padding: 23px 0 25px;
}
@media screen and (max-width:768px){
    .assist-tel{
        margin-top: 20px;
    }
    .assist-tel-body{
        padding: 12px 10px 15px;
    }
}
.assist-tel-title{
    flex: 0 0 auto;
    width: 100%;
    padding: 8px 0 9px;
    background: var(--accent-orange);
    color: #fff;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
@media screen and (max-width:768px){
    .assist-tel-title{
        font-size:1.8rem;
    }
}
.assist-tel-mid-title{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    margin-bottom: 7px;
    padding-bottom: 5px;
    border-bottom: dashed 1px var(--border-brown);
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 5px);
}
.assist-tel-mid-title::before{
    flex: 0 0 auto;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--accent-pink);
    content: "";
}
@media screen and (max-width:768px){
    .assist-tel-mid-title{
        margin-bottom: 10px;
        padding-bottom: 3px;
        font-size: 1.4rem;
    }
    .assist-tel-mid-title::before{
        width: 10px;
        height: 10px;
    }
}
.assist-tel-mid-title._orange::before{
    background: var(--accent-orange);
}
.assist-tel-num{
    text-align: center;
}
@media screen and (max-width:768px){
    .assist-tel-num img{
        width: auto;
        max-height: 30px;
    }
}
.assist-tel-time{
    margin: 15px auto 0;
    padding: 5px 25px 6px;
    border-radius: 99px;
    background: var(--bg-brown);
    line-height: calc(1em + 5px);
    letter-spacing: 0;
    text-align: center;
}
@media screen and (max-width:768px){
    .assist-tel-time{
        padding: 7px 10px 8px;
        border-radius: 5px;
        font-size: 1.3rem;
    }
}
.assist-tel-time-head{
    display: inline;
    font-weight: bold;
}
.assist-tel-time-body{
    display: inline;
}
.assist-tel-btn{
    width: 380px;
    margin: 20px auto 0;
}
@media screen and (max-width:768px){
    .assist-tel-btn{
        width: 100%;
        margin-top: 15px;
    }
}

/* assist-types */
.assist-types{
    display: flex;
    gap: 10px;
    margin-top: 25px;
}
@media screen and (max-width:768px){
    .assist-types{
        flex-direction: column;
        margin-top: 20px;
    }
}
.assist-types-item{
    flex: 1;
    padding: 30px 30px 25px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .assist-types-item{
        padding: 20px var(--inner-sides_sp) 20px;
        border-radius: 5px;
    }
}
.assist-types-img{
    float: right;
    width: 100px;
    margin-left: 5px;
}
@media screen and (max-width:768px){
    .assist-types-img{
        margin-left: 10px;
    }
}
.assist-types-list{
    display: grid;
    grid-template-columns: auto 1fr;
}
.assist-types-list-item{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
}
@media screen and (max-width:768px){
    .assist-types-list,
    .assist-types-list-item{
        display: block;
    }
}
.assist-types-list-head{
    text-align-last: justify;
}
.assist-types-list-item:has(.__more){
    position: relative;
}
.assist-types-list-body:has(.__more)::after{
    display: inline-block;
    content: "　　";
}
.assist-types-list-body .__more{
    position: absolute;
    right: 0;
    bottom: 0;
}

/* assist-group */
.assist-group{
    display: flex;
    align-items: flex-start;
    gap: 0 30px;
}
.assist-group-img{
    flex: 0 0 auto;
    width: 220px;
    margin-top: 5px;
}
@media screen and (max-width:768px){
    .assist-group{
        display: block;
    }
    .assist-group-img{
        width: 100%;
        height: 152px;
        margin: 0 0 19px;
    }
    .assist-group-img img{
        display: block;
        width: auto;
        height: 100%;
        margin: 0 auto;
    }
}

/* assist-link-list */
.assist-link-list{
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 30px;
}
.assist-link-list-item{
    flex: 0 0 auto;
    width: min(calc(50% - 5px), 440px);
}
@media screen and (max-width:768px){
    .assist-link-list{
        flex-direction: column;
        margin-top: 25px;
    }
    .assist-link-list-item{
        width: 100%;
    }
}

/*-------------
help-desk
-------------*/
.helpdesk-tel{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 25px;
    overflow: hidden;
    border-radius: 5px;
    background: var(--bg-gray);
}
.helpdesk-tel-body{
    padding: 23px 0 25px;
}
@media screen and (max-width:768px){
    .helpdesk-tel{
        margin-top: 20px;
    }
    .helpdesk-tel-body{
        padding: 12px 10px 15px;
    }
}
.helpdesk-tel-title{
    flex: 0 0 auto;
    width: 100%;
    padding: 8px 0 9px;
    background: var(--accent-orange);
    color: #fff;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
    text-align: center;
}
@media screen and (max-width:768px){
    .helpdesk-tel-title{
        font-size:1.8rem;
    }
}
.helpdesk-tel-list{
    display: flex;
    justify-content: center;
    gap: 30px;
}
.helpdesk-tel-list::before{
    flex: 0 0 auto;
    width: 1px;
    background: var(--border-brown);
    content: "";
}
@media screen and (max-width:768px){
    .helpdesk-tel-list{
        display: block;
    }
    .helpdesk-tel-list::before{
        content: none;
    }
}
.helpdesk-tel-list-item{
    flex: 0 0 auto;
    min-width: 380px;
}
.helpdesk-tel-list-item:first-child{
    order: -1;
}
@media screen and (max-width:768px){
    .helpdesk-tel-list-item{
        min-width: 0;
    }
    .helpdesk-tel-list-item:first-child{
        margin-bottom: 15px;
    }
}
.helpdesk-tel-list-title{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    margin-bottom: 7px;
    padding-bottom: 5px;
    border-bottom: dashed 1px var(--border-brown);
    font-family: var(--font-maru);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 5px);
}
.helpdesk-tel-list-title::before{
    flex: 0 0 auto;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--accent-pink);
    content: "";
}
@media screen and (max-width:768px){
    .helpdesk-tel-list-title{
        margin-bottom: 10px;
        padding-bottom: 3px;
        font-size: 1.4rem;
    }
    .helpdesk-tel-list-title::before{
        width: 10px;
        height: 10px;
    }
}
.helpdesk-tel-list-title._orange::before{
    background: var(--accent-orange);
}
.helpdesk-tel-list-num{
    text-align: center;
}
@media screen and (max-width:768px){
    .helpdesk-tel-list-num img{
        width: auto;
        max-height: 30px;
    }
}
.helpdesk-tel-time{
    margin: 15px auto 0;
    padding: 5px 10px 6px;
    border-radius: 99px;
    background: var(--bg-brown);
    line-height: calc(1em + 5px);
    letter-spacing: 0;
    text-align: center;
}
@media screen and (max-width:768px){
    .helpdesk-tel-time{
        padding: 7px 10px 8px;
        border-radius: 5px;
        font-size: 1.3rem;
    }
}
.helpdesk-tel-time-head{
    display: inline;
    font-weight: bold;
}
.helpdesk-tel-time-body{
    display: inline;
}
.helpdesk-tel-btn{
    width: 380px;
    margin: 20px auto 0;
}
@media screen and (max-width:768px){
    .helpdesk-tel-btn{
        width: 100%;
        margin-top: 15px;
    }
}
.helpdesk-fax-btn{
    margin-top: 25px;
}
@media screen and (max-width:768px){
    .helpdesk-fax-btn{
        margin-top: 20px;
    }
}

/*-------------
referrals
-------------*/
.refer-list-sect{
    overflow: hidden;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.refer-list-sect:not(:last-child){
    margin-bottom: 10px;
}
@media screen and (max-width:768px){
    .refer-list-sect{
        border-radius: 5px;
    }
    .refer-list-sect:not(:last-child){
        margin-bottom: 5px;
    }
}
.refer-list-sect-title{
    position: relative;
    padding: 16px 58px 17px 20px;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
.refer-list-sect-title::after{
    position: absolute;
    top: calc(50% - 14px);
    right: 20px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    linear-gradient(to top, #fff, #fff) no-repeat center / 12px 2px, 
    var(--accent-orange);
    content: "";
    transition: transform var(--ease);
}
.refer-list-sect-title._active::after{
    transform: rotate(90deg);
    background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 12px, 
    var(--accent-orange);
}
@media screen and (max-width:768px){
    .refer-list-sect-title{
        padding: 11px 40px 12px 14px;
        font-size: 1.8rem;
    }
    .refer-list-sect-title::after{
        top: calc(50% - 10px);
        right: 10px;
        width: 20px;
        height: 20px;
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        linear-gradient(to top, #fff, #fff) no-repeat center / 8px 2px, 
        var(--accent-orange);
    }
    .refer-list-sect-title._active::after{
        background: linear-gradient(to right, #fff, #fff) no-repeat center / 2px 8px, 
        var(--accent-orange);
    }
}
.refer-list{
    padding: 27px 20px;
    border-top: solid 1px var(--border-brown);
}
.refer-list-item{
    padding: 0 10px;
}
@media screen and (max-width:768px){
    .refer-list{
        padding: 23px 14px 17px;
    }
    .refer-list-item{
        padding: 0;
    }
}
.refer-list-item:not(:last-child){
    margin-bottom: 22px;
    padding-bottom: 22px;
    border-bottom: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .refer-list-item:not(:last-child){
        margin-bottom: 18px;
        padding-bottom: 17px;
    }
}
.refer-list-title{
    font-family: var(--font-maru);
    font-size: 2rem;
    font-weight: bold;
    line-height: calc(1em + 4px);
}
.refer-list-title a{
    display: inline-block;
    position: relative;
    margin: -5px 0;
    padding: 5px 0 5px 25px;
    text-decoration: underline;
    text-decoration-thickness: 1px;
}
.refer-list-title a::before{
    position: absolute;
    top: calc(.5em - 2px);
    left: 0;
    transform: rotate(45deg);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: linear-gradient(to top, #fff, #fff) no-repeat top 8px left 6px / 6px 2px, 
    linear-gradient(to right, #fff, #fff) no-repeat top 8px left 10px / 2px 6px, 
    var(--accent-green);
    content: "";
}
@media screen and (max-width:768px){
    .refer-list-title{
        font-size: 1.8rem;
    }
    .refer-list-title a{
        padding-left: 23px;
    }
    .refer-list-title a::before{
        top: calc(.5em - 2px);
        width: 18px;
        height: 18px;
        background: linear-gradient(to top, #fff, #fff) no-repeat top 7px left 5px / 6px 2px, 
        linear-gradient(to right, #fff, #fff) no-repeat top 7px left 9px / 2px 6px, 
        var(--accent-green);
    }
}
@media (any-hover: hover){
    .refer-list-title a:hover{
        text-decoration: none;
    }
}
.refer-list-desc{
    margin-top: 10px;
    line-height: calc(1em + 7px);
}
@media screen and (max-width:768px){
    .refer-list-desc{
        margin-top: 9px;
    }
}

/*-------------
referrals/city
-------------*/
.refer-city-title{
    margin-bottom: 8px;
    font-family: var(--font-maru);
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(1em + 1px);
}
@media screen and (max-width:768px){
    .refer-city-title{
        margin-bottom: 9px;
        font-size: 1.8rem;
    }
}
.refer-city-list{
    display: grid;
    grid-template-columns: auto auto 1fr;
    margin-top: 20px;
    border-right: solid 1px var(--border-brown);
}
.refer-city-list-item{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 3;
}
@media screen and (max-width:768px){
    .refer-city-list{
        grid-template-columns: auto 1fr;
        margin-top: 15px;
    }
    .refer-city-list-item{
        grid-column: span 2;
    }
}
.refer-city-list-item:first-child :where(.refer-city-list-head, .refer-city-list-body){
    border-top: solid 1px var(--border-brown);
}
.refer-city-list-item :where(.refer-city-list-head, .refer-city-list-body){
    border-bottom: solid 1px var(--border-brown);
}
.refer-city-list-item:first-child .refer-city-list-head{
    border-top-color: var(--base-light-brown);
}
.refer-city-list-item:last-child .refer-city-list-head{
    border-bottom-color: var(--base-light-brown);
}
.refer-city-list-head{
    display: grid;
    align-items: center;
    min-width: 140px;
    padding: 11px 15px 12px;
    background: var(--base-light-brown);
    color: #fff;
    font-weight: bold;
    line-height: calc(1em + 7px);
}
@media screen and (max-width:768px){
    .refer-city-list-head{
        width: min(140px, 31.25vw);
        min-width: 0;
        padding: 8px min(20px, 3.75vw) 9px;
        background: var(--base-light-brown);
    }
}
.refer-city-list-body{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    align-items: center;
}
@media screen and (max-width:768px){
    .refer-city-list-body{
        grid-column: span 1;
        padding: 10px min(20px, 3.75vw) 11px;
    }
}
.refer-city-list-name{
    min-width: 250px;
    padding: 11px 15px 12px;
    border-right: solid 1px var(--border-brown);
    line-height: calc(1em + 7px);
}
@media screen and (max-width:768px){
    .refer-city-list-name{
        min-width: 0;
        padding: 0;
        border-right: none;
        line-height: calc(1em + 3px);
    }
}
.refer-city-list-tel a{
    display: block;
    padding: 8px 15px 9px;
    color: var(--accent-green);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
@media screen and (max-width:768px){
    .refer-city-list-tel a{
        padding: 3px 0 0;
    }
}

/*-------------
support
-------------*/
.supp-note-text{
    position: relative;
    padding-left: 1.25em;
    font-size: 1.4rem;
    line-height: calc(1em + 7px);
}
:where(.supp-note-text:not(:first-child)){
    margin-top: 16px;
}
@media screen and (max-width:768px){
    :where(.supp-note-text:not(:first-child)){
        margin-top: 6px;
    }
}
:where(.supp-note-text) + .supp-note-text{
    margin-top: 0;
}
.supp-note-text::before{
    position: absolute;
    top: 0;
    left: 0;
    color: var(--accent-red);
    content: "※";
}
.supp-sect-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
@media screen and (max-width:768px){
    .supp-sect-grid{
        grid-template-columns: 100%;
    }
}
.supp-sect-l{
    padding: 30px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .supp-sect-l{
        padding: 15px var(--inner-sides_sp);
        border-radius: 5px;
    }
}
.supp-table{
    width: 100%;
    background: #fff;
}
:where(.supp-table:not(:first-child)){
    margin-top: 20px;
}
.supp-table :where(th,td){
    padding: 11px 15px 12px;
    border: solid 1px var(--border-brown);
    line-height: calc(1em + 7px);
    vertical-align: middle;
}
.supp-table :where(th){
    width: 140px;
    background: var(--base-light-brown);
    color: #fff;
    font-weight: bold;
    text-align: center;
}
.supp-table tr:first-child th{
    border-top-color: var(--base-light-brown);
}
@media screen and (min-width:769px){
    .supp-table :where(th,td){
        border-left: none;
    }
    .supp-table :where(th){
        border-right: none;
    }
    .supp-table tr:last-child th{
        border-bottom-color: var(--base-light-brown);
    }
}
@media screen and (max-width:768px){
    .supp-table :where(th,td){
        display: block;
        width: 100%;
    }
    .supp-table :where(th){
        padding: 7px min(20px, 3.125vw) 8px;
        border-bottom: none;
        border-color: var(--base-light-brown);
    }
    .supp-table :where(td){
        padding: 8px min(20px, 3.125vw) 10px;
        border-top: none;
    }
}

/* supp-catch */
.supp-catch{
    position: relative;
    z-index: 0;
    margin: -10px 0 25px;
    font-family: var(--font-maru);
    font-size: 42px;
    font-weight: bold;
    line-height: calc(1em + 18px);
    text-align: center;
}
@media screen and (max-width:768px){
    .supp-catch{
        margin: -6px 0 18px;
        font-size: min(30px, 2.8rem);
        line-height: calc(1em + 12px);
    }
}
.supp-catch::before{
    opacity: .8;
    filter: blur(20px);
    position: absolute;
    top: -14px;
    left: 295px;
    z-index: -1;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--bg-pink);
    content: "";
}
@media screen and (max-width:768px){
    .supp-catch::before{
        filter: blur(10px);
        top: 1px;
        left: calc(50% - 118px);
        width: 40px;
        height: 40px;
    }
}
.supp-catch::after{
    opacity: .5;
    filter: blur(20px);
    position: absolute;
    right: 80px;
    bottom: 3px;
    z-index: -1;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--bg-orange);
    content: "";
}
@media screen and (max-width:768px){
    .supp-catch::after{
        filter: blur(10px);
        right: calc(50% - 280px);
        bottom: -8px;
        width: 50px;
        height: 50px;
    }
}
@media screen and (max-width:540px){
    .supp-catch::after{
        right: calc(50% - 120px);
    }
}

/* supp-pagenav */
.supp-pagenav{
    margin-top: 25px;
}
.supp-pagenav-list{
    display: flex;
    gap: 14px;
}
@media screen and (max-width:768px){
    .supp-pagenav{
        margin-top: 20px;
    }
    .supp-pagenav-list{
        flex-direction: column;
        gap: 10px;
    }
}
.supp-pagenav-list-item{
    flex: 1;
}
.supp-pagenav-list-item a{
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    min-height: 60px;
    padding: 7px 40px 9px;
    border-radius: 99px;
    background: var(--bg-light-pink);
    color: var(--accent-pink);
    font-size: 1.6rem;
    line-height: calc(1em + 4px);
    text-align: center;
    transition: background var(--ease), color var(--ease);
}
.supp-pagenav-list-item a::after{
    position: absolute;
    top: calc(50% - 8px);
    right: 20px;
    transform: rotate(45deg);
    width: 10px;
    height: 10px;
    border-right: solid 2px currentColor;
    border-bottom: solid 2px currentColor;
    content: "";
    transition: border-color var(--ease);
}
@media screen and (max-width:768px){
    .supp-pagenav-list-item a{
        min-height: 50px;
        padding: 7px 35px;
        font-size: 1.4rem;
    }
    .supp-pagenav-list-item a::after{
        top: calc(50% - 5px);
        width: 6px;
        height: 6px;
    }
}
@media (any-hover: hover){
    .supp-pagenav-list-item a:hover{
        background: var(--base-pink);
        color: #fff;
    }
}

/* supp-member */
.supp-member-fee{
    margin: 27px 0 16px;
}
@media screen and (max-width:768px){
    .supp-member-fee{
        margin-top: 17px;
    }
}
.supp-member-fee-year-term{
    margin-bottom: 5px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: calc(1em + 12px);
}
@media screen and (max-width:768px){
    .supp-member-fee-year-term{
        font-size: 1.4rem;
    }
}
.supp-member-fee-year td{
    text-align: center;
}
.supp-member-list-btn{
    width: min(100%, 890px);
    margin: 27px auto 0;
}
@media screen and (max-width:768px){
    .supp-member-list-btn{
        margin-top: 22px;
    }
}
@media screen and (min-width:769px){
    .supp-member-join-table th{
        width: 220px;
    }
}
.supp-member-join-tel{
    display: flex;
    align-items: center;
    gap: 5px 10px;
    padding-top: 1px;
}
.supp-member-join-tel-num{
    flex: 0 0 auto;
}
.supp-member-join-tel-time{
    padding: 4px 20px 5px;
    border-radius: 99px;
    background: var(--bg-brown);
    line-height: calc(1em + 5px);
}
@media screen and (max-width:768px){
    .supp-member-join-tel{
        flex-direction: column;
    }
    .supp-member-join-tel-time{
        width: 100%;
        padding: 4px 18px;
        font-size: 1.3rem;
        text-align: center;
    }
}
.supp-member-join-btn{
    width: 460px;
    margin: 10px 0 3px;
}
@media screen and (max-width:768px){
    .supp-member-join-btn{
        width: 100%;
    }
}
@media screen and (max-width:768px){
    .supp-member-pmt-bank td{
        text-align: center;
    }
}
.supp-member-pmt-btn{
    margin: 15px 0 25px;
}
@media screen and (max-width:768px){
    .supp-member-pmt-btn{
        margin: 10px 0 20px;
    }
}
.supp-member-pmt-card{
    margin-bottom: 13px;
    padding-bottom: 10px;
    border-bottom: solid 1px var(--border-brown);
}
@media screen and (max-width:768px){
    .supp-member-pmt-card{
        padding-bottom: 15px;
    }
    .supp-member-pmt-card img{
        display: block;
        width: 200px;
        height: auto;
        margin: 0 auto;
    }
}
.supp-member-pmt-info{
    padding-left: 14px;
}
.supp-member-pmt-info:not(:last-child){
    margin-bottom: 15px;
}
.supp-member-pmt-info-term{
    position: relative;
    margin-bottom: 5px;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
.supp-member-pmt-info-term::before{
    position: absolute;
    top: calc(.5em - 3px);
    left: -14px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--dot-brown);
    content: '';
}
@media screen and (max-width:768px){
    .supp-member-pmt-info-term::before{
        top: calc(.5em - 2.5px);
    }
}
.supp-member-pmt-info-desc{
    line-height: calc(1em + 7px);
}
.supp-member-tax-info{
    margin: 18px 0 16px;
}
.supp-member-tax-info-term{
    margin-bottom: 7px;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(1em + 9px);
}
@media screen and (max-width:768px){
    .supp-member-tax-info{
        margin: 19px 0 20px;
    }
    .supp-member-tax-info-term{
        margin-bottom: 5px;
    }
}
.supp-member-tax-type{
    margin: 25px 0 26px;
}
@media screen and (max-width:768px){
    .supp-member-tax-type{
        margin: 15px 0 16px;
    }
}
.supp-member-tax-pdf{
    display: flex;
    justify-content: center;
    gap: 10px 20px;
    margin-top: 25px;
}
.supp-member-tax-pdf-btn{
    flex: 1;
    max-width: 435px;
}
@media screen and (max-width:768px){
    .supp-member-tax-pdf{
        flex-direction: column;
        margin-top: 22px;
    }
    .supp-member-tax-pdf-btn{
        max-width: 100%;
    }
}

/* supp-vendor */
.supp-vend-about{
    display: flex;
    flex-direction: row-reverse;
    gap: 10px 25px;
    padding: 30px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.supp-vend-about-pic{
    flex: 0 0 auto;
    width: 180px;
    overflow: hidden;
    border-radius: 5px;
}
@media screen and (max-width:768px){
    .supp-vend-about{
        flex-direction: column;
        align-items: center;
        padding: 14px var(--inner-sides_sp) 20px;
        border-radius: 5px;
    }
    .supp-vend-about-pic{
        width: 120px;
    }
}
.supp-vend-flow{
    margin-top: 15px;
    padding: 20px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.supp-vend-flow img{
    display: block;
    margin: 0 auto;
}
@media screen and (max-width:768px){
    .supp-vend-flow{
        padding: 10px;
        border-radius: 5px;
    }
    .supp-vend-flow img{
        width: 265px;
        height: auto;
    }
}
.supp-vend-sticker{
    position: relative;
    z-index: 0;
    min-height: 240px;
    margin-top: 2px;
    padding: 173px 0 0 195px;
}
.supp-vend-sticker-pic{
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}
@media screen and (max-width:768px){
    .supp-vend-sticker{
        min-height: 0;
        padding: 0;
    }
    .supp-vend-sticker-pic{
        position: static;
        margin-bottom: 9px;
    }
}
.supp-vend-provider{
    display: flex;
    justify-content: center;
    gap: 10px 20px;
    margin-top: 40px;
}
.supp-vend-provider-btn{
    flex: 1;
    max-width: 435px;
}
@media screen and (max-width:768px){
    .supp-vend-provider{
        flex-direction: column;
        margin-top: 25px;
    }
    .supp-vend-provider-btn{
        max-width: 100%;
    }
}
.supp-vend-modal{
    width: 1000px;
    padding: 40px;
}
@media screen and (max-width:768px){
    .supp-vend-modal{
        width: 100%;
        padding: 20px var(--inner-sides_sp);
    }
}
.supp-vend-provider-list{
    display: flex;
    flex-wrap: wrap;
    gap: 8px 20px;
}
@media screen and (max-width:768px){
    .supp-vend-provider-list{
        gap: 7px 14px;
    }
}
.supp-vend-provider-list-item{
    min-width: calc(50% - 10px);
    line-height: calc(1em + 4px);
}
@media screen and (min-width:769px){
    .supp-vend-provider-list:has(.supp-vend-provider-list-item:nth-child(9)) .supp-vend-provider-list-item{
        min-width: calc((100% - 40px) / 3);
    }
}
@media screen and (max-width:768px){
    .supp-vend-provider-list-item{
        min-width: calc(50% - 7px);
    }
}

/* supp-book */
.supp-book-donate{
    margin-top: 25px;
}
.supp-book-donate-list-item{
    position: relative;
    padding-left: 15px;
    line-height: calc(1em + 7px);
}
.supp-book-donate-list-item:not(:last-child){
    margin-bottom: 1px;
}
.supp-book-donate-list-item::before{
    position: absolute;
    top: .5em;
    left: 4px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--dot-brown);
    content: "";
}
@media screen and (max-width:768px){
    .supp-book-donate{
        margin-top: 10px;
    }
    .supp-book-donate-list-item{
        padding-left: 14px;
    }
    .supp-book-donate-list-item:not(:last-child){
        margin-bottom: 3px;
    }
    .supp-book-donate-list-item::before{
        top: calc(.5em + 1px);
        width: 6px;
        height: 6px;
    }
}
.supp-book-flow-list{
    counter-reset: flow-num;
}
.supp-book-flow-list-item{
    margin-bottom: 10px;
}
.supp-book-flow-list-item .sect-title-s::before{
    display: inline-block;
    margin-right: .4em;
    content: counter(flow-num, decimal-leading-zero)".";
    counter-increment: flow-num;
}
:where(.supp-book-flow-list-item) p:not(:last-child){
    margin-bottom: 8px;
}
@media screen and (max-width:768px){
    :where(.supp-book-flow-list-item) p:not(:last-child){
        margin-bottom: 9px;
    }
}
.supp-book-flow-step2-list{
    margin-bottom: 15px;
    counter-reset: step-num;
}
@media screen and (max-width:768px){
    .supp-book-flow-step2-list{
        margin-bottom: 10px;
    }
}
.supp-book-flow-step2-list-item{
    position: relative;
    padding-left: 1.2em;
}
.supp-book-flow-step2-list-item:not(:last-child){
    margin-bottom: 3px;
}
@media screen and (max-width:768px){
    .supp-book-flow-step2-list-item:not(:last-child){
        margin-bottom: 9px;
    }
}
.supp-book-flow-step2-list-item::before{
    position: absolute;
    top: 0;
    left: 0;
    color: var(--accent-pink);
    content: counter(step-num)".";
    counter-increment: step-num;
}
.supp-book-flow-qr{
    float: left;
    margin-right: 20px;
}
.supp-book-flow-btn{
    width: 435px;
    margin-top: 15px;
}
@media screen and (max-width:768px){
    .supp-book-flow-btn{
        width: 100%;
        margin-top: 0;
    }
}
.supp-book-bnr{
    width: 600px;
    margin: 40px auto 0;
}
@media screen and (max-width:768px){
    .supp-book-bnr{
        width: 100%;
        margin-top: 30px;
    }
}

/*-------------
song
-------------*/
.song-youtube{
    width: 800px;
    margin: 25px auto 0;
    background: var(--bg-brown);
}
@media screen and (max-width:768px){
    .song-youtube{
        width: 100%;
        margin-top: 20px;
    }
    .song-youtube iframe{
        width: 100%;
        height: unset;
        aspect-ratio: 16 / 9;
    }
}

/* song-profile */
.song-profile{
    margin-top: 35px;
}
@media screen and (max-width:768px){
    .song-profile{
        margin-top: 15px;
    }
}
.song-prof-sect{
    display: flex;
    align-items: flex-start;
    gap: 0 30px;
    padding: 30px;
    border-radius: 8px;
    background: var(--bg-light-brown);
}
.song-prof-sect:not(:last-child){
    margin-bottom: 10px;
}
@media screen and (max-width:768px){
    .song-prof-sect{
        flex-direction: column;
        align-items: center;
        gap: 20px 0;
        padding: 20px var(--inner-sides_sp);
        border-radius: 5px;
    }
    .song-prof-sect:not(:last-child){
        margin-bottom: 15px;
    }
}
.song-prof-sect-pic{
    flex: 0 0 auto;
    width: 210px;
}
@media screen and (max-width:768px){
    .song-prof-sect-pic{
        width: auto;
    }
    .song-prof-sect-pic img{
        width: auto;
        height: 160px;
    }
}
:where(.song-prof-sect-body) p:not(:last-child){
    margin-bottom: 8px;
}
.song-prof-link{
    margin-top: 23px;
}
@media screen and (max-width:768px){
    .song-prof-link{
        margin-top: 13px;
    }
}
.song-prof-link a{
    display: inline-block;
    position: relative;
    padding: 0 0 2px 24px;
    font-size: 1.6rem;
    line-height: calc(1em + 3px);
    text-decoration: underline;
    text-underline-offset: 3px;
}
@media screen and (max-width:768px){
    .song-prof-link a{
        font-size: 1.4rem;
    }
}
.song-prof-link a::before{
    position: absolute;
    top: calc(.5em - 6px);
    left: 0;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--accent-pink);
    content: "";
}
.song-prof-link a::after{
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    position: absolute;
    top: calc(.5em - 2px);
    left: 6px;
    width: 6px;
    height: 8px;
    background: #fff;
    content: "";
}
@media (any-hover: hover){
    .song-prof-link a:hover{
        text-decoration: none;
    }
}

/* song-cd-btn */
.song-cd-btn{
    margin-top: 30px;
}

/*-------------
contact-form & help-desk-form
-------------*/
.form-alt-mag{
    margin: 40px 0;
    padding: 20px 10px;
    border-radius: 5px;
    background: var(--bg-light-brown);
    text-align: center;
}
.contact-form-container{
    margin-top: 25px;
    padding: 40px 60px;
    border-radius: 30px;
    background: var(--bg-light-brown);
}
@media screen and (max-width:768px){
    .contact-form-container{
        margin-top: 15px;
        padding: 20px var(--inner-sides_sp) 25px;
        border-radius: 10px;
    }
}
.contact-form{
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 20px 10px;
}
.contact-form__row{
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 2;
    align-items: flex-start;
}
@media screen and (max-width:768px){
    .contact-form{
        grid-template-columns: 100%;
        gap: 15px 0;
    }
    .contact-form__row{
        display: block;
    }
}
.contact-form__head{
    display: flex;
    align-items: center;
    gap: 0 8px;
    min-width: 185px;
    padding-top: 14px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: calc(1em + 3px);
}
@media screen and (max-width:768px){
    .contact-form__head{
        min-width: 0;
        margin-bottom: 10px;
        padding-top: 0;
        font-size: 1.4rem;
    }
}
.contact-form__head :where(.__opt,.__req){
    flex: 0 0 auto;
    min-width: 36px;
    padding: 3px 5px 4px;
    border-radius: 5px;
    background: #d4c0ac;
    color: #fff;
    font-size: 1.2rem;
    line-height: calc(1em + 3px);
    text-align: center;
}
.contact-form__head .__req{
    background: var(--accent-red);
}
:where(.contact-form__body > p:not(:first-child)){
    margin-top: 10px;
}
.contact-form input:where([type="text"],[type="email"],[type="tel"]){
    width: 100%;
    height: 50px;
    padding: 0 15px;
    border: solid 1px var(--border-brown);
    border-radius: 5px;
    background: #fff;
    font-size: max(1.6rem, 16px);
}
.contact-form__radio{
    margin: 0;
}
.contact-form__radio input{
    display: none;
}
.contact-form__radio label{
    display: inline-flex;
    align-items: center;
    gap: 0 8px;
    min-height: 50px;
    padding: 4px 0 5px;
    font-size: 1.6rem;
    line-height: calc(1em + 4px);
}
.contact-form__radio label .__btn{
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 0 0 auto;
    position: relative;
    transform: translateY(1px);
    width: 20px;
    height: 20px;
    border: solid 1px var(--border-brown);
    border-radius: 50%;
    background: #fff;
}
.contact-form__radio label:has(input:checked) .__btn{
    border-color: var(--base-brown);
}
.contact-form__radio label:has(input:checked) .__btn::after{
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--base-brown);
    content: "";
}
.contact-form__btn-list{
    display: flex;
    flex-wrap: wrap;
    gap: 10px 20px;
}
.contact-form__btn-list > *{
    margin: 0;
}
.contact-form__select{
    position: relative;
}
.contact-form__select::after{
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    position: absolute;
    top: calc(50% - 5px);
    right: 16px;
    width: 10px;
    height: 10px;
    background: var(--base-brown);
    content: "";
    pointer-events: none;
}
.contact-form__select select{
    width: 100%;
    height: 50px;
    padding: 0 30px 0 15px;
    border: solid 1px var(--border-brown);
    border-radius: 5px;
    background: #fff;
    font-size: max(1.6rem, 16px);
}
.contact-form textarea{
    width: 100%;
    min-height: 120px;
    padding: 15px;
    border: solid 1px var(--border-brown);
    border-radius: 5px;
    background: #fff;
    font-size: max(1.6rem, 16px);
    resize: vertical;
}
.contact-form .is-mid-area{
    width: 400px;
}
@media screen and (max-width:768px){
    .contact-form .is-mid-area{
        width: 100%;
    }
}
.contact-form .is-low-area{
    width: min(100%, 200px);
}

/* contact-form._confirm */
.contact-form._confirm{
    margin-bottom: 45px;
}
@media screen and (max-width:768px){
    .contact-form._confirm{
        margin-bottom: 30px;
    }
}
.contact-form._confirm .contact-form__body{
    padding-top: 10px;
    font-size: 1.8rem;
    line-height: calc(1em + 11px);
}
@media screen and (max-width:768px){
    .contact-form._confirm .contact-form__body{
        padding-top: 0;
        font-size: 1.6rem;
        line-height: calc(1em + 11px);
    }
}
@media screen and (min-width:769px){
    .contact-form._confirm .contact-form__body._textarea{
        font-size: 1.6rem;
        line-height: calc(1em + 12px);
    }
}

/* contact-form-btns */
.contact-form-btns{
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 30px;
}
@media screen and (max-width:768px){
    .contact-form-btns{
        flex-direction: column;
        margin-top: 20px;
    }
}
.contact-form-btn{
    flex: 0 0 auto;
    width: 400px;
}
@media screen and (max-width:768px){
    .contact-form-btn{
        width: 100%;
    }
}
.contact-form-backbtn{
    width: 260px;
}
.contact-form-backbtn-inner{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 60px;
    padding-bottom: 2px;
    border: solid 1px var(--base-brown);
    border-radius: 99px;
    font-size: 1.6rem;
    font-weight: bold;
    transition: background var(--ease);
}
@media screen and (max-width:768px){
    .contact-form-backbtn{
        width: 200px;
    }
    .contact-form-backbtn-inner{
        height: 50px;
        padding-bottom: 0;
        font-size: 1.4rem;
    }
}
@media (any-hover: hover){
    .contact-form-backbtn-inner:hover{
        background: #fff;
    }
}
.contact-form-btns._error{
    margin-top: 0;
}
.contact-form-btns._error .contact-form-backbtn{
    width: 100%;
}

/*-------------
privacy
-------------*/
.prv-num-list{
    counter-reset: list-num;
}
.prv-num-list:not(:first-child){
    margin-top: 15px;
}
.prv-num-list:not(:last-child){
    margin-bottom: 14px;
}
.prv-num-list-item{
    position: relative;
    padding-left: 2em;
    line-height: calc(1em + 9px);
}
.prv-num-list-item:not(:last-child){
    margin-bottom: 6px;
}
@media screen and (max-width:768px){
    .prv-num-list-item:not(:last-child){
        margin-bottom: 8px;
    }
}
.prv-num-list-item::before{
    position: absolute;
    top: 0;
    left: 0;
    min-width: 1.6em;
    color: var(--accent-pink);
    text-align: right;
    content: counter(list-num)".";
    counter-increment: list-num;
}

/*-------------
404
-------------*/
.err404{
    text-align: center;
}
.err404-title{
    margin-bottom: 23px;
    font-family: var(--font-maru);
    font-size: 36px;
    font-weight: bold;
    line-height: calc(1em + 8px);
}
.err404-title::after{
    display: block;
    margin-top: 12px;
    color: var(--accent-pink);
    font-size: 2rem;
    line-height: 1;
    content: attr(data-en);
}
.err404-btn{
    width: 360px;
    margin: 45px auto 0;
}
@media screen and (max-width:768px){
    .err404{
        text-align: left;
    }
    .err404-title{
        margin: 21px 0 24px;
        font-size: 2.7rem;
    }
    .err404-title::after{
        font-size: 1.6rem;
    }
    .err404-btn{
        width: 100%;
        margin-top: 30px;
    }
}
