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

	INDEX CSS

-----------------------------------------*/
/*----------------------------------------
	- NEWS
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .news {
    margin-block-start: 120px;
  }
}
@media screen and (max-width: 768px) {
  .news {
    margin-block-start: 15vw;
  }
}
.news .c-box {
  display: grid;
}
@media screen and (min-width: 769px) {
  .news .c-box {
    grid-template-columns: min(16.875vw, 270px) 1fr;
  }
}
@media screen and (max-width: 768px) {
  .news .c-box {
    grid-template-columns: 1fr auto;
    align-items: flex-end;
    row-gap: 9vw;
  }
}
@media screen and (min-width: 769px) {
  .news .c-title__wrap {
    display: grid;
    grid-template-columns: 1fr;
    grid-column: 1/2;
  }
}
.news .c-title__wrap [class*=c-title] + p {
  margin-block: auto 0;
}
@media screen and (min-width: 769px) {
  .news-list {
    grid-column: 2/3;
  }
}
@media screen and (max-width: 768px) {
  .news-list {
    grid-column: 1/-1;
  }
}

/*----------------------------------------
	- PRODUCTS & SERVICE
-----------------------------------------*/
.products {
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .products {
    margin-block-start: 180px;
  }
}
@media screen and (max-width: 768px) {
  .products {
    margin-block-start: 25vw;
  }
}
.products .c-box {
  display: grid;
}
.products .c-box__wrap {
  background: linear-gradient(-125deg, #FFF2F4 0%, #F6F0FF 100%);
}
.products .c-box__wrap .c-box {
  display: grid;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .c-box {
    margin-block-start: 70px;
    grid-template-columns: 1fr 380px;
    grid-template-rows: repeat(2, auto) 1fr auto;
    -moz-column-gap: 40px;
         column-gap: 40px;
    padding-block: 19px 111px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .c-box {
    margin-block-start: 9vw;
    padding-block: 15vw 21.625vw;
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(1) {
    grid-column: 1/2;
    grid-row: 1/2;
    height: -moz-fit-content;
    height: fit-content;
    margin-block-start: 65px;
  }
}
.products .c-box__wrap p:nth-of-type(2) {
  font-weight: var(--font-regular);
  line-height: 2.5;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(2) {
    grid-column: 1/2;
    grid-row: 2/3;
    margin-block-start: 40px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap p:nth-of-type(2) {
    margin-block-start: 5vw;
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(2) span {
    display: inline-block;
  }
}
.products .c-box__wrap p:nth-of-type(3) {
  position: relative;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(3) {
    grid-column: 2/3;
    grid-row: 1/4;
    margin-block: auto;
    padding-block: 20px 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap p:nth-of-type(3) {
    margin-block-start: 8vw;
    width: 100%;
    margin-inline: auto;
    padding-inline: 1.25vw;
  }
}
.products .c-box__wrap p:nth-of-type(3) a {
  position: relative;
  display: block;
  aspect-ratio: 1;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(3) a {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap p:nth-of-type(3) a {
    width: 100%;
  }
}
.products .c-box__wrap p:nth-of-type(3) a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  background-color: var(--color-white);
  transition: background-color 0.2s;
  z-index: -1;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap p:nth-of-type(3) a::before {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap p:nth-of-type(3) a::before {
    width: 100%;
  }
}
@media (hover: hover) {
  .products .c-box__wrap p:nth-of-type(3) a:hover::before {
    background-color: var(--color-palepink);
  }
}
.products .c-box__wrap .btn-list {
  display: grid;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .btn-list {
    grid-column: 1/2;
    grid-row: 3/4;
    grid-template-columns: repeat(auto-fit, minmax(auto, 306px));
    gap: 30px;
    margin-block: 60px 45px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .btn-list {
    grid-template-columns: 1fr;
    gap: 6vw;
    margin-block-start: 6vw;
    grid-row: 4/5;
    max-width: 85vw;
    width: 100%;
    margin-inline: auto;
  }
}
.products .c-box__wrap .btn-list li a {
  display: grid;
  grid-template-columns: 1fr auto;
  justify-content: space-between;
  align-items: center;
  background-color: var(--color-white);
  border-radius: 10em;
  height: 100%;
  transition: background-color 0.2s;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .btn-list li a {
    padding-block: 12px;
    padding-inline: 22px 36px;
    height: 80px;
    gap: 20px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .btn-list li a {
    padding-inline: 10vw 12vw;
    min-height: 20vw;
  }
}
.products .c-box__wrap .btn-list li a::after {
  content: "";
  display: block;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .btn-list li a::after {
    width: 56px;
    height: 56px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .btn-list li a::after {
    width: 14vw;
    height: 14vw;
  }
}
@media (hover: hover) {
  .products .c-box__wrap .btn-list li a:hover {
    background-color: var(--color-palepink);
  }
}
.products .c-box__wrap .btn-list li .font18_16 {
  font-weight: var(--font-medium);
  line-height: 1.2;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .btn-list li .font18_16 {
    font-size: 1.125rem;
    margin-inline: auto;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .btn-list li .font18_16 {
    font-size: 4vw;
  }
}
.products .c-box__wrap .btn-list li:nth-of-type(1) a::after {
  background-image: url(/asset/img/common/ic-condom-pink.svg);
}
.products .c-box__wrap .btn-list li:nth-of-type(2) a::after {
  background-image: url(/asset/img/common/ic-point-pink.svg);
}
.products .c-box__wrap .category-list {
  display: grid;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list {
    grid-column: 1/-1;
    grid-row: 4/5;
    grid-template-columns: repeat(4, 1fr);
    gap: 46px 4.182%;
    margin-block-start: 35px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 7.5vw 5vw;
    margin-block-start: 10vw;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    padding-inline: 1.25vw;
  }
}
.products .c-box__wrap .category-list li {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background-color: var(--color-white);
  border-radius: 50%;
  width: 100%;
  aspect-ratio: 1;
  transition: background-color 0.2s;
}
@media (hover: hover) {
  .products .c-box__wrap .category-list li:hover {
    background-color: var(--color-palepink);
  }
}
.products .c-box__wrap .category-list a {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr auto;
  align-content: space-between;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list a {
    gap: 6px 6px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list a {
    gap: 0;
  }
}
.products .c-box__wrap .category-list a .c-icon-base {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list a .c-icon-base {
    bottom: -10px;
    right: 13%;
    width: 60px;
    height: 60px;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list a .c-icon-base {
    bottom: -2vw;
    right: 5vw;
    width: 9vw;
    height: 9vw;
  }
}
.products .c-box__wrap .category-list p {
  margin-inline: auto;
  text-align: center;
  line-height: 1.1;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list p {
    font-size: 1.5rem;
    margin-block: auto 0;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list p {
    font-size: 5vw;
    margin-block: auto;
    transform: translateY(1.25vw);
  }
}
.products .c-box__wrap .category-list p span {
  display: inline-block;
}
.products .c-box__wrap .category-list figure {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list figure {
    width: 72%;
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list figure {
    width: 72%;
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list li:nth-of-type(1) figure {
    transform: translateY(4px);
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list li:nth-of-type(1) figure {
    transform: translateY(0.75vw);
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list li:nth-of-type(2) figure {
    transform: translateY(-10px);
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list li:nth-of-type(2) figure {
    transform: translateY(-1.25vw);
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list li:nth-of-type(3) figure {
    transform: translateY(4px);
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list li:nth-of-type(3) figure {
    transform: translateY(0.75vw);
  }
}
@media screen and (min-width: 769px) {
  .products .c-box__wrap .category-list li:nth-of-type(4) figure {
    transform: translateY(4px);
  }
}
@media screen and (max-width: 768px) {
  .products .c-box__wrap .category-list li:nth-of-type(4) figure {
    transform: translateY(0.75vw);
  }
}

/*----------------------------------------
	- COMPANY
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .company {
    margin-block-start: 140px;
  }
}
@media screen and (max-width: 768px) {
  .company {
    margin-block-start: 20vw;
  }
}
.company .c-box {
  display: grid;
  grid-template-columns: 1fr;
}
.company .card-list {
  display: grid;
  grid-column: 1/-1;
}
@media screen and (min-width: 769px) {
  .company .card-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 46px 4.182%;
    margin-block-start: 70px;
  }
}
@media screen and (max-width: 768px) {
  .company .card-list {
    grid-template-columns: 1fr;
    gap: 9vw;
    margin-block-start: 9vw;
  }
}
.company li a {
  display: grid;
  grid-template-columns: 1fr auto;
  row-gap: 0;
}
@media screen and (min-width: 769px) {
  .company li a {
    -moz-column-gap: 6.548%;
         column-gap: 6.548%;
  }
}
@media screen and (max-width: 768px) {
  .company li a {
    -moz-column-gap: 6vw;
         column-gap: 6vw;
  }
}
.company li figure {
  grid-column: 1/-1;
  overflow: hidden;
}
.company li img {
  transition: scale 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) {
  .company li:hover img {
    scale: 1.1;
  }
}
.company li p:nth-of-type(1) {
  grid-column: 1/-1;
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .company li p:nth-of-type(1) {
    margin-block: 24px 10px;
  }
}
@media screen and (max-width: 768px) {
  .company li p:nth-of-type(1) {
    margin-block: 3vw 1.25vw;
  }
}
.company li p:nth-of-type(2) {
  grid-column: 1/2;
  line-height: 2;
  font-weight: var(--font-regular);
}
@media screen and (max-width: 768px) {
  .company li .c-icon-base {
    width: 10vw;
    height: 10vw;
  }
}

/*----------------------------------------
	- SAGAMI MAGAZINE
-----------------------------------------*/
.magazine {
  background: linear-gradient(125deg, #FFFAF8 0%, #FAF5F0 100%);
}
@media screen and (min-width: 769px) {
  .magazine {
    margin-block-start: 140px;
    padding-block: 80px 90px;
  }
}
@media screen and (max-width: 768px) {
  .magazine {
    margin-block-start: 20vw;
    padding-block: 15vw 17.5vw;
  }
}
@media screen and (min-width: 769px) {
  .magazine .c-box {
    padding-inline: min(3.75vw, 60px);
  }
}
.magazine .c-box .c-title__wrap [class*=c-title] + p {
  margin-block: auto 0;
}
.magazine .c-box .magazine-item {
  grid-column: 1/-1;
}
@media screen and (min-width: 769px) {
  .magazine .c-box .magazine-item {
    margin-block-start: 60px;
  }
}
@media screen and (max-width: 768px) {
  .magazine .c-box .magazine-item {
    margin-block-start: 9vw;
  }
}

/*----------------------------------------
	- CAREERS AT SAGAMI
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .careers {
    margin-block-start: 140px;
  }
}
@media screen and (max-width: 768px) {
  .careers {
    margin-block-start: 20vw;
  }
}
.careers .c-box__wrap {
  margin-inline: auto;
}
.careers .c-box {
  display: grid;
  grid-template-rows: auto 1fr;
}
@media screen and (min-width: 769px) {
  .careers .c-box {
    display: grid;
    grid-template-columns: min(395px, 38%) 1fr;
    margin-inline: auto 0;
    width: calc(min(90%, 1100px) + (100% - min(90%, 1100px)) / 2);
  }
}
@media screen and (max-width: 768px) {
  .careers .c-box {
    overflow: hidden;
  }
}
@media screen and (min-width: 769px) {
  .careers .c-box .c-title__wrap {
    grid-column: 1/2;
    grid-row: 1/2;
    margin-block-start: 39px;
  }
}
.careers .c-box .c-title__wrap + p {
  height: -moz-fit-content;
  height: fit-content;
  line-height: 2.6;
  font-weight: var(--font-regular);
}
@media screen and (min-width: 769px) {
  .careers .c-box .c-title__wrap + p {
    grid-column: 1/2;
    grid-row: 2/3;
    margin-block-start: 70px;
  }
}
@media screen and (max-width: 768px) {
  .careers .c-box .c-title__wrap + p {
    margin-block-start: 9vw;
  }
}
@media screen and (min-width: 769px) {
  .careers .c-box__img {
    grid-column: 2/3;
    grid-row: 1/3;
    margin-block: auto 0;
    padding-inline-start: min(3.75vw, 60px);
    height: -moz-fit-content;
    height: fit-content;
  }
}
@media screen and (max-width: 768px) {
  .careers .c-box__img {
    margin-block-start: 7.5vw;
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    padding-inline: 6vw 0;
  }
}
.careers .c-box__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left;
     object-position: left;
  border-radius: 300px 0 0 0;
}

/*----------------------------------------
	- SUSTAINABILITY & IR
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .sustainability {
    margin-block-start: 140px;
  }
}
@media screen and (max-width: 768px) {
  .sustainability {
    margin-block-start: 20vw;
  }
}
.sustainability ul {
  display: grid;
}
@media screen and (min-width: 769px) {
  .sustainability ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 20px;
  }
}
@media screen and (max-width: 768px) {
  .sustainability ul {
    gap: 2.5vw;
  }
}
.sustainability li {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .sustainability li {
    aspect-ratio: 790/380;
    min-height: 380px;
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .sustainability li {
    height: 55vw;
    width: 100%;
  }
}
.sustainability li::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: top;
  background-repeat: no-repeat;
  transition: scale 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) {
  .sustainability li:hover::before {
    scale: 1.07;
  }
}
.sustainability li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  height: 100%;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}
@media screen and (min-width: 769px) {
  .sustainability li::after {
    width: 61%;
  }
}
@media screen and (max-width: 768px) {
  .sustainability li::after {
    width: 75%;
  }
}
.sustainability li:nth-of-type(1)::before {
  background-image: url(/asset/img/index/i-sustainability_p01.webp);
}
.sustainability li:nth-of-type(2)::before {
  background-image: url(/asset/img/index/i-ir_p01.webp);
}
.sustainability li a {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .sustainability li a {
    gap: 0;
  }
}
.sustainability li p {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
.sustainability li:nth-of-type(1) p {
  color: var(--color-white);
}
.sustainability li .font14_12 {
  line-height: 1;
}
.sustainability li:nth-of-type(2) .font14_12 {
  color: var(--color-primarydefault);
}
.sustainability li p:nth-of-type(1) {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: var(--font-medium);
}
@media screen and (min-width: 769px) {
  .sustainability li p:nth-of-type(1) {
    gap: 18px;
  }
}
@media screen and (max-width: 768px) {
  .sustainability li p:nth-of-type(1) {
    gap: 1.5vw;
  }
}
.sustainability li p:nth-of-type(2) {
  margin-block-start: 42px;
  display: flex;
  align-items: center;
  gap: 1em;
}
@media screen and (max-width: 768px) {
  .sustainability li p:nth-of-type(2) {
    margin-block-start: 10vw;
  }
}

/*----------------------------------------
	- SAGAMI PROJECT
-----------------------------------------*/
@media screen and (min-width: 769px) {
  .sagamiproject {
    margin-block-start: 140px;
  }
}
@media screen and (max-width: 768px) {
  .sagamiproject {
    margin-block-start: 20vw;
  }
}
.sagamiproject .c-title01 .font36_28 {
  letter-spacing: -0.08em;
}
@media screen and (min-width: 769px) {
  .sagamiproject .slider-box {
    margin-block-start: 70px;
  }
}
@media screen and (max-width: 768px) {
  .sagamiproject .slider-box {
    margin-block-start: 9vw;
  }
}
@media screen and (max-width: 768px) {
  .sagamiproject .slider-box .swiper-container {
    padding-inline: 6vw;
  }
}
.sagamiproject .slider-box figure {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
}
.sagamiproject .slider-box figure.border {
  border: 1px solid var(--color-smokegray);
}
.sagamiproject .slider-box figure img {
  transition: scale 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media (hover: hover) {
  .sagamiproject .slider-box figure:hover img {
    scale: 1.1;
  }
}
.sagamiproject .slider-box .font18_15 {
  font-weight: var(--font-medium);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .sagamiproject .slider-box .font18_15 {
    margin-block-start: 12px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 768px) {
  .sagamiproject .slider-box .font18_15 {
    margin-block-start: 1.75vw;
    font-size: 3.75vw;
  }
}
.sagamiproject .slider-box .font18_15 span {
  display: inline-block;
}