/*
Theme Name: ML DESIGN v26 Theme
Theme URI: https://www.ml-design.jp/
Description: Designed by ML Design
Version: 26.05
Author: ML Design
Author URI: https://www.ml-design.jp/
Tags:
*/

@font-face {
    font-family: 'icomoon';
    src:  url('fonts/icomoon.eot?nt5ja9');
    src:  url('fonts/icomoon.eot?nt5ja9#iefix') format('embedded-opentype'),
    url('fonts/icomoon.ttf?nt5ja9') format('truetype'),
    url('fonts/icomoon.woff?nt5ja9') format('woff'),
    url('fonts/icomoon.svg?nt5ja9#icomoon') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
    font-family: 'icomoon' !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.icon-logo:before {
    content: "\e903";
}
.icon-contact:before {
    content: "\e900";
}
.icon-menu:before {
    content: "\e902";
}
.icon-home:before {
    content: "\e90a";
}
.icon-location:before {
    content: "\e90c";
}
.icon-clock:before {
    content: "\e90d";
}
.icon-arrow-left:before {
    content: "\e90e";
}
.icon-arrow-up:before {
    content: "\e90f";
}
.icon-arrow-right:before {
    content: "\e910";
}
.icon-arrow-down:before {
    content: "\e911";
}
.icon-cross:before {
    content: "\e901";
}
.icon-checkmark:before {
    content: "\e912";
}
.icon-mobile:before {
    content: "\e958";
}

/* clamp処理 */
:root {
    --view-start: 360;
    --view-end: 1400;
    
    --progress: calc((100vw - (var(--view-start) * 1px)) / ((var(--view-end) - var(--view-start)) * 1px));
}

/* common */
* {
    margin: 0px;
    padding: 0px;
}
body {
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.5;
    padding: 0;
    margin: 0;
}
li { list-style: none; }
img { border: none 0px; }
a {
    transition: 0.3s;
    &:hover { color: #F60; }
    &:hover img { opacity: 0.8; translate: 1px 1px; }
}
.alignright { float: right; }
.alignleft { float: left; }
img.alignleft { margin-right: 8px; margin-bottom: 8px; }
img.alignright { margin-left: 8px; margin-bottom: 8px; }
.aligncenter { text-align: center!important; display: block; }
.float_right { float: right; margin-left: 10px; }
.float_left { float: left; margin-right: 10px; }
.clear { clear: both; }
.post-edit-link {
    font-size: 0.9rem;
    font-weight: bold;
    color: #FF0000;
    background-color: #F0F0F0;
    text-decoration: none;
    text-align: center;
    display: block;
    clear: both;
    border: 1px dashed #CCCCCC;
    padding-top: 5px;
    padding-bottom: 5px;
}
.red{ color: #FF0000; }
.orange { color: #c16b1a; }
.blue{ color: #0000FF; }
.green { color: #006600; }


/* wp-pagenavi */
.wp-pagenavi {
    clear: both;
    margin-top: 30px;
    margin-bottom: 30px;
    overflow: hidden;
    margin-right: 10px;
    margin-left: 10px;
    & :is(span, a) {
        --font-min: 1.0;
        --font-max: 1.7;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        display: block;
        float: left;
        padding-right: 8px!important;
        padding-left: 8px!important;
        border: none;
        margin: 4px;
        border-radius: 15px;
    }
    & span {
        background-color: #999999;
        color: #FFFFFF;
    }
    & a {
        color: #FFFFFF!important;
        background-color: #0096c3;
        &:hover {
            background-color: #f60;
        }
    }
}


/* block */
#wrapper {
    width: 100%;
    contain: paint;
    #upper_block {
        width: 100%;
        padding: 0px;
        margin: 0px;
        overflow: hidden;
        #upper_block_inner {
            text-align: left;
            width: 100%;
            margin-top: 0px;
            margin-right: auto;
            margin-left: auto;
            margin-bottom: 0px;
            overflow: hidden;
            padding-top: 0px;
            padding-right: 0px;
            padding-left: 0px;
            padding-bottom: var(--upper_block_inner-padding-bottom);
            overflow: hidden;
            .subpage & {
                padding-bottom: var(--subpage-upper_block_inner-padding-bottom);
            }
        }
    }
    #middle_block {
        margin: 0px;
        width: 100%;
        #middle_block_inner {
            text-align: left;
            width: var(--middle_block_inner-width);
            margin-right: auto;
            margin-left: auto;
            padding-top: 0px;
            padding-right: 0px;
            padding-left: 0px;
            padding-bottom: 15px;
            overflow: hidden;
        }
    }
    #under_block {
        width: 100%;
        margin: 0px;
        padding: 0px;
        position: relative;
    }
}
#wrapper {
    --upper_block_inner-padding-bottom: 110px;
    --subpage-upper_block_inner-padding-bottom: 60px;
    --middle_block_inner-width: 100%;
}
@media (width >= 375px)  { /* 375-789 */
    #wrapper {
        --upper_block_inner-padding-bottom: 120px;
        --subpage-upper_block_inner-padding-bottom: 70px;
        --middle_block_inner-width: 100%;
    }
}
@media (width >= 790px)  { /* 790-999 */
    #wrapper {
        --upper_block_inner-padding-bottom: 100px;
        --subpage-upper_block_inner-padding-bottom: 80px;
        --middle_block_inner-width: 100%;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #wrapper {
        --upper_block_inner-padding-bottom: 120px;
        --subpage-upper_block_inner-padding-bottom: 70px;
        --middle_block_inner-width: 1000px;
    }
}
@media (width >= 1400px) { /* 1400over */
    #wrapper {
        --upper_block_inner-padding-bottom: 160px;
        --subpage-upper_block_inner-padding-bottom: 80px;
        --middle_block_inner-width: 1400px;
    }
}


