html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  line-height: 1;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: 400;
}

ul {
  list-style: none;
}

button,
input,
select,
textarea {
  margin: 0;
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

img,
embed,
object,
audio {
  height: auto;
  max-width: 100%;
}

iframe {
  border: 0;
  max-width: 100%;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
  text-align: left;
}

strong {
  font-weight: bold;
}

html {
  font-size: 16px;
}

body {
  position: relative;
  font-weight: 400;
  color: #231815;
  font-family: "Noto Sans JP", sans-serif;
}

.c-h1 {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.corphead{
  width:100%;
  background:rgba(52, 184, 191, 1);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
}

.corphead__inner{
  max-width:1920px;
  margin:0 auto;
  height:70px;
  padding:0 80px 0 80px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.corphead__logo{
  display:block;
  max-width:280px;

}

.corphead__logo img{
  display:block;
  width: 100%;

}

.corphead__nav{
  display:flex;
  align-items:center;
  gap:14px;
  flex-shrink:0;
}

.corphead__btn{
  min-width:138px;
  height:32px;
  padding:0 20px;
  font-weight: 600;
  border-radius:999px;
  background:#fff;
  color:rgba(52, 184, 191, 1);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  line-height:2;
  letter-spacing:.08em;
  white-space:nowrap;
  transition:.2s ease;
  border: 1px solid #fff;
}
.corphead__btn:hover {
  background: rgba(52, 184, 191, 1);
  color: #fff;
}

@media (max-width: 768px){
  main {
    padding-top: 56px!important;
  }
  .corphead__inner{
    height:56px;
    padding:0 8px;
  }
  .corphead__logo {
    width: 170px;
  }
  .corphead__logo img{
    width: 90%;

  }

  .corphead__nav{
    gap:8px;
  }

  .corphead__btn{
    min-width:84px;
    height:30px;
    padding:0 14px;
    font-size:12px;
    letter-spacing:.04em;
  }
}

main {
    width: 100%;
    overflow: hidden;
    padding-top: 70px;
  }
  
  .main-img {
    width: 100%;
  }
  main .w-80 {
    margin: 0 auto;
  }
  
  main .test-slick__item {
    position: relative;
  }
  .slick-slide {
    width: 100%;
    height: 100vh;
  }

  
  .mv-slick .test-slick__item img {
    /* height: 100vh; */
    margin: auto;
    max-height: 100%;
    max-width: 100%;
    object-fit: cover;
    width: 100%;
  }
  
  .mv-slick .slick-dots {
    bottom: 60px;
  }
  
  .mv-slick .slick-dots li button:before {
    color: #fff;
    font-size: 10px;
    opacity: 9;
  }
  
  .mv-slick .slick-dots li.slick-active button:before {
    color: rgba(52, 184, 191, 1);
  }
  
 
  .test-slick__item img {
    height: auto;
    width: 100%;
  }
  
  .test-slick .test-slick button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    padding: 0;
    border: none;
    background-color: transparent;
  }
  
  .test-slick .test-slick button:focus {
    outline: none;
  }
  .top_slick-wrap .wrapper {
    width: 1300px;
  }
  
  .test-slick button.arrow-common {
    position: absolute;
    top: 338px;
    
    transform: translateY(-50%);
    background-size: contain;
    background-repeat: no-repeat;
    width: 3%;
    padding-top: 6%;
    cursor: pointer;
    z-index: 5;
  }
  
  .sec{
    width:100%;
  }

  .inner{
    width:100%;
    max-width:1100px;
    margin:0 auto;
    padding:0 20px;
  }

  .txt-c{
    text-align:center;
    letter-spacing: 0.2rem;
  }
  .desc_m {
    font-size: 20px!important;
    letter-spacing: 0.2rem;
    font-weight: 500;
  }
  .c-main{
    color:rgba(52, 184, 191, 1);
  }

  .bg-mint{
    background:#d7ecec;
  }

  .intro-sec{
    padding:0 0 80px;
  }

  .message-sec .label{
    font-size:22px;
    margin-bottom:30px;
  }

  .message-sec .title{
    font-size:43px;
    line-height:1.3;
    font-weight: 500;
    margin-bottom:18px;
  }

  .message-sec .sub{
    font-size:22px;
    line-height:1.8;
    margin-bottom:30px;
  }
  .message-sec .desc a {
    color: #34B8BF;
  }
  .intro-sec .desc{
    font-size:16px;
    line-height:2.25;
    margin:0 auto;
    letter-spacing: 0.2rem;
  }

  .intro-sec .diagram{
    width:313px;
    padding-top: 50px;
    margin: 0 auto;
  }

  .news-sec{
    padding: 50px 0;
  }

  .news-list{
    max-width:760px;
    margin: 0 auto;
    /* margin:0 auto 32px; */
  }

  .news-item{
    display:grid;
    grid-template-columns: 90px 110px 1fr;
    gap:8px;
    align-items:center;
    margin-bottom:20px;
  }

  .news-date{
    font-size:14px;
    line-height:1.5;
  }

  .news-tag{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:28px;
    text-align: center;
    padding:4px 10px;
    border:1px solid rgba(52, 184, 191, 1);
    color:rgba(52, 184, 191, 1);
    font-size:14px;
    line-height:1.4;
    background:#fff;
    white-space:nowrap;
  }

  .news-text{
    font-size:14px;
    line-height:1.7;
    margin-left: 20px;
  }

  .btn-wrap{
    text-align:center;
    /* margin-top: 50px; */
  }

  .btn-news{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:205px;
    min-height:30px;
    padding:0 22px;
    border-radius:999px;
    background:rgba(52, 184, 191, 1);
    color:#fff;
    text-decoration:none;
    font-size:13px;
    line-height:2;
    gap:8px;
    transition:.2s ease;
  }
  .btn-news:hover {
    background: #fff;
    color: rgba(52, 184, 191, 1);
  }

  .btn-news::before{
    content:"▶";
    font-size:11px;
    transform:scale(.9);
  }

  .fade-in {
    opacity: 0;
    transition-duration: 1300ms;
    transition-property: opacity, transform;
  }
  .scroll-in {
    opacity: 1;
    transform: translate(0, 0);
}
.float-item {
  opacity: 0;
  transform: translateY(10%);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.float-item.is-show {
  opacity: 1;
  transform: translateY(0);
}
  .message-sec{
    padding:78px 0 92px;
  }

  .message-sec .desc{
    font-size:16px;
    line-height:2.2;
    margin:0 auto 46px;
  }
  .message-sec .desc:last-child {
    margin-bottom: 0;
  }

  .message-logo{
    max-width:310px;
    margin:0 auto;
  }
  .sp_none {
    display: block;
  }
  .pc_none {
    display: none;
  }

  @media (max-width: 768px){
    .pc_none {
      display: block;
    }
    .sp_none {
      display: none;
    }
    .intro-sec{
      padding:0 0 54px;
    }

    .message-sec .label{
      font-size:16px;
      margin-bottom:20px;
    }

    .message-sec .title{
      font-size:32px;
      margin-bottom:24px;
    }

    .message-sec .sub{
      font-size:16px;
      margin-bottom:18px;
    }
    .intro-sec .desc {
      letter-spacing: 0.1rem;
    }
    .intro-sec .desc,
    .intro-sec .bottom-text {
      font-size:12px;
    }
    .message-sec .desc {
      font-size: 12px;
      margin: 0 auto 0;
    }

    .news-item{
      display:grid;
      grid-template-columns: 75px 1fr;
      gap:8px 0;
      align-items:center;
    }
  
    .news-date{
      grid-column:1 / 2;
      font-size: 12px;
    }
  
    .news-tag{
      font-size: 12px;
      grid-column:2 / 3;
      width: 100px;
      justify-self:start;
    }
  
    .news-text{
      font-size: 12px;
      grid-column:1 / -1;
      margin-left: 0;
    }

    .message-sec{
      padding:52px 0 58px;
    }
    .txt-c {
      letter-spacing: 0.1rem;
    }
    .desc_m {
      font-size: 14px!important;
      font-weight: 500;
    }
  }
  .news-sec .news-list .news-item:nth-child(n+4){
    display:none;
  }
  


  .diag-section{
    padding:40px 20px;
    background:#efefef;
  }

  .diag-wrap{
    position:relative;
    max-width:1000px;
    margin:0 auto;
    padding-bottom: 80px;
    padding-top: 50px;
  }
  .diag-wrap h3 {
    font-size: 30px;
    font-weight: 500;
    margin-bottom: 30px;
  }
  .diag-wrap p {
    font-size: 16px;
    margin-bottom: 60px;
  }

  .diag-image{
    display:block;
    width:100%;
    height:auto;
  }

  .diag-hit{
    position:absolute;
    border:0;
    background:transparent;
    cursor:pointer;
    padding:0;
  }

  .diag-hit:focus-visible{
    outline:2px solid rgba(52, 184, 191, 1);
    outline-offset:2px;
  }

  .diag-hit {
    position: absolute;
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
  }
  
  .diag-logo-box {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .diag-logo {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    display: block;
    transition: transform .25s ease;
  }
  
  .diag-hit:hover .diag-logo,
  .diag-hit:focus-visible .diag-logo {
    transform: scale(1.12);
  }

  .diag-hit--1{ left:45%; top:16%; width:12%; height:7%; }
  .diag-hit--2{ right:-2%; top:29%; width:22%; height:7.5%; }
  .diag-hit--3{ right:-2%; top:49%; width:16%; height:8%; }
  .diag-hit--4{ right:0; top:72%; width:17%; height:7%; }
  .diag-hit--5{ left:41%; top:87%;width:20%;height:6.2%; }
  .diag-hit--6{ left:0; top:71.5%; width:22%; height:8%; }
  .diag-hit--7{ left:-2%; top:52.5%; width:19%; height:6.5%; }
  .diag-hit--8{ left:3.5%; top:30.5%; width:18%; height:6.5%; }

  @media (max-width: 768px){
    .diag-image {
      width: 90%;
      margin: 0 auto;
    }

    .diag-hit--1{ left:41%; top:31%; width:14%; height:10%; }
  
    .diag-hit--2{ right:-8px; top:40%; width:25%; height:10%; }
  
    .diag-hit--3{ right:0; top:55%; width:18%; height:11%; }
  
    .diag-hit--4{ right:0; top:72%; width:20%; height:10%; }
  
    .diag-hit--5{ left:40%; top:84%; width:22%; height:9%; }
  
    .diag-hit--6{ left:-7px; top:71.5%; width:28%; height:11%; }
  
    .diag-hit--7{ left:-11px; top:58%; width:24%; height:10%; }
  
    .diag-hit--8{ left:-1%; top:41.5%; width:25%; height:10%; }

    .diag-wrap {
      padding-bottom:50px;
    }
    .diag-hit--3 .corp-popup-related-links #corpPopupRelated2,
    .diag-hit--3 .corp-popup-related-links #corpPopupRelated3 {
      display: none!important;
    }
    .diag-wrap h3 {
      font-size: 20px;
      margin-bottom: 15px;
    }
    .diag-wrap p {
      font-size: 12px;
      line-height: 1.5;
      margin-bottom: 40px;
    }
    .diag-hit:hover .diag-logo,
    .diag-hit:focus-visible .diag-logo {
      transform: none;
    }
  }

  
  .corp-popup{
    position:fixed;
    inset:0;
    display:none;
    align-items:center;
    justify-content:center;
    padding:24px;
    /* background:rgba(0,0,0,.55); */
    z-index:1000;
  }

  .corp-popup.is-open{
    display:flex;
  }

  .corp-popup-panel{
    position:relative;
    width:min(1024px, calc(100vw - 48px));
    aspect-ratio:1024 / 768; /* design.png와 동일 비율 */
    background: rgba(255, 255, 255, 0.9);
    border:1px solid rgba(52, 184, 191, 1);
    overflow:hidden;
    height: 95%;

  }

  .corp-popup-close{
    position:absolute;
    top:24px;
    right:24px;
    width:32px;
    height:32px;
    border:1px solid rgba(52, 184, 191, 1);
    background:transparent;
    cursor:pointer;
  }

  .corp-popup-close::before,
  .corp-popup-close::after{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    width:20px;
    height:1px;
    background:rgba(52, 184, 191, 1);
    transform-origin:center;
  }

  .corp-popup-close::before{
    transform:translate(-50%, -50%) rotate(45deg);
  }

  .corp-popup-close::after{
    transform:translate(-50%, -50%) rotate(-45deg);
  }
  #corpPopupLink {
    margin-bottom: 20px;
    width: 180px;
  }
  #corpPopupLink2 {
    width: 180px;
  }
  .corp-popup-inner{
    width:100%;
    height:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:55px 40px;
  }

  .corp-popup-company{
    font-size:28px;
    line-height:1.4;
    font-weight:700;
    color:#111;
    margin-bottom:26px;
  }

  .corp-popup-logo{
    max-width: 650px;
    margin-bottom:52px;
  }
  .corp-popup-logo img[src*="company_logo1.png"],
  .corp-popup-logo img[src*="company_logo3.png"] {
    max-width:200px;
  }
  .corp-popup-logo img[src*="company_logo4.png"],
  .corp-popup-logo img[src*="company_logo5.png"] {
    width: 250px;
  }
  .corp-popup-logo img[src*="company_logo2.png"] {
    max-width:320px;
  }
  .corp-popup-logo img[src*="company_logo6.png"],
  .corp-popup-logo img[src*="company_logo7.png"] {
    max-width:400px;
  }
  .corp-popup-logo img[src*="company_logo8.png"]{
    max-width:350px;
  }

  .diag-hover-logo {
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.8);
  transition: opacity .25s ease, transform .25s ease;
  z-index: 20;
}

