@charset "UTF-8";


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

:root {
  /* ベースフォントサイズ（本文） */
  --fs-base: clamp(1rem, 0.8rem + 1vw, 1.6rem);


  --fs-middle: clamp(1rem, 0.6rem + 0.5vw, 1.2rem);
  --fs-x-small: clamp(.8rem, 0.4rem + 0.5vw, .8rem);
  --fs-xx-small: clamp(.7rem, 0.3rem + 0.3vw, .6rem);
  --fs-xxx-small: clamp(.6rem, 0.2rem + 0.3vw, .4rem);
  --fs-logo: clamp(.6rem, 0.2rem + 0.3vw, .6rem);

  --fs-large: clamp(2rem, 1.5rem + 1vw, 2.5rem);
  --fs-x-large: clamp(3rem, 2rem + 1.5vw, 3rem);
  --fs-xx-large: clamp(3rem, 3rem + 2vw, 6rem);
  
  --fs-nav-ul-li: clamp(.7rem, 0.3rem + 0.5vw, .9rem);
  /* 見出しスケール */
  --fs-h1: clamp(.5rem, .5rem + .5vw, .5rem);
  --fs-h2: clamp(1.2rem, 1rem + 1vw, 1.2rem);
  --fs-title-middle: clamp(1.2rem, 0.8rem + 0.8vw, 1.2rem);

  /* 色設定 */
  --color-rgba-1: 34, 34, 34;
  /* --color-rgba-2: 255, 255, 255; */
  --color-rgba-2: 250, 252, 247; 
  --color-rgba-3: 0, 0, 0;
  /* --color-rgba-point: 0, 153, 179; */
  --color-rgba-point: 46, 190, 123;
   /* --color-rgba-c-color: 21, 170, 101; */
    --color-rgba-c-color: 46, 190, 123;
  --max-width-:1280px;
  --color-rgba-v-point: 5, 155, 85;
}
.fs-logo{
    font-size: var(--fs-logo);

}

/* @keyframes colorBreathe {
  0%, 100% {
  color: rgba(var(--color-rgba-2), 1);
  }
  50% {
  color: rgba(var(--color-rgba-c-color), 1);
  }
}

.breathe-text {
  animation: colorBreathe 5s ease-in-out infinite;
} */

.max-width{
  max-width: var(--max-width-);
  margin: 0 auto;
  width: 100%;
}

img{
  display: block;
    width: 100%;
  /* aspect-ratio: 16 / 9; */
  object-fit: cover;
}


p {
  font-size: var(--fs-base);
  line-height: 2em;

}

h1,h2,h3,h4,h5{
  font-weight: bold;
}

h1{
      display: flex;
    flex-direction: column;
}
.fs-middle{
   font-size:var(--fs-middle);
   font-weight: 500;
}
.fs-title-middle{
   font-size:var(--fs-title-middle);
}
.fs-x-small{
  font-size:var(--fs-x-small);
}
.fs-xx-small{
  font-size:var(--fs-xx-small);
}
.fs-large{
     font-size:var(--fs-large);
}

h1 { font-size: var(--fs-h1);  }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4);  }
h5 { font-size: var(--fs-h5); }


ul, ol {
  margin: 0;
  padding: 0;
}

li {
  margin-bottom:0;
    list-style: none;
}
a{
    text-decoration: none;
}

.c-color{
  color: rgba(var(--color-rgba-c-color), 1);
}
.c-color-border{
  border: 1px solid rgba(var(--color-rgba-c-color), 1);
  color: rgba(var(--color-rgba-c-color), 1);
  background-color: rgba(var(--color-rgba-2), .9);
  font-weight: bold;
    padding: .25rem 1rem;
}
.c-color-bg{
  background-color: rgba(var(--color-rgba-c-color), 1);
  color: rgba(var(--color-rgba-2), 1);
  font-weight: bold;
}

.f-color{
  color: rgba(var(--color-rgba-2), 1);
}
body, html {
  height: 100%;
  margin: 0;

  line-height: 1.8;
  color: rgba(var(--color-rgba-c-color), 1);
  font-size: var(--fs-base);
  background-color: rgba(var(--color-rgba-2), 1);

    width: 100%;
    max-width: 100vw;

  font-family:
    "Yu Gothic",              /* Windows (英語表記) */
    "游ゴシック",              /* macOS / 日本語環境 */
    "YuGothic",               /* Windows旧環境 */
    "Hiragino Kaku Gothic ProN", /* macOS標準ゴシック体 */
    "Hiragino Sans",          /* macOS Mojave以降 */
    "Meiryo",                 /* Windowsフォールバック */
    "Noto Sans JP",           /* AndroidやGoogleフォント */
    "sans-serif";             /* 最終フォールバック */

  }
.en {
  font-family: 'Manrope', sans-serif;
  /* font-family: 'Cardo', serif; */
    /* font-family: 'Lato', sans-serif; */
  font-weight: 700;
}
.en.def-weight{
  font-weight: 500;
}

.title-en {
  font-weight: 700;
      letter-spacing: .35em;
}
/* .title-ja {

} */

/* .title-en,
.title-ja {
  display: block;
  text-align: justify;
  text-justify: inter-ideograph; 
}


.title-en::after,
.title-ja::after {
  content: "";
  display: inline-block;
  width: 100%;
} */



main{
  position: relative;
  z-index: 0;
}

section{
  width: 100%;
  max-width: 100vw;
    padding: 0 0 6rem;
    
}
section.intro{
  width: 100%;
  max-width: 100vw;
    padding: 0 0 0;
    
}

.section.relative {
  position: relative;

}