/* scroller */
#scroller {
    --font-min: 1.2;
    --font-max: 1.7;
    --wide-min: 40;
    --wide-max: 53;
    
    position: fixed;
    z-index: 99;
    right: 5px;
    bottom: 17px;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.5s, visibility 0.5s;
    &.appearance {
        visibility: visible;
        opacity: 1;
    }
    & a {
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        width: clamp(
            calc(var(--wide-min) * 1px),
            calc((var(--wide-min) + (var(--wide-max) - var(--wide-min)) * var(--progress)) * 1px),
            calc(var(--wide-max) * 1px)
        );
        height: clamp(
            calc(var(--wide-min) * 1px),
            calc((var(--wide-min) + (var(--wide-max) - var(--wide-min)) * var(--progress)) * 1px),
            calc(var(--wide-max) * 1px)
        );
        color: #fff;
        background-color: #a3a3a3;
        text-align: center;
        text-decoration: none;
        display: block;
        &:hover {
            color: #F60;
        }
        & span {
            transform: translate(0px, 50%);
            display: block;
        }
    }
}


/* entry faq */
.entry,
.faq { 
    --font-h1-min: 1.5; --font-h1-max: 2.3;
    --font-h2-min: 1.3; --font-h2-max: 2.0;
    --font-h3-min: 1.1; --font-h3-max: 1.7;
    --font-h4-min: 0.9; --font-h4-max: 1.4;
    --font-h5-min: 0.9; --font-h5-max: 1.4;
    --font-p-min: 0.9; --font-p-max: 1.3;
    --font-li-min: 0.8; --font-li-max: 1.2; /* li,dt,dd */
    
    --entry-h1-margin-bottom-min: 12; --entry-h1-margin-bottom-max: 32;
    --entry-h2-padding-block-min: 12; --entry-h2-padding-block-max: 20;
    --entry-p-padding-bottom-min: 11; --entry-p-padding-bottom-max: 18;
    
    width: var(--entry-width);
    clear: both;
    padding-top: 35px;
    padding-bottom: 35px;
    margin-left: var(--entry-margin-left);
    margin-right: var(--entry-margin-right);
    overflow: hidden;
    & h1 {
        font-size: clamp(
            calc(var(--font-h1-min) * 1rem),
            calc((var(--font-h1-min) + (var(--font-h1-max) - var(--font-h1-min)) * var(--progress)) * 1rem),
            calc(var(--font-h1-max) * 1rem)
        );
        text-align: center;
        padding-block: 8px;
        margin-bottom: clamp(
            calc(var(--entry-h1-margin-bottom-min) * 1px),
            calc((var(--entry-h1-margin-bottom-min) + (var(--entry-h1-margin-bottom-max) - var(--entry-h1-margin-bottom-min)) * var(--progress)) * 1px),
            calc(var(--entry-h1-margin-bottom-max) * 1px)
        );
        transition: font-size 0.6s ease;
    }
    & h2 {
        font-size: clamp(
            calc(var(--font-h2-min) * 1rem),
            calc((var(--font-h2-min) + (var(--font-h2-max) - var(--font-h2-min)) * var(--progress)) * 1rem),
            calc(var(--font-h2-max) * 1rem)
        );
        margin-top: 15px;
        padding-block: clamp(
            calc(var(--entry-h2-padding-block-min) * 1px),
            calc((var(--entry-h2-padding-block-min) + (var(--entry-h2-padding-block-max) - var(--entry-h2-padding-block-min)) * var(--progress)) * 1px),
            calc(var(--entry-h2-padding-block-max) * 1px)
        );
        border-top: 1px solid #ccc;
        transition: 0.6s;
    }
    & h3 {
        font-size: clamp(
            calc(var(--font-h3-min) * 1rem),
            calc((var(--font-h3-min) + (var(--font-h3-max) - var(--font-h3-min)) * var(--progress)) * 1rem),
            calc(var(--font-h3-max) * 1rem)
        );
        padding: 5px 0 15px;
    }
    & h4 {
        font-size: clamp(
            calc(var(--font-h4-min) * 1rem),
            calc((var(--font-h4-min) + (var(--font-h4-max) - var(--font-h4-min)) * var(--progress)) * 1rem),
            calc(var(--font-h4-max) * 1rem)
        );
        padding: 5px 0 15px;
    }
    & h5 {
        font-size: clamp(
            calc(var(--font-h5-min) * 1rem),
            calc((var(--font-h5-min) + (var(--font-h5-max) - var(--font-h5-min)) * var(--progress)) * 1rem),
            calc(var(--font-h5-max) * 1rem)
        );
        padding: 5px 0 15px;
    }
    & p {
        font-size: clamp(
            calc(var(--font-p-min) * 1rem),
            calc((var(--font-p-min) + (var(--font-p-max) - var(--font-p-min)) * var(--progress)) * 1rem),
            calc(var(--font-p-max) * 1rem)
        );
        line-height: 1.8;
        padding-bottom: var(--entry-p-padding-bottom);
        padding-bottom: clamp(
            calc(var(--entry-p-padding-bottom-min) * 1px),
            calc((var(--entry-p-padding-bottom-min) + (var(--entry-p-padding-bottom-max) - var(--entry-p-padding-bottom-min)) * var(--progress)) * 1px),
            calc(var(--entry-p-padding-bottom-max) * 1px)
        );
        padding-inline: 5px;
        transition: 0.6s;
    }
    & :is(ul, ol) {
        padding: 5px 0 15px 10px;
        & li {
            font-size: clamp(
                calc(var(--font-li-min) * 1rem),
                calc((var(--font-li-min) + (var(--font-li-max) - var(--font-li-min)) * var(--progress)) * 1rem),
                calc(var(--font-li-max) * 1rem)
            );
            line-height: 2;
            margin-bottom: 3px;
            padding-left: 10px;
            border-bottom: 1px solid #999;
        }
    }
    & dl {
        padding: 5px 15px 15px 14px;
        & dt {
            font-size: clamp(
                calc(var(--font-li-min) * 1rem),
                calc((var(--font-li-min) + (var(--font-li-max) - var(--font-li-min)) * var(--progress)) * 1rem),
                calc(var(--font-li-max) * 1rem)
            );
            font-weight: bold;
            line-height: 1.5;
            margin: 5px 0 3px;
            padding-left: 5px;
        }
        & dd {
            font-size: clamp(
                calc(var(--font-li-min) * 1rem),
                calc((var(--font-li-min) + (var(--font-li-max) - var(--font-li-min)) * var(--progress)) * 1rem),
                calc(var(--font-li-max) * 1rem)
            );
            padding: 2px 0 3px 35px;
            border-bottom: 1px dotted #fff;
        }
    }
    & table {
        width: 100%;
        border-top-width: 1px;
        border-left-width: 1px;
        border-top-style: solid;
        border-left-style: solid;
        border-top-color: #CCCCCC;
        border-left-color: #CCCCCC;
        :is(td, th) {
            font-size: clamp(
                calc(var(--font-li-min) * 1rem),
                calc((var(--font-li-min) + (var(--font-li-max) - var(--font-li-min)) * var(--progress)) * 1rem),
                calc(var(--font-li-max) * 1rem)
            );
            padding: 3px;
            border-bottom-width: 1px;
            border-bottom-style: solid;
            border-bottom-color: #CCCCCC;
            border-right-width: 1px;
            border-right-style: solid;
            border-right-color: #CCCCCC;
        }
    }
}
.entry {
    --entry-width: calc(100% - 20px);
    --entry-margin-left: 10px;
    --entry-margin-right: 10px;
}
@media (width >= 375px)  { /* 375-789 */
    .entry {
        --entry-width: calc(100% - 20px);
        --entry-margin-left: 10px;
        --entry-margin-right: 10px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    .entry {
        --entry-width: calc(100% - 20px);
        --entry-margin-left: 10px;
        --entry-margin-right: 10px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    .entry {
        --entry-width: 1000px;
        --entry-margin-left: auto;
        --entry-margin-right: auto;
    }
}
@media (width >= 1400px) { /* 1400over */
    .entry {
        --entry-width: 1400px;
        --entry-margin-left: auto;
        --entry-margin-right: auto;
    }
}

/* logo */
#logo {
    text-align: center;
    position: absolute;
    top: var(--logo-top);
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    z-index: 2;
    transition: 0.2s;
    & a {
        --font-min: 2.0;
        --font-max: 4.6;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        color: #fff;
        text-decoration: none;
        display: block;
        width: auto;
        height: auto;
        &:hover {
            opacity: 0.8; translate: 1px 1px;
        }
        & span {
            filter: drop-shadow(0px 0px 10px rgba(1, 2, 2, 0.8));
        }
    }
    .subpage & {
        top: var(--subpage-logo-top);
    }
}
#logo {
    --logo-top: 270px;
    --subpage-logo-top: 120px;
}
@media (width >= 375px)  { /* 375-789 */
    #logo {
        --logo-top: 290px;
        --subpage-logo-top: 130px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    #logo {
        --logo-top: 310px;
        --subpage-logo-top: 140px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #logo {
        --logo-top: 350px;
        --subpage-logo-top: 150px;
    }
}
@media (width >= 1400px) { /* 1400over */
    #logo {
        --logo-top: 400px;
        --subpage-logo-top: 200px;
    }
}