.diag-hover-logo img {
  width: 180px;
  max-width: 22vw;
  height: auto;
  display: block;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18));
}

.diag-hover-logo.is-show {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.08);
}

@media (max-width: 768px) {
  .diag-hover-logo {
    display: none;
  }
}

  .corp-popup-logo img{
    width:100%;
    display:block;
  }

  .corp-popup-label{
    font-size:18px;
    line-height:1.6;
    color:#111;
    margin-bottom:24px;
  }
  .corp-popup-label2 {
    margin-top: 50px;
  }
  .corp-popup-related-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    /* gap: 14px 16px; */
  }
  .corp-popup-related-links a {
    margin-left: 10px;
  }
  .corp-popup-related-links a:first-child {
    margin-left: 0;
  }
  .corp-popup-text{
    font-size:22px;
    font-weight: 500;
    line-height:1.9;
    color:#111;
    /* max-width:760px; */
    margin:0 auto 36px;
    /* word-break:keep-all; */
  }

  .corp-popup-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:140px;
    min-height:36px;
    padding:0 20px;
    border-radius:999px;
    background:#34B8BF;
    color:#fff;
    text-decoration:none;
    font-size:16px;
    line-height:2;
    font-weight:600;
    letter-spacing:.08em;
    gap:8px;
  }

  .corp-popup-link::before{
    content:"▶";
    font-size:10px;
    transform:scale(.9);
  }

  @media (max-width: 768px){
    .diag-section{
      padding:20px 10px;
    }
    .corp-popup-link {
      font-size: 14px;
    }

    .corp-popup{
      padding:12px;
    }
    #corpPopupLink {
      margin-bottom: 10px;
    }

    .corp-popup-panel{
      width:calc(100vw - 24px);
      height: 100%;
    }

    .corp-popup-close{
      top:14px;
      right:14px;
      width:28px;
      height:28px;
    }
    .corp-popup-related-links {
      flex-direction: column;
      align-items: center;
      /* gap: 12px; */
    }
    .corp-popup-related-links a {
      margin-left: 0;
      margin-bottom: 10px;
      line-height: 36px;
    }

    .corp-popup-close::before,
    .corp-popup-close::after{
      width:16px;
    }

    .corp-popup-inner{
      padding:35px 0 35px;
    }
    .corp-popup-text {
      white-space: pre-line;
    }
    .corp-popup-company{
      font-size:20px;
      margin-bottom:18px;
    }

    .corp-popup-logo{
      /* width:130px; */
      margin-bottom:32px;
    }

    .corp-popup-label{
      font-size:15px;
      margin-bottom:16px;
    }

    .corp-popup-text{
      font-size:15px;
      line-height:1.8;
      margin-bottom:20px;
    }
    .corp-popup-logo img[src*="company_logo1.png"], .corp-popup-logo img[src*="company_logo3.png"] {
      max-width: 150px;
    }
    .corp-popup-logo img[src*="company_logo4.png"], .corp-popup-logo img[src*="company_logo5.png"] {
      max-width: 150px;
    }
    .corp-popup-logo img[src*="company_logo2.png"] {
      max-width: 220px;
    }
    .corp-popup-logo img[src*="company_logo8.png"]  {
      max-width: 220px;
    }
    .corp-popup-logo img[src*="company_logo7.png"],
    .corp-popup-logo img[src*="company_logo6.png"] {
      max-width: 250px;
    }
   
    .corp-popup-logo img[src*="company_logo8-sp.png"] {
      width: 100%;
    }
    .corp-popup-logo img {
      max-width: 250px;
      margin: 0 auto;
    }
    .corp-popup-label2 {
      margin-top: 20px;
    }
  }

  .storysec{
    background:rgba(161, 226, 222, 1);
    padding:70px 20px 90px;
  }

  .storysec__inner{
    max-width:1100px;
    margin:0 auto;
  }

  .storysec__head{
    text-align:center;
    margin-bottom:46px;
  }

  .storysec__eyebrow{
    font-size:22px;
    line-height:1.4;
    letter-spacing:.08em;
    margin-bottom:14px;
    color:#555;
  }

  .storysec__title{
    font-size:24px;
    line-height:1.6;
    font-weight:400;
    color:#666;
    letter-spacing: 0.2rem;
  }

  .storysec__cards{
    display:flex;
    justify-content:center;
    align-items:flex-start;
    gap:46px;
  }

  .storycard{
    position:relative;
    width:300px;
    background:#fff;
    cursor:pointer;
    border:0;
    text-align:left;
    padding: 0;
  }

  .storycard:nth-child(2){
    margin-top:66px;
  }

  .storycard:nth-child(3){
    margin-top:132px;
  }

  .storycard__label{
    position:absolute;
    left:0;
    top:-16px;
    z-index:2;
    display:inline-flex;
    align-items:center;
    min-height:28px;
    letter-spacing: 0.2rem;
    padding:8px 14px;
    background:rgba(52, 184, 191, 1);
    color:#fff;
    font-size:18px;
    line-height:1;
    white-space:nowrap;
  }

  .storycard__body{
    background:#fff;

  }
  .storycard__image img {
    transition: transform .6s ease;
  }
  .storycard__body:hover .storycard__image img{
    transform: scale(1.1);
  }

  .storycard__text{
    /* min-height:118px; */
    padding:34px 22px 18px;
    color:rgba(52, 184, 191, 1);
    font-size:18px;
    line-height:1.65;
    font-weight: 600;
    letter-spacing: 0.15rem;
    background:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:left;
  }

  .storycard__image{
    position:relative;
    overflow:hidden;
  }

  .storycard__image img{
    width:100%;
    height:395px;
    object-fit:cover;
    vertical-align: bottom;
  }

  .storycard__arrow{
    /* position:absolute;
    right:10px;
    bottom:10px;
    width:38px;
    height:38px;
    border-radius:50%;
    background:rgba(52, 184, 191, 1);
    display:flex;
    align-items:center;
    justify-content:center; */
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 44px;
    height: 44px;
  }
  .storycard__arrow img {
    width: 100%;
    height: 44px!important;
  }

  .storycard__arrow::before{
    /* content:'';
    width:8px;
    height:8px;
    border-top:2px solid #fff;
    border-right:2px solid #fff;
    transform:rotate(45deg);
    width:9px;
    height:9px;
    border-width:2px; */
  }

  .storycard:focus-visible{
    outline:2px solid rgba(52, 184, 191, 1);
    outline-offset:4px;
  }

  .storymodal{
    position:fixed;
    inset:0;
    display: flex; 
    align-items: center;
    justify-content: center;
    z-index:1000;
    opacity: 0;
    max-width: 1000px;
    margin: 0 auto;
    visibility: hidden;
    pointer-events: none; 
    transition: opacity 0.5s ease, visibility 0.5s ease;
  }

  .storymodal.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto !important;
  }

  .storymodal__panel{
    position:relative;
    width: 100%;
    /* max-width: 1009px; */
    min-height: 650px;
    background:rgba(255, 255, 255, 0.92);
    padding:20px 0;
    /* box-shadow:0 12px 40px rgba(0,0,0,.08); */
    overflow: hidden;
    transform: translateY(30px); /* scale은 빼는게 더 깔끔할 수 있어요 */
  transition: transform 0.5s cubic-bezier(0.2, 1, 0.3, 1);
  will-change: transform;
  }
  .storymodal.is-open .storymodal__panel {
    transform: translateY(0);
    margin: 0 auto;
}
#storyModalImage {
  opacity: 0;
  /* transition: opacity 0.4s ease; */
  object-fit: cover;
}