.c-color-saturate{
    position: relative;
    z-index: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.c-color-saturate::after{
    position: absolute;
    z-index: -1;
    content: '';
    width: 100%;
    height: 100%;
    background-color: rgba(var(--color-rgba-point), 1);
    top: 0;
    left: 0;
}
.c-color-saturate img{
    filter: saturate(.5);
    opacity: .8;
    height: 100%;
}
.link-block {
  position: relative;
  padding: 2rem 0 0;
}
.link-block a{
  position: relative;
  color: rgba(var(--color-rgba-c-color), 1);
    transition: all .2s;
  width: 100%;
    overflow: hidden;
    display: block;
    max-width: max-content;
  right: 0;
}
.link-block a:hover{
      transition: all .2s;
  right: -.5rem;
}

.link-block a::before{
  content: '';
  position: absolute;
  z-index: 1;
  background-color: rgba(var(--color-rgba-c-color), 1);
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;

}
.link-block a::after{
  content: '';
  position: absolute;
  z-index: 1;
  background-color: rgba(var(--color-rgba-2), 1);
  bottom: 0;
  left: -4rem;
  width: 2rem;
  height: 4px;
    transition: all .2s;
}
.link-block a:hover::after{
  position: absolute;
  z-index: 1;
  background-color: rgba(var(--color-rgba-2), 1);
  bottom: 0;
  left: 100%;
  width:4rem;
  height: 4px;
  transition: all .2s;
}


span.link-block{
    padding: 0;
    display: block;
    line-height: 1.2em;
    position: relative;
    top: -.05rem;
}
.view-googlemap{
  display: flex;
  align-items: center;
  
}

.container {
  position: relative;
  max-width: var(--max-width-);
  width: 100%;
  margin: 0 auto;
  padding: 0 1rem;
}
section.intro .container{
    padding: 0;
}
.flex{
  display: flex;
}
.flex.column{
  flex-direction: column;
}
.flex.justify-center{
  justify-content: center;
}
section.hero {
  position: relative;
  padding: 0;
  z-index: 0;

}

section.hero h3{
  /* font-size:var(--fs-x-large); */
  font-size:var(--fs-x-small);
  line-height: 1.2em;
}
.hero img {
  width: 100%;
  height: auto;
}
.overlay-text {
    position: absolute;
    top: 0;
    left: 0;
    /* transform: translate(-50%, -50%); */
    color: rgba(var(--color-rgba-2), 1);
    z-index: 3;
    width: 100%;
    max-width: 100vw;
    height: 100vh;
    justify-content: center;
    padding: 1rem;
    font-weight: bold;
}

.overlay-text .r-sub.flex-center div.flex {
    width: 100%;
    position: relative;
    gap: 1rem;
}

.overlay-text .r-sub.flex-center,
.overlay-text .r-sub.flex-center div.flex div{
  display: flex;
  align-items: center;
  position: relative;
}



div.flex div img.smtic-logo{
align-self: center;
height: 30px;
object-fit: contain;
position: relative;
top: 5px;
    /* filter: drop-shadow(0px 0px 2px rgba(255, 255, 255, 1)); */
    backdrop-filter: blur(.1rem) opacity(0.5);
}
div.flex div img.sbi-logo{
align-self: center;
height: 30px;
object-fit: contain;
    /* filter: drop-shadow(0px 0px 2px rgba(255, 255, 255, 1)); */
    backdrop-filter: blur(.1rem) opacity(0.5);
}

.video-container {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.video-container::after {
content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(var(--color-rgba-v-point), .1);
    background-size: 4px 4px;
    background-position: 0 0, 2px 2px;
    z-index: 1;
    background-image: radial-gradient(rgba(var(--color-rgba-v-point), .1) 50%, transparent 51%), radial-gradient(rgba(var(--color-rgba-v-point), .1) 50%, transparent 51%);
}
video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  z-index: 1;
  filter: saturate(0.2);
    opacity: .9;
}
.video-overlay {
position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(var(--color-rgba-point), .2);
    z-index: 1;
    pointer-events: none;
    backdrop-filter: blur(10px);
    mix-blend-mode: multiply;
}


.header {

    position: fixed;
    z-index: 99;
    width: 100%;
    top: 0;
    left: 0;
    color: rgba(var(--color-rgba-2), 1); 
    display: flex;
    align-items: center;
}
.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: var(--max-width-);
  margin: 0 auto;
}
.header-nav-container{
    display: flex;
    align-items: center;
    gap: 2rem;
}
.header:hover,
.header.scrolled {
  background-color: rgba(var(--color-rgba-2), .95); 
  transition: background-color 0.3s;
  /* backdrop-filter: blur(10px); */
  /* -webkit-backdrop-filter: blur(10px);  */
  color: rgba(var(--color-rgba-c-color), 1); /* フィルター色変更可能 */
    /* box-shadow: 0px 4px 4px 0px rgba(var(--color-rgba-point), 0.07); */
}


/* --- PCデフォルト --- */


.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 50px;
  height: 30px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 999;
  padding: 10px;    
  position: relative;
}

.hamburger span {
  display: block;
  height: 1px;
  background: rgba(var(--color-rgba-2), 1);
  border-radius: 2px;
  transition: all 0.3s ease;
}
header:hover .hamburger span,
header.scrolled .hamburger span {
  background: rgba(var(--color-rgba-c-color), 1);
}

.hamburger.active span:nth-child(1) {
  transform: translateY(0px) translateX(0px) rotate(45deg);
}
.hamburger span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  transform: translateY(-9px) translateX(0px) rotate(-45deg);
}

.nav ul {
  list-style: none;
  display: flex;
  gap: 2rem;

  padding: 0;
  margin: 0;

}
.nav ul li{
font-size: var(--fs-nav-ul-li);
font-weight: 700;
  color: rgba(var(--color-rgba-2), 1);
}

.nav ul li a{
  color: rgba(var(--color-rgba-2), 1);
  text-decoration: none;
}
.nav-list li {
  position: relative;
  cursor: pointer;

}
.nav-list li::before{
  position: absolute;
  content: '';
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 0;
  height: 2px;
  background-color: rgba(var(--color-rgba-point), 1);
  transition: all .2s;
}
.nav-list li:hover::before{
  position: absolute;
  content: '';
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 2px;
  background-color: rgba(var(--color-rgba-point), 1);
    transition: all .2s;
}

.nav-list > li span {
      padding: .75rem;
      display: block;
}

