@charset "UTF-8";

:root {
  --color-white: #FFFFFF;
  --color-black: #3E3A39;
  --color-1a1a1a: #1a1a1a;
  --color-666666: #666666;
  --color-8a8a8a: #8a8a8a;
  --color-cdcdcd: #cdcdcd;
  --color-ebebeb: #ebebeb;
  --color-e1e1e2: #e1e1e2;
  --color-f3f3f3: #f3f3f3;
  --color-ececec: #ececec;
  --color-2b4cdb: #2b4cdb;
  --color-00B9EF: #00B9EF;
  --color-00AB5A: #00AB5A;
  --color-00AB5A-5: rgba(0, 173, 92, 0.5);
  --color-007320: #007320;
  --color-FDD000: #FDD000;
  --color-FFE901: #FFE901;
  --color-E8380D: #E8380D;
  --color-b89023: #b89023;
  --color-6b82e6: #6b82e6;
  --color-6878c1: #6878c1;
  --color-DDF3FA: #DDF3FA;
  --color-EAEDFB: #EAEDFB;
  --color-d7ddf8: #d7ddf8;
  --font10: 0.625rem;
  --font12: 0.75rem;
  --font13: 0.8125rem;
  --font14: 0.875rem;
  --font15: 0.9375rem;
  --font16: 1rem;
  --font17: 1.0625rem;
  --font18: 1.125rem;
  --font20: 1.25rem;
  --font21: 1.3125rem;
  --font24: 1.5rem;
  --font26: 1.625rem;
  --font28: 1.75rem;
  --font30: 1.875rem;
  --font32: 2rem;
  --font35: 2.1875rem;
  --font38: 2.1875rem;
  --font40: 2.5rem;
  --font43: 2.6875rem;
  --font45: 2.8125rem;
  --font50: 50px;
  --font70: 70px;
  --font80: 80px;
  --font90: 90px;

  --font-weight-bold: 700;
  --font-weight-normal: normal;
  --shape-triangle-top: polygon(50% 0, 100% 100%, 0 100%);
  --shape-triangle-bottom: polygon(0 0, 100% 0, 50% 100%);
  --shape-triangle-right: polygon(0 0, 100% 50%, 0 100%);
  --shadow: 0 0.3rem 2.5rem -2rem rgba(85, 96, 96, 0.3), 0 0.3rem 0.5rem rgba(84, 96, 96, 0.376);
  --shadow2: 0 0.2rem 2rem -1rem rgba(85, 96, 96, 0.4), 0 0.2rem 0.3rem rgba(84, 96, 96, 0.4);
  --number-width: clamp(136px, 33.8vw, 180px);
  --stretch: stretch;
  --header-h: clamp(65px, 11vw, 110px);
  --page-header-pt: clamp(20px, 11vw / 1.4, 110px);
}