#storyModalImage[src] {
  opacity: 1;
}

  .storymodal__close{
    position:absolute;
    top:20px;
    right:20px;
    width:28px;
    height:28px;
    border:1px solid rgba(52, 184, 191, 1);
    background:transparent;
    cursor:pointer;
    z-index: 9999 !important;
  }

  .storymodal__close::before,
  .storymodal__close::after{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    width:18px;
    height:1px;
    background:rgba(52, 184, 191, 1);
  }

  .storymodal__close::before{
    transform:translate(-50%,-50%) rotate(45deg);
  }

  .storymodal__close::after{
    transform:translate(-50%,-50%) rotate(-45deg);
  }

  .storymodal__stage{
    position:relative;
    width:100%;
    /* min-height:640px; */
  }

  .storymodal__ghost{
    position:absolute;
    background:#fff;
    opacity:.45;
    pointer-events:none;
  }

  .storymodal__ghost--1{
    left:0;
    top:0;
    width:300px;
    height:515px;
  }

  .storymodal__ghost--2{
    left:348px;
    top:66px;
    width:300px;
    height:515px;
  }

  .storymodal__ghost--3{
    right:0;
    top:132px;
    width:300px;
    height:515px;
  }

  .storymodal__focus{
    position:absolute;
    /* left:84px; */
    top:34px;
    width:100%;
    padding: 0 40px;
    display:flex;
    justify-content: space-around;
    gap:20px;
    align-items:start;
    z-index:2;
  }

  .storymodal__tab{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:6px 18px;
    background:rgba(52, 184, 191, 1);
    color:#fff;
    font-size:18px;
    margin-bottom:25px;
    letter-spacing: 0.15rem;
  }

  .storymodal__headline{
    color:rgba(52, 184, 191, 1);
    font-size:22px;
    line-height:1.55;
    margin-bottom:25px;
    letter-spacing: 0.15rem;
    white-space:pre-line;
  }

  .storymodal__desc{
    color:rgba(52, 184, 191, 1);
    font-size:14px;
    line-height:2.05;
    letter-spacing: 0.15rem;
    white-space:pre-line;
  }

  .storymodal__quote{
    color:rgba(52, 184, 191, 1);
    font-size:14px;
    line-height:2.05;
    white-space:pre-line;
  }

  .storymodal__visual{
    position:relative;
    background:#fff;
  }

  .storymodal__visual img{
    /* width:100%; */
    height: 560px;
  }

  .storymodal__next{
    position:absolute;
    right: 0;
    bottom: 0;
    width:38px;
    height:38px;
    border-radius:50%;
    border:0;
    z-index: 20;
    background:#d8edef;
    cursor:pointer;
  }

  .storymodal__next::before{
    content:"→";
    color:#fff;
    font-size:22px;
    line-height:1;
  }

  @media (max-width: 980px){
    .storysec__cards{
      gap:20px;
    }

    .storycard{
      width:31%;
    }

    .storycard__image img{
      height:280px;
    }

    .storymodal__panel{
      min-height:auto;
      overflow-y:auto;
      overflow-x:hidden;
      height: 100%;
    }

    .storymodal__stage{
      min-height:auto;
    }

    .storymodal__ghost{
      display:none;
    }

  }

  @media (max-width: 768px){
    .storysec{
      padding:42px 16px 56px;
    }

    .storysec__eyebrow{
      font-size:16px;
    }

    .storysec__title{
      font-size:18px;
      letter-spacing: 0.15rem;
    }

    .storysec__cards{
      flex-direction:column;
      align-items:center;
      gap:50px;
    }

    .storycard,
    .storycard:nth-child(2),
    .storycard:nth-child(3){
      width:100%;
      max-width:360px;
      margin-top:0;
    }

    .storymodal{
      padding:10px;
    }

    .storymodal__panel{
      width:100%;
      padding:22px 16px 18px;
    }

    .storymodal__close{
      top:12px;
      right:12px;
    }
    .storymodal__tab {
      font-size: 16px;
      padding: 10px 18px;
      margin-bottom: 20px;
    }

    .storymodal__headline{
      font-size:20px;
      margin-bottom: 20px;
      letter-spacing: 0.15rem;
    }
    .storymodal__focus {
      top: 10px;
    }
    .storymodal__desc {
      font-size: 12px;
      letter-spacing: 0.1rem;
      margin-bottom: 20px;
    }
    .storymodal__quote{
      font-size:13px;
      margin-bottom: 20px;
    }
    .storymodal__next {
      display: none;
    }
    .storymodal__focus {
      padding: 0;
      gap: 10px;
      display: block;
    }
    .storycard__labe,
    .storycard__text {
      font-size: 16px;
    }
    .storycard__text {
      min-height: 90px;
    }
    .storymodal__visual img {
      padding-bottom: 20px;
      height: auto;
    }
    .storycard__label {
      font-size: 16px;
    }
    .storycard__text {
      font-size: 16px;
    }
  }

  .mvvsec{
    position:relative;
    width:100%;
    min-height:100vh;
    padding:72px 20px 84px;
    background:url("../img/top/bg-pc.jpg") center center / cover no-repeat;
  }

  .mvvsec__inner{
    max-width:720px;
    margin:0 auto;
    text-align:center;
  }

  .mvvsec__eyebrow{
    font-size:22px;
    line-height:1.4;
    letter-spacing:.08em;
    color:rgba(52, 184, 191, 1);
    margin-bottom:18px;
  }

  .mvvsec__title{
    font-size:24px;
    letter-spacing: 0.2rem;
    line-height:1.7;
    color:rgba(52, 184, 191, 1);
    margin-bottom:72px;
  }

  .mvvsec__group + .mvvsec__group{
    margin-top:72px;
  }

  .mvvsec__label{
    width:145px;
    min-height:70px;
    margin:0 auto 26px;
    background:rgba(146, 209, 213, 1);
    color:#fff;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    /* margin-top: 72px; */
    text-align:center;
  }

  .mvvsec__label-main{
    font-size:22px;
    line-height:1.2;
    margin-bottom:6px;
    letter-spacing: 0.2rem;
  }

  .mvvsec__label-sub{
    font-size:14px;
    line-height:1.2;
    letter-spacing:.12em;
  }

  .mvvsec__mission{
    font-size:24px;
    line-height: 1.5;
    letter-spacing: 0.3rem;
    color:rgba(89, 87, 87, 1);
  }

  .mvvsec__vision-main{
    font-size:32px;
    line-height:1.6;
    color:rgba(89, 87, 87, 1);
    margin-bottom:6px;
    letter-spacing:0.2rem;
  }

  .mvvsec__vision-sub{
    font-size:16px;
    line-height:1.9;
    letter-spacing:0.2rem;
    color:rgba(89, 87, 87, 1);
  }

  .mvvsec__values{
    width:max-content;
    margin:0 auto;
    text-align:left;
    list-style:none;
  }

  .mvvsec__values li{
    position:relative;
    padding-left:22px;
    font-size:20px;
    letter-spacing:0.2rem;
    line-height:2.05;
    color:rgba(89, 87, 87, 1);
  }



  @media (max-width: 768px){
    .mvvsec{
      min-height:auto;
      padding:44px 16px 54px;
      background: url(../img/top/bg-sp.jpg) center center / cover no-repeat;
    }

    .mvvsec__eyebrow{
      font-size:16px;
      margin-bottom:12px;
    }

    .mvvsec__title{
      font-size:18px;
      margin-bottom:26px;
    }

    .mvvsec__group + .mvvsec__group{
      margin-top:30px;
    }

    .mvvsec__label{
      width:136px;
      min-height:72px;
      margin-bottom:18px;
    }

    .mvvsec__label-main{
      font-size:18px;
    }

    .mvvsec__mission{
      font-size:16px;
      line-height:1.75;
      letter-spacing: 0.2rem;
      margin-bottom: 50px;
    }
    .mvvsec__vision-sub {
      letter-spacing: 0.1rem;
      margin-bottom: 50px;
    }

    .mvvsec__vision-main{
      font-size:24px;
    }

    .mvvsec__vision-sub{
      font-size:13px;
    }

    .mvvsec__values{
      width:100%;
      max-width:320px;
    }

    .mvvsec__values li{
      font-size:16px;
      line-height:1.9;
      letter-spacing: 0.1rem;
    }
  }

  .corpfoot{
    background:rgba(52, 184, 191, 1);
    color:#fff;
    width:100%;
  }

  .corpfoot__inner{
    max-width:1920px;
    margin:0 auto;
    min-height:410px;
    padding:78px 120px 34px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
  }

  .corpfoot__nav{
    display:grid;
    grid-template-columns: 120px 1fr 160px;
    justify-content:center;
    column-gap:56px;
    width:max-content;
    margin:0 auto;
    align-items:start;
  }

  .corpfoot__col{
    min-width:0;
  }

  .corpfoot__mainlink{
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:#fff;
    text-decoration:none;
    font-size:15px;
    line-height:1.4;
    white-space:nowrap;
  }

  .corpfoot__mainlink::before{
    content: url(../img/top/arrow.png);
    width: 16px;
    height: 16px;
    line-height:1;
    
  }

  .corpfoot__sublist{
    list-style:none;
    margin-top:8px;
    padding-left:24px;
  }
 .corpfoot__sublist li {
  cursor: pointer;
 }
  .corpfoot__sublist li + li{
    margin-top:8px;
  }

  .corpfoot__sublist a{
    color:#fff;
    text-decoration:none;
    font-size:12px;
    line-height:1.5;
    white-space:nowrap;
  }

  .corpfoot__bottom{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:20px;
    margin-top:80px;
  }

  .corpfoot__logo{
    display:block;
    flex-shrink:0;
  }

  .corpfoot__logo img{
    display:block;
    width:auto;
    height:38px;
  }

  .corpfoot__copy{
    font-size:14px;
    line-height:1.4;
    color:#fff;
    white-space:nowrap;
  }

  @media (max-width: 1024px){
    .corpfoot__inner{
      padding:56px 32px 28px;
      min-height:360px;
    }

    .corpfoot__nav{
      grid-template-columns: 1fr;
      row-gap:24px;
      width:100%;
      max-width:420px;
    }

    .corpfoot__sublist{
      padding-left:22px;
    }

    .corpfoot__bottom{
      margin-top:56px;
    }
  }

  @media (max-width: 768px){
    .corpfoot__inner{
      min-height:auto;
      padding:40px 40px 22px;
    }

    .corpfoot__mainlink{
      font-size:15px;
    }

    .corpfoot__sublist a{
      font-size:12px;
    }

    .corpfoot__bottom{
      flex-direction:column;
      align-items:center;
      gap:16px;
      margin-top:40px;
    }

    .corpfoot__copy{
      font-size:12px;
    }
  }



  .mv {
    position: relative;
}
.mv img {
  width: 100%;
  height: auto;
  display: block;
}
.mv__title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  
  color: #fff;
  font-size: clamp(32px, 1vw, 32px);
  letter-spacing: 0.3em;
  text-align: center;

  z-index: 2;
  white-space: nowrap;
}
@media screen and (max-width: 799px) {
  .mv__title {
    font-size: 22px;
  }
}


