@charset "UTF-8";
@layer foundation, function, layout, component, project, utility;
:root {
  --bgc: #ffffff;
  --bgtc: #333333;
  --bgc-acc1: #0077FF;
  --bgtc-acc1: #ffffff;
  --bgc-acc2: #0089CA;
  --bgtc-acc2: #ffffff;
  --bgc-acc3: #1A9900;
  --bgtc-acc3: #ffffff;
  --bgc-suf1: #B7D8FF;
  --bgtc-suf1: #000000;
  --bgc-suf2: #F1F4F7;
  --bgtc-suf2: #000000;
  --bgc-suf3: #f7f7f7;
  --bgtc-suf3: #333333;
  --font-xl:clamp(1.6rem, calc(1.6rem + (1vw - 0.32rem) * (2.3214285714)), 4.2rem);
  --font-l:clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.8928571429)), 2.4rem);
  --font-m:clamp(1.3rem, calc(1.3rem + (1vw - 0.32rem) * (0.2678571429)), 1.6rem);
  --font-s:clamp(1.2rem, calc(1.2rem + (1vw - 0.32rem) * (0.1785714286)), 1.4rem);
  --font-xs:clamp(1rem, calc(1rem + (1vw - 0.32rem) * (0.1785714286)), 1.2rem);
  --gap: var(--font-m);
  --bp-xs: 420px;
  --bp-s: 640px;
  --bp-m: 768px;
  --bp-l: 980px;
  --bp-xl: 1440px;
  --logo_width: 348px;
  --logo_height: 65px;
  --max-logo-width: 103px;
  --min-logo-width: 36px;
  --default-logo-width: 7.15vmax;
  --headerheight: calc(clamp(6.72px,7.15vmax,19.24px) + calc(var(--gap) * 2));
  --contentheight: calc(100dvh - var(--headerheight) - calc(var(--gap) * 2));
  --windowpaddinginline: min(5vw, var(--gap) * 2);
  --sectiongap: min(12.8dvh,calc(var(--gap) * 6));
  --blockgap: var(--font-xl);
  --inlinegap: var(--windowpaddinginline);
  --scrollbar: 0px;
  --menubreakpoint: var(--bp-xl);
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
}
@media only screen and (max-width: 767px) {
  :root {
    --sectiongap: min(5.5dvh,calc(var(--gap) * 3));
  }
}
@media print {
  :root {
    --font-xl:20pt;
    --font-l:16px;
    --font-m:10pt;
    --font-s:8pt;
    --font-xs:7pt;
    --headerheight: calc(var(--gap) * 4);
    --print-display: none;
  }
}