/* 初期状態（共通） */
/* .nav-list li .sub-nav {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
  position: fixed;
  left: 0;
  width: 100vw;
  background-color: rgba(var(--color-rgba-3), 0.95);
  padding: 1rem 2rem;
  z-index: 999;
  box-sizing: border-box;
  pointer-events: none;
} */

.nav-list li .sub-nav {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
  position: fixed;
  background-color: rgba(var(--color-rgba-2), .8);
  padding: 0;
  z-index: 999;
  box-sizing: border-box;
  pointer-events: none;
  flex-direction: column;
  color: rgba(var(--color-rgba-c-color), 1);
    /* backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0px 4px 4px 0px rgba(var(--color-rgba-point), 0.07); */
  gap: .5rem;
    z-index: -1;
  
}

/* 新規追加：hoverで表示する */
.nav-list li:hover .sub-nav {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    z-index: 1;
    position: absolute;
    width: calc(100% + 4rem);
    left: -50%;
    gap: 0;
}


/* モーダル展開時（.nav.show中）は常にすべて表示：PCもスマホも共通 */



.nav.show .nav-list li .sub-nav {
  display: flex ;
  opacity: 1 !important;
  visibility: visible !important;
  position: relative;
  transform: none !important;
  pointer-events: auto !important;
  padding: 0.5rem 1rem;
  background-color: transparent !important;
  z-index: 0;
      box-shadow: none;
      top: inherit !important;
}
.nav-list li .sub-nav li {

}
.nav-list li .sub-nav li a{
  width: 100%;
  display: block;
  padding: .5rem 1rem;
}
.nav.show .nav-list {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 2rem;
    position: relative;
    justify-content: flex-start;
}

.nav.show .nav-list li {
display: flex;
    width: calc(20vw - 4rem);
    flex-direction: column;
}

.nav.show .site-header{

    display: flex;
    justify-content: center;
}
.nav.show .nav-list > li span{
    padding: .75rem 0;
    display: block;
    font-size: var(--fs-middle);
}



header:hover .nav ul li,
header:hover .nav ul li a,
header.scrolled .nav ul li,
header.scrolled .nav ul li a{
  color: rgba(var(--color-rgba-c-color), 1);
  text-decoration: none;
}


.nav.show{
    max-width: 100%;
    width: 100%;

    display: flex;
    flex-direction: column;
    gap: 2rem;
  position: fixed;
  inset: 0;
  background: rgba(var(--color-rgba-2), .8);
  justify-content: center;
  align-items: center;
  z-index: 99;
  height: 100vh;
  backdrop-filter: blur(5px);
}


.site-header a{
  display: flex;
  align-items: center;
  gap: 1rem;
  text-decoration: none;
}
header .site-header a{
  color: rgba(var(--color-rgba-2), 1);
}
header:hover .site-header a,
footer .site-header a,
header.scrolled .site-header a{
  color: rgba(var(--color-rgba-c-color), 1);

}


.site-logo {
  /* max-width: 1.75rem; */
    max-width: 2rem;
  height: auto;
  width: 100%;
}
.hero-logo{
    align-items: center;
    padding-right: 1rem;
}
.hero-logo img{
  max-width: 3rem;
  height: auto;
  width: 100%;
}
.site-title {
display: flex;
flex-wrap: wrap;
flex-direction: row;
    /* line-height: 1em; */
}

/* 通常時：ヘッダー内に並ぶ */
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative; /* ← これ重要（relative位置基準） */
  width: 100%;
}

/* モーダル展開時：絶対配置で右上に重ねる */
.nav.show + .hamburger {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 1001;
}
.nav .nav-image{
  display: none;
}
.nav.show .nav-image{
  display: none;
      /* width: inherit;
    height: 10vh; */
}


.image-overlay{
  position: relative;

}
.image-overlay::before{
  position: absolute;
  z-index: 1;
  content: '';
  width: 100%;
  height: 100%;
  background-color: rgba(var(--color-rgba-point), .5); 
}
.image-overlay img{
  filter: saturate(0.5);
}

.slide-fixed-right{
  background-color: rgba(var(--color-rgba-point), 1); 
}

.slide-fixed-right:has(img){
  background-color: transparent;
}

.swiper {
  width: 100%;
  height: auto;
}
.swiper-slide {

  cursor: pointer;
}


.swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ドット（pagination）共通 */
.swiper-pagination {
  position: relative;
  text-align: center;
}

.swiper-pagination-bullet {
  background-color: rgba(var(--color-rgba-2), 1) !important;  
  opacity: .2 !important;
}
.swiper-pagination-bullet-active {
  background-color: rgba(var(--color-rgba-2), 1) !important; 
  opacity: 1 !important;
}


div.xx-large.en.c-color{
  position: relative;
  font-size: var(--fs-xx-large);
  line-height: 1.4em;
  padding-top: 1rem;
}
div.xx-large.en.c-color::before{
    /* content: '';　マーク消去 */
    content: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    height: 30px;
    background-image: url(/img/svg/logo.svg);
    background-position: left;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: 2;
    display: block;
    padding: 1rem 0;
}
.flex.p-block {
  display: flex;
  gap: 6rem;
  flex-wrap: wrap;
  padding: 2rem 0 0;
}

.flex.p-block .l-main {
  flex: 6;

}