.company-info {
  background: rgba(184, 244, 238, 1);
  padding: 80px 20px 100px;
  color: rgba(89, 87, 87, 1);
}

.company-info__inner {
  max-width: 780px;
  margin: 0 auto;
}

.company-info__title {
  margin: 0 0 40px;
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: .2rem;
}
.company-info__sub {
  text-align: center;
  line-height: 2;
}
.company-info__sub p {
  font-size: 20px;
  letter-spacing: 0.15rem;
  line-height: 1.2;
}
.company-info__sub span {
  font-size: 16px;
  letter-spacing: .1rem;
}
.company-info__list {
  margin: 0;
  padding: 0;
}

.company-info__row {
  display: grid;
  grid-template-columns: 140px 1fr;
  column-gap: 65px;
  margin-top: 28px;
}

.company-info__row:first-child {
  margin-top: 0;
}

.company-info__row dt,
.company-info__row dd {
  margin: 0;
  pointer-events: none;
  border: none;
}

.company-info__row dt {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: .3rem;
}

.company-info__row dd {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: .1rem;
}

.company-info__row--name dd {
  text-align: center;
}

.company-info__row--name strong {
  display: block;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.08em;
}

.company-info__row--name span {
  display: block;
  margin-top: 2px;
  font-size: 18px;
  letter-spacing: 0.08em;
}