/* sl sub_theme */
#sl {
    overflow: hidden;
    height: var(--sl-height);
    .subpage & {
        height: var(--subpage-sl-height);
    }
    & video {
        height: var(--sl-height);
        width: 100%;
        position: absolute;
        object-fit: cover;
        object-position: center center;
        clip-path: url(#sl_clip);
        -webkit-clip-path: url(#sl_clip);
    }
    .clip_svg {
        position: absolute;
        width: 0;
        height: 0;
        pointer-events: none;
    }
    #sub_theme {
        overflow: hidden;
        height: var(--subpage-sl-height);
        background-size: cover;
        background-position: center center;
        background-repeat: no-repeat;
        &.theme_all {
            background-image: url(image/sl/theme_all.webp);
        }
        &.theme_webdesign {
            background-image: url(image/sl/theme_webdesign.webp);
        }
        &.theme_graphicdesign {
            background-image: url(image/sl/theme_graphicdesign.webp);
        }
        &.theme_shoot {
            background-image: url(image/sl/theme_shoot.webp);
        }
        &.theme_plan {
            background-image: url(image/sl/theme_plan.webp);
        }
        &.theme_package_1 {
            background-image: url(image/sl/theme_package_1.webp);
        }
        &.theme_package_2 {
            background-image: url(image/sl/theme_package_2.webp);
        }
        &.theme_package_3 {
            background-image: url(image/sl/theme_package_3.webp);
        }
        &.theme_package_4 {
            background-image: url(image/sl/theme_package_4.webp);
        }
        &.theme_package_5 {
            background-image: url(image/sl/theme_package_5.webp);
        }
        &.theme_results {
            background-image: url(image/sl/theme_results.webp);
        }
        &.theme_flow {
            background-image: url(image/sl/theme_flow.webp);
        }
        &.theme_news {
            background-image: url(image/sl/theme_news.webp);
        }
        &.theme_ml_design {
            background-image: url(image/sl/theme_ml_design.webp);
        }
        &.theme_company {
            background-image: url(image/sl/theme_company.webp);
        }
        &.theme_faq {
            background-image: url(image/sl/theme_faq.webp);
        }
    }
}
#sl {
    --sl-height: 600px; --subpage-sl-height: 270px;
}
@media (width >= 375px)  { /* 375-789 */
    #sl { --sl-height: 650px; --subpage-sl-height: 310px; }
}
@media (width >= 790px)  { /* 790-999 */
    #sl { --sl-height: 690px; --subpage-sl-height: 370px; }
}
@media (width >= 1000px) { /* 1000-1400 */
    #sl { --sl-height: 800px; --subpage-sl-height: 400px; }
}
@media (width >= 1400px) { /* 1400over */
    #sl { --sl-height: 890px; --subpage-sl-height: 490px; }
}