.flex.p-block .r-sub {
  flex: 4;

}
footer{
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

footer ul.footer-nav{
    margin: 1rem 0 0;
    padding: 1rem 0 0;
    flex-wrap: wrap;
    gap: 2rem;
    border-top: 2px solid rgba(var(--color-rgba-c-color), 1);
}

footer ul.footer-nav li{
list-style: none;
flex: 2.5;

}


footer ul.footer-nav li div{

border-bottom: 1px solid rgba(var(--color-rgba-c-color), .2);
position: relative;

}

footer ul.footer-nav li div::before{
position: absolute;
content:'';
height:1px;
bottom:-1px;
left:0;
width: 3rem;
background-color: rgba(var(--color-rgba-point), .5);
}



footer ul.footer-nav li a{

  color: rgba(var(--color-rgba-c-color), 1);
  padding: .5em 0;
  position: relative;
  transition: all .2s;
  left: 0;
}
footer ul.footer-nav li a::before{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -1.25rem;
    width: 1rem;
    height: 1px;
    background-color: rgba(var(--color-rgba-c-color), 1);
}
footer ul.footer-nav li a:hover{
  transition: all .2s;
  position: relative;
      left: 1rem;

}footer ul.footer-nav li a:hover::before{
    transition: all .2s;

    width: 2rem;
    left: -2.25rem;
}
footer ul.footer-nav li .footer-sub-nav{
  padding:1rem 1.5rem 1rem;
}

footer address{
  font-style: normal;
  display: flex;
      flex-direction: row;
    flex-wrap: wrap;
}
footer div.flex:has(.site-header){
  width: 100%;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding: 1rem 0;
  gap: 1rem;
}
footer div.flex:has(.site-header)::before{
    content: '';
    position: absolute;
    top: -1rem;
    left: 0;
    width: 6rem;
    height: 1px;
    background-color: rgba(var(--color-rgba-point), 1);
}

.container:has(.page-top-btn){
  display: flex;
  justify-content: flex-end;
}
.page-top-btn {
  width: 4rem;
  cursor: pointer;
  padding: 0 0 2rem;
  position: relative;
  z-index: 0;
}

.gen-partners{
      background-color: rgba(var(--color-rgba-point), .1);
         padding: 2rem 1rem 2rem;
}
.gen-partners .flex{
  gap: 2rem;
}
.footer-copyrights {
    background-color: rgba(var(--color-rgba-point), 1);
    width: 100%;
    max-width: 100vw;
    padding: .25rem 1rem;
}
.footer-copyrights p{
    color: rgba(var(--color-rgba-2), 1);
    text-align: center;
}

.bread-link {
  padding: 1rem 0;
}

.bread-link ul{
gap: 0;
flex-wrap: wrap;
}

.bread-link ul li{
  position: relative;
  padding-right: 1rem;
 color: rgba(var(--color-rgba-c-color), 1);
}
.bread-link ul li a{
  color: rgba(var(--color-rgba-c-color), 1);
  text-decoration: underline;
}
.bread-link ul li::after{
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1rem;
    height: .5rem;
    overflow: hidden;
    background-image: url(/img/svg/arrow-right.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
.bread-link ul li:last-child:after{
  content: none;
}


.has-bg-svg {
  position: relative;
  overflow: hidden;
}
.svg-wrapper {
    position: absolute;
    pointer-events: none;
    z-index: -4;
}
.svg-wrapper object{
    opacity: .8;
}
.wedo > .svg-wrapper {

    top: 0;
    right: -5vw;
    width: 50vw;
    height: 90vh;
    transform: rotate(-20deg);
}
.definition > .svg-wrapper {
    top: 0;
    left: 0;
    width: 60vw;
    height: 100vh;
    transform: rotate(-45deg);
}
.portfolio > .svg-wrapper {
    bottom: 0;
    right: 5vw;
    width: 60vw;
    height: 100vh;
    transform: rotate(-45deg);
    z-index: -1;
}

.articles > .svg-wrapper {

    top: 50vh;
    right: -20vw;
    width: 90vw;
    height: 150vh;
    transform: rotate(-20deg);
    z-index: -1;
}

.news > .svg-wrapper {

    bottom: 0;
    right: -20vw;
    width: 90vw;
    height: 150vh;
    transform: rotate(-20deg);
    z-index: -4;
}
.under-intro > .svg-wrapper {

    bottom: 0;
    right: -20vw;
    width: 90vw;
    height: 150vh;
    transform: rotate(-20deg);
    z-index: -4;
}
.under-intro.vision > .svg-wrapper {

    top: 20vh;
    right: -20vw;
    width: 90vw;
    height: 150vh;
    transform: rotate(-20deg);
    z-index: -4;
}

.circular-economy > .svg-wrapper {

    top: 0;
    left: -70vw;
    width: 100vw;
    height: 140vh;
    transform: rotate(20deg);
    z-index: -4;
}
.circular-economy > .svg-wrapper.bottom {
    top: inherit;
    right: -50vw;
    bottom: 70vh;
    left: inherit;
    width: 120vw;
    height: 160vh;
    transform: rotate(20deg);
    z-index: -4;
}

.nature-positive > .svg-wrapper {

    bottom: 50vh;
    right: -30vw;
    width: 100vw;
    height: 140vh;
    transform: rotate(-20deg);
    z-index: -4;
}

.under-intro.general-partner > .svg-wrapper {

    top: 20vh;
    right: -20vw;
    width: 90vw;
    height: 150vh;
    transform: rotate(-20deg);
    z-index: -4;
}
.under-intro.general-partner > .svg-wrapper.bottom {

bottom: 0;
    left: -40vw;
    top: inherit;
    right: inherit;
    width: 100vw;
    height: 150vh;
    transform: rotate(90deg);
    z-index: -4;
}

.svg-bg {
  width: 100%;
  height: 100%;
  display: block;
}

.intro .slide-fixed-right{
    position: absolute;
    bottom: 0;
    /* transform: translateY(-50%); */
    right: 0;
    width: 50vw;
    z-index: 4;
    padding: 1rem;
    display: block;
}

.intro .slide-fixed-right .news-block.f-color{
    gap: 1rem;
}
.intro .slide-fixed-right .news-block.f-color .news-index-block ul li{
  display: none;
}
.intro .slide-fixed-right .news-block.f-color .news-index-block ul li:first-child{
  display: block;
}

.intro .slide-fixed-right .news-block.f-color .news-index-block ul li .news-date{
  position: relative;
  padding-left: 4rem;
      font-size: var(--fs-x-small);
}
.intro .slide-fixed-right .news-block.f-color .news-index-block ul li .news-date::before{
position: absolute;
    content: '';
    height: 1px;
    width: 3rem;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    background-color: rgba(var(--color-rgba-2), 1);
}

.intro .slide-fixed-right .news-block.f-color .news-index-block ul li .news-detail{
  display: -webkit-box;
  -webkit-line-clamp: 2;       /* 最大2行で切る */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-clamp: 2;

}
.intro .slide-fixed-right .news-block.f-color .news-index-block ul li .news-detail p{
      font-size: var(--fs-x-small);
}

.intro .slide-fixed-right .news-block.f-color .news-index-block ul li .c-color{
   color: rgba(var(--color-rgba-2), 1);
}

.intro .slide-fixed-left{
    width: 50vw;
    max-width: 100%;
    position: absolute;
    top: -2rem;
    z-index: 4;
    background-color: rgba(var(--color-rgba-2), 1); 
    padding: 1rem 2rem;

    height: auto;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.intro .slide-fixed-left div.flex{
  gap: 1rem;
  justify-content: flex-start;
}


.definition .slide-fixed-left{
  max-width: 50vw;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.definition .slide-fixed-right{
  position: absolute;
  top: 0;
  right: 0;
  width: 40vw;
  height: auto;

  /* z-index: -1; */
  padding: 0 0 2.5rem 2rem;
  overflow: hidden;
}
.definition .slide-fixed-right::after{
  content: '';
  background-color: rgba(var(--color-rgba-point), 1); 
  position: absolute;
  top: 2rem;
  left: -2rem;
    width: calc(40vw + 2rem);
  height: 100%;
  z-index: -1;
    overflow: hidden;
}
.definition .flex.column{
  gap: 1rem;
  max-width: 100%;
    width: 70%;
}

.definition-swiper .swiper-slide {
  aspect-ratio: 3 / 4; /* ← 縦長 */
}


.portfolio .slide-fixed-left{
  width: 100%;
  max-width: 100vw;
  display: flex;
  flex-direction: column;

}
.portfolio .slide-fixed-right{
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40vw;
  height: 50vh;
  z-index: -1;
  padding: 0 0 2rem 2rem;
  overflow: hidden;
}
.portfolio .slide-fixed-right::after{
  content: '';
  background-color: rgba(var(--color-rgba-point), 1); 
  position: absolute;
  top: 2rem;
  left: -2rem;
    width: calc(40vw + 2rem);
  height: 100%;
  z-index: -2;
    overflow: hidden;
}

.swiper.portfolio-swiper{
  padding: 4rem 0 4rem;
}

.swiper.portfolio-swiper p{
  padding: 1rem 0 1rem;
}

.swiper.portfolio-swiper .swiper-slide{
border: 1px solid rgba(var(--color-rgba-c-color), 1);
    background-color: rgba(var(--color-rgba-2), 1);
    position: relative;
    padding: 1rem .5rem;

    display: flex;
    align-items: flex-start;

}
.swiper.portfolio-swiper .swiper-slide::before{
  content: '';
  position: absolute;
  z-index: 1;
  background-color: rgba(var(--color-rgba-c-color), 1);
  color: rgba(var(--color-rgba-2), 1);
    font-size:var(--fs-xxx-small);
    padding: .15rem .25rem;
    top: -.5rem;
    right: .5rem;
}
.swiper.portfolio-swiper .swiper-slide.category-1::before{
  content: '事業カテゴリ1';
}
.swiper.portfolio-swiper .swiper-slide.category-2::before{
  content: '事業カテゴリ2';
}
.swiper.portfolio-swiper .swiper-slide.category-3::before{
  content: '事業カテゴリ3';
}
.swiper.portfolio-swiper .swiper-slide.category-4::before{
  content: '事業カテゴリ4';
}
.swiper.portfolio-swiper .swiper-slide.category-5::before{
  content: '事業カテゴリ5';
}
.swiper.portfolio-swiper .swiper-slide.category-6::before{
  content: '事業カテゴリ6';
}


.just-image-container{
  width: 100vw;
  max-width: 100%;
  position: relative;
 padding: 0 0 2rem;
}
.just-image-container .l-image{

  width: 50vw;
  height: 50vh;
  display: flex;
  align-items: flex-end;
  position: relative;
}
.just-image-container .l-image img{
    /* height: 35vh; */
}

.just-image-container .l-image::after {
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: -2rem;
    left: 2rem;
    width: calc(40vw + 2rem);
    height: 3rem;
    z-index: -2;
    overflow: hidden;
}
.definition .just-image-container .r-image::after {
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    top: -2rem;
    right: 0rem;
    width: 6rem;
    height: 3rem;
    z-index: -2;
    overflow: hidden;
}

.portfolio .just-image-container .l-image,
.articles .just-image-container .l-image,
.news .just-image-container .l-image{
  height: 35vh;
}


.portfolio .just-image-container .l-image::after {
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: -4rem;
    left: 0;
    width: 4rem;
    height: 4rem;
    z-index: -2;
    overflow: hidden;
}

.news .just-image-container .l-image::after {
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: -4rem;
    left: 20vw;
    width: 4rem;
    height: 4rem;
    z-index: -2;
    overflow: hidden;
}

.just-image-container .r-image{

    width: 50vw;
        height: 50vh;
        z-index: 0;
        position: relative;
}
.definition .just-image-container .r-image {
    /* flex: 5; */
    width: 40vw;
    height: 30vh;
    z-index: 0;
    position: absolute;
    right: 0;
    bottom: -20vh;
  }

.just-image-container .r-image .svg-wrapper{
  width: 50vw;
}
.just-image-container .r-image .svg-wrapper object{
  object-fit: contain;
  opacity: 1;
}

.articles-swiper .swiper-slide {
  aspect-ratio: 3 / 4; /* ← 縦長 */
}

.articles .slide-fixed-right{
  position: absolute;
  bottom: 0;
  right: 0;
  width: 30vw;
  height: 70vh;
  /* z-index: -1; */
  padding: 0 0 2.5rem 2rem;
  overflow: hidden;
}
.articles .slide-fixed-right::after{
  content: '';
  background-color: rgba(var(--color-rgba-point), 1); 
  position: absolute;
  top: 2rem;
  left: -2rem;
    width: calc(40vw + 2rem);
  height: 100%;
  z-index: -1;
    overflow: hidden;
}
.news .slide-fixed-right{
  position: absolute;
  bottom: 5rem;
  right: 0;
  width: 40vw;
  height: auto;
  /* z-index: -1; */
  padding: 0 0 2.5rem 2rem;
  overflow: hidden;
}
.news .slide-fixed-right::after{
  content: '';
  background-color: rgba(var(--color-rgba-point), 1); 
  position: absolute;
  top: 2rem;
  left: -2rem;
    width: calc(40vw + 2rem);
  height: 100%;
  z-index: -1;
    overflow: hidden;
}


.news-box
.articles-box{

      padding: 2rem 0 2rem;
}
.news-box ul li,
.articles-box ul li{
  list-style-type: none;
      padding: 0 0 1rem;
}
.news-box ul li a:hover p,
.articles-box ul li a:hover p{
  text-decoration: underline;
}
.news-box ul li .news-date,
.articles-box ul li .articles-date{
    display: flex;
    justify-content: flex-end;
    padding: 0 1rem .5rem;
    position: relative;
}
.news-box ul li .news-date::before,
.articles-box ul li .articles-date::before{
    position: absolute;
    content: '';
    height: 1px;
    width: calc(100% - 9rem);
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    background-color: rgba(var(--color-rgba-c-color), 1);
}
.news-box ul li .news-detail,
.articles-box ul li .articles-detail{
      align-items: flex-start;
}
.news-box ul li .news-detail p,
.articles-box ul li .articles-detail p{
  padding: 0 1rem;
      display: -webkit-box;
      line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}
.news .news-box ul li .news-detail p{
  padding: 0;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

main:has(.under-intro) .slide-fixed-left{
  max-width: 50vw;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding: 0 0 3rem;
  justify-content: flex-end;
}
.under-intro .slide-fixed-right{
position: absolute;
    top: 0;
    right: 0;
    width: 40vw;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
}
.under-intro .slide-fixed-right::after{
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: -2rem;
    left: 2rem;
    width: calc(40vw - 4rem);
    height: 4rem;
    z-index: -2;

}

.circular-economy .slide-fixed-right{
position: absolute;
    top: 0;
    right: 0;
    width: 40vw;
    height: 40vh;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
    overflow: hidden;
}
.nature-positive .slide-fixed-left-image{
    position: relative;
    top: 2rem;
    left: 0;
    width: 40vw;
    height: 25vh;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
    overflow: hidden;
}
.slide-fixed-bottom-image{
    position: static;
    top: 0;
    left: 0;
    width: 100vw;
    height: 35vh;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
    overflow: hidden;
}
.slide-fixed-bottom-image::after{
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: 4rem;
    left: 6rem;
    width: calc(40vw - 4rem);
    height: 4rem;
    z-index: -2;

}

section.news-detail{
  overflow: hidden;
}

section.news-detail .slide-fixed-bottom-image::after{
  bottom: inherit;
}

.nature-positive .slide-fixed-bottom-image{
    position: static;
    top: 0;
    left: 0;
    width: 100vw;
    height: 35vh;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
    overflow: hidden;
}
.nature-positive .slide-fixed-bottom-image::after{
    content: '';
    background-color: rgba(var(--color-rgba-point), 1);
    position: absolute;
    bottom: 4rem;
    left: 6rem;
    width: calc(40vw - 4rem);
    height: 4rem;
    z-index: -2;

}
.nature-positive .slide-fixed-right{
position: absolute;
    top: 0;
    right: 0;
    width: 30vw;
    height: 70vh;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 0;
    overflow: hidden;
}



.under-cont-title{
  position: relative;
  padding: 1rem .5rem;
  display: flex;
  flex-direction: column;
  /* gap: 1rem; */
  font-weight: bold;
}
.under-cont-title::before{
    content: '';
    background-color: rgba(var(--color-rgba-c-color), 1);
    position: absolute;
    top: 0;
    left: 0;
    width: 4rem;
    height: 1px;
    z-index: -2;
}
.under-cont-title::after{
    content: '';
    background-color: rgba(var(--color-rgba-c-color), 1);
    position: absolute;
    bottom: 0;
    left: 0;
    /* max-width: calc(100% - 2rem); */
    max-width: calc(60% + 7rem);
    width: 100%;
    height: 2px;
    z-index: -2;
}

.under-cont-title.no-vis::after{
 max-width: 100%;
}

.fund-profile-table-container{
  flex-direction: column;
  border-top: 4px solid rgba(var(--color-rgba-c-color), 1);
    border-bottom: 4px solid rgba(var(--color-rgba-c-color), 1);
}
.fund-profile-table{
  border-bottom: 1px solid rgba(var(--color-rgba-c-color), 1);
}
.fund-profile-table div{
  padding: .5rem;
}
.fund-profile-table div:first-child{
  flex: 3;
}
.fund-profile-table div:last-child{
  flex: 7;
}


.under-intro.fund-profile .flex.p-block .r-sub,
.under-intro.top-message .flex.p-block .r-sub,
.under-intro.top-message .flex.p-block .l-main,
.under-intro.vision .flex.p-block .l-main ul,
.under-intro.vision .flex.p-block .r-sub{ 
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.under-intro.vision .flex.p-block .l-main ul li{ 
  list-style: disc;
  margin-left: 1rem;
}


.gp-list.flex{
    gap: 4rem;
}
.gp-list.flex .gp-l{
  max-width: 40%;
  width: 100%;
    position: relative;
        height: 40vh;
}
.gp-list.flex .gp-r{

  width: 100%;
}

.general-partner  .container.support .under-cont-title::after,
.general-partner  .container.gen .under-cont-title::after{
    width: 100%;
}
.general-partner .under-cont-title::after {

    max-width: calc(60% + 7rem);
}

.gp-attr p{
  line-height: 1.4em;
}
.gp-professional-background{
  padding-top: 1rem;
}



.gp-l img{
    overflow: hidden;
    width: 100%;
    object-position: top;
    object-fit: cover;
    scale: 3.5;
    position: absolute;
    bottom: -34vh;
}


.map-responsive {
  position: relative;
  width: 100%; /* 横幅を100%に設定 */
  height: 400px; /* 固定高さを指定（例: 400px） */
}

.map-responsive iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
      z-index: -1;
}
.map-responsive .c-color-saturate::after {

    background-color: rgba(var(--color-rgba-point), .3);
    pointer-events: none;
}

.no-slide .swiper .swiper-wrapper{
  flex-wrap: wrap;
  gap: 1.5rem;
}

.no-slide .swiper.portfolio-swiper .swiper-slide{
    width: calc(350px - 3rem);
    max-width: 100%;
}

.news-list .news-box ul,
.articles-list .articles-box ul{
  display: flex;
  flex-wrap: wrap;
    gap: 1.5rem;

}

.articles-list .articles-box ul li{
      width: calc(50% - 1.5rem);
    max-width: 100%;
}

section.under-intro.news-list .news-box{
  width: 50%;
}


.news-list .news-box ul li{
        width: calc(100% - 1.5rem);
}

.swiper.portfolio-swiper .swiper-slide .c-color-saturate::after{
  content: none !important;
}

.under-cont-title h3{
  font-weight: bold;
}

.top-message .collab{
  gap: 1rem;
  padding: 2rem 0;
      align-items: center;
}

.under-intro.top-message .container .flex.justify-center div:nth-of-type(2) img{
  width: 2rem;
}

footer address{
justify-content: space-between;
    align-items: center;

}
footer div.flex:has(.site-header) div,
footer div.flex:has(.site-header){
  width: 100%;
  max-width: 100%;
}
footer .location-explain {
        padding-top: .0;
}

span.link-block a.view-googlemap::before{
  height: 2px;
}

footer address .material-symbols-outlined{
      font-size: var(--fs-x-small);
}

.nav.show .nav-list li .sub-nav {
  background-color: transparent;
}

section.definition .link-block{
  padding: 0 0 2rem;
}

.collab.flex.justify-center.gen-logos div:nth-of-type(2) img{
  width: 40px;
}
section.news .container.pad-top,
section.articles .container.pad-top{
  min-height: 120vh;
}


section.news-detail .news-header-container .flex.p-block{
  display: block;
}

section.news-detail .news-header-container .align-left {
  padding:1rem 0 0;
    text-align: left;
}

section.news-detail .news-header-container .align-right {
  padding:0 0 0;
  text-align: right;
}

section.news-detail .news-detail-container p{
  padding:2rem 0 0;
}
.news-detail-table table.news-table a,
section.news-detail .news-detail-container a{
      color: rgba(var(--color-rgba-c-color), 1);
        text-decoration: underline;
}


.news-detail-image{
  padding-bottom:2rem;
}
.news-detail-table{
  display: flex;
  justify-content: center;
}
.news-detail-image{
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 600px;
    text-align: center;
}

.news-detail-image h3{
  padding: 0 0 2rem;
}

.news-detail-image a {
  border: 1px solid rgba(var(--color-rgba-2), 1);
  transition: all .2s;
}
.news-detail-image a:hover {
  border: 1px solid rgba(var(--color-rgba-c-color), 1);
}
.news-detail-table table.news-table{
  max-width: 980px;
    table-layout: fixed;
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    margin: 0 auto;
}
.news-detail-table table.news-table th,
.news-detail-table table.news-table td{
  word-wrap: break-word;
  border:  rgba(var(--color-rgba-c-color), .5) 1px solid;
  font-size: var(--fs-middle);
  padding: .75rem .75rem;
      text-align: left;
}
.news-detail-table table.news-table th{
  background-color:  rgba(var(--color-rgba-c-color), .05);
  white-space: nowrap;
}
.news-detail-table table.news-table tbody{
  width: 100%;
  display: table;
}



.hamburger {
  display: none;
}

body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
}
.pad-top{
  padding-top: 4rem !important;
}
.pad-bottom{
  padding-bottom: 4rem !important;
}
.pc{
  display: block;
}

/* //写真準備時、下記消去 */
.gp-list.flex .gp-l{
  display: none;
}

/* --- スマホ表示切替 --- */
@media screen and (max-width: 1079px) {

  .hamburger {
    display: flex;
  }

.nav.show + .hamburger {
    position: fixed;
  }
  
.pc{
  display: none !important;
}

section{
  padding: 0 0 3rem;
}
section.wedo{
  padding: 3rem 0 3rem;
}
  .nav {
    flex-direction: column;
    background: rgba(var(--color-rgba-3), .95);
    position: fixed;
    inset: 0;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: scale(1.05);
    transition: all 0.4s ease;
  }

  .nav.show {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
  }

  .nav ul {
    flex-direction: column;
    gap: 2rem;
  }



  .nav:not(.show) ul {
    display: none;
  }

  .nav.show .nav-list {
    flex-direction: column;
    gap: 1rem;
  }

  .nav.show .nav-list li .sub-nav {

        padding: 1rem 1rem 1rem;
        width: 100%;
        position: relative;
        display: flex;
        left: inherit;
        gap: 1rem;
  }

  .nav.show .nav-list li.open .sub-nav {
    display: block;
  }

  .nav.show .nav-list li span {
    display: block;
    width: 100%;
    padding: 1rem;
    cursor: pointer;
    border-bottom: 2px solid rgba(var(--color-rgba-point), 1);
  }

  .nav.show .nav-list {
    flex-direction: column;
        width: 100%;
}

.nav.show .nav-list li {
    flex-direction: column;
    width: 100%;
    font-size: var(--fs-middle);
}
.nav ul li a,
.nav.show .nav-list li{
   color: rgba(var(--color-rgba-point), 1);
}
.nav.show .nav-list li a{
        padding: .25rem 0;
        width: 100%;
        display: block;
}

.nav.show{
    max-width: 100%;
    width: 100%;
    margin:0;
    height: auto;
    overflow-y: scroll;
    padding: 1rem 1rem 4rem 1rem;
    justify-content: flex-start;
    gap: 0;
}

.nav.show .nav-image {
    display: none;

}
  .flex {
    /* flex-direction: column; */
  }
  .flex.p-block .l-main,
  .flex.p-block .r-sub {
    flex: inherit;
    width: 100%;
  }

  .flex.p-block{
    gap: 2rem;
  }


.definition-swiper .swiper-slide {
    aspect-ratio:inherit;
}
.portfolio .just-image-container .l-image,
.articles .just-image-container .l-image, 
.news .just-image-container .l-image{
  height: auto;
}
.portfolio .just-image-container .l-image::after,
.articles .just-image-container .l-image::after, 
.news .just-image-container .l-image::after{
 content: none;
}
footer ul.footer-nav,
footer div.flex:has(.site-header){
  flex-direction: column;
    padding: 0;
    gap: 1rem;
    align-items: flex-start;
    margin: 0;
   padding: 1rem 0;
   flex-wrap: wrap;
   flex-direction: row;
}
footer ul.footer-nav{
    padding: 2rem 0; 
}
.gp-list.flex,
.just-image-container{
    flex-direction: column;
}
.portfolio .just-image-container .l-image,
.nature-positive .slide-fixed-right,
.nature-positive .slide-fixed-left-image,
.circular-economy .slide-fixed-right,
.gp-list.flex .gp-l,
.articles .just-image-container .l-image, .news .just-image-container .l-image,
.articles .slide-fixed-right,
.definition .flex.column,
  .definition .slide-fixed-right,
.definition .slide-fixed-left,
  .intro .slide-fixed-right,
  .intro .slide-fixed-left{
        width: 100% !important;
        position: relative;
        top: inherit;
        right: inherit;
        left: inherit;
        bottom: inherit;
        transform: none;
        max-width: 100% !important;
  }
  .nature-positive .slide-fixed-right{
    
    height: 25vh;
  }
  .no-slide .swiper.portfolio-swiper .swiper-slide{
    width: 100%;
            justify-content: center;
  }

.articles .slide-fixed-right,  
.definition .slide-fixed-right
{
  /* padding-top: 4rem;
height: 50vh */
display: none;
}


main:has(.no-hero) .news-list .news-box ul,
main:has(.no-hero) .articles-list .articles-box ul{

  flex-direction: column;
}

main:has(.no-hero) .news-list .news-box ul li, 
main:has(.no-hero) .articles-list .articles-box ul li{
  width:100%
}

main:has(.no-hero) .news-list .news-box ul li .c-color-saturate, 
main:has(.no-hero) .articles-list .articles-box ul li .c-color-saturate{
  width: 30vw;
}
main:has(.under-intro) .slide-fixed-left{
  padding: 0;
}

section.under-intro .slide-fixed-left {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding: 0 0 0;
    justify-content: flex-end;
}
.gp-list.flex {
    gap: 2rem;
}
.under-intro .slide-fixed-right{
      position: relative;
    top: inherit;
    right: inherit;
    width: 100%;
    z-index: -1;
    /* z-index: -1; */
    padding: 0 0 4rem;
}

.under-cont-title::after{
  max-width: 100%;
}
.under-intro .slide-fixed-right::after{
  bottom: 0;
}

main:has(.under-intro) .slide-fixed-left{
  width: 100%;
  max-width: 100%;
}
.header-inner{
  padding: 1rem;
}
footer ul.footer-nav li {
    list-style: none;
    flex: inherit;
    width: calc(50vw - 2rem);
    padding: 0 0 1rem;
}

footer ul.footer-nav li .footer-sub-nav {
    padding: 2rem 0rem 0rem 1.5rem;
}


footer .location-explain{
  padding-top: .25rem;
}

div.xx-large.en.c-color::before {
  top: -1rem;
}
div.xx-large.en.c-color{
  line-height: 1.1em;
}
.general-partner  .container.support .under-cont-title::after,
.general-partner  .container.gen .under-cont-title::after{
     width: 100%;
    max-width: 100%;
}
.news-list .news-box ul li, .articles-list .articles-box ul li{
  width: 100%;
}
.video-container{
  height: 90vh;
}
.overlay-text{
  padding: 0;
}
.nav.show .nav-list li.fs-x-small {
   font-size: var(--fs-middle);
}
.intro .slide-fixed-left{
  padding: 1rem .5rem;
}
section.under-intro.news-list .news-box {
    width: 100%;
}

.flex.gen-logos > div:has(.smtic-logo) {
  flex: 0 0 auto;
  max-width:55%;
  width: 100%;
}

.flex.gen-logos > div:has(.sbi-logo) {
  flex: 0 0 auto;
  max-width: 32%;
    width: 100%;
}
.collab.flex.justify-center.gen-logos div:nth-of-type(2) img,
img.smtic-logo,
img.sbi-logo {
  width: 100%;
  height: auto !important;
  max-width: 100%;
  object-fit: contain;
  display: block;
}
.under-intro.general-partner > .svg-wrapper.bottom,
.under-intro.general-partner > .svg-wrapper,
.nature-positive > .svg-wrapper,
.circular-economy > .svg-wrapper.bottom,
.circular-economy > .svg-wrapper,
.under-intro.vision > .svg-wrapper,
.under-intro > .svg-wrapper,
.news > .svg-wrapper,
.articles > .svg-wrapper,
.portfolio > .svg-wrapper ,
.definition > .svg-wrapper,
.wedo > .svg-wrapper {
    width: 90vw;
    height: 40vh;
}

.pad-top {
    padding-top: 2rem !important;
}
.pad-bottom {
    padding-bottom: 2rem !important;
}

section.news .container.pad-top,
section.articles .container.pad-top{
  min-height: auto;
}


}

/* 20250822logo非表示 */

.site-logo{
  display: none !important;
}