.company-info__row a {
  color: #39bac0;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  pointer-events: all;
}

/* =========================
   2. 代表メッセージ
========================= */
.message {

  padding: 80px 20px 100px;
  color: rgba(89, 87, 87, 1);
}

.message__inner {
  max-width: 980px;
  margin: 0 auto;
  line-height: 2;
  letter-spacing: 0.15rem;
}

.message__image img {
  width: 100%;
  display: block;
  height: auto;
}

.message__text p {
  margin: 0 0 22px;
  font-size: 16px;
  line-height: 2.0;
letter-spacing: 0.15rem;
  line-height: 2;

}

.message__text p:last-child {
  margin-bottom: 0;
}
.message__content {
  max-width: 760px;
  margin: 0 auto;
}
.message__title {
  font-size: 22px;
font-style: normal;
font-weight: 700;
letter-spacing: 2.2px;
text-align: center;
margin-bottom: 50px;
}
.message__text {
  text-align: center;
}
.message__name {
  margin-top: 70px;          
  text-align: right;
  letter-spacing: 0.1rem;
}

.message__position {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.15rem;
  font-weight: 500;
}
.message__position2{
  margin-bottom: 15px;
}

.message__person {
  font-size: 24px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.15rem;
}

/* =========================
   SP
========================= */
@media screen and (max-width: 799px) {
  .company-info {
    padding: 56px 20px 70px;
  }

  .company-info__inner {
    max-width: 100%;
  }

  .company-info__title {
    margin-bottom: 28px;
    font-size: 20px;
  }
  .company-info__sub p {
    font-size: 16px;
  }
  .company-info__sub span {
    font-size: 12px;
  }
  .company-info__row {
    grid-template-columns: 1fr;
    row-gap: 4px;
    margin-top: 24px;
  }

  .company-info__row dt {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: .1rem;
  }

  .company-info__row dd {
    font-size: 14px;
    line-height: 1.8;
    border: none;
  }

  .company-info__row--name dd {
    text-align: left;
  }

  .company-info__row--name strong {
    font-size: 20px;
    line-height: 1.6;
  }

  .company-info__row--name span {
    font-size: 14px;
    line-height: 1.6;
  }

  .message {
    padding: 56px 20px 70px;
  }

  .message__inner {
    /* grid-template-columns: 1fr; */
    row-gap: 28px;
  }
  .message__title {
    font-size: 20px;
  }

  .message__text p {
    margin-bottom: 18px;
    font-size: 12px;
    letter-spacing: 0.1rem;
    line-height: 2;
  }

  .message__name {
    margin-top: 40px;
    /* justify-content: flex-end; */
    gap: 12px;
  }

  .message__position {
    font-size: 12px;
    letter-spacing: 0.1rem;
  }

  .message__person {
    letter-spacing: 0.1rem;
    font-size: 20px;
  }
}