/* modal_nav */
#modal_nav {
    position: absolute;
    top: var(--modal_nav-top);
    right: var(--modal_nav-right);
    z-index: 99;
    display: flex;
    gap: var(--modal_nav-gap);
    width: auto;
    height: auto;
    .btn_trigger {
        --font-min: 1.1;
        --font-max: 2.4;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        color: #fff;
        background-color: #7f7f7f;
        border: none;
        cursor: pointer;
        padding: var(--modal_nav-btn_trigger-padding);
    }
    &.fixed {
        position: fixed;
        top: 0;
        .subpage & {
            top: 0;
        }
    }
    .subpage & {
        top: var(--subpage-modal_nav-top);
    }
}
#modal_nav {
    --modal_nav-top: 600px;
    --subpage-modal_nav-top: 270px;
    --modal_nav-right: 10px;
    --modal_nav-btn_trigger-padding: 10px;
    --modal_nav-gap: 5px;
}
@media (width >= 375px)  { /* 375-789 */
    #modal_nav {
        --modal_nav-top: 650px;
        --subpage-modal_nav-top: 310px;
        --modal_nav-right: 20px;
        --modal_nav-btn_trigger-padding: 12px;
        --modal_nav-gap: 8px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    #modal_nav {
        --modal_nav-top: 690px;
        --subpage-modal_nav-top: 370px;
        --modal_nav-right: 25px;
        --modal_nav-btn_trigger-padding: 14px;
        --modal_nav-gap: 10px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #modal_nav {
        --modal_nav-top: 800px;
        --subpage-modal_nav-top: 400px;
        --modal_nav-right: 30px;
        --modal_nav-btn_trigger-padding: 17px;
        --modal_nav-gap: 15px;
    }
}
@media (width >= 1400px) { /* 1400over */
    #modal_nav {
        --modal_nav-top: 890px;
        --subpage-modal_nav-top: 490px;
        --modal_nav-right: 6%;
        --modal_nav-btn_trigger-padding: 20px;
        --modal_nav-gap: 20px;
    }
}


/* modal */
#modal {
    & h1 {
        --font-min: 1.2;
        --font-max: 2.0;
        
        font-size: clamp(calc(var(--font-min) * 1rem), calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem), calc(var(--font-max) * 1rem));
        text-align: center;
        padding-top: 20px;
    }
    & h2 {
        --font-min: 0.9;
        --font-max: 1.4;
        
        font-size: clamp(calc(var(--font-min) * 1rem), calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem), calc(var(--font-max) * 1rem));
        padding: 10px 0px;
        margin: 20px 10px;
        text-align: center;
    }
    & ul {
        margin: 0 20px;
        display: grid;
        grid-template-columns: var(--modal-ul-grid-template-columns);
        grid-template-rows: auto;
        gap: 20px;
        & li {
            --font-min: 0.9;
            --font-max: 1.4;
            
            font-size: clamp(calc(var(--font-min) * 1rem), calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem), calc(var(--font-max) * 1rem));
            text-align: center;
            display: flex;
            flex-direction: column;
            box-sizing: border-box;          
            & a {
                color: #000;
                font-weight: 500;
                text-decoration: none;
                display: block;
                padding: 4px 10px;
                background-color: #f1f1f1;
                &:hover {
                    color: #f60;
                    background-color: fff;
                }
            }
        }
    }
    & p {
        --font-min: 0.8;
        --font-max: 1.3;
        
        font-size: clamp(calc(var(--font-min) * 1rem), calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem), calc(var(--font-max) * 1rem));
        padding-top: 20px;
        padding-bottom: 10px;
    }
}
#modal {
    --modal-ul-grid-template-columns: repeat(1, calc(100% / 1 - 15px));
}
@media (width >= 375px)  { /* 375-789 */
    #modal {
        --modal-ul-grid-template-columns: repeat(2, calc(100% / 2 - 15px));
    }
}
@media (width >= 790px)  { /* 790-999 */
    #modal {
        --modal-ul-grid-template-columns: repeat(2, calc(100% / 2 - 15px));
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #modal {
        --modal-ul-grid-template-columns: repeat(3, calc(100% / 3 - 15px));
    }
}
@media (width >= 1400px) { /* 1400over */
    #modal {
        --modal-ul-grid-template-columns: repeat(3, calc(100% / 3 - 15px));
    }
}