@layer function {
  html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
  }
  body {
    line-height: 1;
  }
  article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
  }
  nav ul {
    list-style: none;
  }
  blockquote, q {
    quotes: none;
  }
  blockquote:before, blockquote:after, q:before, q:after {
    content: "";
    content: none;
  }
  a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
  }
  /* change colours to suit your needs */
  ins {
    background-color: #ff9;
    color: #000;
    text-decoration: none;
  }
  /* change colours to suit your needs */
  mark {
    background-color: #ff9;
    color: #000;
    font-style: italic;
    font-weight: bold;
  }
  del {
    text-decoration: line-through;
  }
  abbr[title], dfn[title] {
    border-bottom: 1px dotted;
    cursor: help;
  }
  table {
    border-collapse: collapse;
    border-spacing: 0;
  }
  /* change border colour to suit your needs */
  hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #cccccc;
    margin: 1em 0;
    padding: 0;
  }
  input, select {
    vertical-align: unset;
  }
  img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
  .slick-slider {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
  }
  .slick-list, .slick-slider {
    position: relative;
    display: block;
  }
  .slick-list {
    overflow: hidden;
    margin: 0;
    padding: 0;
  }
  .slick-list:focus {
    outline: 0;
  }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand;
  }
  .slick-slider .slick-list, .slick-slider .slick-track {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  .slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
  }
  .slick-track:after, .slick-track:before {
    display: table;
    content: "";
  }
  .slick-track:after {
    clear: both;
  }
  .slick-loading .slick-track {
    visibility: hidden;
  }
  .slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
  }
  [dir=rtl] .slick-slide {
    float: right;
  }
  .slick-slide img {
    display: block;
  }
  .slick-slide img.slick-loading {
    display: none;
  }
  .slick-slide.dragging img {
    pointer-events: none;
  }
  .slick-loading .slick-slide {
    visibility: hidden;
  }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
  }
  .slick-arrow.slick-hidden {
    display: none;
  }
  .slick-loading .slick-list {
    background: #fff url("ajax-loader.gif") center center no-repeat;
  }
  @font-face {
    font-family: "slick";
    font-weight: normal;
    font-style: normal;
  }
  .slick-prev,
  .slick-next {
    position: absolute;
    display: block;
    z-index: 100;
    top: 0;
    bottom: 0;
    cursor: pointer;
    background: transparent;
    font-size: 1%;
    width: 5vw;
    height: 100%;
    border: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .slick-prev:hover, .slick-prev:focus,
  .slick-next:hover,
  .slick-next:focus {
    color: transparent;
    outline: none;
  }
  .slick-prev:hover:before, .slick-prev:focus:before,
  .slick-next:hover:before,
  .slick-next:focus:before {
    opacity: 1;
  }
  .slick-prev.slick-disabled:before,
  .slick-next.slick-disabled:before {
    opacity: 0.25;
  }
  .slick-prev:before,
  .slick-next:before {
    text-decoration: none;
    display: block;
    width: 0;
    height: 0;
    line-height: 1;
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    border: transparent 50px solid;
    opacity: 0.3;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
  }
  .slick-prev {
    left: -70px;
  }
  [dir=rtl] .slick-prev {
    right: -70px;
    left: auto;
  }
  .slick-prev:before {
    border-right: #7a858e 15px solid;
    border-left: none;
  }
  [dir=rtl] .slick-prev:before {
    border-left: #7a858e 15px solid;
    border-right: none;
  }
  .slick-next {
    right: -70px;
  }
  [dir=rtl] .slick-next {
    right: auto;
    left: -70px;
  }
  .slick-next:before {
    border-left: #7a858e 15px solid;
    border-right: none;
  }
  [dir=rtl] .slick-next:before {
    border-right: #7a858e 15px solid;
    border-left: none;
  }
  .slick-dotted.slick-slider {
    margin-bottom: 30px;
  }
  .slick-dots {
    display: block;
    width: auto;
    padding: 0;
    margin: 0 auto;
    overflow: hidden;
    list-style: none;
    text-align: center;
  }
  .slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    margin: 10px 5px 0;
    padding: 0;
    cursor: pointer;
  }
  .slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 20px;
    height: 20px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
  }
  .slick-dots li button:hover,
  .slick-dots li button:focus {
    outline: none;
  }
  .slick-dots li button:hover:before,
  .slick-dots li button:focus:before {
    opacity: 1;
  }
  .slick-dots li button:before {
    font-family: "slick";
    font-size: 20px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: "•";
    text-align: center;
    color: #8A8899;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .slick-dots li.slick-active button:before {
    opacity: 1;
    color: #113956;
  }
  #colorbox,
  #cboxOverlay,
  #cboxWrapper {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9999;
    overflow: hidden;
    -webkit-transform: translate3d(0, 0, 0);
  }
  #cboxWrapper {
    max-width: none;
  }
  #cboxOverlay {
    position: fixed;
    width: 100%;
    height: 100%;
  }
  #cboxMiddleLeft,
  #cboxBottomLeft {
    clear: left;
  }
  #cboxContent {
    position: relative;
  }
  #cboxLoadedContent {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  #cboxTitle {
    margin: 0;
  }
  #cboxLoadingOverlay,
  #cboxLoadingGraphic {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  #cboxPrevious,
  #cboxNext,
  #cboxClose,
  #cboxSlideshow {
    cursor: pointer;
  }
  .cboxPhoto {
    float: left;
    margin: auto;
    border: 0;
    display: block;
    max-width: none;
    -ms-interpolation-mode: bicubic;
  }
  .cboxIframe {
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
    padding: 0;
    margin: 0;
  }
  #colorbox,
  #cboxContent,
  #cboxLoadedContent {
    box-sizing: content-box;
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
  }
  #cboxOverlay {
    background: url(images/overlay.png) repeat 0 0;
    opacity: 0.9;
    filter: alpha(opacity=90);
  }
  #colorbox {
    outline: 0;
  }
  #cboxTopLeft {
    width: 21px;
    height: 21px;
    background: url(images/controls.png) no-repeat -101px 0;
  }
  #cboxTopRight {
    width: 21px;
    height: 21px;
    background: url(images/controls.png) no-repeat -130px 0;
  }
  #cboxBottomLeft {
    width: 21px;
    height: 21px;
    background: url(images/controls.png) no-repeat -101px -29px;
  }
  #cboxBottomRight {
    width: 21px;
    height: 21px;
    background: url(images/controls.png) no-repeat -130px -29px;
  }
  #cboxMiddleLeft {
    width: 21px;
    background: url(images/controls.png) left top repeat-y;
  }
  #cboxMiddleRight {
    width: 21px;
    background: url(images/controls.png) right top repeat-y;
  }
  #cboxTopCenter {
    height: 21px;
    background: url(images/border.png) 0 0 repeat-x;
  }
  #cboxBottomCenter {
    height: 21px;
    background: url(images/border.png) 0 -29px repeat-x;
  }
  #cboxContent {
    background: #fff;
    overflow: hidden;
  }
  .cboxIframe {
    background: #fff;
  }
  #cboxError {
    padding: 50px;
    border: 1px solid #ccc;
  }
  #cboxLoadedContent {
    margin-bottom: 28px;
  }
  #cboxTitle {
    position: absolute;
    bottom: 4px;
    left: 0;
    text-align: center;
    width: 100%;
    color: #949494;
  }
  #cboxCurrent {
    position: absolute;
    bottom: 4px;
    left: 58px;
    color: #949494;
  }
  #cboxLoadingOverlay {
    background: url(images/loading_background.png) no-repeat center center;
  }
  #cboxLoadingGraphic {
    background: url(images/loading.gif) no-repeat center center;
  }
  #cboxPrevious,
  #cboxNext,
  #cboxSlideshow,
  #cboxClose {
    border: 0;
    padding: 0;
    margin: 0;
    overflow: visible;
    width: auto;
    background: none;
  }
  #cboxPrevious:active,
  #cboxNext:active,
  #cboxSlideshow:active,
  #cboxClose:active {
    outline: 0;
  }
  #cboxSlideshow {
    position: absolute;
    bottom: 4px;
    right: 30px;
    color: #0092ef;
  }
  #cboxPrevious {
    position: absolute;
    bottom: 0;
    left: 0;
    background: url(images/controls.png) no-repeat -75px 0;
    width: 25px;
    height: 25px;
    text-indent: -9999px;
  }
  #cboxPrevious:hover {
    background-position: -75px -25px;
  }
  #cboxNext {
    position: absolute;
    bottom: 0;
    left: 27px;
    background: url(images/controls.png) no-repeat -50px 0;
    width: 25px;
    height: 25px;
    text-indent: -9999px;
  }
  #cboxNext:hover {
    background-position: -50px -25px;
  }
  #cboxClose {
    position: absolute;
    bottom: 0;
    right: 0;
    background: url(images/controls.png) no-repeat -25px 0;
    width: 25px;
    height: 25px;
    text-indent: -9999px;
  }
  #cboxClose:hover {
    background-position: -25px -25px;
  }
  .cboxIE #cboxTopLeft,
  .cboxIE #cboxTopCenter,
  .cboxIE #cboxTopRight,
  .cboxIE #cboxBottomLeft,
  .cboxIE #cboxBottomCenter,
  .cboxIE #cboxBottomRight,
  .cboxIE #cboxMiddleLeft,
  .cboxIE #cboxMiddleRight {
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#00FFFFFF, endColorstr=#00FFFFFF);
  }
  .gsc-control-cse {
    background-color: transparent !important;
    border: none !important;
  }
  .gsc-control-cse {
    padding: 0 !important;
  }
  table.gsc-search-box td.gsc-input {
    padding-right: 0 !important;
  }
  html {
    scroll-behavior: smooth;
    font-size: 62.5%;
    overflow-x: hidden;
    font-family: "Noto Sans JP", "Noto Sans CJK JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.08em;
  }
  body {
    width: 100%;
    padding: 0;
    margin: 0;
    -webkit-font-feature-settings: "palt", 1;
            font-feature-settings: "palt", 1;
    position: relative;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%; /*Chrome,Safari*/
    -ms-text-size-adjust: 100%; /*EgdeMobile*/
    -moz-text-size-adjust: 100%; /*firefox*/
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  *, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  a[href="#"]:after {
    content: "（リンク先未適用）";
    color: #f00;
    font-weight: bold;
  }
  a:where([href^="tel:"]) {
    pointer-events: none;
    color: inherit;
    text-decoration: none;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 1439px) {
    a:where([href^="tel:"]) {
      pointer-events: all;
      text-decoration: underline;
    }
  }
  /*
  .fixwidth {
  	width: 100%;
  	margin: auto;
  	max-width: 1439px;
  	@include media(ul) {
  		max-width: 1439px;
  	}
  	@include media(l-ul) {
  		max-width: 979px;
  	}
  }*/
  * sup {
    font-size: 75%;
    vertical-align: super;
  }
  * sub {
    font-size: 75%;
    vertical-align: baseline;
  }
}
@layer layout {
  .l-main__main, .l-main__footer {
    display: -ms-grid;
    display: grid;
    --_contentside: calc((100vw - var(--bp-xl)) / 2);
    -ms-grid-columns: var(--_contentside) 0 var(--windowpaddinginline) 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 1fr 0 var(--windowpaddinginline) 0 var(--_contentside);
    grid-template-columns: var(--_contentside) var(--windowpaddinginline) repeat(12, 1fr) var(--windowpaddinginline) var(--_contentside);
    gap: var(--sectiongap) 0;
  }
  #top .l-main__main, #top .l-main__footer {
    gap: 0;
  }
}
@layer component {
  .c-headline--h2-default {
    font-size: var(--font-xl);
    color: var(--bgtc);
    font-weight: 500;
    line-height: 1.8;
    text-align: center;
    position: relative;
    -webkit-margin-after: calc(var(--gap) * 5.5);
            margin-block-end: calc(var(--gap) * 5.5);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .c-headline--h2-default::before {
    content: "";
    display: block;
    --w: 3px;
    width: var(--w);
    height: 1em;
    background-color: var(--bgc-acc1);
    position: absolute;
    top: calc(100% + 1rem);
    left: calc(50% + var(--w) / 2 * -1);
  }
  .c-headline--h2-default span {
    font-size: var(--font-l);
  }
  @media only screen and (max-width: 767px) {
    .c-headline--h2-default {
      -webkit-margin-after: calc(var(--gap) * 2);
              margin-block-end: calc(var(--gap) * 2);
    }
  }
  .c-headline--h2-default:has(strong):has(span) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .c-headline--h2-default:has(strong):has(span) br {
    display: none;
  }
  .c-headline--h3-default {
    font-size: var(--font-l);
    font-weight: 700;
    line-height: 1.47;
  }
  .c-lead__text {
    text-align: center;
  }
  .c-preparation__wrap {
    grid-column: 3/-3;
  }
  .c-preparation__text {
    font-size: var(--font-l);
    font-weight: 700;
    line-height: 1.76;
    text-align: center;
  }
  .c-unit__box {
    grid-column: 3/-3;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -ms-grid-rows: -webkit-max-content;
    -ms-grid-rows: max-content;
    grid-template-rows: -webkit-max-content;
    grid-template-rows: max-content;
    gap: calc(var(--blockgap) / 2) var(--inlinegap);
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    color: var(--bgtc);
    font-size: var(--font-m);
    font-weight: 400;
    line-height: 1.76;
    scroll-snap-align: start;
  }
  .c-unit__box > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .c-unit__box > :where(h1, h2, h3, h4, h5, h6) {
    grid-column: 1/-1;
  }
  .c-unit__box > :where(*) {
    grid-column: span var(--spans);
  }
  .c-unit__box--full {
    --spans: 16 !important;
    grid-column: 1/-1 !important;
  }
  .c-unit__box--full-limitedcontent, .p-recruit-voice__wrap, .p-company-qualification__wrap, .p-company-access__wrap {
    --spans: 16;
    grid-column: 1/-1 !important;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    gap: calc(var(--blockgap) / 2) 0;
  }
  .c-unit__box--full-limitedcontent > :where(*), .p-recruit-voice__wrap > :where(*), .p-company-qualification__wrap > :where(*), .p-company-access__wrap > :where(*) {
    grid-column: 3/-3;
  }
  :where(.c-unit__box) :where(p, figure, table, ul, ol, dl):not(last-child) {
    -webkit-margin-after: calc(var(--gap) * 1);
            margin-block-end: calc(var(--gap) * 1);
  }
  :where(.c-unit__box) :where(figure) :where(img) {
    width: 100%;
    height: auto;
  }
  :where(.c-unit__box) :where(figure).size-auto :where(img) {
    width: auto;
  }
  :where(.c-unit__box) :where(table) {
    --_bd: 1px solid #ccc;
    -webkit-border-before: var(--_bd);
            border-block-start: var(--_bd);
    width: 100%;
  }
  :where(.c-unit__box) :where(table) :where(th),
  :where(.c-unit__box) :where(table) :where(td) {
    -webkit-border-after: var(--_bd);
            border-block-end: var(--_bd);
  }
  :where(.c-unit__box) :where(table) :where(tbody) :where(th),
  :where(.c-unit__box) :where(table) :where(tbody) :where(td) {
    padding-block: calc(var(--gap) * 1);
  }
  :where(.c-unit__box) :where(table) :where(tbody) :where(th) {
    text-align: left;
    padding-inline: calc(var(--gap) * 1);
    font-weight: 700;
    word-break: keep-all;
  }
  :where(.c-unit__box) :where(table) :where(tbody) :where(td) {
    padding-inline: calc(var(--gap) * 0.5) calc(var(--gap) * 1);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    :where(.c-unit__box) :where(table) :where(tbody) :where(td) {
      padding-inline: calc(var(--gap) * 0.5) calc(var(--gap) * 1);
    }
  }
  :where(.c-unit__box) :where(ul) {
    -webkit-padding-start: calc(var(--gap) * 1.75);
            padding-inline-start: calc(var(--gap) * 1.75);
  }
  :where(.c-unit__box) :where(ul) :where(li) {
    list-style: none;
    position: relative;
  }
  :where(.c-unit__box) :where(ul) :where(li):not(:last-child) {
    -webkit-margin-after: calc(var(--gap) * 0.5);
            margin-block-end: calc(var(--gap) * 0.5);
  }
  :where(.c-unit__box) :where(ul) :where(li)::before {
    content: "";
    display: block;
    width: 1em;
    height: 1em;
    border-radius: 100%;
    background-color: var(--bgc-acc1);
    position: absolute;
    top: 0.5lh;
    left: calc(var(--gap) * -1.75);
    translate: 0 -50%;
  }
  :where(.c-unit__box) :where(ol) {
    -webkit-padding-start: calc(var(--gap) * 1.75);
            padding-inline-start: calc(var(--gap) * 1.75);
  }
  :where(.c-unit__box) :where(ol) :where(li) {
    list-style: decimal;
    position: relative;
  }
  :not(li) :where(.c-unit__box) :where(ol) :where(li):not(:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
  :where(.c-unit__box) :where(ol) :where(li)::before {
    content: none;
  }
  :where(.c-unit__box) :where(ol).c-liststyle__alpha :where(li) {
    list-style: lower-alpha;
  }
  :where(.c-unit__box) :where(ol).c-liststyle__roman :where(li) {
    list-style: lower-roman;
  }
  .c-gallery__list {
    display: -ms-grid;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(420px, 100%), 1fr));
    gap: calc(var(--gap) * 1);
    padding: 0;
  }
  .c-gallery__item {
    list-style: none;
  }
  .c-gallery__item::before {
    content: none;
  }
  .c-gallery__fig {
    margin: 0;
    text-align: center;
  }
  .c-gallery__img {
    max-width: var(--bp-m);
  }
  .p-ctanav__wrap {
    grid-column: 1/-1;
  }
  .p-ctanav__list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 1px 1fr 1px 1fr 1px 1fr;
    grid-template-columns: repeat(4, 1fr);
    -ms-grid-rows: auto;
    grid-template-rows: auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1px;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-ctanav__list > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-ctanav__list > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-ctanav__list > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
  }
  .p-ctanav__list > *:nth-child(4) {
    -ms-grid-row: 1;
    -ms-grid-column: 7;
  }
  @media only screen and (max-width: 767px) {
    .p-ctanav__list {
      -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
    }
  }
  .p-ctanav__item {
    -ms-grid-column-span: 2;
    grid-column: span 2;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -ms-grid-rows: subgrid;
    grid-template-rows: subgrid;
  }
  .p-ctanav__item > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-ctanav__item--contact {
    --_bg: var(--bgc-acc1);
  }
  .p-ctanav__item--recruit {
    --_bg: var(--bgc-acc2);
  }
  .p-ctanav__link {
    --_c: var(--bgtc-acc1);
    -ms-grid-column-span: 2;
    grid-column: span 2;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -ms-grid-rows: subgrid;
    grid-template-rows: subgrid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background: var(--_bg);
    color: var(--_c);
    text-decoration: none;
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
  }
  .p-ctanav__link > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-ctanav__link:hover {
    opacity: 0.6;
  }
  .p-ctanav__article {
    display: -ms-grid;
    display: grid;
    place-content: center;
  }
  .p-ctanav__title {
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: auto auto;
    -ms-grid-columns: auto auto;
        grid-template: "subtitle subtitle" "maintitle icon" auto/auto auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p-ctanav__maintitle {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-area: maintitle;
    font-size: var(--font-xl);
    font-weight: 400;
  }
  .p-ctanav__subtitle {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-area: subtitle;
    font-weight: 400;
    font-size: clamp(1.2rem, calc(1.2rem + (1vw - 0.32rem) * (0.7142857143)), 2rem);
    margin-bottom: 1em;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    position: relative;
    left: 2em;
  }
  .p-ctanav__subtitle::before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: -2em;
    width: 1.5em;
    height: 3px;
    background-color: var(--_c);
    z-index: 1;
    translate: 0 -50%;
  }
  .p-ctanav__icon {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
    grid-area: icon;
  }
  .p-ctanav__icon--contact {
    --_bg: var(--_c);
    --_arrowc: var(--bgc-acc1);
    display: block;
    font-size: var(--font-l);
    width: 1.41em;
    height: 1.41em;
    border-radius: 100%;
    background-color: var(--_bg);
    -webkit-margin-start: 1em;
            margin-inline-start: 1em;
    position: relative;
  }
  .p-ctanav__icon--contact::before {
    position: absolute;
    display: block;
    content: "";
    width: 0.25em;
    height: 0.25em;
    top: 50%;
    left: 50%;
    border: 1px solid var(--_arrowc);
    border-bottom: none;
    border-left: none;
    rotate: 45deg;
    translate: -50% -50%;
  }
  .p-ctanav__iconimg--recruit {
    font-size: var(--font-l);
    -webkit-margin-start: 1em;
            margin-inline-start: 1em;
    width: 1em;
  }
  .p-ctanav__figure--recruit {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
  .c-contactbox__wrap {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 1) var(--windowpaddinginline);
    margin-inline: auto;
  }
  html {
    --_caution_color: #c00;
  }
  .c-contactbox__wrap--form {
    width: 100%;
  }
  .c-contactbox__wrap--submit {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  .c-contactbox__list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: -webkit-max-content var(--windowpaddinginline) 1fr;
    -ms-grid-columns: max-content var(--windowpaddinginline) 1fr;
    grid-template-columns: -webkit-max-content 1fr;
    grid-template-columns: max-content 1fr;
    gap: calc(var(--gap) * 0.5) var(--windowpaddinginline);
    padding: calc(var(--gap) * 1);
    background: #f8f8f8;
  }
  .c-contactbox__item {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .c-contactbox__item::before {
    content: none;
  }
  @media only screen and (max-width: 767px) {
    .c-contactbox__item {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      gap: calc(var(--gap) * 0.5);
    }
  }
  .c-contactbox__box {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: var(--font-m);
    line-height: 1.5;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .c-contactbox__box {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      gap: calc(var(--gap) * 0.5);
    }
  }
  .c-contactbox__title {
    color: var(--bgc-acc1);
    font-weight: 500;
  }
  .c-contactbox__label {
    cursor: pointer;
  }
  .c-contactbox__required {
    font-size: var(--font-s);
    background: var(--_caution_color);
    color: #fff;
    font-weight: 700;
    padding: 0.2em 0.5em;
    font-size: 83.3%;
    -webkit-margin-start: calc(var(--gap) * 0.5);
            margin-inline-start: calc(var(--gap) * 0.5);
  }
  .c-contactbox__privacybox {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 1) var(--windowpaddinginline);
    -webkit-margin-after: var(--blockgap);
            margin-block-end: var(--blockgap);
  }
  .c-contactbox__privacyinclude {
    border: 1px solid #999;
    padding: var(--windowpaddinginline);
    border-radius: calc(var(--gap) * 0.5);
    height: 20em;
    overflow-y: auto;
    resize: vertical;
  }
  .c-contactbox__privacyinclude .c-unit__box {
    display: block;
  }
  .c-contactbox__privacyinclude .c-unit__box:has(+ .c-unit__box) {
    -webkit-margin-after: var(--blockgap);
            margin-block-end: var(--blockgap);
  }
  .c-contactbox__privacyinclude h2 {
    font-size: var(--font-l);
  }
  .c-contactbox__privacylabel {
    text-align: center;
    cursor: pointer;
  }
  .c-contactbox__btnwrap {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: calc(var(--gap) * 2);
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .c-contactbox__btn {
    font-size: var(--font-l);
    border-radius: calc(var(--gap) * 0.5);
    padding: calc(var(--gap) * 1) calc(var(--gap) * 2);
    border: none;
    background: none;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
  }
  .c-contactbox__btn[disabled] {
    background: #ccc;
    color: #fff;
    cursor: not-allowed;
  }
  .c-contactbox__btn:not([disabled]) {
    scale: 1;
    -webkit-transition: scale 0.3s ease-in-out;
    transition: scale 0.3s ease-in-out;
  }
  .c-contactbox__btn:not([disabled]):hover {
    scale: 1.05;
  }
  .c-contactbox__btn--submit {
    background: var(--bgc-acc1);
    color: var(--bgtc-acc1);
  }
  .c-contactbox__btn--cancel {
    background: var(--bgc-suf3);
    color: var(--bgtc-suf3);
  }
  .c-contactbox__error_box {
    background: #eee;
    border: 1px solid #ccc;
    padding: var(--windowpaddinginline);
    border-radius: calc(var(--gap) * 0.5);
    -webkit-margin-after: var(--blockgap);
            margin-block-end: var(--blockgap);
    text-align: center;
  }
  .c-contactbox__error_box > * {
    margin: 0;
  }
  .c-contactbox__error_text {
    color: var(--_caution_color);
    font-weight: 700;
  }
  .c-contactbox__thanks_text {
    text-align: center;
    font-size: var(--font-l);
  }
  .c-form__inputtext, .c-form__select, .c-form__textarea {
    font-size: var(--font-m);
    padding: 0.5em 1em;
    border-radius: calc(var(--gap) * 0.5);
    border: 1px solid #ccc;
    width: 50%;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .c-form__inputtext.S, .c-form__select.S, .c-form__textarea.S {
    width: 20%;
    min-width: 15em;
  }
  .c-form__inputtext.M, .c-form__select.M, .c-form__textarea.M {
    width: 50%;
    min-width: 15em;
  }
  .c-form__inputtext.L, .c-form__select.L, .c-form__textarea.L {
    width: 100%;
  }
  @media only screen and (max-width: 767px) {
    .c-form__inputtext, .c-form__select, .c-form__textarea {
      width: 100%;
    }
    .c-form__inputtext.S, .c-form__inputtext.M, .c-form__inputtext.L, .c-form__select.S, .c-form__select.M, .c-form__select.L, .c-form__textarea.S, .c-form__textarea.M, .c-form__textarea.L {
      width: 100%;
    }
  }
  .c-form__select {
    cursor: pointer;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
  .c-form__textarea {
    width: 100%;
    min-height: 10em;
    resize: vertical;
  }
  .c-form__label {
    cursor: pointer;
  }
  .c-breadcrumbs__wrap {
    position: relative;
    grid-column: 1/-1;
  }
  .c-breadcrumbs__list {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
  }
  .c-btn__styleA_link {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    text-decoration: none;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr auto;
    grid-template-columns: 1fr auto;
    color: var(--bgc-acc1);
    font-weight: bold;
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
  }
  .c-btn__styleA_link:hover {
    opacity: 0.6;
  }
  .c-btn__styleA_icon {
    --_bg: var(--bgc-acc1);
    --_arrowc: var(--bgtc-acc1);
    display: block;
    font-size: var(--font-l);
    width: 1.41em;
    height: 1.41em;
    border-radius: 100%;
    background-color: var(--_bg);
    -webkit-margin-start: 1em;
            margin-inline-start: 1em;
    position: relative;
  }
  .c-btn__styleA_icon::before {
    position: absolute;
    display: block;
    content: "";
    width: 0.25em;
    height: 0.25em;
    top: 50%;
    left: 50%;
    border: 1px solid var(--_arrowc);
    border-bottom: none;
    border-left: none;
    rotate: 45deg;
    translate: -50% -50%;
  }
  .c-btn__styleB_link {
    --_c: var(--bgc-acc2);
    --_bg: var(--bgtc-acc2);
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr auto;
    grid-template-columns: 1fr auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    padding: calc(var(--gap) * 0.5) calc(var(--gap) * 2);
    background: var(--_bg);
    color: var(--_c);
    border: 1px solid var(--_c);
    border-radius: 9999px;
    text-decoration: none;
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
  }
  .c-btn__styleB_link:hover {
    opacity: 0.6;
  }
  .c-btn__styleB_icon {
    -webkit-margin-start: calc(var(--gap) * 0.5);
            margin-inline-start: calc(var(--gap) * 0.5);
    position: relative;
    width: 1.5em;
    --_misalignment: 0.15em;
  }
  .c-btn__styleB_icon::before, .c-btn__styleB_icon::after {
    content: "";
    display: block;
    aspect-ratio: 16/12;
    width: 80%;
    background: var(--_bg);
    border: 2px solid var(--_c);
    position: absolute;
    top: 50%;
  }
  .c-btn__styleB_icon::before {
    right: 0;
    translate: 0 calc(-50% - var(--_misalignment));
  }
  .c-btn__styleB_icon::after {
    left: 0;
    translate: 0 calc(-50% + var(--_misalignment));
  }
  .c-btn__viewmore_link {
    --_c: var(--bgc-acc1);
    --_bg: var(--bgtc-acc1);
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr auto;
    grid-template-columns: 1fr auto;
    padding: calc(var(--gap) * 0.5);
    padding-inline: calc(var(--gap) * 1.5) calc(var(--gap) * 0.5);
    background: var(--_bg);
    color: var(--_c);
    border: 1px solid var(--_c);
    border-radius: 9999px;
    margin-inline: auto 0;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    text-decoration: none;
    --_bg: none;
    border: none;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-inline: 0 auto;
    padding: 0;
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
  }
  .c-btn__viewmore_link:hover {
    opacity: 0.6;
  }
  .c-btn__viewmore_text {
    text-transform: uppercase;
  }
  .c-btn__viewmore_icon {
    --_bg: var(--bgc-acc1);
    --_arrowc: var(--bgtc-acc1);
    display: block;
    font-size: var(--font-l);
    width: 1.41em;
    height: 1.41em;
    border-radius: 100%;
    background-color: var(--_bg);
    -webkit-margin-start: 1em;
            margin-inline-start: 1em;
    position: relative;
  }
  .c-btn__viewmore_icon::before {
    position: absolute;
    display: block;
    content: "";
    width: 0.25em;
    height: 0.25em;
    top: 50%;
    left: 50%;
    border: 1px solid var(--_arrowc);
    border-bottom: none;
    border-left: none;
    rotate: 45deg;
    translate: -50% -50%;
  }
}
@layer project {
  /*
  メニュー状況整理

  トップページとそれ以外
      @at-root #top & {
      }

      通常時
          平書き
      一定量スクロール時
          @at-root .is-scrolled & {
          }
          @at-root .is-scrolled#top & {
          }
      メニュー展開時
          @at-root .is_active & {
          }
          @at-root .is_active#top & {
          }

  制御
      ロゴ画像fill：--_c
      メニュー文字色：--_c
      メニュー背景色：--_bgc
      開閉ナビバー色：--_c
      開閉ナビ文字色：--_c

  */
  .p-siteheader__wrap {
    width: 100%;
    height: auto;
    --_headernavheight: 0fr;
    padding: 0;
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: -webkit-max-content var(--_headernavheight);
    -ms-grid-rows: max-content var(--_headernavheight);
    -ms-grid-columns: -webkit-max-content 1fr;
    -ms-grid-columns: max-content 1fr;
        grid-template: "logobox headernav" -webkit-max-content "meganav meganav" var(--_headernavheight)/max-content 1fr;
        grid-template: "logobox headernav" max-content "meganav meganav" var(--_headernavheight)/max-content 1fr;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 100%;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .is_active .p-siteheader__wrap {
    --_headernavheight: 1fr;
  }
  @media only screen and (max-width: 1439px) {
    .p-siteheader__wrap {
      --_headernavheight: 0fr;
    }
    .p-siteheader__wrap.is_active {
      --_headernavheight: 1fr;
    }
  }
  .p-siteheader__homelink {
    display: block;
    padding: calc(var(--gap) * 1) var(--windowpaddinginline);
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.9821428571)), 2.5rem);
    text-decoration: none;
    color: var(--bgtc);
    font-weight: 500;
    line-height: 1.3;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-siteheader__homelink br {
    display: none;
  }
  @media only screen and (max-width: 1439px) {
    .p-siteheader__homelink br {
      display: block;
    }
  }
  .p-siteheader__fig {
    aspect-ratio: 303/55;
    width: var(--default-logo-width);
    max-width: var(--max-logo-width);
    min-width: var(--min-logo-width);
  }
  .p-siteheader__logo {
    width: 100%;
    height: 100%;
  }
  .p-siteheader__headernav {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
    -ms-grid-column-align: end;
        justify-self: end;
    grid-area: headernav;
    height: 100%;
  }
  .p-siteheader__navtrigger {
    -ms-grid-column-align: end;
        justify-self: end;
    grid-area: navtrigger;
  }
  .p-siteheader__meganav {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    -ms-grid-column-align: end;
        justify-self: end;
    grid-area: meganav;
    height: 100%;
  }
  .p-headernav {
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-headernav__wrap {
    width: 100%;
    font-size: var(--font-m);
    -webkit-transition: grid-template-rows 0.3s ease-in-out;
    transition: grid-template-rows 0.3s ease-in-out;
    transition: grid-template-rows 0.3s ease-in-out, -ms-grid-rows 0.3s ease-in-out;
    --_c: var(--bgtc);
  }
  .p-headernav__nav {
    height: 100%;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
  .p-headernav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: calc(var(--gap) * 1);
    padding: 0 calc(var(--gap) * 1);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 1439px) {
    .p-headernav__list {
      display: none;
    }
  }
  .p-headernav__link {
    display: block;
    padding: calc(var(--gap) * 0.5) calc(var(--gap) * 0.5);
    color: var(--_c);
    text-decoration: none;
    -webkit-transition: color 0.3s ease-in-out;
    transition: color 0.3s ease-in-out;
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.3571428571)), 1.8rem);
    white-space: nowrap;
  }
  .p-headernav__link.current {
    color: var(--bgc-acc1);
  }
  #top .p-headernav__link.current {
    color: var(--_c);
  }
  .p-headernav__link:hover {
    color: var(--bgc-acc1);
  }
  .p-headernav__btn {
    height: 100%;
    display: -ms-grid;
    display: grid;
    place-items: center;
    background-color: var(--bgc-acc1);
    padding: calc(var(--gap) * 1) calc(var(--gap) * 2);
    text-decoration: none;
    color: var(--bgtc-acc1);
    font-size: clamp(1.2rem, calc(1.2rem + (1vw - 0.32rem) * (0.5357142857)), 1.8rem);
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
    white-space: nowrap;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-headernav__btn:hover {
    opacity: 0.6;
  }
  @media only screen and (max-width: 1439px) {
    .p-headernav__btn {
      padding: calc(var(--gap) * 0.5) calc(var(--gap) * 0.5);
    }
  }
  .p-gNav_trigger__wrap {
    --_c: var(--bgc-acc1);
    height: 100%;
    aspect-ratio: 1/1;
    -webkit-border-start: 1px solid var(--bgc-acc1);
            border-inline-start: 1px solid var(--bgc-acc1);
    display: -ms-grid;
    display: grid;
    place-content: center;
    cursor: pointer;
  }
  .p-gNav_trigger__box {
    display: -ms-grid;
    display: grid;
    gap: 0.7lh;
    place-items: center;
    position: relative;
    font-size: var(--font-xs);
  }
  .p-gNav_trigger__bars {
    width: calc(var(--gap) * 2);
    height: calc(0.7lh + 2px);
    position: relative;
  }
  .p-gNav_trigger__bar {
    --_deg: 0deg;
    --_bar1deg: calc(var(--_deg) * -1);
    --_bar2deg: calc(var(--_deg) * 1);
    --_bar1top: 0%;
    --_bar2top: 100%;
    position: absolute;
    -webkit-transform: translateY(-1px);
            transform: translateY(-1px);
    display: block;
    background: var(--_c);
    height: 2px;
    width: 100%;
    -webkit-transition: rotate 0.3s ease-in, top 0.3s 0.3s ease-out, background 0.3s ease-in-out;
    transition: rotate 0.3s ease-in, top 0.3s 0.3s ease-out, background 0.3s ease-in-out;
  }
  .p-gNav_trigger__bar:nth-child(1) {
    top: var(--_bar1top);
    rotate: var(--_bar1deg);
  }
  .p-gNav_trigger__bar:nth-child(2) {
    top: var(--_bar2top);
    rotate: var(--_bar2deg);
  }
  .is_active .p-gNav_trigger__bar {
    --_deg: 20deg;
    --_bar1top: 50%;
    --_bar2top: 50%;
    -webkit-transition: rotate 0.3s 0.3s ease-out, top 0.3s ease-in, background 0.3s ease-in-out;
    transition: rotate 0.3s 0.3s ease-out, top 0.3s ease-in, background 0.3s ease-in-out;
  }
  .p-gNav_trigger__text {
    display: block;
    display: none;
    color: var(--_c);
    position: relative;
    width: 3.5em;
    height: 1em;
    overflow: hidden;
  }
  .p-gNav_trigger__text::before, .p-gNav_trigger__text::after {
    position: absolute;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    inset: 0;
    width: 100%;
    text-align: center;
  }
  .p-gNav_trigger__text::before {
    content: "MENU";
    translate: 0 0;
  }
  .p-gNav_trigger__text::after {
    content: "CLOSE";
    translate: 0 -110%;
  }
  .is_active .p-gNav_trigger__text::before {
    translate: 0 -110%;
  }
  .is_active .p-gNav_trigger__text::after {
    translate: 0 0;
  }
  .p-meganav__wrap {
    background: var(--bgc-suf2);
    width: 100%;
    overflow: hidden;
    -webkit-border-before: 1px solid var(--bgc-acc1);
            border-block-start: 1px solid var(--bgc-acc1);
  }
  .p-meganav__nav {
    padding-block: calc(var(--gap) * 1);
  }
  .p-meganav__list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[4];
    grid-template-columns: repeat(4, 1fr);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-meganav__list {
      -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media only screen and (max-width: 419px) {
    .p-meganav__list {
      -ms-grid-columns: (1fr)[1];
      grid-template-columns: repeat(1, 1fr);
    }
  }
  .p-meganav__item {
    -webkit-border-end: 1px solid var(--bgtc-acc1);
            border-inline-end: 1px solid var(--bgtc-acc1);
    padding: calc(var(--gap) * 1) var(--windowpaddinginline);
  }
  .p-meganav__item:last-child {
    -webkit-border-end: none;
            border-inline-end: none;
  }
  .p-meganav__link {
    display: block;
    padding: calc(var(--gap) * 0.5) calc(var(--gap) * 0.5);
    font-size: var(--font-l);
    color: var(--bgtc);
    text-decoration: none;
    -webkit-border-after: 2px solid var(--bgc-acc1);
            border-block-end: 2px solid var(--bgc-acc1);
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
  }
  .p-meganav__link:hover {
    opacity: 0.6;
  }
  .p-meganav__sublist {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
  .p-meganav__subitem {
    -webkit-border-after: 1px dotted var(--bgc-acc1);
            border-block-end: 1px dotted var(--bgc-acc1);
  }
  .p-meganav__sublink {
    display: block;
    padding: calc(var(--gap) * 0.5);
    color: var(--bgtc);
    text-decoration: none;
    font-size: var(--font-s);
  }
  .p-meganav__sublink:hover {
    opacity: 0.6;
  }
  .p-mainvisual__wrap {
    grid-column: 1/-1;
    position: relative;
    height: calc(100vh - var(--headerheight));
  }
  .p-mainvisual__content {
    position: absolute;
    inset: 0 0 30%;
    display: -ms-grid;
    display: grid;
    place-content: center;
    z-index: 1;
  }
  .p-mainvisual__text {
    font-size: clamp(2.5rem, calc(2.5rem + (1vw - 0.32rem) * (1.3392857143)), 4rem);
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
  }
  .p-mainvisual__strong {
    font-size: clamp(4rem, calc(4rem + (1vw - 0.32rem) * (2.6785714286)), 7rem);
  }
  .p-mainvisual__fig {
    position: absolute;
    inset: 0;
  }
  .p-mainvisual__img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    z-index: -1;
  }
  .p-pageTitle__wrap {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
  }
  .p-pageTitle__box {
    grid-column: 1/-1;
    -ms-grid-row-span: 2;
    grid-row: span 2;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    font-size: clamp(2rem, calc(2rem + (1vw - 0.32rem) * (2.6785714286)), 5rem);
    padding-block: 1.2em;
    --c: var(--bgc-acc1);
    color: var(--c);
    --h: 5px;
    -webkit-border-after: var(--h) solid var(--bgc-suf1);
            border-block-end: var(--h) solid var(--bgc-suf1);
    position: relative;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-pageTitle__box::after {
    content: "";
    position: absolute;
    bottom: calc(var(--h) * -1);
    left: 0;
    width: 50%;
    height: var(--h);
    background-color: var(--c);
  }
  @media only screen and (max-width: 767px) {
    .p-pageTitle__box {
      --h: 3px;
    }
  }
  .p-pageTitle__title {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    grid-column: 3/-3;
    font-weight: 500;
    letter-spacing: -0.02em;
  }
  .p-categorynav__wrap:not(:has(li:nth-child(2))) {
    display: none;
  }
  .p-categorynav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: var(--windowpaddinginline);
    font-size: var(--font-m);
    line-height: 1.1 0.5;
    padding: 1lh 0 0;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-categorynav__item::before {
    content: none;
  }
  .p-categorynav__link {
    display: block;
    text-decoration: none;
    color: var(--bgtc);
    position: relative;
  }
  .p-categorynav__link::before {
    display: block;
    content: "";
    position: absolute;
    width: 0.5em;
    height: 0.5em;
    rotate: 45deg;
    border: 2px solid var(--bgc-acc1);
    border-left: none;
    border-top: none;
    top: 50%;
    right: -0.8em;
    -webkit-transition: translate 0.2s ease-in-out;
    transition: translate 0.2s ease-in-out;
    translate: 0 -66%;
  }
  .p-categorynav__link:hover::before {
    translate: 0 -30%;
  }
  .p-company-greeting__wrap,
  .p-recruit-message__wrap {
    grid-column: 3/-3;
  }
  .p-company-greeting__wrap h2,
  .p-recruit-message__wrap h2 {
    -webkit-margin-after: 0;
            margin-block-end: 0;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-company-greeting__wrap h2,
    .p-recruit-message__wrap h2 {
      -webkit-margin-after: calc(var(--gap) * 1);
              margin-block-end: calc(var(--gap) * 1);
    }
  }
  .p-company-greeting__box,
  .p-recruit-message__box {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 2);
    max-width: var(--bp-l);
    margin-inline: auto;
    padding: calc(var(--blockgap) * 2);
    background: var(--bgc-suf2);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-company-greeting__box,
    .p-recruit-message__box {
      padding: calc(var(--blockgap) * 1.5);
    }
  }
  .p-company-greeting__article,
  .p-recruit-message__article {
    line-height: 1.5;
  }
  .p-company-greeting__message strong,
  .p-recruit-message__message strong {
    font-weight: 600;
    font-size: var(--font-l);
  }
  .p-company-greeting__signature-text,
  .p-recruit-message__signature-text {
    text-align: right;
  }
  .p-company-greeting__fig,
  .p-recruit-message__fig {
    display: -ms-grid;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(150px, 100%), 1fr));
    gap: calc(var(--gap) * 1);
  }
  .p-company-info__wrap {
    grid-column: 3/-3;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    gap: calc(var(--gap) * 2);
  }
  .p-company-info__article {
    grid-column: 1/var(--_sp);
  }
  .p-company-info__aside {
    grid-column: var(--_sp)/-1;
  }
  .p-company-info__table {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    --_sp: 9;
    width: 100%;
    max-width: var(--bp-l);
    margin-inline: auto;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 419px) {
    .p-company-info__table {
      display: block;
    }
    .p-company-info__table tbody,
    .p-company-info__table tr,
    .p-company-info__table th,
    .p-company-info__table td {
      display: block;
      width: 100%;
    }
    .p-company-info__table th, .p-company-info__table td {
      padding: calc(var(--gap) * 0.5);
    }
    .p-company-info__table th {
      -webkit-padding-after: 0;
              padding-block-end: 0;
      -webkit-border-after: none;
              border-block-end: none;
    }
    .p-company-info__table td {
      -webkit-padding-before: 0;
              padding-block-start: 0;
    }
  }
  .p-company-access__wrap {
    background: var(--bgc-suf2);
    padding-block: var(--sectiongap);
  }
  .p-company-clients__list {
    display: -ms-grid;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(420px, 100%), 1fr));
    gap: calc(var(--gap) * 0.5) calc(var(--gap) * 2);
    padding: 0;
  }
  .p-company-clients__item::before {
    content: none;
  }
  .p-company-clients__note {
    text-align: right;
    font-size: var(--font-s);
  }
  .p-company-qualification__wrap {
    background: var(--bgc-suf2);
    padding-block: var(--sectiongap);
  }
  .p-company-qualification__box {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr calc(var(--gap) * 3) 1fr calc(var(--gap) * 3) 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(var(--gap) * 3);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-company-qualification__box {
      -ms-grid-columns: (1fr)[1];
      grid-template-columns: repeat(1, 1fr);
    }
  }
  .p-company-qualification__category {
    -ms-grid-column-span: 1;
    grid-column: span 1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 1);
  }
  .p-company-qualification__list {
    --_bd: 1px solid #ccc;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    padding: 0;
  }
  .p-company-qualification__item {
    -webkit-border-after: var(--_bd);
            border-block-end: var(--_bd);
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: auto;
    -ms-grid-columns: auto calc(var(--gap) * 1) 1fr calc(var(--gap) * 1) -webkit-max-content;
    -ms-grid-columns: auto calc(var(--gap) * 1) 1fr calc(var(--gap) * 1) max-content;
        grid-template: "name bar count" auto/auto 1fr -webkit-max-content;
        grid-template: "name bar count" auto/auto 1fr max-content;
    -ms-flex-line-pack: center;
        align-content: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: calc(var(--gap) * 1);
    padding: calc(var(--gap) * 0.5);
    margin: 0;
  }
  .p-company-qualification__item:first-child {
    -webkit-border-before: var(--_bd);
            border-block-start: var(--_bd);
  }
  .p-company-qualification__item::before {
    content: none;
  }
  .p-company-qualification__item::after {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    grid-area: bar;
    content: none;
    display: block;
    width: 100%;
    height: 1px;
    margin-block: auto;
    background-color: currentColor;
    opacity: 0.6;
  }
  .p-company-qualification__name {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    grid-area: name;
    display: block;
  }
  .p-company-qualification__count {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
    grid-area: count;
    display: block;
    text-align: right;
  }
  .p-company-qualification__count::after {
    content: "名";
  }
  .p-business-about__wrap {
    grid-column: 3/-3;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    gap: calc(var(--gap) * 2);
  }
  .p-business-about__wrap h2 {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
  .p-business-about__box {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 2);
    max-width: var(--bp-l);
    margin-inline: auto;
    padding: calc(var(--blockgap) * 2);
    background: var(--bgc-suf2);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-business-about__box {
      padding: calc(var(--blockgap) * 1.5);
    }
  }
  .p-business-about__content {
    grid-column: 1/-1;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-business-about__content {
      grid-column: 1/-1;
    }
  }
  .p-business-about__fig {
    grid-column: 1/-1;
    width: 100%;
    margin: 0;
  }
  .p-business-service__box {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr calc(var(--gap) * 3) 1fr calc(var(--gap) * 3) 1fr;
    grid-template-columns: repeat(3, 1fr);
    -ms-grid-rows: auto;
    grid-template-rows: auto;
    gap: calc(var(--gap) * 1) calc(var(--gap) * 3);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-business-service__box > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-business-service__box > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-business-service__box > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
  }
  @media only screen and (max-width: 979px) {
    .p-business-service__box {
      -ms-grid-columns: 1fr;
      grid-template-columns: repeat(1, 1fr);
      gap: calc(var(--gap) * 2);
    }
  }
  .p-business-service__item {
    -ms-grid-row-span: 4;
    grid-row: span 4;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    -ms-grid-rows: subgrid;
    grid-template-rows: subgrid;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-business-service__item > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  @media only screen and (max-width: 979px) {
    .p-business-service__item {
      -ms-grid-columns: 1fr calc(var(--gap) * 1) 1.61fr;
      grid-template-columns: 1fr 1.61fr;
      -ms-grid-rows: auto;
      grid-template-rows: auto;
      gap: calc(var(--gap) * 1);
    }
    .p-business-service__item > *:nth-child(1) {
      -ms-grid-row: 1;
      -ms-grid-column: 1;
    }
    .p-business-service__item > *:nth-child(2) {
      -ms-grid-row: 1;
      -ms-grid-column: 3;
    }
  }
  @media only screen and (max-width: 639px) {
    .p-business-service__item {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
    }
  }
  .p-business-service__textbox {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    display: contents;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-business-service__textbox {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      gap: calc(var(--gap) * 1);
    }
  }
  .p-business-service__title {
    font-size: var(--font-l);
    text-align: center;
    color: var(--bgc-acc1);
    line-height: 1.5;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-business-service__title {
      text-align: left;
    }
    .p-business-service__title br {
      display: none;
    }
  }
  .p-business-service__text {
    -webkit-margin-after: 0;
            margin-block-end: 0;
    font-size: var(--font-m);
  }
  .p-business-service__caption {
    font-size: var(--font-m);
    -webkit-margin-after: 0;
            margin-block-end: 0;
    background: #F3F3F3;
    color: #2C2C2C;
    padding: calc(var(--gap) * 1);
    border-radius: calc(var(--gap) * 0.5);
  }
  .p-business-service__fig {
    margin: 0;
  }
  .p-recruit-teaser__wrap {
    grid-column: 3/-3;
    display: -ms-grid;
    display: grid;
  }
  .p-recruit-teaser__lead {
    text-align: center;
    font-weight: bold;
    font-size: var(--font-l);
  }
  .p-recruit-space__slider {
    --_mg: calc(var(--gap) * 1);
    margin-inline: calc(var(--_mg) * -1);
    padding: 0;
  }
  .p-recruit-space__slider .slick-dots {
    padding: 0;
  }
  .p-recruit-space__slider .slick-dots li {
    list-style: none;
  }
  .p-recruit-space__slider .slick-dots li::before {
    content: none;
  }
  .p-recruit-space__slider .slick-dots button {
    display: -ms-grid;
    display: grid;
    place-items: center;
  }
  .p-recruit-space__slider .slick-dots button::before {
    position: static;
    content: "";
    background: #ccc;
    border-radius: 100%;
    width: 10px;
    height: 10px;
  }
  .p-recruit-space__slider .slick-dots .slick-active button::before {
    background: var(--bgc-acc1);
  }
  .p-recruit-space__item {
    list-style: none;
    margin-inline: var(--_mg);
  }
  .p-recruit-space__item::before {
    content: none;
  }
  .p-recruit-space__caption {
    text-align: center;
  }
  .p-recruit-nav__list {
    padding: 0;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[4];
    grid-template-columns: repeat(4, 1fr);
    --_bd: 1px dotted var(--bgc-acc1);
    border: var(--_bd);
    border-radius: 100vmax;
    overflow: hidden;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-recruit-nav__list {
      border-radius: calc(var(--gap) * 1);
      -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media only screen and (max-width: 419px) {
    .p-recruit-nav__list {
      -ms-grid-columns: (1fr)[1];
      grid-template-columns: repeat(1, 1fr);
    }
  }
  .p-recruit-nav__item {
    margin: 0;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-recruit-nav__item:not(:last-child) {
    -webkit-border-end: var(--_bd);
            border-inline-end: var(--_bd);
  }
  .p-recruit-nav__item::before {
    content: none;
  }
  @media only screen and (max-width: 979px) {
    .p-recruit-nav__item:nth-child(-n+2) {
      -webkit-border-after: var(--_bd);
              border-block-end: var(--_bd);
    }
  }
  @media only screen and (max-width: 419px) {
    .p-recruit-nav__item:nth-child(-n+3) {
      -webkit-border-after: var(--_bd);
              border-block-end: var(--_bd);
    }
  }
  .p-recruit-nav__link {
    --bgc: var(--bgtc-acc1);
    --bgtc: var(--bgc-acc1);
    display: block;
    height: 100%;
    text-align: left;
    padding: calc(var(--gap) * 1) calc(var(--gap) * 2);
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: auto calc(var(--gap) * 1) auto;
    grid-template-columns: auto auto;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--gap) * 1);
    color: var(--bgtc);
    text-decoration: none;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  .p-recruit-nav__link::after {
    content: "▶";
    font-size: 83.3%;
  }
  .p-recruit-nav__link:hover {
    background: #0077FF;
    color: #000000;
    color: var(--bgc);
    border-color: var(--bgc);
  }
  @media only screen and (max-width: 419px) {
    .p-recruit-nav__link {
      padding: calc(var(--gap) * 0.5) calc(var(--gap) * 1);
    }
  }
  .p-recruit-strength__list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: -webkit-max-content -webkit-max-content 1fr;
    -ms-grid-columns: max-content max-content 1fr;
    grid-template-columns: -webkit-max-content -webkit-max-content 1fr;
    grid-template-columns: max-content max-content 1fr;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    counter-reset: name;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__list {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      padding: 0;
    }
  }
  .p-recruit-strength__item {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -ms-grid-rows: auto calc(var(--gap) * 1) auto;
    grid-template-rows: auto auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--gap) * 1) calc(var(--gap) * 4.5);
    counter-increment: name;
    line-height: 1;
    padding: calc(var(--gap) * 1);
    --_bd: 1px dotted var(--bgc-acc1);
    -webkit-border-after: var(--_bd);
            border-block-end: var(--_bd);
  }
  .p-recruit-strength__item > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-recruit-strength__item > *:nth-child(2) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-recruit-strength__item:last-child {
    -webkit-border-after: none;
            border-block-end: none;
  }
  .p-recruit-strength__strength {
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1/2;
    grid-row: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: auto auto;
    grid-template-columns: auto auto;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    color: var(--bgc-acc1);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__strength {
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
    }
  }
  .p-recruit-strength__strength--span {
    font-size: clamp(2rem, calc(2rem + (1vw - 0.32rem) * (0.8928571429)), 3rem);
    font-weight: 500;
    font-weight: bold;
  }
  .p-recruit-strength__strength--num {
    font-size: clamp(5rem, calc(5rem + (1vw - 0.32rem) * (4.4642857143)), 10rem);
    font-weight: 500;
    position: relative;
  }
  .p-recruit-strength__strength--num::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-block: calc(var(--gap) * 1) solid transparent;
    -webkit-border-start: calc(var(--gap) * 1) solid var(--bgc-acc1);
            border-inline-start: calc(var(--gap) * 1) solid var(--bgc-acc1);
    top: 50%;
    left: 100%;
    translate: calc(var(--gap) * 1.5) 0;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__strength--num::after {
      content: none;
    }
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__strength {
      grid-column: 1/-1;
      -ms-grid-row: 1;
      -ms-grid-row-span: 1;
      grid-row: 1/2;
    }
  }
  .p-recruit-strength__title {
    grid-column: 3/-1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    grid-row: 1/2;
    color: var(--bgc-acc1);
    font-size: var(--font-l);
    -webkit-margin-before: auto;
            margin-block-start: auto;
    font-weight: 550;
    line-height: 1.3;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__title {
      grid-column: 1/-1;
      -ms-grid-row: 2;
      -ms-grid-row-span: 1;
      grid-row: 2/3;
    }
  }
  .p-recruit-strength__text {
    grid-column: 3/-1;
    grid-row: 2/-1;
    font-size: var(--font-m);
    line-height: 1.5;
    -webkit-margin-after: auto;
            margin-block-end: auto;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-strength__text {
      grid-column: 1/-1;
      -ms-grid-row: 3;
      -ms-grid-row-span: 1;
      grid-row: 3/4;
    }
  }
  .p-recruit-requirements__table {
    width: 100%;
    max-width: var(--bp-l);
    margin-inline: auto;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 419px) {
    .p-recruit-requirements__table {
      display: block;
    }
    .p-recruit-requirements__table tbody,
    .p-recruit-requirements__table tr,
    .p-recruit-requirements__table th,
    .p-recruit-requirements__table td {
      display: block;
      width: 100%;
    }
    .p-recruit-requirements__table th, .p-recruit-requirements__table td {
      padding: calc(var(--gap) * 0.5);
    }
    .p-recruit-requirements__table th {
      -webkit-padding-after: 0;
              padding-block-end: 0;
      -webkit-border-after: none;
              border-block-end: none;
    }
    .p-recruit-requirements__table td {
      -webkit-padding-before: 0;
              padding-block-start: 0;
    }
  }
  .p-recruit-requirements__fig {
    width: 100%;
    max-width: var(--bp-l);
    margin-inline: auto;
  }
  .p-recruit-voice__wrap {
    --_c: var(--bgc-acc1);
    --_t: var(--bgtc-acc1);
    background: var(--_c);
    padding-block: var(--sectiongap);
  }
  .p-recruit-voice__wrap h2 {
    color: var(--_t);
  }
  .p-recruit-voice__wrap h2::before {
    background: var(--_t);
  }
  .p-recruit-voice__item {
    background: var(--_t);
    padding: var(--blockgap);
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
  }
  .p-recruit-voice__item:last-child {
    -webkit-margin-before: calc(var(--gap) * 2);
            margin-block-start: calc(var(--gap) * 2);
  }
  .p-recruit-voice__title {
    grid-column: 1/-1;
    background: var(--_c);
    color: var(--_t);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    -webkit-padding-after: calc(var(--gap) * 1);
            padding-block-end: calc(var(--gap) * 1);
    -webkit-padding-end: calc(var(--gap) * 2);
            padding-inline-end: calc(var(--gap) * 2);
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.8928571429)), 2.4rem);
    margin: calc(var(--blockgap) * -1) 0 calc(var(--blockgap) * 1) calc(var(--blockgap) * -1);
    font-weight: 500;
  }
  .p-recruit-voice__subtitle {
    -webkit-margin-after: calc(var(--gap) * 1);
            margin-block-end: calc(var(--gap) * 1);
    color: var(--_c);
    font-size: var(--font-l);
    font-weight: bold;
  }
  .p-recruit-voice__textbox {
    grid-column: 1/-1;
  }
  .p-recruit-voice__box {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    --_separatepoint: 9;
    gap: calc(var(--gap) * 2);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-voice__box {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
    }
  }
  .p-recruit-voice__content {
    grid-column: 1/var(--_separatepoint);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-voice__content {
      grid-column: 1/-1;
    }
  }
  .p-recruit-voice__images {
    grid-column: var(--_separatepoint)/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: calc(var(--gap) * 1);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 639px) {
    .p-recruit-voice__images {
      grid-column: 1/-1;
    }
  }
  .p-recruit-voice__img {
    width: 100%;
    height: auto;
  }
  .p-recruit-voice__messages {
    grid-column: 1/-1;
  }
  .p-contact-phone__content {
    background: var(--bgc-suf2);
    padding: calc(var(--blockgap) * 2);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-contact-phone__content {
      padding: calc(var(--blockgap) * 1.5);
    }
  }
  .p-contact-phone__addresslist {
    display: -ms-grid;
    display: grid;
    padding: 0;
    -ms-grid-columns: 1fr calc(var(--gap) * 3) 1fr;
    grid-template-columns: repeat(2, 1fr);
    place-items: center;
    gap: calc(var(--gap) * 3);
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-contact-phone__addresslist {
      -ms-grid-columns: 1fr;
      grid-template-columns: repeat(1, 1fr);
      gap: 0;
    }
  }
  .p-contact-phone__address {
    margin: 0;
    font-size: clamp(1.6rem, calc(1.6rem + (1vw - 0.32rem) * (1.7857142857)), 3.6rem);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
  .p-contact-phone__address::before {
    content: none;
  }
  .p-contact-phone__worktime {
    font-size: var(--font-m);
    text-align: center;
  }
  .s-fadein {
    opacity: 0;
    translate: 0 calc(var(--gap) * 3);
    -webkit-transition: opacity 1s ease-in, translate 1s ease-out;
    transition: opacity 1s ease-in, translate 1s ease-out;
  }
  .s-fadein.is_active {
    opacity: 1;
    translate: 0 0;
  }
  .p-top-lead__wrap {
    position: relative;
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    overflow: hidden;
    min-height: 80vh;
    --imgsize: max(8em,10vw);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__wrap {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      min-height: 0;
    }
  }
  .p-top-lead__textbox {
    grid-column: 9/-1;
    background: rgba(0, 0, 0, 0.4);
    color: #fff;
    backdrop-filter: blur(5px);
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: var(--sectiongap) 0;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__textbox {
      padding: calc(var(--blockgap) * 2.5 + var(--imgsize) / 2) 0 var(--sectiongap);
      grid-column: 1/-1;
      -webkit-box-ordinal-group: 3;
          -ms-flex-order: 2;
              order: 2;
      background: #777;
      min-height: calc(min(100vmin, 50dvh) - 100vmin);
    }
  }
  .p-top-lead__content {
    grid-column: 2/-1;
    padding-inline: calc(var(--windowpaddinginline) * 2);
    display: -ms-grid;
    display: grid;
    gap: var(--sectiongap);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__content {
      gap: var(--blockgap);
    }
  }
  @media only screen and (max-width: 419px) {
    .p-top-lead__content {
      padding-inline: var(--windowpaddinginline);
    }
  }
  .p-top-lead__title {
    font-size: clamp(1.8rem, calc(1.8rem + (1vw - 0.32rem) * (0.625)), 2.5rem);
    line-height: 1.7;
    -webkit-padding-end: calc(var(--imgsize) / 2 + var(--windowpaddinginline));
            padding-inline-end: calc(var(--imgsize) / 2 + var(--windowpaddinginline));
    word-break: auto-phrase;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__title {
      -webkit-padding-end: 0;
              padding-inline-end: 0;
    }
  }
  .p-top-lead__text {
    font-size: var(--font-m);
    line-height: 1.9;
  }
  .p-top-lead__bgfig {
    position: absolute;
    inset: 0;
    z-index: -1;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__bgfig {
      -webkit-box-ordinal-group: 2;
          -ms-flex-order: 1;
              order: 1;
      position: static;
      height: min(100vmin, 50dvh);
    }
  }
  .p-top-lead__bg {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 50% 50%;
       object-position: 50% 50%;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__bg {
      -o-object-position: 0% 50%;
         object-position: 0% 50%;
    }
  }
  .p-top-lead__imgfig {
    position: absolute;
    top: calc(var(--sectiongap) / 2);
    left: 50%;
    translate: -50% 0;
    z-index: 1;
    border: 3px solid #fff;
    border-radius: 100vmax;
    overflow: hidden;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-lead__imgfig {
      top: min(100vmin, 50dvh);
      translate: -50% -50%;
    }
  }
  .p-top-lead__img {
    font-size: var(--font-l);
    width: var(--imgsize);
    height: var(--imgsize);
    -o-object-fit: cover;
       object-fit: cover;
  }
  .p-top-business__wrap {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    padding-block: var(--sectiongap);
    gap: var(--blockgap);
  }
  .p-top-business__title {
    grid-column: 3/-3;
    display: -ms-grid;
    display: grid;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: var(--gap);
    font-size: clamp(1.8rem, calc(1.8rem + (1vw - 0.32rem) * (2.8571428571)), 5rem);
    text-align: center;
    font-weight: 600;
  }
  .p-top-business__title--main {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .p-top-business__title--sub {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.9821428571)), 2.5rem);
  }
  .p-top-business__title::after {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    content: "";
    display: block;
    margin-inline: auto;
    width: 3px;
    height: 0.8em;
    background: var(--bgc-acc1);
  }
  .p-top-business__content {
    grid-column: 1/-1;
    width: 100%;
    max-width: var(--bp-m);
    margin-inline: auto;
    padding-inline: var(--windowpaddinginline);
    font-size: var(--font-m);
    line-height: 1.5;
  }
  .p-top-business__services {
    grid-column: 1/-1;
    max-width: var(--bp-m);
    margin-inline: auto;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr calc(var(--gap) * 1) 1fr calc(var(--gap) * 1) 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(var(--gap) * 1);
  }
  .p-top-business__item {
    list-style: none;
    text-decoration: none;
    background: var(--bgc-acc1);
    border-radius: 100vmax;
    -webkit-transition: opacity 0.3s ease-in-out;
    transition: opacity 0.3s ease-in-out;
  }
  .p-top-business__item:hover {
    opacity: 0.6;
  }
  .p-top-business__link {
    text-decoration: none;
  }
  .p-top-business__cardtitle {
    aspect-ratio: 1/1;
    text-align: center;
    font-size: var(--font-m);
    padding: calc(var(--gap) * 2);
    display: -ms-grid;
    display: grid;
    place-content: center;
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (1.4285714286)), 3rem);
    color: var(--bgtc-acc1);
  }
  .p-top-business__gallery {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[4];
    grid-template-columns: repeat(4, 1fr);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 979px) {
    .p-top-business__gallery {
      -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
    }
  }
  .p-top-business__galitem {
    list-style: none;
  }
  .p-top-business__galfig {
    margin: 0;
    padding: 0;
  }
  .p-top-business__galimg {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .p-top-business__btnwrap {
    --c: var(--bgc-acc1);
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.5357142857)), 2rem);
    grid-column: 3/-3;
    -ms-flex-line-pack: center;
        align-content: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-top-business__btn {
    display: -ms-grid;
    display: grid;
    margin-inline: auto;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    -ms-grid-columns: auto var(--gap) auto;
    grid-template-columns: auto auto;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: var(--gap);
    color: var(--c);
    font-weight: 600;
    text-decoration: none;
  }
  .p-top-business__btn::after {
    content: "▶";
    display: block;
    padding: 0.8em;
    border-radius: 100vmax;
    color: var(--c);
    font-size: 66%;
    line-height: 1;
    border: 1px dotted var(--c);
  }
  .p-top-business__btn:hover::after {
    background: var(--c);
    color: #fff;
  }
  .p-top-recruit__wrap {
    --c: var(--bgc-acc1);
    position: relative;
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    overflow: hidden;
    padding-block: var(--sectiongap);
    gap: var(--blockgap);
  }
  .p-top-recruit__title {
    grid-column: 3/-3;
    color: var(--c);
    font-size: clamp(1.6rem, calc(1.6rem + (1vw - 0.32rem) * (3.4821428571)), 5.5rem);
    line-height: 1.3;
    text-align: center;
  }
  .p-top-recruit__title--strong {
    font-size: clamp(2.4rem, calc(2.4rem + (1vw - 0.32rem) * (5)), 8rem);
  }
  .p-top-recruit__content {
    grid-column: 1/-1;
    width: 100%;
    max-width: var(--bp-m);
    margin-inline: auto;
    padding-inline: var(--windowpaddinginline);
  }
  .p-top-recruit__lead {
    font-size: clamp(1.2rem, calc(1.2rem + (1vw - 0.32rem) * (0.7142857143)), 2rem);
    line-height: 1.5;
    font-weight: bold;
  }
  .p-top-recruit__appeal {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: subgrid;
    grid-template-columns: subgrid;
    gap: var(--gap);
  }
  .p-top-recruit__points {
    grid-column: 1/-1;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr var(--gap) 1fr var(--gap) 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gap);
    max-width: var(--bp-l);
    margin-inline: auto;
    padding-inline: var(--windowpaddinginline);
  }
  .p-top-recruit__point {
    list-style: none;
    aspect-ratio: 1/1;
    display: -ms-grid;
    display: grid;
    place-content: center;
    border-radius: 100vmax;
    background: var(--c);
    padding-inline: calc(var(--gap) * 0.5);
    color: #fff;
    text-align: center;
    font-size: clamp(1rem, calc(1rem + (1vw - 0.32rem) * (1.3392857143)), 2.5rem);
    line-height: 1.5;
    font-weight: bold;
  }
  .p-top-recruit__appealmessage {
    grid-column: 1/-1;
    font-size: clamp(1.6rem, calc(1.6rem + (1vw - 0.32rem) * (0.3571428571)), 2rem);
    line-height: 1.5;
    font-weight: bold;
    text-align: center;
    color: var(--c);
  }
  .p-top-recruit__bgfig {
    position: absolute;
    inset: 0;
    z-index: -1;
  }
  .p-top-recruit__bg {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .p-top-recruit__btnwrap {
    grid-column: 1/-1;
    max-width: var(--bp-l);
    margin-inline: auto;
    padding-inline: var(--windowpaddinginline);
  }
  .p-top-recruit__btn {
    display: block;
    background: #fff;
    border: 1px dotted var(--c);
    border-radius: 100vmax;
    color: var(--c);
    font-size: clamp(1.4rem, calc(1.4rem + (1vw - 0.32rem) * (0.5357142857)), 2rem);
    line-height: 1;
    font-weight: bold;
    text-decoration: none;
    padding: calc(var(--gap) * 1) calc(var(--gap) * 4) calc(var(--gap) * 1) calc(var(--gap) * 2);
    position: relative;
  }
  .p-top-recruit__btn::after {
    content: "▶";
    display: block;
    position: absolute;
    right: calc(var(--gap) * 1);
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    font-size: 50%;
  }
  .p-top-recruit__btn:hover {
    background: var(--c);
    color: #fff;
  }
  .p-top-recruit__btn:hover::after {
    color: #fff;
  }
  .p-pagetopanchor__wrap {
    grid-column: 1/-1;
    position: relative;
    position: sticky;
    bottom: var(--windowpaddinginline);
    pointer-events: none;
  }
  .p-pagetopanchor__btn {
    pointer-events: auto;
    margin-inline: auto var(--windowpaddinginline);
    background: var(--bgc-acc1);
    color: var(--bgtc-acc1);
    text-decoration: none;
    display: -ms-grid;
    display: grid;
    place-content: center;
    aspect-ratio: 1/1;
    border-radius: 100vmax;
    width: 5em;
    -webkit-padding-before: 1em;
            padding-block-start: 1em;
    text-align: center;
    font-size: var(--font-m);
    line-height: 1.2;
    position: relative;
    translate: 0 150%;
    -webkit-transition: translate 0.3s ease-in-out;
    transition: translate 0.3s ease-in-out;
  }
  .p-pagetopanchor__btn::before {
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -250%;
    content: "";
    display: block;
    width: 0;
    height: 0;
    -webkit-border-after: 0.5em solid var(--bgtc-acc1);
            border-block-end: 0.5em solid var(--bgtc-acc1);
    -webkit-border-start: 0.5em solid transparent;
            border-inline-start: 0.5em solid transparent;
    -webkit-border-end: 0.5em solid transparent;
            border-inline-end: 0.5em solid transparent;
  }
  .pcactive .p-pagetopanchor__btn {
    translate: 0 0;
  }
  .p-sitefooter__wrap {
    padding-block: var(--sectiongap) 0;
    gap: var(--gap);
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-sitefooter__wrap {
      gap: var(--blockgap) 0;
    }
  }
  .p-sitefooter__info {
    grid-column: 3/-3;
  }
  .p-sitefooter__logo {
    grid-column: 3/-3;
  }
  .p-sitefooter_info__wrap {
    display: -ms-grid;
    display: grid;
    gap: var(--gap);
  }
  .p-sitefooter_info__homelink {
    text-decoration: none;
    color: var(--bgtc);
  }
  .p-sitefooter_info__headline {
    font-size: clamp(1.8rem, calc(1.8rem + (1vw - 0.32rem) * (1.0714285714)), 3rem);
    font-weight: 500;
  }
  .p-sitefooter_info__address {
    font-size: var(--font-m);
    font-style: normal;
  }
  .p-sitefooter_info__address--text {
    font-size: var(--font-m);
    line-height: 1.5;
  }
  .p-sitefooter_info__address--text br {
    display: none;
    /*
    モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
    @if $breakpoint == $menubreakpoint {
    	@media only screen and (max-width: 1439px), (any-hover: none) {
    		@content;
    	}
    }
    @else if $breakpoint == $menubreakpointmin {
    	@media only screen and (min-width: 1440px) and (any-hover: hover) {
    		@content;
    	}
    }
    @else {
    }
    */
  }
  @media only screen and (max-width: 767px) {
    .p-sitefooter_info__address--text br {
      display: block;
    }
  }
  .p-sitefooter_info__address--list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: var(--gap);
  }
  .p-sitefooter_info__address--item {
    list-style: none;
  }
  .p-sitefooter_jtia__img {
    font-size: clamp(2.5rem, calc(2.5rem + (1vw - 0.32rem) * (0.4464285714)), 3rem);
    width: 100%;
    max-width: 10em;
  }
}
@layer utility {
  .ouxs {
    display: inherit !important;
  }
  td.ouxs, th.ouxs {
    display: table-cell !important;
  }
  .olxs {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 419px) {
    .ouxs {
      display: none !important;
    }
    td.ouxs, th.ouxs {
      display: none !important;
    }
    .olxs {
      display: inherit !important;
    }
    td.olxs, th.olxs {
      display: table-cell !important;
    }
  }
  .ouxs-s {
    display: inherit !important;
  }
  td.ouxs-s, th.ouxs-s {
    display: table-cell !important;
  }
  .olxs-s {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 420px) and (max-width: 639px) {
    .ouxs-s {
      display: none !important;
    }
    td.ouxs-s, th.ouxs-s {
      display: none !important;
    }
    .olxs-s {
      display: inherit !important;
    }
    td.olxs-s, th.olxs-s {
      display: table-cell !important;
    }
  }
  .ous {
    display: inherit !important;
  }
  td.ous, th.ous {
    display: table-cell !important;
  }
  .ols {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 639px) {
    .ous {
      display: none !important;
    }
    td.ous, th.ous {
      display: none !important;
    }
    .ols {
      display: inherit !important;
    }
    td.ols, th.ols {
      display: table-cell !important;
    }
  }
  .ousmin {
    display: inherit !important;
  }
  td.ousmin, th.ousmin {
    display: table-cell !important;
  }
  .olsmin {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 639px) {
    .ousmin {
      display: none !important;
    }
    td.ousmin, th.ousmin {
      display: none !important;
    }
    .olsmin {
      display: inherit !important;
    }
    td.olsmin, th.olsmin {
      display: table-cell !important;
    }
  }
  .ous-m {
    display: inherit !important;
  }
  td.ous-m, th.ous-m {
    display: table-cell !important;
  }
  .ols-m {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 640px) and (max-width: 767px) {
    .ous-m {
      display: none !important;
    }
    td.ous-m, th.ous-m {
      display: none !important;
    }
    .ols-m {
      display: inherit !important;
    }
    td.ols-m, th.ols-m {
      display: table-cell !important;
    }
  }
  .oum {
    display: inherit !important;
  }
  td.oum, th.oum {
    display: table-cell !important;
  }
  .olm {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 767px) {
    .oum {
      display: none !important;
    }
    td.oum, th.oum {
      display: none !important;
    }
    .olm {
      display: inherit !important;
    }
    td.olm, th.olm {
      display: table-cell !important;
    }
  }
  .oummin {
    display: inherit !important;
  }
  td.oummin, th.oummin {
    display: table-cell !important;
  }
  .olmmin {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 767px) {
    .oummin {
      display: none !important;
    }
    td.oummin, th.oummin {
      display: none !important;
    }
    .olmmin {
      display: inherit !important;
    }
    td.olmmin, th.olmmin {
      display: table-cell !important;
    }
  }
  .oum-l {
    display: inherit !important;
  }
  td.oum-l, th.oum-l {
    display: table-cell !important;
  }
  .olm-l {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 768px) and (max-width: 979px) {
    .oum-l {
      display: none !important;
    }
    td.oum-l, th.oum-l {
      display: none !important;
    }
    .olm-l {
      display: inherit !important;
    }
    td.olm-l, th.olm-l {
      display: table-cell !important;
    }
  }
  .oul {
    display: inherit !important;
  }
  td.oul, th.oul {
    display: table-cell !important;
  }
  .oll {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 979px) {
    .oul {
      display: none !important;
    }
    td.oul, th.oul {
      display: none !important;
    }
    .oll {
      display: inherit !important;
    }
    td.oll, th.oll {
      display: table-cell !important;
    }
  }
  .oulmin {
    display: inherit !important;
  }
  td.oulmin, th.oulmin {
    display: table-cell !important;
  }
  .ollmin {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 979px) {
    .oulmin {
      display: none !important;
    }
    td.oulmin, th.oulmin {
      display: none !important;
    }
    .ollmin {
      display: inherit !important;
    }
    td.ollmin, th.ollmin {
      display: table-cell !important;
    }
  }
  .oul-ul {
    display: inherit !important;
  }
  td.oul-ul, th.oul-ul {
    display: table-cell !important;
  }
  .oll-ul {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 980px) and (max-width: 1439px) {
    .oul-ul {
      display: none !important;
    }
    td.oul-ul, th.oul-ul {
      display: none !important;
    }
    .oll-ul {
      display: inherit !important;
    }
    td.oll-ul, th.oll-ul {
      display: table-cell !important;
    }
  }
  .ouul {
    display: inherit !important;
  }
  td.ouul, th.ouul {
    display: table-cell !important;
  }
  .olul {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 1439px) {
    .ouul {
      display: none !important;
    }
    td.ouul, th.ouul {
      display: none !important;
    }
    .olul {
      display: inherit !important;
    }
    td.olul, th.olul {
      display: table-cell !important;
    }
  }
  .ouulmin {
    display: inherit !important;
  }
  td.ouulmin, th.ouulmin {
    display: table-cell !important;
  }
  .olulmin {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 1440px) {
    .ouulmin {
      display: none !important;
    }
    td.ouulmin, th.ouulmin {
      display: none !important;
    }
    .olulmin {
      display: inherit !important;
    }
    td.olulmin, th.olulmin {
      display: table-cell !important;
    }
  }
  .oud {
    display: inherit !important;
  }
  td.oud, th.oud {
    display: table-cell !important;
  }
  .old {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (min-width: 1440px) {
    .oud {
      display: none !important;
    }
    td.oud, th.oud {
      display: none !important;
    }
    .old {
      display: inherit !important;
    }
    td.old, th.old {
      display: table-cell !important;
    }
  }
  .ouh {
    display: inherit !important;
  }
  td.ouh, th.ouh {
    display: table-cell !important;
  }
  .olh {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media (orientation: landscape) {
    .ouh {
      display: none !important;
    }
    td.ouh, th.ouh {
      display: none !important;
    }
    .olh {
      display: inherit !important;
    }
    td.olh, th.olh {
      display: table-cell !important;
    }
  }
  .ouv {
    display: inherit !important;
  }
  td.ouv, th.ouv {
    display: table-cell !important;
  }
  .olv {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media (orientation: portrait) {
    .ouv {
      display: none !important;
    }
    td.ouv, th.ouv {
      display: none !important;
    }
    .olv {
      display: inherit !important;
    }
    td.olv, th.olv {
      display: table-cell !important;
    }
  }
  .oup {
    display: inherit !important;
  }
  td.oup, th.oup {
    display: table-cell !important;
  }
  .olp {
    display: none !important;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media print {
    .oup {
      display: none !important;
    }
    td.oup, th.oup {
      display: none !important;
    }
    .olp {
      display: inherit !important;
    }
    td.olp, th.olp {
      display: table-cell !important;
    }
  }
  .ml0 {
    margin-left: 0 !important;
  }
  .dib {
    display: inline-block;
    font-size: inherit;
    color: inherit;
    font-weight: inherit;
  }
  .displaynone {
    display: none;
  }
  .wating {
    color: #f00;
    font-weight: bold;
  }
  .mp {
    text-align: center;
    display: -ms-grid;
    display: grid;
    place-content: center;
  }
  .mawmc {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
  }
  .maw1 {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
  }
  .maw2 {
    max-width: var(--bp-l);
    margin-left: auto;
    margin-right: auto;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
  }
  .maw3 {
    max-width: var(--bp-m);
    margin-left: auto;
    margin-right: auto;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
  }
  .ggmap, .p-company-access__map,
  .wp-block-embed__wrapper,
  .youtube {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
  }
  .ggmap iframe, .p-company-access__map iframe,
  .ggmap object,
  .p-company-access__map object,
  .ggmap embed,
  .p-company-access__map embed,
  .wp-block-embed__wrapper iframe,
  .wp-block-embed__wrapper object,
  .wp-block-embed__wrapper embed,
  .youtube iframe,
  .youtube object,
  .youtube embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .clearfix {
    zoom: 1;
  }
  .clearfix:before, .clearfix:after {
    content: "";
    display: table;
  }
  .clearfix:after {
    clear: both;
  }
  .btnsHoverList > *,
  .btnsHover {
    cursor: pointer !important;
  }
  .px8 {
    font-size: 0.8rem;
  }
  .px9 {
    font-size: 0.9rem;
  }
  .px10 {
    font-size: 1rem;
  }
  .px11 {
    font-size: 1.1rem;
  }
  .px12 {
    font-size: 1.2rem;
  }
  .px13 {
    font-size: 1.3rem;
  }
  .px14 {
    font-size: 1.4rem;
  }
  .px15 {
    font-size: 1.5rem;
  }
  .px16 {
    font-size: 1.6rem;
  }
  .px17 {
    font-size: 1.7rem;
  }
  .px18 {
    font-size: 1.8rem;
  }
  .px19 {
    font-size: 1.9rem;
  }
  .px20 {
    font-size: 2rem;
  }
  .px21 {
    font-size: 2.1rem;
  }
  .px22 {
    font-size: 2.2rem;
  }
  .px23 {
    font-size: 2.3rem;
  }
  .px24 {
    font-size: 2.4rem;
  }
  .red {
    color: red;
  }
  .clear {
    clear: both;
  }
  .txtAlignC,
  .allTxtAlignC th,
  .allTxtAlignC td {
    text-align: center;
  }
  .txtAlignL {
    text-align: left;
  }
  .txtAlignR,
  .tar {
    text-align: right;
  }
  .vAlignMiddle {
    vertical-align: middle;
    margin: 0 5px;
  }
  .flr {
    float: right;
  }
  .fll {
    float: left;
  }
  .flr,
  .fll {
    margin-bottom: calc(var(--gap) * 1);
    max-width: 30%;
    max-width: calc(33.3% - var(--gap) * 1);
  }
  .flr img,
  .fll img {
    width: 100%;
  }
  /*
  モバイル用メニューの発動トリガーをブレイクポイントによる制御とは別にタッチ端末による制御を追加する場合コメントアウトを解除する
  @if $breakpoint == $menubreakpoint {
  	@media only screen and (max-width: 1439px), (any-hover: none) {
  		@content;
  	}
  }
  @else if $breakpoint == $menubreakpointmin {
  	@media only screen and (min-width: 1440px) and (any-hover: hover) {
  		@content;
  	}
  }
  @else {
  }
  */
  @media only screen and (max-width: 979px) {
    .flr,
    .fll {
      max-width: 33%;
    }
  }
  ol.zengokakko {
    counter-reset: li;
    padding-left: 0;
  }
  ol.zengokakko li:before {
    counter-increment: li;
    content: "（" counter(li, decimal) "）";
  }
  ol.zengokakko > li {
    list-style: none;
    position: relative;
    padding-left: 2.5em;
  }
  ol.zengokakko > li:before {
    position: absolute;
    left: 0;
    color: #000000 !important;
  }
  ul.comelist {
    padding-left: 0;
  }
  ul.comelist > li {
    list-style: none;
    position: relative;
    padding-left: 1.5em;
  }
  ul.comelist > li:before {
    position: absolute;
    left: 0;
    color: #000000 !important;
  }
  ul.comelist > li {
    margin-top: 0;
    font-size: 1rem;
  }
  ul.comelist > li:before {
    content: "※";
  }
  .tabledl {
    overflow: hidden;
  }
  .tabledl dt {
    float: left;
  }
  .tabledl dd {
    margin-bottom: 0.5em;
  }
  .tabledl.tdl1em dt {
    width: "1em";
  }
  .tabledl.tdl1em dd {
    margin-left: "1.5em";
  }
  .tabledl.tdl2em dt {
    width: "2em";
  }
  .tabledl.tdl2em dd {
    margin-left: "2.5em";
  }
  .tabledl.tdl3em dt {
    width: "3em";
  }
  .tabledl.tdl3em dd {
    margin-left: "3.5em";
  }
  .tabledl.tdl4em dt {
    width: "4em";
  }
  .tabledl.tdl4em dd {
    margin-left: "4.5em";
  }
  .tabledl.tdl5em dt {
    width: "5em";
  }
  .tabledl.tdl5em dd {
    margin-left: "5.5em";
  }
  .widthbox-1-harf {
    width: 50%;
    margin: auto;
  }
  .widthbox-3-quarter {
    width: 75%;
    margin: auto;
  }
  img[src=""] {
    background: #f00;
  }
  .icon i {
    margin-left: 5px;
  }
  .fa-file-pdf {
    color: #f21d1d;
  }
  .fa-file-word {
    color: #121b83;
  }
  .fa-file-excel {
    color: #0e9a2f;
  }
  .fa-file-powerpoint {
    color: #ff9300;
  }
  .fa-clone {
    color: #0077FF;
  }
}