@charset "utf-8";
/*--------------------------------------------------------------------------------

  header

--------------------------------------------------------------------------------*/
header {
  width: 100%;
  position: relative;
  background-color: #FFF;
}

/*--------------------------------------------------------------------------------
  .l-hd
--------------------------------------------------------------------------------*/
.l-hd { display: grid; }
@media (min-width: 641px) {
  .l-hd {
    width: calc(var(--base-width) * 1px);
    max-width: calc(100% - (var(--side-space) * 2));
    margin: 0 auto;
    padding-top: 1rem;
    padding-bottom: 1rem;
    grid-column-gap: 1.5rem;
    grid-row-gap: 0.75rem;
    grid-template-columns: auto 1fr auto;
    grid-template-areas:
      "hd-logo hd-info hd-fsize"
      "hd-logo hd-nav hd-nav";
  }
  .l-hd-logo { grid-area: hd-logo; align-self: center; }
  .l-hd-info { grid-area: hd-info; align-self: center; justify-self: end; }
  .l-fsize { grid-area: hd-fsize; align-self: center; }
  .l-hd-nav { grid-area: hd-nav; justify-self: end; }
}
@media (max-width: 640px) {
  .l-hd {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "hd-logo gnav-btn";
  }
  .l-gnav-btn { grid-area: gnav-btn; }
}

/*--------------------------------------------------------------------------------
  .l-hd-logo
--------------------------------------------------------------------------------*/
.l-hd-logo { line-height: 0; }
@media (min-width: 641px) {
  .l-hd-logo { width: 480px; padding-bottom: 0.5rem }
}
@media (max-width: 640px) {
  .l-hd-logo { padding: 0.5rem 1rem 0.75rem 0.75rem; }
  .l-hd-logo img { width: auto; height: 4rem; }
}

/*--------------------------------------------------------------------------------
  .l-hd-info
--------------------------------------------------------------------------------*/
.l-hd-info_tel {
  text-decoration: none !important;
  line-height: 1;
  font-weight: 900;
  display: flex;
  align-items: center;
  column-gap: 0.5rem;
}
.l-hd-info_tel:before {
  content: "";
  width: 1em;
  height: 1em;
  line-height: 1;
  background: currentColor;
  color: inherit;
  mask-repeat: no-repeat;
  mask-image: var(--icon-tel);
}
@media (min-width: 641px) {
  .l-hd-info_ad { font-size: var(--fs-2s-rem); }
  .l-hd-info_tel {
    font-size: var(--fs-2l-rem);
    color: var(--orange) !important;
  }
}
@media (max-width: 640px) {
  .l-hd-info {
    padding: 1.5rem 0 1rem 0;
    text-align: center;
  }
  .l-hd-info_tel {
    width: min(100%, 400px);
    font-size: var(--fs-3l);
    padding: calc(0.5rem + 0.15em) 1rem;
  }
}

/*--------------------------------------------------------------------------------
  .l-fsize
--------------------------------------------------------------------------------*/
.l-fsize { text-align: center; }
.l-fsize_ttl { display: block; font-size: var(--fs-2s-rem); }
.l-fsize_btn {
  padding-top: 0.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
.l-fsize_btn-item { font-size: var(--fs-2s-rem); padding: 0.3rem 0.7rem; }
.l-fsize_btn-item:first-of-type {
  border-radius: 0.2rem 0 0 0.2rem;
  border-right: 0 !important;
}
.l-fsize_btn-item:last-of-type {
  border-radius: 0 0.2rem 0.2rem 0;
  border-left: 0 !important;
}
html.fs-standard .l-fsize_btn-item[data-size="S"],
html.fs-standard .l-fsize_btn-item[data-size="S"]:hover,
html.fs-large .l-fsize_btn-item[data-size="L"],
html.fs-large .l-fsize_btn-item[data-size="L"]:hover {
  background-color: var(--green);
  border-color: var(--green);
  color: #FFF;
}

/*--------------------------------------------------------------------------------
  .l-hd-nav
--------------------------------------------------------------------------------*/
.l-hd-nav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  column-gap: 0.5rem;
}
.l-hd-nav-list {
  display: flex;
  line-height: 1.5;
}
.l-hd-nav-list_item {
  position: relative;
  white-space: nowrap;
}
.l-hd-nav-list_item:not(:first-of-type):before {
  content: "";
  width: 1px;
  height: 1rem;
  line-height: 1;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-color: var(--border-color);
}
.l-hd-nav-list_link {
  display: block;
  padding: 0 1rem;
}