/* popover */
[popover] {
    inset: 0;
    margin: auto;
    width: var(--popover-width);
    height: fit-content;
    max-height: calc(100% - 40px);
    padding: 20px;
    background: #ebeaea;
    border: none;
    border-radius: 15px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    transition: 
        display 0.4s allow-discrete, 
        overlay 0.4s allow-discrete, 
        opacity 0.4s, 
        transform 0.4s;
    opacity: 0;
    transform: scale(0.95);
    
    --popover-width: calc(100% - 70px);
}
/* 表示中の状態 */
[popover]:popover-open {
    opacity: 1;
    transform: scale(1);
}
@media (width >= 375px)  { /* 375-789 */
    [popover] {
        --popover-width: calc(100% - 70px);
    }
}
@media (width >= 790px)  { /* 790-999 */
    [popover] {
        --popover-width: calc(100% - 70px);
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    [popover] {
        --popover-width: 1000px;
    }
}
@media (width >= 1400px) { /* 1400over */
    [popover] {
        --popover-width: 1200px;
    }
}
@starting-style {
    [popover]:popover-open {
        opacity: 0;
        transform: scale(0.95);
    }
}
[popover]::backdrop {
    background: rgba(0, 0, 0, 0);
    backdrop-filter: blur(0px);
    transition: 
        display 0.4s allow-discrete, 
        overlay 0.4s allow-discrete, 
        background-color 0.4s, 
        backdrop-filter 0.4s;
}
[popover]:popover-open::backdrop {
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(3px);
}
.close_btn {
    --font-min: 0.8;
    --font-max: 1.4;
    
    font-size: clamp(
        calc(var(--font-min) * 1rem),
        calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
        calc(var(--font-max) * 1rem)
    );
    font-weight: 800;
    color: #fff;
    background-color: #333;
    display: block;
    float: right;
    margin-top: 20px;
    padding: 8px 15px;
    cursor: pointer;
    border: none;
}


/* site_branding */
#site_branding {
    display: block;
    position: absolute;
    top: var(--site_branding-top);
    z-index: 2;
    left: auto;
    right: var(--site_branding-right);
    .subpage & {
        top: var(--subpage-site_branding-top);
    }
    a {
        --font-min: 0.8;
        --font-max: 1.4;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        color: #000;
        text-decoration: none;
        text-align: center;
        display: block;
        width: var(--site_branding-a-width);
        & small {
            font-size: 70%;
            margin-bottom: 1em;
        }
        & span {
            display: block;
        }
    }
}
#site_branding {
    --site_branding-top: 660px;
    --subpage-site_branding-top: 320px;
    --site_branding-right: calc(50% - 70px);
    --site_branding-a-width: 140px;
}
@media (width >= 375px)  { /* 375-789 */
    #site_branding {
        --site_branding-top: 720px;
        --subpage-site_branding-top: 380px;
        --site_branding-right: 16px;
        --site_branding-a-width: 140px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    #site_branding {
        --site_branding-top: 780px;
        --subpage-site_branding-top: 450px;
        --site_branding-right: 20px;
        --site_branding-a-width: 158px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #site_branding {
        --site_branding-top: 910px;
        --subpage-site_branding-top: 500px;
        --site_branding-right: 25px;
        --site_branding-a-width: 180px;
    }
}
@media (width >= 1400px) { /* 1400over */
    #site_branding {
        --site_branding-top: 1010px;
        --subpage-site_branding-top: 600px;
        --site_branding-right: 6%;
        --site_branding-a-width: 200px;
    }
}


/* first_block */
#first_block {
    position: relative;
    width: 100%;
    height: auto;
}


/* top_entry */
#entry_block {
    width: 100%;
    .top_entry {
        width: var(--top_entry-width);
        height: auto;
        padding-bottom: var(--top_entry-padding-bottom);
        margin-left: var(--top_entry-margin-left);
        & :is(h1, p) {
            color: #000;
            margin-bottom: 8px;
        }
        & h1 {
            --font-min: 1.4;
            --font-max: 3.3;
            
            font-size: clamp(
                calc(var(--font-min) * 1rem),
                calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
                calc(var(--font-max) * 1rem)
            );
            & em {
                font-style: normal;
                display: block;
                &.b_space {
                    margin-left: var(--top_entry-h1-em-b_space-margin-left);
                }
            }
        }
        & p {
            --font-min: 0.9;
            --font-max: 1.6;
            
            font-size: clamp(
                calc(var(--font-min) * 1rem),
                calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
                calc(var(--font-max) * 1rem)
            );
            font-weight: bold;
        }
    }
    .top_entry {
        --top_entry-width: calc(100% - 40px);
        --top_entry-padding-bottom: 40px;
        --top_entry-margin-left: 20px;
        --top_entry-h1-em-b_space-margin-left: 33px;
    }
    @media (width >= 375px)  { /* 375-789 */
        .top_entry {
            --top_entry-width: calc(100% - 60px);
            --top_entry-padding-bottom: 50px;
            --top_entry-margin-left: 30px;
            --top_entry-h1-em-b_space-margin-left: 80px;
        }
    }
    @media (width >= 790px)  { /* 790-999 */
        .top_entry {
            --top_entry-width: 427px;
            --top_entry-padding-bottom: 60px;
            --top_entry-margin-left: 40px;
            --top_entry-h1-em-b_space-margin-left: 134px;
        }
    }
    @media (width >= 1000px) { /* 1000-1400 */
        .top_entry {
            --top_entry-width: 510px;
            --top_entry-padding-bottom: 70px;
            --top_entry-margin-left: 5%;
            --top_entry-h1-em-b_space-margin-left: 156px;
        }
    }
    @media (width >= 1400px) { /* 1400over */
        .top_entry {
            --top_entry-width: 600px;
            --top_entry-padding-bottom: 90px;
            --top_entry-margin-left: 10%;
            --top_entry-h1-em-b_space-margin-left: 178px;
        }
    }
}


