/*
Theme Name: 後藤機工オリジナルテーマ
*/

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{-webkit-appearance:none;appearance:none;border-radius:0}input[type="search"]{-webkit-appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:500}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;transition:all 0.5s ease}

body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;line-height:normal;word-wrap:break-word;}

h1, h2, h3, h4, h5, h6{font-weight:500;margin:0}
/* h1{font-size:35px}
h2{font-size:30px}
h3{font-size:25px}
h4{font-size:20px}
h5{font-size:18px}
h6{font-size:16px} */
a:hover, a:focus{text-decoration:none}
strong{font-weight:500}
em{font-style:italic}
pre{overflow-x:auto;white-space:pre-wrap}
pre, code{font-family:'courier new',courier,serif}
hr{height:1px;border:0;margin:30px 0;background:#ccc}
blockquote{padding:15px;border-left:4px solid #ccc;margin:30px 0}
blockquote p:first-of-type{margin-top:0}
.entry-content ul, .widget-container ul, .comment-body ul, .entry-content ol, .widget-container ol, .comment-body ol{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;margin:30px 0 30px 60px}
.entry-content ul ul, .widget-container ul ul, .comment-body ul ul, .entry-content ol ol, .widget-container ol ol, .comment-body ol ol, .entry-content ul ol, .widget-container ul ol, .comment-body ul ol, .entry-content ol ul, .widget-container ol ul, .comment-body ol ul{margin-top:0;margin-bottom:0}
.entry-content ol, .widget-container ol, .comment-body ol{list-style:decimal outside;list-style-type:decimal-leading-zero;margin-left:70px}
.entry-content ul li, .widget-container ul li, .comment-body ul li{list-style-type:'— '}
.entry-content li, .widget-container li, .comment-body li{line-height:125%;margin:20px 0}
input, textarea{font-size:16px;padding:15px;border:0;border-bottom:1px solid transparent;outline:0;margin-top:10px;background:#f6f6f6}
input:focus, textarea:focus{border-bottom:1px solid #007acc}
input[type="submit"], button, .button{display:inline-block;font-size:18px;color:#fff;text-align:center;text-decoration:none;padding:15px 25px;border:0;background:#007acc;cursor:pointer}
input[type="submit"]:hover, input[type="submit"]:focus, button:hover, button:focus, .button:hover, .button:focus{opacity:0.8}
a img, input[type="image"], iframe{border:0}
a img:hover, a:focus img, a svg:hover, a:focus svg{opacity:0.8}
img, img[src$=".svg"], svg{display:inline-block;line-height:normal;vertical-align:middle}
img, video, audio, table, select, textarea{max-width:100% !important;height:auto}
table{width:100%;margin:30px 0}

#wrapper{display:flex;flex-direction:column;max-width:100%;min-height:100vh;margin:0 auto}
#logo{max-height:100%}
#container{flex:1;background:#fff}
#content{width:75%;padding-right:5%;float:left}
#content.full-width{width:100%;padding-right:0;float:none}
#sidebar{width:25%;float:right}
#footer{clear:both}

.header-nav__menu li.menu-item-has-children > a:after, .header-nav__menu li.page_item_has_children > a:after{font-family:serif;content:' ▾';line-height:0}
.header-nav__menu li.current-menu-item a, .header-nav__menu li.current_page_parent a{}
.header-nav__menu a{display:inline-block;color:#fff;text-align:right;text-decoration:none;}
.header-nav__menu a:hover, .header-nav__menu a:focus{color:#767676;text-decoration:none}
.header-nav__menu ul.sub-menu, .header-nav__menu ul.children{position:absolute;display:block;top:100%;left:-9999px;margin-top:20px;transition:unset;z-index:1000}
.header-nav__menu ul.sub-menu a, .header-nav__menu ul.children a{width:200px;font-size:14px;color:#333;text-align:left;line-height:20px;padding:15px;border:1px solid #eee;background:#fff}
.header-nav__menu ul.sub-menu a:hover, .header-nav__menu ul.sub-menu a:focus, .header-nav__menu ul.children a:hover, .header-nav__menu ul.children a:focus{color:#767676;background:#f7f7f7}
.header-nav__menu li.menu-item-has-children a:hover + ul.sub-menu, .header-nav__menu li.menu-item-has-children a:focus + ul.sub-menu, .header-nav__menu li.menu-item-has-children a + ul.sub-menu:hover, .header-nav__menu li.menu-item-has-children a + ul.sub-menu:focus-within, .header-nav__menu li.page_item_has_children a:hover + ul.children, .header-nav__menu li.page_item_has_children a:focus + ul.children, .header-nav__menu li.page_item_has_children a + ul.children:hover, .header-nav__menu li.page_item_has_children a + ul.children:focus-within{left:0}
.header-nav__menu .menu-toggle{display:none;color:#fff;text-align:center;padding:0;border:0;margin:0;background:none;transition:unset}
.header-nav__menu .menu-icon{font-size:50px}

#search{float:right}
#search .search-field{width:36px;height:36px;color:transparent;padding:10px;border-color:transparent;margin-top:0;background-color:#transparent;background-image:url(images/find-light.png);cursor:pointer}
#search .search-field:focus{width:200px;color:#fff;border-color:#007acc;cursor:text}
.widget-container .search-field{width:100%}
.error404 .entry-content .search-field, .search .entry-content .search-field{width:200px;margin-top:30px}
.error404 .entry-content .search-field, .search .entry-content .search-field, .widget-container .search-field{background-color:#f6f6f6}
.search-field{background:url(images/find.png) no-repeat 98% center / 24px auto}

#site-title h1, #site-title a{display:inline-block;font-size:40px;font-weight:normal;color:#fff;text-decoration:none;margin-bottom:0}
#site-description, #copyright, #copyright a{color:#8a8a8a}
.single h1.entry-title a{color:#767676;text-decoration:none}
h2.entry-title, h3.widget-title{margin-top:0}
#commentform label{display:block}
#commentform #comment{width:100%;max-width:400px !important;height:auto}
#comments .comment-author{line-height:14px}
#comments .comment-author img{margin-right:5px;float:left}
#comments .comment{margin:20px 10px}
#comments .comment-body{padding:15px}
#comments .odd > .comment-body{background:#f6f6f6}
#comments .comment-body > p{font-size:16px;margin:15px 0 0}
#copyright{text-align:center}
.entry-meta, .entry-footer, .archive-meta{margin:30px 0}
.entry-footer{clear:both}
.entry-meta, .entry-meta a, .entry-footer, .entry-footer a, .comment-meta, .comment-meta a, .comment-author, .comment-author a{font-size:14px;color:#767676}

.sticky{padding-bottom:60px;border-bottom:4px solid #ccc}
.bypostauthor{}
.post, .widget-container, .search article{margin-bottom:60px}
.post:last-of-type{margin-bottom:0}
.wp-caption{width:auto !important}
.wp-caption.aligncenter, .wp-caption-text, .gallery-caption{text-align:center}
.wp-block-gallery ul, .wp-block-gallery ul li, .wp-block-gallery ul li:before{content:'';margin:0}
.wp-post-image{display:block;margin-bottom:30px}
.entry-attachment img{display:block;margin:60px auto 30px}
.attachment .entry-caption{text-align:center}
.alignleft{margin:0 30px 30px 0;float:left}
.alignright{margin:0 0 30px 30px;float:right}
.aligncenter{display:block;margin:30px auto;clear:both}
#content p.wp-block-cover-text{color:#fff}
.nav-links{margin-top:30px}
.nav-links a, #nav-above a{text-decoration:none}
#nav-above a{display:block;font-family:tahoma,sans-serif;font-size:50px;color:#767676;line-height:0;margin:30px 0 15px}
.nav-previous{text-align:left;float:left}
.nav-next{text-align:right;float:right}

.note{display:block;font-size:14px;padding:20px;margin:30px 0}
.icon{display:inline-block;width:32px;height:32px;line-height:normal;vertical-align:middle;mask-size:cover;background-color:currentColor}
.symbol{font-family:"Times","Times New Roman","serif","sans-serif",system-ui,-apple-system,BlinkMacSystemFont,"Avenir Next","Avenir","Segoe UI","Lucida Grande","Helvetica Neue","Helvetica","Fira Sans","Roboto","Noto","Droid Sans","Cantarell","Oxygen","Ubuntu","Franklin Gothic Medium","Century Gothic","Liberation Sans",sans-serif,"EmojiSymbols"}

.round{border-radius:100px}
.circle{border-radius:50%}

.blue, .blue *, .blue-dark, .blue-dark *, .green, .green *, .green-dark, .green-dark *, .orange, .orange *, .purple, .purple *, .red, .red *, .black, .black *{color:#fff}
.white, .white *, .yellow, .yellow *{color:#000}
.white{background-color:#fff !important}
.blue{background-color:#007acc !important}
.blue-dark{background-color:#1c78b5 !important}
.green{background-color:#91da29 !important}
.green-dark{background-color:#5d8c1a !important}
.orange{background-color:#f98733 !important}
.purple{background-color:#bb6cf8 !important}
.red{background-color:#ef645d !important}
.yellow{background-color:#f8f658 !important}
.black{background-color:#4a4a45 !important}
.lighter{background-color:rgba(255,255,255,0.05)}
.darker{background-color:rgba(0,0,0,0.05)}
.overlay:before{position:fixed;top:0;left:0;width:100%;height:100%;content:'';background:rgba(0,0,0,0.5);z-index:0}

.layer{width:100%;padding:5%}
.layer-inner{max-width:800px;margin:0 auto}

.box, .box-2, .box-3, .box-4, .box-5, .box-6, .box-1-3, .box-2-3{display:inline-block;width:100%;padding:5%;vertical-align:top;float:left}
.box-2{width:50%}
.box-3, .box-1-3{width:33.3333333%}
.box-4{width:25%}
.box-5{width:20%}
.box-6{width:16.6666667%}
.box-2-3{width:66.6666666%}

.left{text-align:left}
.center{text-align:center}
.right{text-align:right}
.float-left{float:left}
.float-right{float:right}
.clear{clear:both}
.clear-left{clear:left}
.clear-right{clear:right}
.clear-float:after, #header:after, #container:after, .boxes:after{display:table;content:'';clear:both}
.offset{padding-top:100px;margin-top:-100px}
.spacer{display:inline-block;width:25px}
.mobile, .desktop{display:none}

@media(max-width:1024px){.box-5, .box-6{width:25%}.boxes .box-5:nth-child(5){width:100%}.boxes .box-6:nth-child(5), .boxes .box-6:nth-child(6){width:50%}}
@media(min-width:769px){#logo-container{display:block;height:35px;margin-bottom:10px}.desktop{display:block}}
@media(max-width:768px){#header, #footer{text-align:center}#content, #sidebar{width:100%;padding:0}#branding, .header-nav__menu, .header-nav__menu div:first-of-type, #search{float:none}#search{margin-top:20px}#search .search-field{width:100%;color:#fff;border-color:#8a8a8a;cursor:text}#search .search-field:focus{width:100%}.box-4, .box-5, .box-6{width:50%}.mobile{display:block}}
@media(max-width:767px){.single .nav-links .nav-previous, .single .nav-links .nav-next{float:none}.box-3{width:50%}.boxes .box-3:nth-child(3){width:100%}}
@media(max-width:576px){.wp-caption, input, textarea, .button{width:100% !important}input[type="checkbox"], input[type="radio"]{width:auto !important}.box-2, .box-3, .box-4, .box-5, .box-6, .boxes .box-6:nth-child(5), .boxes .box-6:nth-child(6), .box-2-3, .box-1-3{width:100%}.spacer{display:block;width:100%;height:30px}}
/* @media(prefers-color-scheme:light){body, #container{background:#fff}#header{background:#111}}
@media(prefers-color-scheme:dark){body, #container{background:#111}} */
@media print{*{color:#000 !important;background:#fff !important}body{padding:50px !important;margin:0 !important}#content{display:block !important;padding:0 !important;margin:0 !important}#header, #sidebar, #footer, #comments, .entry-footer, .navigation, .share, .video-wrap, iframe, img{display:none !important}}

.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:#f7f7f7;border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;-webkit-clip-path:none;clip-path:none;color:#007acc;display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}
.looper{display:none}
.search-submit{display:none !important}

/* 全体設定 */
body {
    --color-navy: #00365a;
    --color-lightblue: #c0f4ea;
    --color-gray: #f5f4fa;
    font-family: "Noto Sans JP", -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.175em;
}

/* ヘッダー */
.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: var(--color-navy);
    z-index: 100;
}
.header .header-inner {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 2em;
    width: 100%;
    box-sizing: border-box;
    padding: 10px 30px 20px;
}
.header .logo-container .logo {
    width: 300px;
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
    max-width: 100%;
}
.header-nav__menu .menu {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 2.5em;
}
.header-content__left {
    flex: 1;
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
}
.header-nav__menu {
    margin: 0 2.5em;
}
.header-nav__contact {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    color: #fff;
    gap: 1.15em;
    margin-top: 0.5em;
}
.header-nav__contact__item img {
    width: auto;
    height: 0.8em;
}
.header-nav__contact__item.mail img {
    height: 0.75em;
}
.header-nav__contact__item__inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}
.header-nav__contact__item a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    height: 100%;
    gap: 0.85em;
    padding: 0.5em 0;
}
.header-nav__contact__item a::before {
    content: "";
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
}
.header-nav__contact__item.tel a::before {
    background: url(images/icon_tel_wh.svg) no-repeat center / contain;
}
.header-nav__contact__item.tel .time {
    display: block;
    margin-top: 0.5em;
    font-size: 10px;
    letter-spacing: 0.15em;
}
.header-nav__contact__item.mail a {
    padding-left: 1.25em;
    padding-right: 0.65em;
    border-left: 1px solid #fff;
}
.header-nav__contact__item.mail a::before {
    background: url(images/icon_mail_wh.svg) no-repeat center / contain;
}
.header-nav__menu__drawer .menu-close,
.header-nav__contact__drawer,
.header-nav__logo__drawer {
    display: none;
}
.header-nav__menu .menu .drawer-only {
    display: none;
}
@media (max-width: 1280px) {
    .header-nav__menu__drawer .menu-close,
    .header-nav__logo__drawer {
        display: block;
    }
    .header-content__right {
        padding-right: 60px;
    }
    .header-nav__menu .menu-toggle {
        position: absolute;
        top: 10px;
        right: 20px;
        margin: 0;
    }
    .header-nav__menu .header-nav__menu__container {
        display: block;
        width: 400px;
        height: auto;
        position: absolute;
        top: 0;
        right: 0;
        overflow-x: hidden;
        overflow-y: auto;
        box-sizing: border-box;
        padding: 40px 30px;
        padding-top: 70px;
        z-index: 1000;
        background: var(--color-navy);
        color: #fff;
        transform: translateX(100%);
    }
    .header-nav__menu.toggled .header-nav__menu__container {
        transform: translateX(0);
    }
    .header-nav__menu .menu-toggle {
        display: inline-block
    }
    .header-nav__menu .menu {
        flex-direction: column;
        gap: 1.5em;
    }
    .header-nav__contact__drawer {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        gap: 20px;
        margin: 40px auto;
    }
    .header-nav__contact__drawer .header-nav__contact__item {
        background: #fff;
        width: 100%;
    }
    .header-nav__contact__drawer .header-nav__contact__item.mail {
        padding: 0;
        border: none;
    }
    .header-nav__contact__drawer .header-nav__contact__item a {
        width: 100%;
        justify-content: center;
        padding: 1.25em 1em;
        color: var(--color-navy);
    }
    .header-nav__menu__drawer .header-nav__contact__item.tel a::before {
        background: url(images/icon_tel_bl.svg) no-repeat center / contain;
    }
    .header-nav__menu__drawer .header-nav__contact__item.mail a::before {
        background: url(images/icon_mail_bl.svg) no-repeat center / contain;
    }
    .header-nav__logo__drawer img {
        width: 100%;
        height: auto;
        vertical-align: bottom;
        padding: 0 20px;
    }
    .header-nav__menu__drawer .menu-close {
        position: absolute;
        top: 20px;
        right: 20px;
        font-size: inherit;
        padding: 0;
        width: 2em;
        height: 2em;
        background: none;
    }
    .header-nav__menu__drawer .menu-icon-close {
        display: inline-block;
        width: 100%;
        height: 100%;
        background: url(images/icon_cross_wh.svg) no-repeat center / contain;
    }
    .header-nav__menu .menu .drawer-only {
        display: block;
    }
}
@media (max-width: 768px) {
    .header-nav__menu .header-nav__menu__container {
        width: 90vw;
        height: 100vh;
    }
    .header-content__right {
        display: none;
    }
    #site-title h1, #site-title a {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .header .header-inner {
        padding: 12px;
    }
    .header .logo-container .logo {
        width: 70%;
        height: auto;
    }
    .header .logo-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .header-nav__menu .menu-icon {
        font-size: 2em;
    }
    .header-nav__menu .menu-toggle {
        display: flex;
        justify-content: center;
        align-items: center;
        top: 4px;
        right: 12px;
    }
}

/* フッター */
.footer {
    background: var(--color-navy);
    color: #fff;
    font-size: 17px;
    text-align: center;
    position: relative;
    z-index: 10;
}
.footer-inner {
    padding: 3em 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2em;
}
.footer-nav .menu {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
    letter-spacing: 0.25em;
}
.footer-nav .menu-item {
    display: flex;
    justify-content: center;
    align-items: center;
}
.footer-nav .menu-item:not(:first-child)::before {
    content: "";
    display: inline-block;
    width: 1px;
    height: 1em;
    margin-right: 1em;
    background: #fff;
}
.footer-nav .menu-item a {
    color: #fff;
    text-decoration: none;
}
.footer-copyright {
    letter-spacing: 0.25em;
}

/* トップページ */
/* 共通要素 */
a:hover {
    opacity: .7;
    cursor: pointer;
}
.inner {
    width: 1100px;
    max-width: 100%;
    margin: 0 auto;
}
.bg-white {
    background: #fff;
}
.bg-gray {
    background: var(--color-gray);
}
.bg-navy {
    background: var(--color-navy);
}
.bg-lightblue {
    background: var(--color-lightblue);
}
.page-wrapper .section {
    margin: 120px 0;
}
.page-wrapper .section:last-of-type {
    margin-bottom: 0;
}
.page-wrapper .section .section-title {
    margin: 0 0 2.75em;
    font-size: 30px;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.25em;
}
.page-wrapper .section .section-text {
    margin-bottom: 1.7em;
    font-size: 17px;
    text-align: center;
    line-height: 2;
}
.--arrow > * {
    position: relative;
}
.--arrow > *::after {
    content: "";
    width: 2.5em;
    height: 1em;
    display: inline-block;
    position: absolute;
    top: 50%;
    right: 1.75em;
    transform: translateY(-50%);
    background: url(images/icon_arrow.svg) no-repeat center / contain;
}
/* 選ばれる理由 */
.section.sec-feature {
    margin: 0 0 160px;
    padding-top: 190px;
}
.sec-feature .section-title {
    margin-bottom: 2em;
}
.sec-feature__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 160px;
    row-gap: 120px;
}
.sec-feature__item__pic img {
    border-radius: 20px;
    width: 100%;
    height: auto;
    vertical-align: bottom;
}
.sec-feature__item__title {
    padding: 1.5em 0 1.25em;
    border-bottom: 3px solid;
    font-size: 22px;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.25em;
    color: var(--color-navy);
}
.sec-feature__item__text {
    margin-top: 1.25em;
    letter-spacing: 0.25em;
    line-height: 1.75;
}
/* 業務内容 */
.section.sec-menu {
    margin-top: 0;
    padding-top: 160px;
}
.section.sec-menu .section-title {
    margin-bottom: 3.5em;
}
.sec-menu__pic img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    vertical-align: bottom;
}
.sec-menu__container + .sec-menu__container {
    margin-top: 70px;
}
.sec-menu__desc {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}
.sec-menu__desc__title {
    width: 11em;
    padding-top: 1.95em;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.25em;
    color: var(--color-navy);
}
.sec-menu__desc__text {
    flex: 1;
    box-sizing: border-box;
    padding: 2.5em 2em 1em;
    padding-right: 0;
    margin: 0;
    border-left: 1px solid;
    line-height: 2;
}
.sec-menu__more-button {
    text-align: center;
}
.sec-menu__more-button a {
    position: relative;
    display: inline-block;
    color: var(--color-navy);
    text-decoration: none;
    background: var(--color-lightblue);
    padding: 0.5em;
    padding-right: 2.5em;
    margin-top: 2.5em;
    max-width: 100%;
    width: 300px;
    border-radius: 2em;
    box-sizing: border-box;
    line-height: 1.75;
    font-weight: 500;
}
.sec-menu__more-button.--arrow a::after {
    width: 2.75em;
    right: 2.5em;
}
.section-button.sec-menu__button {
    text-align: center;
}
.section-button.sec-menu__button a {
    position: relative;
    display: inline-block;
    color: var(--color-navy);
    text-decoration: none;
    padding: 0.75em;
    padding-right: 2em;
    margin: 7em auto 4em;
    max-width: 100%;
    width: 520px;
    font-size: 22px;
    font-weight: 500;
    border-radius: 2em;
    box-sizing: border-box;
    border: 1px solid;
    letter-spacing: 0.25em;
}
.section-button.sec-menu__button.--arrow a::after {
    width: 2em;
    right: 5.5em;
}
.sec-menu__attention {
    text-align: center;
    padding: 2.5em;
    border-radius: 20px;
    line-height: 2;
}
.sec-menu__attention__title span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 1em;
    font-weight: 400;
    font-size: 20px;
    border-bottom: 1px solid;
    padding: 0 0 0.5em;
    margin-bottom: 0.75em;
}
.sec-menu__attention__title span::before {
    content: "";
    display: inline-block;
    width: 1.75em;
    height: 1.75em;
    background: url(images/icon_attention.svg) no-repeat center / contain;
}
.sec-menu__attention__text {
    line-height: 1.75;
}

/* 技術者資格保有 */
.section.sec-license .section-title {
    margin-bottom: 1em;
}
.section.sec-license .section-text {
    line-height: 2.25;
    letter-spacing: 0.25em;
    margin-bottom: 5em;
}

/* 教育制度 */
.section.sec-training {
    position: relative;
    margin-bottom: 0;
}
.sec-training__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(((100vw - 1100px) / 2) + (1100px * 0.3));
    height: 100%;
    background: url(images/bg_sec-training01.jpg) no-repeat center / cover;
    display: inline-block;
}
.sec-training__wrapper {
    width: 63.5%;
    margin-left: auto;
    text-align: left;
    box-sizing: border-box;
    padding: 70px 100px;
    padding-right: 0;
}
.section .section-title.sec-training__heading {
    text-align: left !important;
    margin-bottom: 0.5em;
    line-height: 1.65;
}
.sec-training__desc {
    text-align: left !important;
}
.sec-training__button a {
    text-decoration: none;
    color: var(--color-navy);
    display: inline-block;
    padding: 1em 3em;
    padding-right: 5em;
    background: #fff;
    letter-spacing: 0.275em;
    line-height: 1;
    font-weight: 500;
}
/* 技術者資格保有 */
.section.sec-license {
    margin-bottom: 180px;
}
.sec-license__table__wrapper {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 40px;
}
.sec-license__table__box {
    border: 1px solid var(--color-navy);
    color: var(--color-navy);
}
.sec-license__table__title {
    font-size: 22px;
    font-weight: 500;
    text-align: center;
    padding: 0.75em;
    border-bottom: 1px solid;
    line-height: 1.35;
    letter-spacing: 0.25em;
}
.sec-license__table__desc.--col2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
.sec-license__table__list__wrapper {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    font-size: 15px;
    line-height: 2.25;
    padding: 2.25em 2em;
}
.sec-license__table__list__wrapper:not(:last-child) {
    border-right: 1px solid;
}
.sec-license__table__item {
    color: #000;
    letter-spacing: 0.25em;
}
/* よくある質問 */
.section.sec-faq {
    padding: 100px 0;
}
.section.sec-faq .section-title {
    margin-bottom: 4em;
}
.sec-faq__item_question {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    font-size: 125%;
    font-weight: 500;
    color: var(--color-navy);
    line-height: 1.5;
}
 .sec-faq__item_question span {
    flex: 1;
}
.sec-faq__item_answer {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-top: 1.5em;
    margin-left: 0;
    line-height: 2;
}
.sec-faq__item:not(:last-child) {
    margin-bottom: 3.5em;
}
.sec-faq__item_question::before {
    content: "";
    display: inline-block;
    width: 2em;
    height: 2em;
    font-size: initial;
    margin-right: 0.75em;
    background: url(images/icon_question.svg) no-repeat center / contain;
}
.sec-faq__item_answer::before {
    content: "";
    display: inline-block;
    width: 2em;
    height: 2em;
    margin-top: 0.2em;
    margin-right: 0.75em;
    background: url(images/icon_answer.svg) no-repeat center / contain;
}
.sec-faq__item_answer span {
    flex: 1;
}
/* お問い合わせ */
.section.sec-contact {
    margin-top: 170px;
}
.sec-contact__list {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 70px;
}
.sec-contact .sec-contact__item {
    margin: 0;
}
/* 代表挨拶 */
.section.sec-message {
    margin-top: 170px;
    margin-bottom: 220px;
}
.sec-message__box {
    border: 1px solid;
    box-sizing: border-box;
    padding: 5em 3em 3.5em;
    font-size: 17px;
    line-height: 2.25;
    letter-spacing: 0.25em;
}
.sec-message__box .name {
    margin-top: 1.75em;
    display: block;
    text-align: right;
    font-size: 130%;
    letter-spacing: 0.25em;
}
.sec-message__box .name .text-sm {
    display: inline-block;
    font-size: 68%;
    margin-right: 2em;
}
/* 会社概要 */
.section.sec-company {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin: 0 !important;
}
.section.sec-company .section-title {
    text-align: left;
    margin-bottom: 1.75em;
}
.sec-company__content {
    padding: 120px 100px 150px;
    box-sizing: border-box;
}
.sec-company__list {
    font-size: 17px;
    line-height: 1.5;
}
.sec-company__item {
    display: flex;
    justify-content: flex-start;
    padding: 1.25em 0;
    border-top: 1px solid;
    gap: 2.5em;
}
.sec-company__item:last-child {
    border-bottom: 1px solid;
}
.sec-company__item__title {
    width: 8em;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    font-weight: 500;
}
.sec-company__item__text {
    flex: 1;
    margin: 0;
}
.sec-company__item__text span {
    display: inline-block;
}
.sec-company__notice {
    margin-top: 0.5em;
    font-size: 15px;
    text-align: right;
    letter-spacing: 0.05em;
}

/*----------------------------------------
key-visual
----------------------------------------*/
.p-main-content {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
}
@media screen and (max-width: 767px) {
    .p-main-content {
        padding: 52px 0 0;
    }
}
.p-main-content-mv {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100vh;
    min-height: 640px;
    aspect-ratio: 4 / 3;
    padding: 0;
    justify-content: center;
    align-items: flex-end;
    background: transparent;
}
@media screen and (max-width: 767px) {
    .p-main-content-mv {
        position: relative;
        height: calc(100vh - 60px);
        min-height: 500px;
        margin: 0;
        padding: 0;
        -webkit-box-align: center;
                align-items: center;
        -webkit-box-pack: end;
                justify-content: flex-end;
    }
}
/* key-visual */
.key-visual {
    position: fixed;
    z-index: 0;
    top: 0;
    left: 0;
    width: 76.5%;
    height: 100%;
    min-height: 100vh;
}
@media screen and (max-width: 767px) {
    .key-visual {
        width: 100%;
    }
}
@media screen and (min-width: 1025px) {
    [data-menu="active"] .key-visual {
        width: calc(68.75% - 7px);
    }
}
.key-visual__inner {
    height: 100%;
}
.key-visual__slider {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
    min-height: 640px;
    background-repeat: no-repeat;
    background-size: cover;
}
.key-visual__slider__item {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: #fff;
}
.key-visual__slider__item img {
    position: absolute;
    top: 0;
    right: -5%;
    width: 100%;
    height: auto;
    transform: scale(1.2);
    transition: 5s;
    animation: move-slide 20s;
}
.key-visual__slider__item:not(.swiper-slide-active) img {
    animation: move-back-slide 20s;
}
@keyframes move-slide {
    0% {
        right: -5%;
    }
    50% {
        right: 0;
    }
}
@keyframes move-back-slide {
    0% {
        right: 0;
    }
    50% {
        right: -5%;
    }
}
.key-visual__copy__wrapper {
    position: relative;
    width: 23.5%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding-top: 88px;
}
.key-visual__copy {
    position: relative;
    width: 55%;
    height: 72%;
    writing-mode: vertical-rl;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1.5em;
    padding-left: 12%;
}
.key-visual__copy__main {
    width: 100%;
    flex: 1;
}
.key-visual__copy__main img {
    height: auto;
    width: 100%;
}
.key-visual__copy__sub {
    display: block;
    color: var(--color-navy);
    font-size: 16px;
    letter-spacing: 0.3em;
}
@media (max-width: 768px) {
    .key-visual::after {
        content: "";
        width: 100%;
        height: 100%;
        display: block;
        background: rgb(0 20 34 / 30%);
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
    }
    .key-visual__slider__item img {
        width: auto;
        height: 100%;
        object-fit: cover;
    }
    .key-visual__copy__wrapper {
        padding-top: 0;
    }
    .key-visual__copy {
        width: auto;
        height: 60%;
        font-size: 3.7vw;
        padding: 0;
    }
    .key-visual__copy__sub {
        font-size: inherit;
        color: #fff;
    }
}
/* About */
.section.sec-about {
    width: 100%;
    padding: 40px 0 55px;
    opacity: 0.9;
    color: #fff;
    margin-top: 0;
}
.section.sec-about .section-title {
    font-size: 28px;
    font-weight: 500;
    margin-bottom: 0.75em;
    letter-spacing: 0.15em;
}
.section.sec-about .section-text {
    margin: 0;
    font-size: 16px;
    line-height: 1.75;
}
/* pagetop */
.page-top {
    position: fixed;
    display: block;
    right: 20px;
    bottom: 30%;
    width: 20px;
    height: 200px;
    background: url(images/icon_pagetop.svg) no-repeat center / contain;
    z-index: 100;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity 0.28s ease, transform 0.28s ease, visibility 0.28s;
}
.page-top.--visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.sp-only {
    display: none;
}

@media (max-width: 768px) {
    .sp-only {
        display: block;
    }
    .pc-only {
        display: none;
    }
    .page-top {
        right: 2vw;
        bottom: 4vw;
        width: 4vw;
        height: 40vw;
    }
    .page-wrapper .section {
        margin: 60px 0 !important;
    }
    .page-wrapper .section .section-title {
        font-size: 22px !important;
        margin-bottom: 2em;
    }
    .section .section-text {
        font-size: 14px !important;
        text-align: justify !important;
    }
    .inner {
        padding: 0 20px;
    }
    .section.sec-about .section-text {
        font-size: 14px;
        text-align: justify;
    }
    .section.sec-feature {
        padding-top: 60px;
        margin: 0 !important;
    }

    .sec-feature__list {
        grid-template-columns: 1fr;
        row-gap: 40px;
        padding: 0 20px;
    }

    .sec-feature__item__title {
        font-size: 17px;
    }

    .sec-feature__item__text {
        font-size: 13px;
        text-align: justify;
    }

    .sec-training__wrapper {
        width: 100%;
        padding: 30px 0 40px;
    }
    .section.sec-training .sec-training__desc {
        text-align: justify !important;
    }
    .sec-training__bg {
        position: relative;
        width: 100%;
        height: 50vw;
    }

    .sec-training__button a {
        width: 100%;
        text-align: center;
    }

    .section.sec-about {
        margin: 0 !important;
    }
    .section.sec-about .section-title {
        font-size: 22px;
    }
    .section.sec-menu {
        margin-top: 0;
        padding-top: 60px;
    }
    .sec-menu__desc {
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .sec-menu__desc__title {
        width: 100%;
        font-size: 17px;
        padding-top: 0;
    }

    .sec-menu__desc__text {
        margin-top: 1em;
        padding: 1em 0 0;
        border: none;
        border-top: 1px solid;
        font-size: 14px;
    }

    .sec-menu__container {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    .sec-menu__more-button a {
        margin: 0;
    }

    .sec-menu__container + .sec-menu__container {
        margin-top: 60px;
    }

    .section-button.sec-menu__button a {
        margin: 2em auto;
        font-size: 18px;
    }
    .section-button.sec-menu__button.--arrow a::after {
        width: 2em;
        right: 1em;
    }

    .sec-menu__attention {
        padding: 16px 20px 20px;
    }

    .sec-menu__attention__title span {
        width: 100%;
        flex-direction: column;
        line-height: 1.5;
        padding: 0 0 0.5em;
        font-size: 17px;
        gap: 0.5em;
        padding-bottom: 0.75em;
    }

    .sec-menu__attention__text {
        font-size: 14px;
        text-align: justify;
        line-height: 1.75;
    }

    .sec-license__table__wrapper {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .sec-license__table__title {
        font-size: 17px;
    }

    .sec-license__table__list__wrapper {
        font-size: 13px;
        align-items: flex-start;
        padding: 1em;
        line-height: 1.5;
    }

    .section.sec-faq {
        padding: 60px 0;
    }
    .section.sec-faq .section-title {
        margin-bottom: 2em;
    }
    .sec-faq__item {
        font-size: 14px;
    }

    .sec-faq__item_answer {
        line-height: 1.75;
    }

    .sec-faq__item:not(:last-child) {
        margin-bottom: 2em;
    }

    .sec-contact__list {
        align-items: center;
        flex-direction: column;
        gap: 20px;
    }

    .sec-message__box {
        padding: 1.5em;
        font-size: 14px;
        line-height: 1.75;
    }

    .sec-message__box .name {
        margin-top: 0.5em;
    }

    .section.sec-company {
        grid-template-columns: 1fr;
        margin-bottom: 0 !important;
    }

    .sec-company__content {
        padding: 40px 20px;
    }

    .sec-company__list {
        font-size: 14px;
    }

    .sec-company__notice {
        font-size: 11px;
    }

    .footer-nav .menu {
        flex-direction: column;
        gap: 0.75em;
    }

    .footer-nav .menu-item:not(:first-child)::before {
        display: none;
    }

    .footer-nav .menu-item a {
        font-size: 14px;
    }

    .footer-copyright {
        font-size: 12px;
    }

    .footer {
        font-size: 15px;
        padding: 2em 0;
    }

    .sec-company__map {
        height: 80vw;
        order: 1;
    }
}

/* ボタン */
.--arrow-left > *::after {
    right: unset;
    left: 1.75em;
    transform: translateY(-50%) scaleX(-1);
}
.section-button.sec-menu__button.--arrow-left a::after {
    right: unset;
    left: 5.5em;
}
.section-button.sec-menu__button.--arrow-left a {
    padding: 0.75em;
    padding-left: 2em;
}
@media (max-width: 768px) {
    .section-button.sec-menu__button.--arrow-left a {
        margin: 2em auto;
    }
    .section-button.sec-menu__button.--arrow-left a::after {
        right: unset;
        left: 2em;
    }
}

/* 下層ページ */
.page-header-pic {
    width: 100%;
    height: 412px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}
.page-breadcrumbs {
    padding: 20px 40px;
}
.breadcrumbs__item {
    display: inline-block;
}
.breadcrumbs__item:not(:last-child)::after {
    content: "/";
    display: inline-block;
    padding: 0 0.5em;
}
.breadcrumbs__item a {
    text-decoration: none;
    color: var(--color-navy);
}
.page-breadcrumbs {
    padding: 54px 90px 20px;
}
.breadcrumbs__item {
    display: inline-block;
    font-size: 16px;
}
.breadcrumbs__item:not(:last-child)::after {
    content: "/";
    display: inline-block;
    padding: 0 0.5em;
}
.breadcrumbs__item a {
    text-decoration: none;
    color: var(--color-navy);
}
.page-title {
    font-size: 25px;
    text-align: center;
    margin: 2.5em auto 1.5em;
    letter-spacing: 0.25em;
}
.page-wrapper {
    overflow: hidden;
}
.page-wrapper.--lower {
    padding-bottom: 120px;
    font-size: 17px;
    line-height: 1.75;
}
.page-wrapper.--lower p {
    margin-bottom: 1em;
}
#container {
    padding-top: 86px;
}
.home #container {
    padding-top: 0;
}
.page-privacy li + li {
    margin-top: 1em;
}
.page-privacy address {
    font-style: normal;
}
.page-wrapper.--lower .page-lead {
    display: block;
    text-align: center;
    margin-bottom: 4em;
    letter-spacing: 0.2em;
}
@media (max-width: 768px) {
    #container {
        padding-top: 52px;
    }
    .page-header-pic {
        height: 40vw;
    }
    .page-breadcrumbs {
        padding: 20px;
    }
    .breadcrumbs__item {
        font-size: 14px;
    }
    .page-title {
        font-size: 20px;
        margin-bottom: 2.5em;
    }
    .page-wrapper.--lower {
        padding-bottom: 60px;
        font-size: 15px;
    }
}

/* お問い合わせ */
.page-contact__item__title {
    font-weight: inherit;
}
textarea, input[type="text"], input[type="tel"], input[type="email"] {
    width: 100%;
    background: #fff;
    border: 1px solid var(--color-navy);
}
textarea::placeholder, input[type="text"]::placeholder, input[type="tel"]::placeholder, input[type="email"]::placeholder {
    color: #ccc;
}
.page-contact__item {
    margin-bottom: 3em;
}
.page-contact__item__title::before {
    content: "任意";
    display: inline-block;
    background: #00bbbb;
    color: #fff;
    padding: 0 1em;
    margin-right: 1em;
}
.page-contact__item__title > p {
    display: inline;
}
.page-contact__item__title.required::before {
    content: "必須";
    background: var(--color-navy);
}
.page-contact__notice {
    text-align: center;
}
.page-contact__button.--arrow {
    position: relative;
    text-align: center;
}
.wpcf7-spinner {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.wpcf7-acceptance span {
    margin: 0;
}
.page-contact__notice__title {
    font-weight: 400;
}
.page-contact__notice__content {
    margin: 0;
}
.page-contact__button.--arrow > p::after {
    content: none;
}
.page-contact__button.--arrow > p > span {
    position: relative;
}
.page-contact__button.--arrow > p > span::after {
    content: "";
    width: 2.5em;
    height: 1em;
    display: inline-block;
    position: absolute;
    top: 50%;
    right: 5em;
    transform: translateY(-50%);
    background: url(images/icon_arrow.svg) no-repeat center / contain;
}
.page-contact__button.--arrow .wpcf7-submit {
    position: relative;
    display: inline-block;
    color: var(--color-navy);
    text-decoration: none;
    padding: 0.5em;
    padding-right: 1em;
    margin: 5em auto 3em;
    max-width: 100%;
    width: 520px;
    font-size: 22px;
    border-radius: 2em;
    box-sizing: border-box;
    border: 1px solid;
    background: #fff;
}


@media (max-width: 768px) {
    .page-wrapper.--lower .page-lead {
        margin-top: -1em;
        margin-bottom: 4em;
    }
    .page-contact__button.--arrow .wpcf7-submit {
        margin: 2em auto;
    }
    .page-contact__button.--arrow > p > span::after {
        width: 2em;
        right: 2em;
    }
}

/* 採用情報 */
.page-recruit__content {
    width: 100%;
    max-width: 860px;
    margin: 0 auto;
}
.page-recruit__box__title {
    position: absolute;
    top: 0;
    left: 50%;
    width: 20em;
    max-width: 100%;
    box-sizing: border-box;
    background: #ffff99;
    border: 1px solid var(--color-navy);
    border-radius: 3em;
    padding: 0.25em 0.75em;
    color: var(--color-navy);
    font-size: 17px;
    transform: translate(-50%, -50%);
}
.page-recruit__box {
    position: relative;
    text-align: center;
    color: var(--color-navy);
    letter-spacing: 0.15em;
}
.page-recruit__box__text {
    padding: 2.5em 1em 2em;
    font-size: 16px;
    border: 1px solid;
}
.page-recruit__box + .page-recruit__box {
    margin-top: 100px;
}
.page-recruit__points {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 0.75em;
    font-size: 22px;
    margin: 5em auto;
}
.page-recruit__points__item {
    width: 100%;
    background: #c0f4ea;
    text-align: center;
    padding: 0.25em;
    color: var(--color-navy);
    border-radius: 0.25em;
}
@media (max-width: 768px) {
    .page-recruit__box__title {
        font-size: 16px;
    }
    .page-recruit__box__text {
        font-size: 14px;
        text-align: justify;
    }
    .page-recruit__box + .page-recruit__box {
        margin-top: 60px;
    }
    .page-recruit__points {
        font-size: 18px;
        margin: 3em auto;
    }
}
.page-recruit__info__item {
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
    font-size: 17px;
}
.page-recruit__info__title {
    width: 10em;
    font-weight: inherit;
    text-align: right;
    padding: 2em 0;
    padding-right: 2em;
    box-sizing: border-box;
    margin-right: 2em;
    border-right: 1px solid;
}
.page-recruit__info__text {
    flex: 1;
    padding: 2em 0;
    margin: 0;
}
@media (max-width: 768px) {
    .page-recruit__info__item {
        font-size: 14px;
    }
    .page-recruit__info__title {
        width: 6em;
        padding: 1em;
        padding-left: 0;
        margin-right: 1em;
    }
    .page-recruit__info__text {
        padding: 1em 0;
    }
}

/* 施工実績 */
.archive-work__item {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
}
.archive-work__item__pic {
    width: 200px;
    height: auto;
    vertical-align: bottom;
}
.archive-work__item__desc {
    flex: 1;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}
.archive-work__item__name {
    width: 100%;
    color: var(--color-navy);
    border-bottom: 1px solid;
    font-size: 20px;
    font-weight: inherit;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
    padding-left: 40px;
}
.archive-work__item__text {
    font-size: 18px;
    padding-left: 40px;
}
.archive-work__item__pic img {
    margin: 0;
}
.archive-work__item + .archive-work__item {
    margin-top: 60px;
}

@media (max-width: 768px) {
    .archive-work__item {
        /* flex-direction: column; */
    }
    .archive-work__item__pic {
        width: 120px;
    }
    .archive-work__item__name {
        padding-left: 20px;
        font-size: 16px;
        line-height: 1.5;
    }
    .archive-work__item__text {
        padding-left: 20px;
        font-size: 14px;
    }
    .archive-work__item + .archive-work__item {
        margin-top: 30px;
    }
}


.page-menu__points {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 0.75em;
    font-size: 22px;
    font-weight: 500;
    margin: 3.5em auto;
    letter-spacing: 0.25em;
}
.page-menu__points__item {
    width: 100%;
    background: #c0f4ea;
    text-align: center;
    padding: 0.75em 0.5em;
    color: var(--color-navy);
    border-radius: 0.25em;
    line-height: 1.5;
}
@media (max-width: 768px) {
    .page-menu__points {
        font-size: 17px;
        margin: 2em auto;
    }
}
.page-menu__info__wrapper {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 70px;
}
.page-menu__info__box {
    background: #fff;
    border: 1px solid var(--color-navy);
    height: 100%;
}
.page-menu__info__title {
    font-size: 25px;
    font-weight: 500;
    text-align: center;
    padding: 1em;
    border-bottom: 1px solid;
    line-height: 1.75;
    letter-spacing: 0.25em;
    color: var(--color-navy);
}
.page-menu__info__desc.--col2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
.page-menu__info__wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 15px;
    line-height: 2;
    padding: 2.75em 2em;
}
.page-menu .page-menu__info__wrapper > p {
    margin-bottom: 0;
}
.page-menu__info__wrapper:not(:last-child) {
    border-right: 1px solid;
}
.page-menu__info__item {
    display: flex;
    color: #000;
    justify-content: space-between;
    gap: 5em;
    letter-spacing: 0.2em;
}

.page-menu__info__inner {
    position: relative;
    width: 100%;
    max-width: 860px;
    margin: 0 auto;
    margin-top: -40px;
    z-index: 1;
}

.page-menu__gallery__item img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    vertical-align: bottom;
}
.page-menu__gallery {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 50px;
    row-gap: 70px;
    margin-top: 90px;
}

.page-menu__gallery__item.wide {
    grid-column: 1 / 3;
}

.page-menu__info__col2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin-top: 40px;
}
.page-wrapper.--lower .page-menu .page-catch {
    display: block;
    text-align: center;
    margin-bottom: 2.25em;
}
.page-wrapper.--lower .page-menu .page-catch img {
    width: 100%;
    max-width: 700px !important;
    height: auto;
    margin: 0 auto;
}


@media (max-width: 768px) {
    .page-wrapper .section {
        margin: 60px 0;
    }
    .page-menu__info__title {
        font-size: 18px;
    }
    .page-menu__info__wrapper {
        font-size: 14px;
        padding: 1.5em 2em;
    }
    
    .page-menu__info__inner {
        width: calc(100% - 40px);
    }
    
    .page-menu__gallery {
        gap: 20px;
        grid-template-columns: 1fr;
        margin-top: 30px;
    }
    .page-menu__info__pic {
        margin: 0 -20px;
    }
    
    .page-menu__gallery__item.wide {
        grid-column: unset;
    }
    
    .page-menu__info__desc.--col2 {grid-template-columns: 1fr;}
    #sec04 .page-menu__info__wrapper {
        font-size: 14px !important;
    }
    .page-menu__info__wrapper:not(:last-child) {
        border-right: none;
        border-bottom: 1px solid;
    }
    
    .page-menu__info__item {
        gap: 1em;
    }
    .page-menu__info__list {
        width: 100%;
    }
    .page-menu__info__col2 {
        grid-template-columns: 1fr;
        gap: 30px;
        margin-top: 30px;
    }
    .page-wrapper.--lower .page-menu .page-lead {
        text-align: left;
    }
}

/* アニメーション */
.js-fade {
    opacity: 0;
}
.js-fade.animated {
    animation: fade 3s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.js-fade-up {
    transform: translateY(50px);
    opacity: 0;
}
.js-fade-up.animated {
    animation: fadeup 3s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
@keyframes fade {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
@keyframes fadeup {
    0% {
        transform: translateY(50px);
        opacity: 0;
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

/* タブレット */
@media (min-width: 768px) and (max-width: 1100px){
    .inner {
        padding-left: 20px;
        padding-right: 20px;
        box-sizing: border-box;
    }
    .section.sec-feature {
        margin: 0 0 80px;
        padding-top: 80px;
    }
    .sec-feature__list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 60px;
        row-gap: 40px;
    }
    .section.sec-menu {
        padding-top: 40px;
    }
    .section.sec-menu .section-title {
        margin-bottom: 2em;
    }
    .sec-training__bg {
        width: 45%;
    }
    .sec-company__map {
        height: 50vw;
    }
    .section.sec-company {
        grid-template-columns: 1fr;
        margin-bottom: 0 !important;
    }
}

/* reCAPTCHA非表示 */
.grecaptcha-badge {
    display: none !important;
}