.policy {
  padding: 90px 20px 120px;
  color: rgba(89, 87, 87, 1);
}

.policy__inner {
  max-width: 1200px;
  margin: 0 auto;
}


.policy__title {
  color: var(--Brand, #34B8BF);
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 22px;
  font-style: normal;
  font-weight: 500;
  line-height: 100%; /* 22px */
  letter-spacing: 2.2px;
}

.policy__lead {
  color: var(--Text_secondary, #595757);
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.64px;
}

.policy__list {
  margin: 0;
}

.policy__list li {
  margin-left: 1.2em;
font-style: normal;
font-weight: 400;
line-height: 200%;
letter-spacing: 0.64px;
}

.policy__list li:last-child {
  margin-bottom: 0;
}
#policy,
#policy2 {
  scroll-margin-top: 120px;
}

.policy-block a {
  color: var(--Text_secondary, #595757);
}

.policy-block h2 {
  color: var(--Text_secondary, #595757);
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.64px;
}

.policy-block h3 {
  color: var(--Text_secondary, #595757);
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.64px;
}
.policy-block p {
  color: var(--Text_secondary, #595757);
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.64px;
}
.policy-block li + li {
  margin-top: 10px;
}
.policy-contact a {
  color: #34B8BF;
}

.policy-mini__block a {
  text-decoration: underline;
  color: #595757;
}
.po_text {
  color: var(--Text_secondary, #595757);
  font-family: "Noto Sans JP";
  font-size: 18px;
  font-style: normal;
  margin-top: 30px;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.72px;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  text-underline-position: from-font;
}


/* SP */
@media screen and (max-width: 799px) {
  .policy {
    padding: 56px 20px 72px;
  }


  .policy__title {
    font-size: 20px;
    line-height: 1.5;
  }

  .policy__lead {
    font-size: 12px;
  }

  .policy__list {
    padding-left: 1.4em;
  }

  .policy__list li {
    font-size: 12px;
    margin-bottom: 0;
    margin-left:0;
    line-height: 2;
  }
 
  .policy-block h2 {
    font-size: 12px;
  }
  .policy-block p {
    font-size: 12px;
    line-height: 2;
  }
  .policy-block h3 {
    font-size: 12px;
    margin: 10px 0 0;
  }
}

.news-archive {
  padding: 80px 20px 100px;
}

.news-archive__inner {
  max-width: 1000px;
  margin: 0 auto;
}

.news-archive__category {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 48px;
}

.news-archive__category-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 1.6px;
  color: #595757;
  white-space: nowrap;
}

.news-archive__category-label::after {
  content: "";
  display: block;
  width: 44px;
  height: 1px;
  background: #4a4a4a;
  margin-left: 12px;
}

.news-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.news-filter__btn {

  padding: 8px 16px;
  border: 1px solid transparent;
  background: transparent;
  color: #9e9e9e;
  font-size: 14px;
  font-weight: 500;
  line-height: 100%; 
  cursor: pointer;
  transition: .2s ease;
}

.news-filter__btn.is-active {
  border:1px solid #34B8BF;
  color: #34B8BF;
}

#newsList {
  border-top: 0;
  max-width: 100%;
  display: block;
  height: auto;
  max-height: none;
  overflow: visible;
}

/* 
.news .news-item.is-hidden {
  display: none;
} */
.news-archive,
.news-archive__inner,
.news-list {
    display: block;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

.news-item__link {
  display: block;
  text-decoration: none;
}

.news-item__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}

.news-item__date {
  font-size: 14px;
  font-weight: 500;
  line-height: 100%;
  color: #595757;
}

.news-item__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  border: 1px solid #34b8bf;
  color: #34b8bf;
  background: #fff;
  width: 100px;
  font-size: 12px;
  font-style: normal;
  line-height: 100%; 
  white-space: nowrap;
}
.news-archive__inner .news-item {
  display: block;
  border-bottom: 1px solid #34B8BF;
  margin-bottom: 0;
  padding: 30px 0;
}
.news-item__text {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  font-weight: 500;
  color: #595757;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-pagination {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 52px;
}

.news-pagination__btn {
  width: 40px;
  height: 40px;
  border: 1px solid #34b8bf;
  background: #fff;
  color: #34b8bf;
  font-size: 18px;
  line-height: 1;
  font-weight: 500;
  cursor: pointer;
  transition: .2s ease;
}

.news-pagination__btn.is-active {
  background: #34b8bf;
  color: #fff;
}

@media (max-width: 768px) {
  .news-archive {
    padding: 56px 20px 72px;
  }

  .news-archive__category {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 32px;
  }
  .news-archive__inner .news-item {
    padding: 15px 0;
  }

  .news-archive__category-label {
    font-size: 20px;
  }

  .news-filter {
    gap: 10px;
  }

  .news-filter__btn {
    min-width: auto;
    height: 32px;
    padding: 0 12px;
    font-size: 12px;
  }


  .news-item__meta {
    gap: 10px;
    margin-bottom: 10px;
  }

  .news-item__date {
    font-size: 12px;
  }

  .news-item__tag {
    min-height: 22px;
    padding: 1px 8px;
    font-size: 12px;
  }

  .news-item__text {
    font-size: 13px;
    line-height: 1.8;
  }

  .news-pagination {
    gap: 10px;
    margin-top: 36px;
  }

  .news-pagination__btn {
    width: 36px;
    height: 36px;
    font-size: 16px;
  }
}

.news-detail {
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 20px 120px;
}

.news-detail__inner {
  max-width: 1140px;
  margin: 0 auto;
}

.news-detail__article {
  max-width: 1120px;
  margin: 0 auto;
}

.news-detail__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
}

.news-detail__title {
  margin: 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  color: #595757;
}

.news-detail__divider {
  margin: 32px 0 32px;
  border-bottom: 1px solid #A1E2DE;
}

.news-detail__body {
  color: #595757;
}

.news-detail__body p {
  margin: 0;
  font-size: 16px;
  line-height: 200%;
  letter-spacing: 1.5px;
}

.news-detail__body p + p {
  margin-top: 20px;
}

.news-detail__back {
  display: flex;
  justify-content: center;
  margin-top: 64px;
}

.news-detail__backlink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 128px;
  height: 32px;
  padding: 8px 24px;
  border-radius: 999px;
  background: #34b8bf;
  color: #fff;
  text-decoration: none;
  font-size: 13px;
  line-height: 2;
  letter-spacing: .1rem;
  transition:.2s ease;
}

.news-detail__backlink:hover {
  background: #fff;
  border: 1px solid #34b8bf;
  color: #34b8bf;
}

.news-detail__backlink::before {
  content: "◀";
  font-size: 10px;
  margin-right: 6px;
  transform: translateY(-1px);
}

.news-detail__backlink:hover {
  opacity: 0.85;
}

@media (max-width: 768px) {
  .news-detail {
    padding: 56px 20px 80px;
  }

  .news-detail__meta {
    gap: 12px;
    margin-bottom: 8px;
  }

  .news-detail__date {
    font-size: 13px;
  }

  .news-detail__tag {
    width: 90px;
    height: 22px;
    font-size: 11px;
  }

  .news-detail__title {
    font-size: 16px;
    line-height: 1.7;
  }

  .news-detail__divider {
    margin: 16px 0 24px;
  }

  .news-detail__body p {
    font-size: 12px;
    line-height: 2;
  }

  .news-detail__body p + p {
    margin-top: 14px;
  }

  .news-detail__back {
    margin-top: 48px;
  }

  .news-detail__backlink {
    min-width: 120px;
    height: 30px;
    font-size: 13px;
  }
  .po_text {
    font-size: 15px;
    margin-top: 20px;
    line-height: 2;
    letter-spacing: 0.1rem;
  }
}