/* perspective_wrapper */
.perspective_wrapper {
    perspective: 2000px;
    padding: 0px;
    width: var(--perspective_wrapper-width);
    margin-left: var(--perspective_wrapper-margin-left);
    margin-right: var(--perspective_wrapper-margin-right);
    margin-bottom: 50px;

    .grid_container {
        display: grid;
        grid-template-columns: var(--grid_container-grid-template-columns);
        grid-template-rows: auto;
        /*grid-template-rows: repeat(3, 245px);*/
        gap: var(--grid_container-gap);
        transform-origin: right center;
        transform: rotateY(-7deg);
        transform-style: preserve-3d;
        
        .tile {
            aspect-ratio: 4 / 2.8;
            background-color: var(--tile-bg, #e0e0e0);
            transition: background 0.5s ease;

            padding: var(--tile-padding);
            display: flex;
            flex-direction: column;
            justify-content: flex-end;
            border: 1px solid rgba(0,0,0,0.05);
            color: #333;
            box-sizing: border-box;
            transform-style: preserve-3d;
            transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
            overflow: hidden;
            .tile_image {
                position: absolute;
                top: 10px;
                left: 10px;
                right: 10px;
                width: calc(100% - 20px);
                height: 100%;
                background-size: cover;
                background-position: center;
                background-repeat: no-repeat;
                opacity: 0.9;
            }
            & span {
                --font-min: 0.9;
                --font-max: 1.4;
                
                font-size: clamp(
                    calc(var(--font-min) * 1rem),
                    calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
                    calc(var(--font-max) * 1rem)
                );
                font-weight: 800;
                display: block;
                transform: translateZ(30px);
                text-shadow: 2px  2px 0 #fff, -2px  2px 0 #fff, 2px -2px 0 #fff, -2px -2px 0 #fff, 2px  0px 0 #fff, -2px  0px 0 #fff, 0px  2px 0 #fff, 0px -2px 0 #fff;
                & small {
                    font-size: 70%;
                    color: #fff;
                    text-shadow: none;
                    text-align: center;
                    display: block;
                    width: var(--tile-span-small-width);
                    padding: 5px 0;
                    margin-top: 8px;
                    transform: translateZ(15px);
                    &.cat_icon_a {
                        background-color: #62c25a;
                    }
                    &.cat_icon_b {
                        background-color: #554cc7;
                    }
                    &.cat_icon_c {
                        background-color: #a15b82;
                    }
                }
                & time {
                    font-size: 80%;
                    font-weight: normal;
                    color: #0b571b;
                    display: block;
                }
            }
            & a {
                color: #000;
                text-decoration: none;
                display: block;
                &:hover {
                    color: #f60;
                }
            }
            &:hover {
                background: #ffffff;
                transform: translateZ(40px);
            }
            &.white_priority {
                background: #ffffff;
                transform: translateZ(40px);
                box-shadow: 0 25px 50px rgba(0,0,0,0.15);
                border: none;
            }
        }
    }
}
.perspective_wrapper {
    --perspective_wrapper-width: calc(100% - 20px);
    --perspective_wrapper-margin-left: 10px;
    --perspective_wrapper-margin-right: 10px;
    --grid_container-grid-template-columns: repeat(1, calc(100% / 1 - 15px));
    --grid_container-gap: 20px;
    --tile-padding: 12px;
    --white_priority-em-margin-left: 40px;
    --tile-span-small-width: 58px;
}
@media (width >= 375px)  { /* 375-789 */
    .perspective_wrapper {
        --perspective_wrapper-width: calc(100% - 20px);
        --perspective_wrapper-margin-left: 10px;
        --perspective_wrapper-margin-right: 10px;
        --grid_container-grid-template-columns: repeat(2, calc(100% / 2 - 5px));
        --grid_container-gap: 10px;
        --tile-padding: 14px;
        --white_priority-em-margin-left: 40px;
        --tile-span-small-width: 64px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    .perspective_wrapper {
        --perspective_wrapper-width: calc(100% - 40px);
        --perspective_wrapper-margin-left: 20px;
        --perspective_wrapper-margin-right: 20px;
        --grid_container-grid-template-columns: repeat(3, calc(100% / 3 - 15px));
        --grid_container-gap: 20px;
        --tile-padding: 18px;
        --white_priority-em-margin-left: 40px;
        --tile-span-small-width: 74px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    .perspective_wrapper {
        --perspective_wrapper-width: calc(100% - 80px);
        --perspective_wrapper-margin-left: 40px;
        --perspective_wrapper-margin-right: 40px;
        --grid_container-grid-template-columns: repeat(3, calc(100% / 3 - 15px));
        --grid_container-gap: 20px;
        --tile-padding: 22px;
        --white_priority-em-margin-left: 60px;
        --tile-span-small-width: 82px;
    }
}
@media (width >= 1400px) { /* 1400over */
    .perspective_wrapper {
        --perspective_wrapper-width: 1400px;
        --perspective_wrapper-margin-left: auto;
        --perspective_wrapper-margin-right: auto;
        --grid_container-grid-template-columns: repeat(3, calc(100% / 3 - 15px));
        --grid_container-gap: 20px;
        --tile-padding: 25px;
        --white_priority-h1-font-size: 1.9rem;
        --white_priority-p-font-size: 1.2rem;
        --white_priority-em-margin-left: 100px;
        --tile-span-small-width: 100px;
    }
}


/* button_detail */
.button_detail {
    overflow: hidden;
    margin-top: var(--button_detail-margin-top);
    margin-bottom: var(--button_detail-margin-bottom);
    a {
        --font-min: 1.1;
        --font-max: 1.4;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        font-weight: 800;
        color: #000;
        text-decoration: none;
        display: flex;
        justify-content: center;
        align-items: center;
        width: var(--button_detail-width);
        height: var(--button_detail-height);
        margin-left: auto;
        margin-right: auto;
        background-image: url(image/base/button_detail_bg.svg);
        background-repeat: no-repeat;
        background-position: center center;
        background-size: 100% auto;
        text-shadow: 2px 2px 1px #fff, -2px 2px 1px #fff, 2px -2px 1px #fff, -2px -2px 1px #fff, 2px 0px 1px #fff, 0px 2px 1px #fff, -2px 0px 1px #fff, 0px -2px 1px #fff;
        &:hover {
            color: #f60;
        }
    }
}
.button_detail {
    --button_detail-margin-top: 20px;
    --button_detail-margin-bottom: 40px;
    --button_detail-width: 123px;
    --button_detail-height: 42px;
}
@media (width >= 375px)  { /* 375-789 */
    .button_detail {
        --button_detail-margin-top: 25px;
        --button_detail-margin-bottom: 45px;
        --button_detail-width: 142px;
        --button_detail-height: 45px;
    }
}
@media (width >= 790px)  { /* 790-999 */
    .button_detail {
        --button_detail-margin-top: 30px;
        --button_detail-margin-bottom: 50px;
        --button_detail-width: 158px;
        --button_detail-height: 52px;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    .button_detail {
        --button_detail-margin-top: 35px;
        --button_detail-margin-bottom: 55px;
        --button_detail-width: 180px;
        --button_detail-height: 57px;
    }
}
@media (width >= 1400px) { /* 1400over */
    .button_detail {
        --button_detail-margin-top: 40px;
        --button_detail-margin-bottom: 60px;
        --button_detail-width: 200px;
        --button_detail-height: 65px;
    }
}


/* middle_theme */
#middle_theme {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: var(--middle_theme-height);
    overflow: hidden;
    .middle_theme_image {
        width: 100%;
        height: 100%;
        & img {
            clip-path: url(#clip_middle_theme);
            -webkit-clip-path: url(#clip_middle_theme);
            object-position: center;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }
}
#middle_theme { 
    --middle_theme-height: 260px; 
}
@media (width >= 375px)  { /* 375-789 */
    #middle_theme { 
        --middle_theme-height: 290px; 
    }
}
@media (width >= 790px)  { /* 790-999 */
    #middle_theme { 
        --middle_theme-height: 570px; 
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #middle_theme { 
        --middle_theme-height: 700px; 
    }
}
@media (width >= 1400px) { /* 1400over */
    #middle_theme { 
        --middle_theme-height: 800px; 
    }
}


/* under_theme */
#under_theme {
    width: 100%;
    height: var(--under_theme-height);
    overflow: hidden;
    .under_theme_image {
        width: 100%;
        height: 100%;
        img {
            clip-path: url(#clip_under_theme);
            -webkit-clip-path: url(#clip_under_theme);
            object-position: center;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }
}
#under_theme { 
    --under_theme-height: 200px; 
}
@media (width >= 375px)  { /* 375-789 */
    #under_theme { --under_theme-height: 300px; }
}
@media (width >= 790px)  { /* 790-999 */
    #under_theme { --under_theme-height: 400px; }
}
@media (width >= 1000px) { /* 1000-1400 */
    #under_theme { --under_theme-height: 500px; }
}
@media (width >= 1400px) { /* 1400over */
    #under_theme { --under_theme-height: 600px; }
}


/* under_logo */
#under_logo {
    & a {
        --font-min: 2.0;
        --font-max: 4.6;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        color: #000;
        text-align: center;
        text-decoration: none;
        display: block;
        width: 100%;
        margin-top: 50px;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 30px;
        &:hover {
            color: #e60;
        }
    }
}


/* company_area */
#company_area_spc {
    width: var(--company_area_spc-width);
    margin-left: var(--company_area_spc-left);
    margin-right: var(--company_area_spc-right);
    padding-top: 0px;
    padding-bottom: 20px;
    overflow: hidden;
    #company_area {
        text-align: center;
        overflow: hidden;
        width: 100%;
        padding-bottom: 30px;
        .under_logo {
            display: block;
            width: 100%;
            height: var(--under_logo-height);
            background-image: url(image/base/logo.svg);
            background-size: var(--under_logo-width) auto;
            background-repeat: no-repeat;
            background-position: center center;
            transition: 0.2s;
        }
        .company_profile {
            --font-min: 0.9;
            --font-max: 1.4;
            
            font-size: clamp(
                calc(var(--font-min) * 1rem),
                calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
                calc(var(--font-max) * 1rem)
            );
            padding-top: var(--company_profile-padding-top);
            padding-bottom: 2px;
            & ul {
                margin-bottom: 15px;
            }
        }
    }
    .company_detail {
        --font-min: 0.9;
        --font-max: 1.4;
        
        font-size: clamp(
            calc(var(--font-min) * 1rem),
            calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
            calc(var(--font-max) * 1rem)
        );
        text-align: center;
        overflow: hidden;
        width: var(--company_detail-width);
        height: auto;
        padding-top: 20px;
        margin-left: auto;
        margin-right: auto;
        & ul {
            & li {
                padding-top: 8px;
                & small {
                    font-size: 70%;
                    display: block;
                    color: #333;
                }
            }
        }
    }
}
#company_area_spc {
    --company_area_spc-width: calc(100% - 20px);
    --company_area_spc-left: 10px;
    --company_area_spc-right: 10px;
    --company_name-width: 175px;
    --under_logo-width: 131px;
    --under_logo-height: 84px;
    --company_profile-padding-top: 2px;
    --company_detail-width: calc(100% - 20px);
}
@media (width >= 375px)  { /* 375-789 */
    #company_area_spc {
        --company_area_spc-width: calc(100% - 20px);
        --company_area_spc-left: 10px;
        --company_area_spc-right: 10px;
        --company_name-width: 230px;
        --under_logo-width: 138px;
        --under_logo-height: 92px;
        --company_profile-padding-top: 5px;
        --company_detail-width: calc(100% - 20px);
    }
}
@media (width >= 790px)  { /* 790-999 */
    #company_area_spc {
        --company_area_spc-width: calc(100% - 20px);
        --company_area_spc-left: 10px;
        --company_area_spc-right: 10px;
        --company_name-width: 247px;
        --under_logo-width: 190px;
        --under_logo-height: 116px;
        --company_profile-padding-top: 9px;
        --company_detail-width: calc(100% - 20px);
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    #company_area_spc {
        --company_area_spc-width: 1000px;
        --company_area_spc-left: auto;
        --company_area_spc-right: auto;
        --company_name-width: 309px;
        --under_logo-width: 210px;
        --under_logo-height: 130px;
        --company_profile-padding-top: 13px;
        --company_detail-width: 820px;
    }
}
@media (width >= 1400px) { /* 1400over */
    #company_area_spc {
        --company_area_spc-width: 1400px;
        --company_area_spc-left: auto;
        --company_area_spc-right: auto;
        --company_name-width: 340px;
        --under_logo-width: 230px;
        --under_logo-height: 148px;
        --company_profile-padding-top: 16px;
        --company_detail-width: 900px;
    }
}