:where(html, body, div, span, h1, h2, h3, h4, p, a, img,dl, dt, dd, ul, li, ol,form, label, footer, header,section, button, figure, input, time, textarea){
  margin: 0;
  padding: 0;
  border: 0;
  overflow-wrap: break-word;
  font-size: 100%;
  line-height: 1.4;
  vertical-align: baseline;
}
body, html, input, button, a, textarea {
  color: var(--color-black);
  font-family: 'Roboto', "Hiragino Sans", "Noto Sans JP", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, Arial, sans-serif;
  font-weight: var(--font-weight-normal);
}
body{
  background: var(--color-white);
}
html{
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
  scroll-padding-top: 100px;
}
img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
a, a:active, a:focus, a::before {
  text-decoration: none;
  transition: .3s;
}
:where(ul, ol) {
  list-style-type: none;
}
span, label, a{
  display: inline-block;
}
button{ background: initial; }
p, li, a, dd, dt, h3, button, th, td, .text{
  font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.8px) * (4 / 13.7))), var(--font18));
}
strong{
  font-weight: var(--font-weight-bold);
}
address{ font-style: normal; }
/* Utility Classes (Recommended)
---------------------------------------------*/
.pb-100-50{ padding-bottom: clamp(50px, 10vw / 1.75, 100px); }
.pb-150-60{ padding-bottom: clamp(60px, 15vw / 1.75, 150px); }
.pb-250-100{ padding-bottom: clamp(100px, 25vw / 1.75, 250px); }
.pb-350-100{ padding-bottom: clamp(100px, 35vw / 1.75, 350px); }
.pb-450-100{ padding-bottom: clamp(100px, 45vw / 1.75, 450px); }
.p-block-100-50{ padding-block: clamp(50px, 10vw / 1.75, 100px); }
.p-block-150-60{ padding-block: clamp(60px, 15vw / 1.75, 150px); }
.mb-150-60{ margin-bottom: clamp(60px, 15vw / 1.75, 150px); }
.width-1920{
  width: min(calc(100vw - 6vw), 1920px);
  margin-inline: auto;
}
.width-1750{
  width: min(calc(100vw - 6vw), 1750px);
  margin-inline: auto;
}
.width-1600{
  width: min(calc(100vw - 10vw), 1600px);
  margin-inline: auto;
}
.width-1500{
  width: min(calc(100vw - 6vw), 1500px);
  margin-inline: auto;
}
.width-1400{
  width: min(calc(100vw - 6vw), 1400px);
  margin-inline: auto;
}
.width-1300{
  width: min(calc(100vw - 6vw), 1300px);
  margin-inline: auto;
}
.width-1200{
  width: min(calc(100vw - 6vw), 1200px);
  margin-inline: auto;
}
.width-1100{
  width: min(calc(100vw - 6vw), 1100px);
  margin-inline: auto;
}
.width-1000{
  width: min(calc(100vw - 6vw), 1000px);
  margin-inline: auto;
}
.width-900{
  width: min(calc(100vw - 6vw), 900px);
  margin-inline: auto;
}
.width-800{
  width: min(calc(100vw - 6vw), 800px);
  margin-inline: auto;
}
/*位置*/
.left{ left: 0; }
.right{ right: 0; }
.text-center{text-align: center;}
.text-left{text-align: left;}
.text-right{text-align: right;}
*/*背景*/
.background-white{ background: var(--color-white); }
.background-gray{ background: var(--color-f3f3f3); }
.background-main{ background: var(--color-main); }
.background-main-light{ background: var(--color-main-light); }
/*フォント-Aldrich*/
.font-aldrich{
  font-family: 'Aldrich', sans-serif;
  font-weight: normal;
}
/*乗算*/
.mul{ mix-blend-mode: multiply; }
/*テキスト*/
.text-color-main{ color: var(--color-main);}
.text-red{ color: var(--color-E8380D);}
.text-white{ color: var(--color-white);}
.text-small{ font-size: 65%;}
.font-bold{ font-weight: var(--font-weight-bold); }
.text-s, .text-s a, a.text-s{ font-size: clamp(var(--font13), calc((0.0625rem * 13) + ((1vw - 3.8px) * (3 / 13.7))), var(--font16)); }
.underline{
  text-decoration: underline;
  &:hover{
    text-decoration: none;
    opacity: .7;
  }
}
/*矢印*/
.arrow, .arrow-right, .arrow-left{
  position: relative;
  &::before{
    content: '';
    position: absolute;
    top: 50%;
    border-top: 2px solid;
    border-right: 2px solid;
    transition: 0.3s;
  }
}
.arrow-right, .arrow-left{
  &::before{
    --size: 4px;
    width: var(--size);
    height: var(--size);
    transform: translateY(-50%) rotate(45deg);
  }
}
.arrow-right::before{ right: 0.9em; }
:is(.arrow-right:hover, a:hover .arrow-right)::before{ right: 0.6em; }
.arrow-left::before{ left: 0; }
.arrow-left:hover::before{ left: 0.5em; }
/*三角*/
.triangle, .triangle-bottom{
  position: relative;
  &::before{
    --size: 12px;
    content: '';
    position: absolute;
    width: var(--size);
    height: calc(var(--size) / 1.5 * tan(60deg));
    background: var(--color-main);
  }
}
.triangle::before{ clip-path: var(--shape-triangle-right); }
.triangle-bottom::before{ clip-path: var(--shape-triangle-bottom); }
/*別タブ*/
.open-in-new_b, .open-in-new_w{
  position: relative;
  &::after{
    content: '';
    position: absolute;
    top: 50%;
    right: 0.2em;
    transform: translateY(-50%);
    width: 1em;
    aspect-ratio: 1;
    transition: .3s;
  }
}
.open-in-new_b{
  &::after{
    mask: url("../images/common/icon_open-in-new_b.svg") no-repeat center / contain;
    -webkit-mask: url("../images/common/icon_open-in-new_b.svg") no-repeat center / contain;
    background-color: var(--color-black);
  }
}
.open-in-new_w{
  &::after{
    mask: url("../images/common/icon_open-in-new_w.svg") no-repeat center / contain;
    -webkit-mask: url("../images/common/icon_open-in-new_w.svg") no-repeat center / contain;
    background-color: var(--color-white);
  }
}
/*ボタン*/
.btn{
  border-radius: 0.8em;
  padding-block: 0.2em;
  padding-inline: 0.8em 2em;
}
/*hover 下にライン*/
.line-hover{
  position: relative;
  &::before{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    transform: scale(0, 1);
    transform-origin: left top;
    width: 100%;
    height: 1px;
    background: var(--color-black);
    transition: .3s;
  }
  &:hover{
    &::before{
      transform: scale(1, 1);
    }
  }
}
/*※*/
.text__note{
  position: relative;
  font-size: clamp(var(--font13), calc((0.0625rem * 13) + ((1vw - 4px) * (3 / 4))), var(--font16));
  margin-bottom: 0.5em;
  padding-left: 1.2em;
  &::before{
    content: '※';
    position: absolute;
    top: 0;
    left: .1em;
  }
}
span.text__note{
  display: inline;
  &::before{
    line-height: 1;
  }
}
/* スクロールロック */
.no-scroll{ overflow: hidden;}
/*ヘッダー
---------------------------*/
.header{
  --padding-left: clamp(15px, 3.5vw, 35px);
  --logo-w: clamp(75px, 16vw / 1.3, 160px);
  --gap: clamp(1px, 4vw / 1.5, 40px);
  --button-w: clamp(65px, 10vw, 100px);
  width: 100%;
  position: fixed;
  z-index: 2;
  &.open{
    &::before{
      content: '';
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.1);
      z-index: 9;
    }
  }
}
.header__inner{
  display: grid;
  place-items: end;
  width: calc(100% - var(--padding-left) - var(--button-w) - (var(--gap) * 2));
  width: var(--stretch);
  height: var(--header-h);
  grid-template-columns: var(--logo-w) 1fr;
  background: var(--color-white);
  padding-inline: var(--padding-left) calc(var(--button-w) + var(--gap));
  transition: .5s;
  .header-height &{
    --button-w: clamp(65px, 8.5vw, 85px);
    --logo-w: clamp(80px, 10vw / 1.2, 100px);
    --header-h: clamp(65px, 8.5vw, 85px);
    place-items: center end;
  }
}
.gnav__list{
  display: flex;
  gap: calc(var(--gap) / 1.5);
  .header-height &{
    margin-block: 40px 0;
  }
  .gnav__item6 span{
    padding-right: 1.5em;
  }
}
.gnav__item{
  --padding-block: 10px;
  &::before{
    --size: 7px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    display: none;
    height: calc(var(--size) / 2 * tan(60deg));
    clip-path: var(--shape-triangle-bottom);
    background: var(--color-main);
  }
  &.active::before{
    display: block;
  }
}
.gnav__button{
  background: transparent;
  padding-block: var(--padding-block);
  margin-inline: calc(var(--gap) / 2.5);
  &::before{
    right: 0;
    width: 0.2em;
    height: 0.2em;
    transform: translate(200%, -90%) rotate(135deg);
    opacity: 0;
  }
  &:has( + .true){
    &::before{
      top: 50%;
      opacity: 1;
    }
  }
}
.gnav__sub-list{
  position: absolute;
  left: 50%;
  transform: translate(-50%, 100%);
  background: var(--color-white);
  border: 1px solid;
  padding-block: 1em;
  padding-inline: 1.2em 1em;
  &.false{
    bottom: -30px;
    display: none;
    opacity: 0;
    animation: Sub-list2 .5s ease-out;
  }
  &.true{
    bottom: 1px;
    display: block;
    opacity: 1;
    animation: Sub-list .5s ease-out;
    z-index: 1;
  }
  li{
    border-left: 4px solid var(--color-e1e1e2);
  }
  a{
    width: 12em;
    font-size: 1rem;
    padding-block: 0.8em;
    padding-inline: 1em 0;
    &::after{
      content: '';
      position: absolute;
      inset: 0 100% 0 -4px;
      transform: scaleY(0);
      transform-origin: top;
      transition: .5s;
    }
    .gnav__item1 &::after{
      background: var(--color-2b4cdb);
    }
    .gnav__item2 &::after{
      background: var(--color-00B9EF);
    }
    .gnav__item3 &::after{
      background: var(--color-E8380D);
    }
    &:hover{
      .gnav__item1 &{
        color: var(--color-2b4cdb);
      }
      .gnav__item2 &{
        color: var(--color-00B9EF);
      }
      .gnav__item3 &{
        color: var(--color-E8380D);
      }
      &::after{
        transform: scaleY(1);
      }
    }
  }
}
@keyframes Sub-list {
  0% { bottom: -30px; opacity: 0; }
  40% { opacity: 1; }
  100% { bottom: 1px; opacity: 1; }
}
@keyframes Sub-list2 {
  0% { bottom: 1px; opacity: 1; display: block; }
  60% { opacity: 1; }
  99% { bottom: -30px; opacity: 0; display: block;}
  100% { bottom: -30px; opacity: 0; display: none;}
}
.gnav__item-link{
  position: relative;
  height: 1em;
  overflow: hidden;
  margin-top: var(--padding-block);
  padding-bottom: var(--padding-block);
  a{
    display: grid;
    gap: .5em;
    &:hover{
      transform: translateY(-59%);
    }
  }
}
@media (width <=1000px){
  .header__inner{
    place-items: center end;
  }
  .gnav{
    display: none;
  }
}
/*-- お問合せ --*/
.header-actions{
  position: absolute;
  top: 0;
  right: calc(var(--button-w) + var(--gap));
  display: flex;
  gap: clamp(1px, 2vw, 20px);
  transition: .5s;
  a{
    display: grid;
    place-content: center;
    width: clamp(85px, 14vw / 0.7, 140px);
    height: 45px;
    border-top: 0;
    font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.8px)*(4/13.7))), var(--font18));
    .header-height &{
      height: 38px;
    }
  }
}
.btn--contact{
  background: var(--color-white);
  &:hover{
    background: var(--color-ebebeb);
  }
}
.btn--request{
  background: var(--color-black);
  color: var(--color-white);
  &:hover{
    opacity: .8;
  }
}
.btn--contact, .btn--request{
  border: 1px solid var(--color-black);
}
/*-- 開閉ボタン --*/
.menu-toggle{
  position: fixed;
  top: 0;
  right: 5px;
  width: var(--button-w);
  aspect-ratio: 1;
  background: initial;
  cursor: pointer;
  transition: .5s;
  z-index: 11;
  &::before{
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: var(--color-ebebeb);
    transition: .3s;
    transform: scale(0.0);
  }
  span{
    position: absolute;
    inset: calc(50% - 3px) 20% 50%;
    background: var(--color-black);
    transition: .3s;
    &:nth-child(1){
      transform: translateY(5px);
    }
    &:nth-child(2){
      transform: translateY(-5px);
    }
    .open &{
      &:nth-child(1){
        transform: rotate(45deg);
      }
      &:nth-child(2){
        transform: rotate(-45deg);
      }
    }
  }
  &:hover{
    &::before{
      transform: scale(0.9);
    }
  }
}
/*-- モバイルメニュー、フッターナビゲーション --*/
.ov-nav__inner, .footer__sections{
  --gap: clamp(20px, 4vw / 1.92, 40px);
  display: grid;
  grid-template-columns: 1fr clamp(250px, 29vw / 1.3, 290px);
  gap: var(--gap);
}
.ov-nav__list, .footer-nav__list{
  display: grid;
  grid-auto-flow: column;
  grid-template-columns: 1fr 19% 12%;
  grid-template-rows: auto auto 1fr;
  gap: var(--gap);
  a{
    margin-bottom: 0.5em;
    &:hover{
      color: var(--color-666666);
    }
  }
  .nav__item1{
    grid-row: span 3;
  }
  .nav__item6 a{
    display: block;
  }
  .nav__label{
    border-bottom: 2px solid;
    font-size: var(--font17);
    font-weight: var(--font-weight-bold);
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
  }
  > li a{
    font-size: var(--font15);
  }
  .nav__sub-sub-list{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 0 clamp(20px, 3vw / 1.92, 30px);
    li{
      container-type: inline-size;
    }
  }
  .nav__sub-sub-link{
    display: grid;
    align-content: center;
    gap: 0.1em;
    font-size: clamp(14px, calc(4.4px + 4cqi), 15px);
    .nav__sub-sub-name{
      font-size: var(--font14);
      font-weight: var(--font-weight-bold);
    }
  }
}
.ov-nav__contact, .footer-nav-contact{
  container-type: inline-size;
  a{
    margin-bottom: 0.8em;
    padding-block: 0.5em;
  }
  .nav-contact__list, .nav-inquiry-list{
    padding-bottom: 1rem;
    a{
      display: grid;
      place-content: center start;
      gap: 0.2em;
      height: 3em;
      font-size: clamp(14px, calc(4.4px + 4cqi), 16px);
      font-weight: var(--font-weight-bold);
      padding-inline: 0.7em 1em;
    }
  }
  .line-hover-desc{
    font-weight: normal;
    font-size: var(--font12);
  }
}
.webket-info{
  background: var(--color-6b82e6);
  color: var(--color-white);
  &:hover{
    background: var(--color-6878c1);
  }
  &::after{
    top: 65%;
    right: 1.6em;
  }
}
.interview{
  background: var(--color-e1e1e2);
  border: 1px solid;
  &:hover{
    background: var(--color-black);
    color: var(--color-white);
  }
}
.footer-nav__list, .nav__policy-list{
  a{
    font-size: var(--font14);
  }
  a:hover{
    color: var(--color-8a8a8a);
  }
}
/*-- モバイルメニュー --*/
.ov-nav{
  --padding-inline: 4%;
  position: fixed;
  top: 0;
  right: 0;
  width: min((100vw - (var(--logo-w) + ((var(--padding-left) + var(--padding-inline)) * 2))) , 1280px);
  transform: translateX(110%);
  background: var(--color-white);
  padding-block: var(--button-w) 20px;
  padding-inline: var(--padding-inline);
  transition: .4s ease-in-out;
  box-shadow: var(--shadow2);
  z-index: 10;
  .open &{
    transform: translateX(0);
  }
}
.ov-nav__inner{
  max-height: calc(100dvh - (var(--button-w) + 40px));
  -webkit-overflow-scrolling: touch;
  overflow: auto;
  padding-block: 20px 50px;
  padding-right: 15px;
}
.ov-nav__list{
  padding-bottom: 50px;
  a{
    padding-block: 0.5em;
  }
  .nav__item2{
    grid-row: span 2;
  }
}
.nav__sub-list > li > a{
  &::before{
    height: 2px;
  }
  .nav__item1 &::before {
    background: var(--color-2b4cdb);
  }
  .nav__item2 &::before {
    background: var(--color-00B9EF);
  }
  .nav__item3 &::before {
    background: var(--color-E8380D);
  }
  .nav__item4 &::before {
    background: var(--color-00AB5A);
  }
  .nav__item6 &::before {
    background: var(--color-6b82e6);
  }
}
.nav__sub-sub-list.industrys{
  margin-bottom: 1em;
}
.nav__sub-sub-link{
  position: relative;
  border-bottom: 1px solid;
  padding-inline: 1em 0;
  &::before{
    content: '';
    position: absolute;
    transform: scale(0, 1);
    transform-origin: left top;
    inset: 1.1em calc(100% - 0.7em) calc(100% - 1.1em - 2px) 0;
    background: var(--color-2b4cdb);
    transition: .3s;
  }
  .ov-nav &:hover::before{
    transform: scale(1, 1);
  }
}
.nav__policy-list{
  a{
    display: block;
    width: max(14em, 70%);
  }
}
@media (width <=1450px){
  .ov-nav__list{
    grid-template-columns: 1fr max(8rem, 16%);
    grid-template-rows: auto auto auto auto 1fr;
    .nav__item1{
      grid-row: span 5;
    }
    .nav__item2{
      grid-row: span 1;
    }
  }
}
@media (width <=1000px){
  .ov-nav__list{
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-template-rows: none;
  }
}
@media (width <=780px){
  .ov-nav{
    width: calc(100vw - (var(--logo-w) + (var(--padding-left) * 1.3) + var(--padding-inline) + 5px));
    padding-inline: var(--padding-inline) 5px;
  }
  .ov-nav__inner{
    grid-template-columns: 1fr;
  }
  .ov-nav__list{
    order: 2;
  }
  .ov-nav__contact{
    order: 1;
  }
}
/*main
---------------------------*/
.main{
  --header-top-h: clamp(65px, 8.5vw, 85px);
  position: relative;
  width: 100%;
  /* overflow: hidden; */
  overflow: clip;
  padding-top: calc(var(--header-h) + 20px);
  overflow-wrap: anywhere; /* 収まらない場合に折り返す */
  word-break: normal; /* 単語の分割はデフォルトに依存 */
  line-break: strict; /* 禁則処理を厳格に適用 */
  .product &{
    overflow: visible;
  }
}
/*-- blog --*/
.c-article__list{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 4vw, 40px) 3%;
  height: 100%;
}
.c-article__card{
  display: flex;
  flex-direction: column;
}
.c-article__card-desc{
  border-bottom: 1px solid;
  font-weight: var(--font-weight-bold);
  font-size: clamp(var(--font16), calc((0.0625rem * 16) + ((1vw - 3.7px)*(4/13.8))), var(--font20));
  padding-bottom: 0.2em;
  margin-bottom: 0.5em;
  span{
    font-size: 140%;
  }
}
.c-article__card-img{
  overflow: hidden;
  img{
    aspect-ratio: 1.8;
    object-fit: cover;
    transition: transform 0.4s;
  }
}
.c-article__card-link{
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  gap: 0.8em;
  padding-bottom: 0.5em;
  &:hover{
    img{
      transform: scale(1.15);
    }
  }
}
.c-article__card-text{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex-grow: 1;
  gap: 0.5em;
}
.c-article__card-title{
  font-size: clamp(var(--font16), calc((0.0625rem * 16) + ((1vw - 3.7px)*(2/13.8))), var(--font18));
}
.c-article__card-tags{
  display: flex;
  flex-wrap: wrap;
  flex-grow: 1;
  gap: 0 0.8em;
  li{
    font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.7px)*(2/13.8))), var(--font16));
  }
}
.c-article__card-day{
  font-size: var(--font15);
}
@media (width <=650px){
  /*導入事例、blog*/
  .c-article__list{
    grid-template-columns: 1fr !important;
  }
  .c-article__card-img{
    width: 30%;
    min-height: 100px;
    img{
      width: 100%;
      aspect-ratio: auto;
      height: 100%;
    }
  }
  .c-article__card-link{
    flex-direction: row;
  }
  .c-article__card-desc{
    br{
      display: none;
    }
  }
  .c-article__card-ext{
    width: 70%;
    justify-content: start;
  }
}
/*緊急告知
-------------------------------------------*/
.bold{
  font-weight: 700;
}
.emergency-notice__button, .emergency-notice__popup{
  position: fixed;
  width: 100%;
  left: 0;
  transition: 0.3s;
}
.emergency-notice__button{
  height: clamp(50px, calc(6vw / 1.2), 60px);
  top: 100px;
  border: 1px solid;
  background: var(--col010);
  color: var(--col009);
  font-weight: 700;
  font-size: clamp(var(--fz14), calc(1.8vw / 1.2),var(--fz18));
  .hide &{
    top: 80px;
    height: 40px;
  }
  &:has(.active){
    z-index: 1;
  }
  span{
    padding-inline: 1em;
  }
}
.emergency-notice__popup{
  top: 0;
  place-items: center;
  height: 100lvh;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
  transition: 0.3s;
  z-index: 2;
  &.false{
    display: none;
    body.top &{
      display: grid;
    }
  }
  &.true{
    display: grid;
    body.top &{
      display: none;
    }
  }
}
.notice-wrap{
  position: relative;
  display: grid;
  justify-items: center;
  width: var(--main-width_1200);
  background: var(--col003);
  border-radius: 2rem;
  height: 90%;
  overflow: auto;
  padding-bottom: 2rem;
  .close-icon{
    position: fixed;
    top: 0.5rem;
    right: 3%;
    display: block;
    width: clamp(50px, (10vw / 1.2), 100px);
    aspect-ratio: 1;
    background: #ddd;
    border-radius: 50%;
    &::before, &::after{
      content: '';
      position: absolute;
      inset: calc(50% - 1px) 13%;
      background: var(--col);
    }
    &::before{
      rotate: 45deg;
    }
    &::after{
      rotate: -45deg;
    }
  }
  .close-text{
    display: grid block;
    justify-items: center;
    width: min(80vw, 480px);
    background: var(--col010);
    border-radius: 2em;
    border: 1px solid;
    color: var(--col009);
    font-size: var(--fz21);
    padding-block: 1em;
  }
}
.notice-header, .notice-body{
  width: min(78vw, 750px);
  padding: 1rem clamp(10px, 4.5vw, 45px);
}
.notice-header{
  h2{
    text-align: center;
    font-size: clamp(var(--fz18), 2.8vw, var(--fz28));
    margin-bottom: 1em;
  }
  span{
    display: block;
    text-align: right;
    font-size: clamp(var(--fz13), 1.6vw, var(--fz16));
  }
}
.notice-body{
  background: var(--col-w);
  margin-bottom: 1.5rem;
  p{
    margin-bottom: 1em;
  }
  dl{
    container-type: inline-size;
    width: max(80%, 280px);
    margin-inline: auto;
  }
  dt, dd{
    border: 1px solid var(--col009);
    font-weight: 700;
    small{
      height: auto;
      text-align: center;
      line-height: 1.4;
    }
  }
  dt{
    background: var(--col009);
    text-align: center;
    color: var(--col-w);
    padding: 0.5em;
  }
  dd{
    display: grid block;
    justify-items: center;
    padding: 1em 0.5em;
    margin-bottom: 1.5em;
  }
}
.notice__first-greetings, .contact-intro{
  text-align: center;
  padding-block: 1em;
}
.contact-intro__link{
  position: relative;
  display: grid block;
  width: max(80%, 220px);
  background: var(--col011);
  border: 1px solid;
  color: var(--col009);
  font-weight: 500;
  padding: 0.5em 1.5em;
  margin-top: 1em;
  transition: 0.3s;
  &::before {
    --size: 12px;
    content: '';
    position: absolute;
    top: 50%;
    right: 2.5em;
    transform: translateY(-50%);
    display: block;
    width: var(--size);
    height: calc(var(--size) / 1.5 * tan(60deg));
    clip-path: var(--shape-triangle-right);
    background: var(--col009);
    transition: 0.3s;
  }
  &:hover{
    background: var(--col010);
    color: var(--col009);
    &::before{
      right: 1.5em;
    }
  }
}
@media (width <=1000px){
  .notice-header{
    h2{
      padding-right: 40px;
    }
  }
  .contact-intro__link{
    padding-inline: 1em 2em;
    &::before{
      right: 1.5em;
    }
    &:hover{
      &::before{
        right: 0.5em;
      }
    }
  }
}
@media (width <=1000px){
  .notice-header{
    h2{
      padding-right: 40px;
    }
  }
  .contact-intro__link{
    &::before{
      right: 1.5em;
    }
    &:hover{
      &::before{
        right: 0.5em;
      }
    }
  }
}
/*footer
---------------------------*/
.footer__slogan{
  display: grid;
  align-items: center;
  font-size: clamp(var(--font28), calc((0.0625rem * 28) + ((1vw - 3.6px)*(72/15.6))), 100px);
  opacity: 0.2;
  padding-block: 1.1em .7em;
}
/*-- サイトマップ --*/
.footer-nav__list{
  grid-template-columns: 1fr 19% 18%;
  .nav__item3{
    grid-row: span 2;
  }
  a{
    padding-bottom: .4em;
  }
  .nav__sub-sub-list{
    padding-left: 1em;
  }
}
.footer__misc-list{
  margin-block: 2rem 5px;
  li{
    font-size: var(--font12);
  }
}
@media (width <=1150px){
  /*--footer--*/
  .footer-nav__list{
    grid-template-columns: 1fr max(170px, 40%);
    grid-template-rows: auto auto auto auto 1fr;
    .nav__item1{
      grid-row: span 5;
    }
    .nav__item3{
      grid-row: span 1;
    }
    .nav__sub-sub-list{
      grid-template-columns: 1fr;
    }
  }
}
/*-- address --*/
.footer-info{
  background: var(--color-ececec);
}
.footer-info__inner{
  display: grid;
  align-items: center;
  grid-template-columns: clamp(100px, 16vw, 160px) 1fr clamp(90px, 11vw, 110px);
  gap: clamp(20px, 6vw, 60px);
  padding-block: 50px;
  .iso{
    font-size: var(--font13);
    span{
      display: block;
    }
  }
}
.footer-info__addr{
  p:not(.footer-info__company), a{
    font-size: var(--font15);
    font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.7px)*(1/11.3))), var(--font15));
    line-height: 1.4;
  }
}
.footer-info__company{
  font-size: var(--font21);
  font-size: clamp(var(--font17), calc((0.0625rem * 17) + ((1vw - 3.7px)*(4/11.3))), var(--font21));
  font-weight: var(--font-weight-bold);
  margin-bottom: 0.3em;
}
.copyright{
  font-size: var(--font14);
  padding-block: 0.5em;
  color: var(--color-666666);
}
@media (width <=1000px){
  /*--footer--*/
  .footer-nav__list{
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-template-rows: none;
  }
}
@media (width <=780px){
  /*--footer--*/
  .footer__sections{
    grid-template-columns: 1fr;
    a{
      margin-bottom: 1em;
    }
  }
  .footer-nav{
    order: 2;
  }
  .footer-nav-contact{
    order: 1;
  }
  .footer-info__inner{
    grid-template-columns: 1fr;
    img{
      width: 100px;
    }
  }
}
/*トップへ戻る
---------------------------*/
.page-top{
  position: fixed;
  bottom: 20px;
  right: 25px;
  width: 45px;
  aspect-ratio: 1;
  background: var(--color-black);
  border: 1px solid var(--color-black);
  border-radius: 50%;
  color: var(--color-white);
  cursor: pointer;
  opacity: 0;
  transition: .3s;
  z-index: 10;
  &::before{
    width: 0.6rem;
    left: 50%;
    transform: translate(-50%, -25%) rotate(-45deg);
  }
  &:hover{
    background: var(--color-main);
  }
  &.visible{
    opacity: 1;
  }
}
@media (width <=780px){
  .page-top{
    display: none;
  }
}