/*--------------------------------------------------------------------------------
  .l-gsearch（Googleカスタム検索）
--------------------------------------------------------------------------------*/
.gsc-control-cse { padding: 0 !important; }
.gsc-search-box-tools { margin: 0 !important; }
.gsc-input-box { padding: 5px 0 !important; }
.gsib_b { height: auto !important; }

/* 検索結果 */
.gsc-results-wrapper-overlay {
  width: calc(100% - (var(--side-space) * 2)) !important;
  left: 50% !important;
  transform: translateX(-50%);
}
@media (min-width: 641px) {
  .gsc-results-wrapper-overlay {
    height: calc(100% - (var(--side-space) * 2)) !important;
    top: 50% !important;
    transform: translate(-50%, -50%);
  }
}
@media (max-width: 640px) {
  .gsc-results-wrapper-overlay {
    height: calc((100% - var(--side-space)) - 6rem) !important;
    top: 6rem !important;
    transform: translateX(-50%);
  }
}

@media (min-width: 641px) {
  .l-gsearch {
    width: 240px;
  }
}
@media (max-width: 640px) {
  .l-gsearch {
    position: sticky;
    bottom: 0;
    background-color: var(--color-primary-light);
    padding: 1rem;
  }
  .l-gsearch_inner { overflow: hidden; }
  .gsc-control-cse {
    border-radius: 0.25rem !important;
  }
  .gsc-input-box {
    border: 0 !important;
  }
}

/*--------------------------------------------------------------------------------

  global navigation

--------------------------------------------------------------------------------*/
.l-gnav { background-color: var(--color-primary-lighter); }
@media (min-width: 641px) {
  .l-gnav {
    border-bottom: 3px solid var(--color-primary-dark);
  }
}
@media (max-width: 640px) {
  .l-gnav {
    width: 100%;
    height: calc(100vh - 100%);
    height: calc(100dvh - 100%);
    position: absolute;
    top: 100%;
    left: 0;
    overflow-y: auto;
  }
  .l-gnav_frame {
    min-height: 100%;
    position: relative;
    display: grid;
    grid-template-rows: 1fr auto;
  }
  .l-gnav_inner {
    padding: var(--box-space-m);
  }
}
.l-gnav a { text-decoration: none; color: inherit; }
.l-gnav a:hover { color: var(--color-link-hover); }

/* open
----------------------------------------*/
@media (max-width: 640px) {
  header,
  html.is-gnav-open { overflow-y: hidden; }
  html.is-gnav-open header,
  html.is-gnav-close header { overflow-y: visible; z-index: 900; }
}
.l-gnav.is-open { animation: 0.4s ani-gnav-open forwards; }
.l-gnav.is-close { animation: 0.3s ani-gnav-close forwards; }
@keyframes ani-gnav-open { from { opacity: 0; } to { opacity: 1; } }
@keyframes ani-gnav-close { from { opacity: 1; } to { opacity: 0; } }