/* under_nav */
#under_nav {
    overflow: hidden;
    & ul {
        padding-top: 40px;
        padding-bottom: 10px;
        & li {
            width: 300px;
            margin-left: auto;
            margin-right: auto;
            & a {
                --font-min: 0.8;
                --font-max: 1.2;
                
                font-size: clamp(
                    calc(var(--font-min) * 1rem),
                    calc((var(--font-min) + (var(--font-max) - var(--font-min)) * var(--progress)) * 1rem),
                    calc(var(--font-max) * 1rem)
                );
                color: #000;
                text-decoration: none;
                text-align: center;
                padding: 5px 0;
                display: block;
                width: 100%;
                &:hover {
                    color: #f60;
                }
            }
        }
    }
}


/* copy_design */
#copy_design {
    height: 145px;
    text-align: center;
    #copy {
        font-size: 0.9rem;
        padding-top: 29px;
        padding-bottom: 10px;
    }
}


/* smf-form */
.smf-form {
    text-align: left;
    padding-top: 15px;
    padding-left: 15px;
    padding-right: 10px;
}
.wp-block-snow-monkey-forms-item {
    padding-bottom: 10px;
}
.smf-item__col--label {
    font-size: 1.0rem;
    font-weight: bold;
}
.smf-item__description {
        font-size: 80%!important;
        font-weight: normal;
        color: #333;
}
.smf-form input,
.smf-form textarea {
    font-size: 0.8rem;
}
.smf-placeholder {
    font-size: 0.8rem;
    padding-top: 10px;
    padding-bottom: 10px;
    background-color: #858974;
    padding-left: 10px;
    padding-right: 10px;
    margin-top: 4px;
    margin-bottom: 15px;
    border-radius: 9px;
}
.smf-form .smf-text-control__control,
.smf-form .smf-textarea-control__control {
    background-color: #f1f1f1;
    line-height: 1.6;
}
.smf-action .smf-button-control__control {
    font-size: 1.0rem;
    color: #fff;
    background-color: #257370;
    background-image: none;
    border: none;
    margin-top: 20px;
    margin-bottom: 20px;
}
.smf-control-description {
    font-size: 1.4rem;
    color: #000;
}
.smf-progress-tracker__item[aria-current=true] .smf-progress-tracker__item__number {
    background-color: #858974;
}
.smf-progress-tracker__item__number {
    width: 35px;
    height: 35px;
}
.smf-label {
    float: left;
    margin-right: 10px;
}
.smf-checkboxes-control__control {
    overflow: hidden;
}
@media (width >= 375px)  { /* 375-789 */
    .smf-item__col--label {
        font-size: 1.2rem;
    }
    .smf-form input,
    .smf-form textarea  {
        font-size: 1.0rem;
    }
    .smf-placeholder {
        font-size: 1.0rem;
    }
    .smf-action .smf-button-control__control {
        font-size: 1.2rem;
    }
}
@media (width >= 790px)  { /* 790-999 */
    .smf-item__col--label {
        font-size: 1.4rem;
    }
    .smf-form input,
    .smf-form textarea  {
        font-size: 1.2rem;
    }
    .smf-placeholder {
        font-size: 1.2rem;
    }
    .smf-action .smf-button-control__control {
        font-size: 1.4rem;
    }
}
@media (width >= 1000px) { /* 1000-1400 */
    .smf-item__col--label {
        font-size: 1.6rem;
    }
    .smf-form input,
    .smf-form textarea {
        font-size: 1.3rem;
    }
    .smf-placeholder {
        font-size: 1.3rem;
    }
    .smf-action .smf-button-control__control {
        font-size: 1.6rem;
    }
}
@media (width >= 1400px) { /* 1400over */
    .smf-item__col--label {
        font-size: 1.8rem;
    }
    .smf-form input,
    .smf-form textarea  {
        font-size: 1.5rem;
    }
    .smf-placeholder {
        font-size: 1.5rem;
    }
    .smf-action .smf-button-control__control {
        font-size: 1.8rem;
    }
}