/*--------------------------------------------------------------------------------
  .l-gnav-list
--------------------------------------------------------------------------------*/
.l-gnav-list {
  line-height: 1.5;
}
@media (min-width: 641px) {
  .l-gnav-list {
    width: calc(var(--base-width) * 1px);
    max-width: calc(100% - (var(--side-space) * 2));
    margin: 0 auto;
    display: flex;
  }
  .l-gnav-list_item,
  .l-gnav-list_link {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .l-gnav-list_item {
    flex-grow: 2;
    position: relative;
    font-size: var(--fs-m);
    font-weight: bold;
    text-align: center;
  }
  .l-gnav-list_item:not(:first-of-type):before,
  .l-gnav-list_item.-active:after {
    content: "";
    width: 1px;
    position: absolute;
  }
  .l-gnav-list_item:not(:first-of-type):before {
    height: 1.5rem;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--color-primary-light);
  }
  .l-gnav-list_item.-active:not(:last-of-type):after {
    height: 100%;
    top: 0;
    right: -1px;
    z-index: 2;
    background-color: var(--color-primary-dark);
  }
  .l-gnav-list_link {
    width: 100%;
    padding: 1.15rem;
  }
  .l-gnav-list_item.-active { background-color: var(--color-primary-dark); }
  .l-gnav-list_item.-active,
  .l-gnav-list_item.-active .l-gnav-list_link { color: #FFF; }
  .l-gnav-list_item.-active:before { display: none; }
}
@media (max-width: 640px) {
  .l-gnav-list {
    padding-bottom: 1.5rem;
    margin-top: -0.5rem;
  }
  .l-gnav-list_item {
    border-bottom: 1px solid var(--color-primary-light);
  }
  .l-gnav-list_link {
    font-size: var(--fs-m);
    font-weight: bold;
    display: block;
    padding: 1.25rem 0;
  }
}

/* accordion
----------------------------------------*/
@media (max-width: 640px) {
  .l-gnav-list_item.-acod .l-gnav-list_link {
    width: 100%;
    display: flex;
    column-gap: 1rem;
  }
  .l-gnav-list_item.-acod .l-gnav-list_link:after {
    content: "";
    width: 1.25em;
    height: 1.25em;
    margin-top: 0.125em;
    margin-left: auto;
    line-height: 1;
    background: var(--color-primary-dark);
    mask-repeat: no-repeat;
    mask-image: var(--icon-arrow-down);
  }
  .l-gnav-list_item.-acod.is-active .l-gnav-list_link:after { mask-image: var(--icon-arrow-up); }
}

/*--------------------------------------------------------------------------------
  .l-gnav-child
--------------------------------------------------------------------------------*/
@media (max-width: 640px) {
  .l-gnav-child {
    padding-bottom: 1.5rem;
  }
  .l-gnav-child_link {
    padding: 0.5rem 0;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-column-gap: 0.5rem;
  }
  .l-gnav-child_link:before {
    content: "";
    width: 1.2em;
    height: 1.2em;
    margin-top: 0.15em;
    line-height: 1;
    background: var(--color-primary-dark);
    mask-repeat: no-repeat;
    mask-image: var(--icon-arrowV-circle);
  }
}
@media (min-width: 641px) {
  .l-gnav-child { display: none; }
}

/* accordion
----------------------------------------*/
@media (max-width: 640px) {
  .l-gnav-list_item.-acod .l-gnav-child { display: none; }
}

/*--------------------------------------------------------------------------------
  .l-gnav-btn
--------------------------------------------------------------------------------*/
:root {
  --gnav-btn-txt-size: var(--fs-2s);
  --gnav-btn-txt-color: var(--color-primary-dark);
  --gnav-btn-line-color: var(--color-primary-dark);
}
@media (min-width: 401px) {
  :root {
    --gnav-btn-pd: 0.75rem 1.25rem;
    --gnav-btn-line-height: 3px;
    --gnav-btn-icon-width: 28px;
    --gnav-btn-icon-height: 18px;
  }
}
@media (max-width: 400px) {
  :root {
    --gnav-btn-pd: 0.75rem 1rem;
    --gnav-btn-line-height: 2px;
    --gnav-btn-icon-width: 22px;
    --gnav-btn-icon-height: 14px;
  }
}
.l-gnav-btn {
  border-left: 1px solid var(--border-color-light);
  padding: var(--gnav-btn-pd);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  row-gap: 0.75rem;
}
.l-gnav-btn:after {
  content: "MENU";
  font-size: var(--gnav-btn-txt-size);
  color: var(--gnav-btn-txt-color);
  line-height: 1.2;
}
.l-gnav-btn.is-close:after { content: "CLOSE"; }
.l-gnav-btn_icon {
  margin-top: 0.25rem;
  position: relative;
  width: var(--gnav-btn-icon-width);
  height: var(--gnav-btn-icon-height);
  transition: all 0.1s ease-out;
}
.l-gnav-btn_line {
  position: absolute;
  right: 0;
  height: var(--gnav-btn-line-height);
  transition: all 0.3s ease-out;
  background-color: var(--gnav-btn-line-color);
}
.l-gnav-btn_line:nth-of-type(1) { width: 100%; top: 0; }
.l-gnav-btn_line:nth-of-type(2) { width: 100%; top: 50%; }
.l-gnav-btn_line:nth-of-type(3) { width: 100%; top: 100%; }
.l-gnav-btn.is-close .l-gnav-btn_line:nth-of-type(1) {
  width: 100%;
  top: 0;
  transform: translateY(calc((var(--gnav-btn-icon-height) / 2))) rotate(-45deg);
}
.l-gnav-btn.is-close .l-gnav-btn_line:nth-of-type(2) { opacity: 0; }
.l-gnav-btn.is-close .l-gnav-btn_line:nth-of-type(3) {
  width: 100%;
  bottom: 0;
  transform: translateY(calc(-1 * (var(--gnav-btn-icon-height) / 2))) rotate(45deg);
}

/*--------------------------------------------------------------------------------
  .l-sp-snav
--------------------------------------------------------------------------------*/
@media (max-width: 640px) {
  .l-sp-snav {
    display: flex;
    flex-wrap: wrap;
    column-gap: 1.5rem;
  }
  .l-sp-snav_item {
    min-width: calc(50% - 0.75rem);
    flex-grow: 2;
    word-break: keep-all;
    overflow-wrap: anywhere;
  }
  .l-sp-snav_link {
    display: block;
    padding: 0.5rem 0;
  }
}

/*--------------------------------------------------------------------------------

  footer

--------------------------------------------------------------------------------*/
.l-ft_inner {
  width: calc(var(--base-width) * 1px);
  max-width: calc(100% - (var(--side-space) * 2));
  margin: 0 auto;
}
@media (min-width: 641px) {
  .l-ft { background-color: var(--color-secondary-dark); }
}
@media (max-width: 640px) {
  .l-ft { background-color: var(--color-secondary); }
}

/*--------------------------------------------------------------------------------
  .l-ft_info
--------------------------------------------------------------------------------*/
.l-ft-info-area {
  background-color: var(--color-gray-lightest);
  padding: var(--space-s) 0;
}
.l-ft-info_logo { padding: 0.25rem 0; }
.l-ft-info_ad {
  font-size: var(--fs-s);
  line-height: 1.4;
}
.l-ft-info_tel {
  display: flex;
  column-gap: 1.25rem;
  flex-wrap: wrap;
}
@media (min-width: 641px) {
  .l-ft-info {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: 1fr auto;
    grid-column-gap: 2rem;
    grid-row-gap: 0.15rem;
  }
  .l-ft-info_logo { grid-area: 1 / 1 / 3 / 2; align-self: end; width: 360px; }
  .l-ft-info_ad { grid-area: 1 / 2 / 2 / 3; align-self: end; }
  .l-ft-info_tel { grid-area: 2 / 2 / 3 / 3; align-self: end; }
}
@media (max-width: 640px) {
  .l-ft-info_logo img { width: auto; height: 3rem; }
  .l-ft-info_ad { padding: 1rem 0 0.25rem 0; }
}

/*--------------------------------------------------------------------------------
  .l-ft-bt
--------------------------------------------------------------------------------*/
.l-ft-bt {
  display: flex;
  color: #FFF;
  padding: 0.75rem 0;
}
.l-ft-bt a { color: inherit; }

/* .l-ft-list
----------------------------------------*/
.l-ft-list {
  display: flex;
  column-gap: 2rem;
  font-size: var(--fs-2s);
}
.l-ft-list_item {
  position: relative;
}
.l-ft-list_item:not(:first-of-type):before {
  content: "";
  width: 1px;
  height: 0.75rem;
  position: absolute;
  left: -1rem;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(255,255,255,0.2);
}

/* copyright
----------------------------------------*/
.l-ft_copy {
  font-size: var(--fs-3s);
}
@media (min-width: 641px) {
  .l-ft_copy { margin-left: auto; }
}
@media (max-width: 640px) {
  .l-ft_copy { flex-grow: 2; text-align: center; }
}

/*--------------------------------------------------------------------------------
  .l-page-top
--------------------------------------------------------------------------------*/
.l-page-top {
  position: sticky;
  bottom: 0;
  padding: 0 var(--side-space) var(--side-space) var(--side-space);
  display: flex;
  justify-content: flex-end;
  pointer-events: none;
}
.l-page-top_btn { display: none; pointer-events: auto; }
.l-page-top_btn .c-btn { padding: 0.5em; }
@media (max-width: 640px) {
  .l-page-top { bottom: clamp(3.8rem, 16vw, 5rem); }
}

/*--------------------------------------------------------------------------------
  .l-sp-fixnav
--------------------------------------------------------------------------------*/
.l-sp-fixnav {
  width: 100%;
  min-width: 300px;
  background-color: var(--color-secondary-dark);
  color: #FFF;
  position: sticky;
  bottom: 0;
  z-index: 800;
}
.l-sp-fixnav a { text-decoration: none; color: inherit; }

/* .l-sp-fixnav-list
----------------------------------------*/
.l-sp-fixnav-list {
  display: flex;
  line-height: 1.3;
  font-size: clamp(0.6em, 2.6vw, var(--fs-2s));
}
.l-sp-fixnav-list_item,
.l-sp-fixnav-list_link {
  display: flex;
}
.l-sp-fixnav-list_item {
  flex-direction: column;
  flex-basis: calc(100% / 6);
  flex-grow: 2;
  text-align: center;
}
.l-sp-fixnav-list_item:not(:first-of-type) {
  border-left: 1px solid rgba(255,255,255,0.2);
}
.l-sp-fixnav-list_item.-home { flex-basis: 13%; }
.l-sp-fixnav-list_item.-contact { flex-basis: 21%; }
.l-sp-fixnav-list_link {
  height: 100%;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  padding: 0.75em 0.75em 0.5em 0.75em;
}
.l-sp-fixnav-list_link:before {
  content: "";
  border: 1px solid #FFF;
  width: 1.8em;
  height: 1.8em;
  margin-top: 0.25em;
  margin-bottom: 0.25rem;
  line-height: 1;
  display: inline-block;
  vertical-align: middle;
  background: currentColor;
  color: inherit;
  mask-repeat: no-repeat;
}
.l-sp-fixnav-list_ttl {
  flex-grow: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
}
.l-sp-fixnav-list_item.-home .l-sp-fixnav-list_link:before { mask-image: var(--icon-home); }
.l-sp-fixnav-list_item.-about .l-sp-fixnav-list_link:before { mask-image: var(--icon-about); }
.l-sp-fixnav-list_item.-service .l-sp-fixnav-list_link:before { mask-image: var(--icon-service); }
.l-sp-fixnav-list_item.-group .l-sp-fixnav-list_link:before { mask-image: var(--icon-group); width: 2.4em; }
.l-sp-fixnav-list_item.-recruit .l-sp-fixnav-list_link:before { mask-image: var(--icon-recruit); }
.l-sp-fixnav-list_item.-contact .l-sp-fixnav-list_link:before { mask-image: var(--icon-mail); }


/*--------------------------------------------------------------------------------

  container

--------------------------------------------------------------------------------*/
.l-container.-column {
  display: grid;
  grid-column-gap: var(--space-m);
  grid-row-gap: var(--space-m);
}
@media (min-width: 641px) {
  .l-container {
    width: calc(var(--base-width) * 1px);
    max-width: calc(100% - (var(--side-space) * 2));
    margin: 0 auto;
    padding-bottom: var(--space-m);
  }
  .l-container.-column {
    display: grid;
    grid-template-columns: 260px 1fr;
    grid-template-areas: 
      "side main";
    align-content: start;
  }
  .l-side { grid-area: side; }
  .l-main { grid-area: main; }
}

.l-inner { padding-left: var(--side-space); padding-right: var(--side-space); }
@media (max-width: 640px) { .l-inner-sp { padding-left: var(--side-space); padding-right: var(--side-space); } }

/*--------------------------------------------------------------------------------

  container > side

--------------------------------------------------------------------------------*/
.l-side {
  display: grid;
  grid-row-gap: 1rem;
  align-content: start;
}

/*--------------------------------------------------------------------------------
  .l-menu-list
--------------------------------------------------------------------------------*/
.l-menu-ttl {
  line-height: 1.4;
  color: #FFF;
  font-weight: bold;
  font-size: var(--fs-m);
  padding: 0.8em 1rem;
  border-radius: 0.3rem 0.3rem 0 0;
  background-color: var(--color-primary-dark);
}
.l-menu-list {
  overflow: hidden;
  line-height: 1.6;
  border-width: 2px;
  border-style: solid;
  border-color: var(--color-primary-dark);
  border-radius: 0 0 0.3rem 0.3rem;
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
}
.l-menu-list_item {
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: var(--color-primary-light);
}
.l-menu-list_item:first-child { border-top: 0; }
.l-menu-list_item.-active { background-color: var(--color-primary-lightest); color: var(--color-link); }
.l-menu-list_link {
  color: inherit;
  text-decoration: none;
  position: relative;
  padding: 0.9em 1rem;
  display: grid;
  grid-column-gap: 0.5rem;
  grid-template-columns: auto 1fr;
}
.l-menu-list_link:before {
  content: "";
  width: var(--root-icon-size);
  height: var(--root-icon-size);
  display: inline-block;
  margin-top: 0.15em;
  margin-left: -0.15rem;
  line-height: 1;
  background: var(--color-primary-dark);
  mask-repeat: no-repeat;
  mask-image: var(--icon-arrowV-circle);
}
.l-menu-list_link.-more {
  grid-template-columns: 1fr auto;
  justify-items: end;
  align-items: center;
}
.l-menu-list_link.-more:before {
  grid-column: 2 / 4;
  grid-row : 1 / 2;
  width: var(--root-pager-icon-size);
  height: var(--root-pager-icon-size);
  margin-top: 0;
  margin-left: 0;
}
.l-menu-list_link:hover { background-color: var(--color-primary-lightest); }
@media (max-width: 640px) {
  .l-menu-ttl, .l-menu-list { border-radius: 0; }
  .l-menu-list { border: none; border-bottom: 1px solid var(--color-primary-light); }
  .l-menu-list_link.-more { padding-top: 1.5rem; display: inline-grid; }
}

/* archive
----------------------------------------*/
.l-menu-ttl.-archive { background-color: var(--color-tertiary); }
.l-menu-list.-archive { border-color: var(--color-tertiary); }
.l-menu-list.-archive .l-menu-list_item { border-top-color: var(--border-color-light); }
.l-menu-list.-archive .l-menu-list_link:before { background: var(--color-tertiary); }
.l-menu-list.-archive .l-menu-list_link:hover { background-color: inherit; color: var(--color-tertiary); }
@media (max-width: 640px) {
  .l-menu-list.-archive { border-bottom: 0; }
  .l-menu-ttl.-archive { margin-top: 1rem; }
  .l-menu-list.-archive .l-menu-list_item:has(.l-menu-list_link.-more) { text-align: right; }
}

.l-side-archive {
  display: flex;
  flex-direction: column;
}
.l-side-archive_item {
  padding: 1em 1rem;
  display: flex;
  flex-direction: column;
  row-gap: 0.25rem;
}
.l-side-archive_item:not(:first-child) { border-top: 1px solid var(--border-color-light); }
.l-side-archive_date { font-size: var(--fs-2s); color: var(--color-gray); }
.l-side-archive_ttl { color: var(--color-tertiary-dark); }
.l-side-archive_item:hover { background-color: var(--color-tertiary-lightest); }
.l-side-archive_item:hover .l-side-archive_ttl { color: var(--color-tertiary) !important; }
@media (max-width: 640px) {
  .l-side-archive_item { padding: 1.25rem 1rem; }
}

/*--------------------------------------------------------------------------------
  .l-side-bnr
--------------------------------------------------------------------------------*/
.l-side-bnr { display: flex; flex-wrap: wrap;  }
@media (min-width: 641px) {
  .l-side-bnr { flex-direction: column; gap: 1rem; }
}
@media (max-width: 640px) {
  .l-side-bnr { gap: 0.75rem; }
  .l-side-bnr_item { width: calc(50% - (0.75rem / 2)); }
}

/*--------------------------------------------------------------------------------
  .l-side-ssl
--------------------------------------------------------------------------------*/
.l-side-ssl {
  display: grid;
  align-items: center;
  grid-gap: 1rem;
  margin-top: 1rem;
}
.l-side-ssl_seal { text-align: center; }
.l-side-ssl_txt { font-size: clamp(0.6em, 2.6vw, var(--fs-2s)); }
@media (max-width: 640px) {
  .l-side-ssl {
    padding-bottom: var(--space-s);
    grid-template-columns: minmax(0, min(25%, 140px)) 1fr;
  }
  .l-side-ssl input[type="image"] { width: 100%; height: auto; }
}

/*--------------------------------------------------------------------------------

  container > main

--------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------
  .l-pg-ttl
--------------------------------------------------------------------------------*/
.l-pg-ttl {
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  row-gap: 0.25rem;
  margin-bottom: var(--space-s);
  color: var(--color-primary-dark);
  border-top: 2px solid var(--color-primary-dark);
  border-bottom: 1px solid var(--border-color);
}
.l-pg-ttl_sub { font-size: var(--fs-s); }
.l-pg-ttl_main { font-family: var(--ff-go); font-weight: 700; font-size: var(--fs-2l); }
@media (min-width: 641px) {
  .l-pg-ttl { padding: 1.75em 0; }
}
@media (max-width: 640px) {
  .l-pg-ttl { padding: 1.75rem var(--side-space); }
}
